1 #include QMK_KEYBOARD_H
3 extern keymap_config_t keymap_config;
5 #ifdef BACKLIGHT_ENABLE
13 void backlight_toggle(void){
24 enum roadkit_keycodes {
41 #include "dynamic_macro.h"
43 // Fillers to make keymaps cleaner looking
44 #define _______ KC_TRNS
47 const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
48 [_NUMPAD] = LAYOUT_numpad_4x4( /* Numpad */
49 KC_KP_7, KC_KP_8, KC_KP_9, KC_KP_PLUS, \
50 KC_KP_4, KC_KP_5, KC_KP_6, \
51 KC_KP_1, KC_KP_2, KC_KP_3, KC_KP_ENTER, \
52 LT(_ADJUST, KC_KP_0), KC_KP_DOT \
54 [_FPH] = LAYOUT_numpad_4x4( /* Quiet T9 */
55 FPH_7, FPH_8, FPH_9, KC_KP_PLUS, \
56 FPH_4, FPH_5, FPH_6, \
57 FPH_1, FPH_2, FPH_3, SFT_T(KC_KP_ENTER), \
58 LT(_ADJUST, KC_SPACE), KC_KP_DOT \
60 [_FPHNOISY] = LAYOUT_numpad_4x4( /* Noisy T9 */
61 FPH_7, FPH_8, FPH_9, KC_KP_PLUS, \
62 FPH_4, FPH_5, FPH_6, \
63 FPH_1, FPH_2, FPH_3, SFT_T(KC_KP_ENTER), \
64 LT(_ADJUST, KC_SPACE), KC_KP_DOT \
66 [_ADJUST] = LAYOUT_numpad_4x4( /* Adjustments */
67 KC_NUMLOCK, TG(_FPHNOISY), TG(_FPH), TG(_NUMPAD), \
68 KC_BSPC, BACKLIT, KC_DEL, \
69 MACSLEEP, _______, _______, _______, \
72 [_DYN] = LAYOUT_numpad_4x4( /* DYNAMIC MACRO */
73 DYN_REC_START1, DYN_REC_START2, _______, DYN_REC_STOP, \
74 _______, _______, _______, \
75 DYN_MACRO_PLAY1, DYN_MACRO_PLAY2, _______, _______, \
80 const uint16_t PROGMEM fn_actions[] = {
84 void persistant_default_layer_set(uint16_t default_layer) {
85 eeconfig_update_default_layer(default_layer);
86 default_layer_set(default_layer);
89 uint16_t fph_tap_qty = false;
90 uint16_t fph_keycode = 0; // stores which spacebar was used, either raise or lower...
92 uint16_t get_render_keycode(uint16_t keycode, uint16_t tap_qty){ // maybe replace shift with "mods"
93 tap_qty--; // reduce by one to match array indexes.
96 {uint16_t kc[] = {KC_A, KC_B, KC_C};
98 return LSFT(kc[tap_qty % 3]);
99 return kc[tap_qty % 3];}
102 {uint16_t kc[] = {KC_D, KC_E, KC_F};
104 return LSFT(kc[tap_qty % 3]);
105 return kc[tap_qty % 3];}
108 {uint16_t kc[] = {KC_G, KC_H, KC_I};
110 return LSFT(kc[tap_qty % 3]);
111 return kc[tap_qty % 3];}
114 {uint16_t kc[] = {KC_J, KC_K, KC_L};
116 return LSFT(kc[tap_qty % 3]);
117 return kc[tap_qty % 3];}
120 {uint16_t kc[] = {KC_M, KC_N, KC_O};
122 return LSFT(kc[tap_qty % 3]);
123 return kc[tap_qty % 3];}
126 {uint16_t kc[] = {KC_P, KC_Q, KC_R, KC_S};
128 return LSFT(kc[tap_qty % 4]);
129 return kc[tap_qty % 4];}
132 {uint16_t kc[] = {KC_T, KC_U, KC_V};
134 return LSFT(kc[tap_qty % 4]);
135 return kc[tap_qty % 4];}
138 {uint16_t kc[] = {KC_W, KC_X, KC_Y, KC_Z};
140 return LSFT(kc[tap_qty % 4]);
141 return kc[tap_qty % 4];}
144 {uint16_t kc[] = {KC_COMM, LSFT(KC_SLSH), KC_EXLM, KC_AT, KC_MINS, KC_UNDS, KC_PLUS, \
145 KC_SCLN, LSFT(KC_SCLN), KC_QUOT, LSFT(KC_QUOT), KC_TILD, \
146 KC_PIPE, KC_BSLS, KC_HASH, LSFT(KC_4), KC_PERC, KC_CIRC, KC_AMPR, KC_ASTR, \
147 KC_LBRC, KC_RBRC, KC_LCBR, KC_RCBR, LSFT(KC_COMM), LSFT(KC_DOT)};
148 return kc[tap_qty % 26];}
153 bool process_record_user(uint16_t keycode, keyrecord_t *record) {
154 if (!process_record_dynamic_macro(keycode, record)) {
158 layer = biton32(layer_state);
161 case FPH_1 ... FPH_9:
162 if(layer == _FPHNOISY){
163 if (record->event.pressed) {
164 if(fph_keycode != keycode) { // key change
166 fph_keycode = keycode;
167 } else { // same key tapped again so erase and increment.
168 register_code(KC_BSPC);
169 unregister_code(KC_BSPC);
172 uint16_t render_keycode = get_render_keycode(keycode, fph_tap_qty);
173 // find mods? Apply mods..
174 register_code(render_keycode);
175 unregister_code(render_keycode);
177 // do we need to do anything on key-release?
179 } else { // not noisy, be demure .
180 if (record->event.pressed) {
181 if(fph_keycode != keycode) { // key change, kill everything.
182 uint16_t render_keycode = get_render_keycode(fph_keycode, fph_tap_qty);
183 // find mods? Apply mods..
184 register_code(render_keycode);
185 unregister_code(render_keycode);
186 fph_keycode = keycode;
188 } else { // same key tapped again so increment counter silently
192 // do we need to do anything on key-release?
193 // maybe start a timer on this one?
199 if (record->event.pressed) {
200 #ifdef BACKLIGHT_ENABLE
207 if (record->event.pressed) {
208 register_code(KC_RSFT);
209 register_code(KC_RCTL);
210 register_code(KC_POWER);
211 unregister_code(KC_POWER);
212 unregister_code(KC_RCTL);
213 unregister_code(KC_RSFT);