2022-04-19 13:05:13 +02:00
/* Copyright 2021 Jonavin Eng @Jonavin
2022-07-02 16:11:26 +02:00
Copyright 2022 gourdo1 < gourdo1 @ outlook . com >
2022-04-19 13:05:13 +02:00
This program is free software : you can redistribute it and / or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation , either version 2 of the License , or
( at your option ) any later version .
This program is distributed in the hope that it will be useful ,
but WITHOUT ANY WARRANTY ; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
GNU General Public License for more details .
You should have received a copy of the GNU General Public License
along with this program . If not , see < http : //www.gnu.org/licenses/>.
*/
# include QMK_KEYBOARD_H
# include "gourdo1.h"
2022-07-02 16:11:26 +02:00
# include "custom_double_taps.h"
2022-04-19 13:05:13 +02:00
2022-08-13 18:24:07 +02:00
# include "autocorrect/autocorrection.h"
2022-04-19 13:05:13 +02:00
// RGB NIGHT MODE
# ifdef RGB_MATRIX_ENABLE
static bool rgb_nightmode = false ;
// Turn on/off NUM LOCK if current state is different
void activate_rgb_nightmode ( bool turn_on ) {
if ( rgb_nightmode ! = turn_on ) {
rgb_nightmode = ! rgb_nightmode ;
}
}
bool get_rgb_nightmode ( void ) {
return rgb_nightmode ;
}
# endif // RGB_MATRIX_ENABLE
// TIMEOUTS
# ifdef IDLE_TIMEOUT_ENABLE
static uint16_t timeout_timer = 0 ;
static uint16_t timeout_counter = 0 ; //in minute intervals
static uint16_t timeout_threshold = TIMEOUT_THRESHOLD_DEFAULT ;
uint16_t get_timeout_threshold ( void ) {
return timeout_threshold ;
}
void timeout_reset_timer ( void ) {
timeout_timer = timer_read ( ) ;
timeout_counter = 0 ;
} ;
void timeout_update_threshold ( bool increase ) {
if ( increase & & timeout_threshold < TIMEOUT_THRESHOLD_MAX ) timeout_threshold + + ;
if ( ! increase & & timeout_threshold > 0 ) timeout_threshold - - ;
} ;
void timeout_tick_timer ( void ) {
if ( timeout_threshold > 0 ) {
if ( timer_elapsed ( timeout_timer ) > = 60000 ) { // 1 minute tick
timeout_counter + + ;
timeout_timer = timer_read ( ) ;
}
# ifdef RGB_MATRIX_ENABLE
if ( timeout_threshold > 0 & & timeout_counter > = timeout_threshold ) {
rgb_matrix_disable_noeeprom ( ) ;
}
# endif
} // timeout_threshold = 0 will disable timeout
}
# endif // IDLE_TIMEOUT_ENABLE
# if defined(ALTTAB_SCROLL_ENABLE) || defined(IDLE_TIMEOUT_ENABLE) // timer features
__attribute__ ( ( weak ) ) void matrix_scan_keymap ( void ) { }
void matrix_scan_user ( void ) {
# ifdef ALTTAB_SCROLL_ENABLE
encoder_tick_alttabscroll ( ) ;
# endif
# ifdef IDLE_TIMEOUT_ENABLE
timeout_tick_timer ( ) ;
# endif
matrix_scan_keymap ( ) ;
}
# endif // ALTTAB_SCROLL_ENABLE or IDLE_TIMEOUT_ENABLE
// Initialize variable holding the binary representation of active modifiers.
uint8_t mod_state ;
// ============================================= PROCESS KEY CODES =============================================
__attribute__ ( ( weak ) ) bool process_record_keymap ( uint16_t keycode , keyrecord_t * record ) {
return true ;
}
bool process_record_user ( uint16_t keycode , keyrecord_t * record ) {
mod_state = get_mods ( ) ;
2022-07-02 16:11:26 +02:00
if ( ! process_record_keymap ( keycode , record ) ) { return false ; }
if ( ! process_capsnum ( keycode , record ) ) { return false ; }
if ( ! process_esc_to_base ( keycode , record ) ) { return false ; }
2022-08-13 18:24:07 +02:00
if ( ! process_lsft_for_caps ( keycode , record ) ) { return false ; }
if ( ! process_autocorrection ( keycode , record ) ) { return false ; }
2022-04-19 13:05:13 +02:00
2022-07-02 16:11:26 +02:00
// Key macros ...
2022-04-19 13:05:13 +02:00
switch ( keycode ) {
2022-07-02 16:11:26 +02:00
// User configuration toggles
case PRNCONF : // Print verbose status of all user_config toggles (open a text editor before engaging!!)
if ( record - > event . pressed ) {
2022-08-13 18:24:07 +02:00
send_string ( " \n " SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) " ######### " ) ;
send_string ( " gourdo1 " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_3 ) SS_TAP ( X_KP_9 ) ) " s GMMK Pro User Settings " ) ;
send_string ( " ######### " SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) " \n " ) ;
send_string ( " Hold " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_1 ) ) " Fn " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_3 ) ) " and the number corresponding to a setting below to toggle. \n " ) ;
send_string ( " Re " SS_TAP ( X_KP_MINUS ) " print this screen with " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_1 ) ) " Fn " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_3 ) ) SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_1 ) ) " ` " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_3 ) ) " to see your changes reflected. \n " ) ;
send_string ( " Config also visible as RGB under number keys by holding " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_1 ) ) " Fn " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_3 ) ) " . \n " ) ;
send_string ( SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) ) ;
send_string ( SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) ) ;
send_string ( SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) ) ;
send_string ( SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) SS_TAP ( X_KP_MINUS ) " \n " ) ;
2022-07-02 16:11:26 +02:00
send_string ( " 1. CapsLock RGB highlight alpha keys................ " ) ;
if ( user_config . rgb_hilite_caps ) {
2022-08-13 18:24:07 +02:00
send_string ( SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_1 ) ) " ON " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_3 ) ) " \n " ) ;
2022-07-02 16:11:26 +02:00
} else {
2022-08-13 18:24:07 +02:00
send_string ( SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_1 ) ) " OFF " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_3 ) ) " \n " ) ;
2022-07-02 16:11:26 +02:00
}
send_string ( " 2. Numpad RGB highlight layer keys.................. " ) ;
if ( user_config . rgb_hilite_numpad ) {
2022-08-13 18:24:07 +02:00
send_string ( SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_1 ) ) " ON " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_3 ) ) " \n " ) ;
2022-07-02 16:11:26 +02:00
} else {
2022-08-13 18:24:07 +02:00
send_string ( SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_1 ) ) " OFF " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_3 ) ) " \n " ) ;
2022-07-02 16:11:26 +02:00
}
send_string ( " 3. Double tap ESC to revert to BASE layer........... " ) ;
if ( user_config . esc_double_tap_to_baselyr ) {
2022-08-13 18:24:07 +02:00
send_string ( SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_1 ) ) " ON " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_3 ) ) " \n " ) ;
2022-07-02 16:11:26 +02:00
} else {
2022-08-13 18:24:07 +02:00
send_string ( SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_1 ) ) " OFF " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_3 ) ) " \n " ) ;
2022-07-02 16:11:26 +02:00
}
2022-08-13 18:24:07 +02:00
send_string ( " 4. DEL " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_3 ) SS_TAP ( X_KP_8 ) ) " HOME key locations......................... " ) ;
2022-07-02 16:11:26 +02:00
if ( user_config . del_right_home_top ) {
2022-08-13 18:24:07 +02:00
send_string ( SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_1 ) ) " HOME on F13 " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_5 ) SS_TAP ( X_KP_9 ) ) " DEL right of BKSPC " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_3 ) ) " \n " ) ;
2022-07-02 16:11:26 +02:00
} else {
2022-08-13 18:24:07 +02:00
send_string ( SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_1 ) ) " DEL on F13 " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_5 ) SS_TAP ( X_KP_9 ) ) " HOME right of BKSPC " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_3 ) ) " \n " ) ;
2022-07-02 16:11:26 +02:00
}
2022-08-13 18:24:07 +02:00
send_string ( " 5. Numpad on CapsLock " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_5 ) SS_TAP ( X_KP_9 ) ) " double tap LSHIFT for Caps... " ) ;
2022-07-02 16:11:26 +02:00
if ( user_config . double_tap_shift_for_capslock ) {
2022-08-13 18:24:07 +02:00
send_string ( SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_1 ) ) " ON " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_3 ) ) " \n " ) ;
2022-07-02 16:11:26 +02:00
} else {
2022-08-13 18:24:07 +02:00
send_string ( SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_1 ) ) " OFF " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_3 ) ) " \n " ) ;
2022-07-02 16:11:26 +02:00
}
send_string ( " 6. Encoder button function.......................... " ) ;
if ( user_config . encoder_press_mute_or_media ) {
2022-08-13 18:24:07 +02:00
send_string ( SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_1 ) ) " MUTE " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_3 ) ) " \n " ) ;
2022-07-02 16:11:26 +02:00
} else {
2022-08-13 18:24:07 +02:00
send_string ( SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_1 ) ) " MEDIA PLAY " SS_TAP ( X_KP_SLASH ) " PAUSE " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_3 ) ) " \n " ) ;
2022-07-02 16:11:26 +02:00
}
send_string ( " 7. Insert function accessed with.................... " ) ;
if ( user_config . ins_on_shft_bkspc_or_del ) {
2022-08-13 18:24:07 +02:00
send_string ( SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_1 ) ) " SHIFT " SS_TAP ( X_KP_MINUS ) " BKSPC " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_3 ) ) " \n " ) ;
2022-07-02 16:11:26 +02:00
} else {
2022-08-13 18:24:07 +02:00
send_string ( SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_1 ) ) " SHIFT " SS_TAP ( X_KP_MINUS ) " DEL " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_3 ) ) " \n " ) ;
2022-07-02 16:11:26 +02:00
}
2022-08-13 18:24:07 +02:00
send_string ( " 8. Force SHIFT " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_3 ) SS_TAP ( X_KP_8 ) ) " CTRL " SS_TAP ( X_KP_MINUS ) " SPACE to function like SPACE.. " ) ;
2022-07-02 16:11:26 +02:00
if ( user_config . disable_space_mods ) {
2022-08-13 18:24:07 +02:00
send_string ( SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_1 ) ) " ON " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_3 ) ) " \n " ) ;
} else {
send_string ( SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_1 ) ) " OFF " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_3 ) ) " \n " ) ;
}
send_string ( " 9. AutoCorrect...................................... " ) ;
if ( user_config . autocorrect ) {
send_string ( SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_1 ) ) " ON " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_3 ) ) " \n " ) ;
2022-07-02 16:11:26 +02:00
} else {
2022-08-13 18:24:07 +02:00
send_string ( SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_1 ) ) " OFF " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_3 ) ) " \n " ) ;
2022-07-02 16:11:26 +02:00
}
2022-08-13 18:24:07 +02:00
send_string ( " 0. CapsLock highlights extended alphas " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_4 ) SS_TAP ( X_KP_0 ) ) " ISO " SS_TAP ( X_KP_MINUS ) " only " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_4 ) SS_TAP ( X_KP_1 ) ) " ... " ) ;
if ( user_config . rgb_english_caps ) {
send_string ( SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_1 ) ) " OFF " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_3 ) ) " \n " ) ;
} else {
send_string ( SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_1 ) ) " ON " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_9 ) SS_TAP ( X_KP_3 ) ) " \n " ) ;
}
send_string ( " \n The latest firmware updates are always here " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_5 ) SS_TAP ( X_KP_8 ) ) " https " SS_LALT ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_5 ) SS_TAP ( X_KP_8 ) ) SS_TAP ( X_KP_SLASH ) SS_TAP ( X_KP_SLASH ) " github.com " SS_TAP ( X_KP_SLASH ) " gourdo1 " SS_TAP ( X_KP_SLASH ) " gmmkpro " SS_TAP ( X_KP_MINUS ) " media \n " ) ;
2022-07-02 16:11:26 +02:00
}
break ;
case TG_CAPS : // Toggle RGB highlighting of Capslock state
if ( record - > event . pressed ) {
user_config . rgb_hilite_caps ^ = 1 ; // Toggles the status
eeconfig_update_user ( user_config . raw ) ; // Writes the new status to EEPROM
}
break ;
case TG_PAD : // Toggle RGB highlighting of Numpad state
if ( record - > event . pressed ) {
user_config . rgb_hilite_numpad ^ = 1 ; // Toggles the status
eeconfig_update_user ( user_config . raw ) ; // Writes the new status to EEPROM
}
break ;
case TG_ESC : // Toggle alternate ESC functionality
if ( record - > event . pressed ) {
user_config . esc_double_tap_to_baselyr ^ = 1 ; // Toggles the status
eeconfig_update_user ( user_config . raw ) ; // Writes the new status to EEPROM
}
break ;
case TG_DEL : // Toggle alternate placement of DEL and HOME keys
if ( record - > event . pressed ) {
user_config . del_right_home_top ^ = 1 ; // Toggles the status
eeconfig_update_user ( user_config . raw ) ; // Writes the new status to EEPROM
}
break ;
case TG_TDCAP : // Toggle alternate Capslock/Numpad functionality
if ( record - > event . pressed ) {
user_config . double_tap_shift_for_capslock ^ = 1 ; // Toggles the status
eeconfig_update_user ( user_config . raw ) ; // Writes the new status to EEPROM
}
break ;
case TG_ENC : // Toggle Encoder function
if ( record - > event . pressed ) {
user_config . encoder_press_mute_or_media ^ = 1 ; // Toggles the status
eeconfig_update_user ( user_config . raw ) ; // Writes the new status to EEPROM
}
break ;
case TG_INS : // Toggle Encoder function
if ( record - > event . pressed ) {
user_config . ins_on_shft_bkspc_or_del ^ = 1 ; // Toggles the status
eeconfig_update_user ( user_config . raw ) ; // Writes the new status to EEPROM
}
break ;
case TG_SPCMOD : // Toggle forcing SHIFT&CTRL-SPACE to function like SPACE
if ( record - > event . pressed ) {
user_config . disable_space_mods ^ = 1 ; // Toggles the status
eeconfig_update_user ( user_config . raw ) ; // Writes the new status to EEPROM
}
break ;
2022-08-13 18:24:07 +02:00
case TG_AUTOCR : // Toggle AutoCorrect
if ( record - > event . pressed ) {
user_config . autocorrect ^ = 1 ; // Toggles the status
eeconfig_update_user ( user_config . raw ) ; // Writes the new status to EEPROM
}
break ;
case TG_ENGCAP : // Toggle highlighting Non-English letters during CAPSLOCK
if ( record - > event . pressed ) {
user_config . rgb_english_caps ^ = 1 ; // Toggles the status
eeconfig_update_user ( user_config . raw ) ; // Writes the new status to EEPROM
}
break ;
2022-07-02 16:11:26 +02:00
//return false;
// Key to the left of encoder function (default HOME)
case LEFTOFENC :
if ( ! ( user_config . del_right_home_top ) ) {
if ( ! ( user_config . ins_on_shft_bkspc_or_del ) ) {
static bool inskey_registered ;
if ( record - > event . pressed ) {
// Detect the activation of either shift keys
if ( mod_state & MOD_MASK_SHIFT ) {
// First temporarily canceling both shifts so that
// shift isn't applied to the KC_INS keycode
del_mods ( MOD_MASK_SHIFT ) ;
register_code ( KC_INS ) ;
// Update the boolean variable to reflect the status of KC_INS
inskey_registered = true ;
// Reapplying modifier state so that the held shift key(s)
// still work even after having tapped the key.
set_mods ( mod_state ) ;
return false ;
} else {
register_code ( KC_DEL ) ;
return false ;
}
} else { // on release of KC_DEL
// In case KC_INS is still being sent even after the release of KC_DEL
if ( inskey_registered ) {
unregister_code ( KC_INS ) ;
inskey_registered = false ;
return false ;
} else {
unregister_code ( KC_DEL ) ;
return false ;
}
}
} else {
if ( record - > event . pressed ) {
register_code ( KC_DEL ) ;
return false ;
} else {
unregister_code ( KC_DEL ) ;
return false ;
}
}
} else {
if ( record - > event . pressed ) {
register_code ( KC_HOME ) ;
return false ;
} else {
unregister_code ( KC_HOME ) ;
return false ;
}
}
break ;
// Key below encoder function (default DEL)
case BELOWENC :
if ( user_config . del_right_home_top ) {
if ( ! ( user_config . ins_on_shft_bkspc_or_del ) ) {
static bool inskey_registered ;
if ( record - > event . pressed ) {
// Detect the activation of either shift keys
if ( mod_state & MOD_MASK_SHIFT ) {
// First temporarily canceling both shifts so that
// shift isn't applied to the KC_INS keycode
del_mods ( MOD_MASK_SHIFT ) ;
register_code ( KC_INS ) ;
// Update the boolean variable to reflect the status of KC_INS
inskey_registered = true ;
// Reapplying modifier state so that the held shift key(s)
// still work even after having tapped the key.
set_mods ( mod_state ) ;
return false ;
} else {
register_code ( KC_DEL ) ;
return false ;
}
} else { // on release of KC_DEL
// In case KC_INS is still being sent even after the release of KC_DEL
if ( inskey_registered ) {
unregister_code ( KC_INS ) ;
inskey_registered = false ;
return false ;
} else {
unregister_code ( KC_DEL ) ;
return false ;
}
}
} else {
if ( record - > event . pressed ) {
register_code ( KC_DEL ) ;
return false ;
} else {
unregister_code ( KC_DEL ) ;
return false ;
}
}
} else {
if ( record - > event . pressed ) {
register_code ( KC_HOME ) ;
return false ;
} else {
unregister_code ( KC_HOME ) ;
return false ;
}
}
break ;
// Encoder button function
case ENCFUNC :
if ( user_config . encoder_press_mute_or_media ) {
if ( record - > event . pressed ) {
register_code ( KC_MUTE ) ;
} else unregister_code16 ( keycode ) ;
}
else {
if ( record - > event . pressed ) {
register_code ( KC_MPLY ) ;
} else unregister_code16 ( keycode ) ;
}
break ;
// DotCom domain macros
2022-04-19 13:05:13 +02:00
case DOTCOM :
if ( record - > event . pressed ) {
2022-07-02 16:11:26 +02:00
send_string ( " .com " ) ;
2022-04-19 13:05:13 +02:00
} else {
// when keycode is released
}
break ;
case YAHOO :
if ( record - > event . pressed ) {
2022-07-02 16:11:26 +02:00
send_string ( " yahoo.com " ) ;
2022-04-19 13:05:13 +02:00
} else {
// when keycode is released
}
break ;
case OUTLOOK :
if ( record - > event . pressed ) {
2022-07-02 16:11:26 +02:00
send_string ( " outlook.com " ) ;
2022-04-19 13:05:13 +02:00
} else {
// when keycode is released
}
break ;
case GMAIL :
if ( record - > event . pressed ) {
2022-07-02 16:11:26 +02:00
send_string ( " gmail.com " ) ;
2022-04-19 13:05:13 +02:00
} else {
// when keycode is released
}
break ;
case HOTMAIL :
if ( record - > event . pressed ) {
2022-07-02 16:11:26 +02:00
send_string ( " hotmail.com " ) ;
2022-04-19 13:05:13 +02:00
} else {
// when keycode is released
}
break ;
2022-07-02 16:11:26 +02:00
// Windows Key lockout
case WINLOCK :
2022-04-19 13:05:13 +02:00
if ( record - > event . pressed ) {
keymap_config . no_gui = ! keymap_config . no_gui ; //toggle status
} else unregister_code16 ( keycode ) ;
break ;
2022-07-02 16:16:33 +02:00
// Double Zero
2022-04-19 13:05:13 +02:00
case KC_00 :
if ( record - > event . pressed ) {
// when keycode KC_00 is pressed
2022-08-13 18:24:07 +02:00
send_string ( SS_TAP ( X_KP_0 ) SS_TAP ( X_KP_0 ) ) ;
2022-04-19 13:05:13 +02:00
} else unregister_code16 ( keycode ) ;
break ;
2022-07-02 16:11:26 +02:00
// Treat Control & Shift-Space as if regular Space
case KC_SPC :
if ( user_config . disable_space_mods ) {
// Initialize a boolean variable that keeps track of the space key status: registered or not?
static bool spckey_registered ;
if ( record - > event . pressed ) {
// Detect the activation of either ctrl keys
if ( mod_state & MOD_MASK_CTRL ) {
// First temporarily canceling both ctrls so that
// ctrl isn't applied to the KC_SPC keycode
del_mods ( MOD_MASK_CTRL ) ;
register_code ( KC_SPC ) ;
// Update the boolean variable to reflect the status of KC_SPC
spckey_registered = true ;
// Reapplying modifier state so that the held ctrl key(s)
// still work even after having tapped the Space key.
set_mods ( mod_state ) ;
return false ;
}
else if ( mod_state & MOD_MASK_SHIFT ) {
// First temporarily canceling both shifts so that
// shift isn't applied to the KC_SPC keycode
del_mods ( MOD_MASK_SHIFT ) ;
register_code ( KC_SPC ) ;
// Update the boolean variable to reflect the status of KC_SPC
spckey_registered = true ;
// Reapplying modifier state so that the held shift key(s)
// still work even after having tapped the Space key.
set_mods ( mod_state ) ;
return false ;
}
} else { // on release of KC_SPC
// In case KC_SPC is still being sent even after the release of KC_SPC
if ( spckey_registered ) {
unregister_code ( KC_SPC ) ;
spckey_registered = false ;
return false ;
}
2022-04-19 13:05:13 +02:00
}
}
break ;
2022-07-02 16:11:26 +02:00
// INS as SHIFT-modified BackSpace key
2022-04-19 13:05:13 +02:00
case KC_BSPC : {
2022-07-02 16:11:26 +02:00
if ( user_config . ins_on_shft_bkspc_or_del ) {
// Initialize a boolean variable that keeps track of the ins key status: registered or not?
static bool inskey_registered ;
if ( record - > event . pressed ) {
// Detect the activation of either shift keys
if ( mod_state & MOD_MASK_SHIFT ) {
// First temporarily canceling both shifts so that
// shift isn't applied to the KC_INS keycode
del_mods ( MOD_MASK_SHIFT ) ;
register_code ( KC_INS ) ;
// Update the boolean variable to reflect the status of KC_INS
inskey_registered = true ;
// Reapplying modifier state so that the held shift key(s)
// still work even after having tapped the key.
set_mods ( mod_state ) ;
return false ;
}
} else { // on release of KC_BSPC
// In case KC_INS is still being sent even after the release of KC_BSPC
if ( inskey_registered ) {
unregister_code ( KC_INS ) ;
inskey_registered = false ;
return false ;
}
2022-04-19 13:05:13 +02:00
}
}
2022-07-02 16:11:26 +02:00
}
break ;
2022-04-19 13:05:13 +02:00
# ifdef IDLE_TIMEOUT_ENABLE
case RGB_TOI :
if ( record - > event . pressed ) {
timeout_update_threshold ( true ) ;
} else unregister_code16 ( keycode ) ;
break ;
case RGB_TOD :
if ( record - > event . pressed ) {
timeout_update_threshold ( false ) ; //decrease timeout
} else unregister_code16 ( keycode ) ;
break ;
# endif // IDLE_TIMEOUT_ENABLE
# ifdef RGB_MATRIX_ENABLE
case RGB_NITE :
if ( record - > event . pressed ) {
rgb_nightmode = ! rgb_nightmode ;
} else unregister_code16 ( keycode ) ;
break ;
# endif // RGB_MATRIX_ENABLE
# ifdef EMOTICON_ENABLE
case EMO_SHRUG :
2022-07-02 16:11:26 +02:00
if ( record - > event . pressed ) send_string ( " ` \\ _( \" /)_/` " ) ;
2022-04-19 13:05:13 +02:00
else unregister_code16 ( keycode ) ;
break ;
case EMO_CONFUSE :
2022-07-02 16:11:26 +02:00
if ( record - > event . pressed ) send_string ( " (*_*) " ) ;
2022-04-19 13:05:13 +02:00
else unregister_code16 ( keycode ) ;
break ;
case EMO_TEARS :
2022-07-02 16:11:26 +02:00
if ( record - > event . pressed ) send_string ( " (T_T) " ) ;
2022-04-19 13:05:13 +02:00
else unregister_code16 ( keycode ) ;
break ;
case EMO_NERVOUS :
2022-07-02 16:11:26 +02:00
if ( record - > event . pressed ) send_string ( " (~_~;) " ) ;
2022-04-19 13:05:13 +02:00
else unregister_code16 ( keycode ) ;
break ;
case EMO_JOY :
2022-07-02 16:11:26 +02:00
if ( record - > event . pressed ) send_string ( " (^o^) " ) ;
2022-04-19 13:05:13 +02:00
else unregister_code16 ( keycode ) ;
break ;
case EMO_SAD :
2022-07-02 16:11:26 +02:00
if ( record - > event . pressed ) send_string ( " :'-( " ) ;
2022-04-19 13:05:13 +02:00
else unregister_code16 ( keycode ) ;
break ;
# endif // EMOTICON_ENABLE
# ifdef ALTTAB_SCROLL_ENABLE
case KC_TSTOG :
if ( record - > event . pressed ) encoder_toggle_alttabscroll ( ) ;
else unregister_code16 ( keycode ) ;
break ;
# endif // ALTTAB_SCROLL_ENABLE
default :
if ( record - > event . pressed ) {
# ifdef RGB_MATRIX_ENABLE
rgb_matrix_enable ( ) ;
# endif
# ifdef IDLE_TIMEOUT_ENABLE
timeout_reset_timer ( ) ; //reset activity timer
# endif
}
break ;
}
return true ;
} ;
2022-07-02 16:11:26 +02:00
// Define custom Caps Word continuity characters
bool caps_word_press_user ( uint16_t keycode ) {
2022-04-19 13:05:13 +02:00
switch ( keycode ) {
2022-07-02 16:11:26 +02:00
// Keycodes that continue Caps Word, with shift applied.
case KC_A . . . KC_Z :
case KC_TILD :
case KC_UNDS :
case KC_DQT :
case KC_COLN :
case KC_RSFT :
2022-08-13 18:24:07 +02:00
case KC_LSFT :
2022-07-02 16:11:26 +02:00
add_weak_mods ( MOD_BIT ( KC_LSFT ) ) ; // Apply shift to next key.
return true ;
// Keycodes that continue Caps Word, without shifting.
case KC_1 . . . KC_0 :
case KC_GRV :
case KC_MINS :
case KC_QUOT :
case KC_SCLN :
case KC_BSPC :
case KC_DEL :
return true ;
default :
return false ; // Deactivate Caps Word.
2022-04-19 13:05:13 +02:00
}
}
// Turn on/off NUM LOCK if current state is different
void activate_numlock ( bool turn_on ) {
2023-02-06 03:36:09 +01:00
if ( host_keyboard_led_state ( ) . num_lock ! = turn_on ) {
2022-10-10 21:06:26 +02:00
tap_code ( KC_NUM_LOCK ) ;
2022-04-19 13:05:13 +02:00
}
}
// INITIAL STARTUP
2022-07-02 16:11:26 +02:00
__attribute__ ( ( weak ) ) void keyboard_post_init_keymap ( void ) {
}
2022-04-19 13:05:13 +02:00
void keyboard_post_init_user ( void ) {
2022-07-02 16:11:26 +02:00
// Read the user config from EEPROM
user_config . raw = eeconfig_read_user ( ) ;
2022-04-19 13:05:13 +02:00
keyboard_post_init_keymap ( ) ;
# ifdef STARTUP_NUMLOCK_ON
activate_numlock ( true ) ; // turn on Num lock by default so that the numpad layer always has predictable results
2022-07-02 16:11:26 +02:00
# endif // STARTUP_NUMLOCK_ON
2022-04-19 13:05:13 +02:00
# ifdef IDLE_TIMEOUT_ENABLE
2022-07-02 16:11:26 +02:00
timeout_timer = timer_read ( ) ; // set initial time for idle timeout
2022-04-19 13:05:13 +02:00
# endif
2022-07-02 16:11:26 +02:00
}
/* Set defaults for EEPROM user configuration variables */
void eeconfig_init_user ( void ) {
user_config . raw = 0 ;
user_config . rgb_hilite_caps = true ;
user_config . rgb_hilite_numpad = true ;
user_config . double_tap_shift_for_capslock = true ;
user_config . del_right_home_top = true ;
user_config . encoder_press_mute_or_media = true ;
user_config . esc_double_tap_to_baselyr = true ;
user_config . ins_on_shft_bkspc_or_del = true ;
user_config . disable_space_mods = true ;
2022-08-13 18:24:07 +02:00
user_config . autocorrect = true ;
user_config . rgb_english_caps = true ;
2022-07-02 16:11:26 +02:00
eeconfig_update_user ( user_config . raw ) ;
}