aboutsummaryrefslogtreecommitdiff
path: root/keyboards/whitefox/keymaps
diff options
context:
space:
mode:
Diffstat (limited to 'keyboards/whitefox/keymaps')
-rw-r--r--keyboards/whitefox/keymaps/konstantin/config.h24
-rw-r--r--keyboards/whitefox/keymaps/konstantin/keymap.c141
-rw-r--r--keyboards/whitefox/keymaps/konstantin/rules.mk11
3 files changed, 7 insertions, 169 deletions
diff --git a/keyboards/whitefox/keymaps/konstantin/config.h b/keyboards/whitefox/keymaps/konstantin/config.h
index ab920a50b..d7a072b06 100644
--- a/keyboards/whitefox/keymaps/konstantin/config.h
+++ b/keyboards/whitefox/keymaps/konstantin/config.h
@@ -1,27 +1,7 @@
1#pragma once 1#pragma once
2 2
3#define FORCE_NKRO 3#define LAYER_FN
4#define LAYER_NUMPAD
4 5
5#undef IS_COMMAND 6#undef IS_COMMAND
6#define IS_COMMAND() (keyboard_report->mods == (MOD_BIT(KC_LSFT) | MOD_BIT(KC_RCTL))) 7#define IS_COMMAND() (keyboard_report->mods == (MOD_BIT(KC_LSFT) | MOD_BIT(KC_RCTL)))
7
8#define MAGIC_KEY_LAYER0_ALT1 BSLS
9#define MAGIC_KEY_BOOTLOADER ESC
10
11#define MOUSEKEY_DELAY 50
12#define MOUSEKEY_INTERVAL 15
13#define MOUSEKEY_MAX_SPEED 4
14#define MOUSEKEY_TIME_TO_MAX 50
15#define MOUSEKEY_WHEEL_MAX_SPEED 1
16#define MOUSEKEY_WHEEL_TIME_TO_MAX 50
17
18#define NO_ACTION_FUNCTION
19#define NO_ACTION_MACRO
20
21#define PERMISSIVE_HOLD
22#define TAPPING_TERM 200
23#define TAPPING_TOGGLE 2
24
25#define UNICODE_CYCLE_PERSIST false
26#define UNICODE_SELECTED_MODES UC_WINC, UC_LNX
27#define UNICODE_WINC_KEY KC_RGUI
diff --git a/keyboards/whitefox/keymaps/konstantin/keymap.c b/keyboards/whitefox/keymaps/konstantin/keymap.c
index 54777cfe0..e37097361 100644
--- a/keyboards/whitefox/keymaps/konstantin/keymap.c
+++ b/keyboards/whitefox/keymaps/konstantin/keymap.c
@@ -1,136 +1,5 @@
1#include QMK_KEYBOARD_H 1#include QMK_KEYBOARD_H
2 2#include "konstantin.h"
3#define TOP LCTL(KC_HOME)
4#define BOTTOM LCTL(KC_END)
5#define DSKTP_L LCTL(LGUI(KC_LEFT))
6#define DSKTP_R LCTL(LGUI(KC_RGHT))
7
8#define FN MO(L_FN)
9#define FN_CAPS LT(L_FN, KC_CAPS)
10#define FN_FNLK TT(L_FN)
11
12#define DESKTOP TD(TD_DESKTOP)
13#define FN_RCTL TD(TD_FN_RCTL)
14#define RAL_LAL TD(TD_RAL_LAL)
15#define RAL_RGU TD(TD_RAL_RGU)
16#define RCT_RSF TD(TD_RCT_RSF)
17
18#define COMMA UC(0x002C)
19#define L_PAREN UC(0x0028)
20#define R_PAREN UC(0x0029)
21#define EQUALS UC(0x003D)
22#define TIMES UC(0x00D7)
23#define DIVIDE UC(0x00F7)
24#define MINUS UC(0x2212)
25
26enum layers {
27 L_BASE,
28 L_FN,
29 L_NUMPAD,
30};
31
32enum custom_keycodes {
33 CLEAR = SAFE_RANGE,
34 NUMPAD,
35};
36
37bool process_record_user(uint16_t keycode, keyrecord_t *record) {
38 switch (keycode) {
39 case CLEAR:
40 if (record->event.pressed) {
41 SEND_STRING(SS_LCTRL("a") SS_TAP(X_DELETE));
42 }
43 return false;
44
45 case NUMPAD:
46 if (record->event.pressed) {
47 layer_invert(L_NUMPAD);
48 bool num_lock = host_keyboard_leds() & 1<<USB_LED_NUM_LOCK;
49 if (num_lock != (bool)IS_LAYER_ON(L_NUMPAD)) {
50 tap_code(KC_NLCK); // Toggle Num Lock to match layer state.
51 }
52 }
53 return false;
54
55 default:
56 return true;
57 }
58}
59
60struct {
61 bool fn_on; // Layer state when tap dance started
62 bool started;
63} td_fn_rctrl_data;
64
65void td_fn_rctrl_each(qk_tap_dance_state_t *state, void *user_data) {
66 if (!td_fn_rctrl_data.started) {
67 td_fn_rctrl_data.fn_on = IS_LAYER_ON(L_FN);
68 td_fn_rctrl_data.started = true;
69 }
70 // Single tap → Fn, double tap → RCtrl, triple tap etc. → Fn+RCtrl
71 if (state->count == 1 || state->count == 3) {
72 layer_on(L_FN);
73 } else if (state->count == 2) {
74 if (!td_fn_rctrl_data.fn_on) {
75 layer_off(L_FN);
76 }
77 register_code(KC_RCTL);
78 }
79}
80
81void td_fn_rctrl_reset(qk_tap_dance_state_t *state, void *user_data) {
82 if ((state->count == 1 || state->count > 2) && !td_fn_rctrl_data.fn_on) {
83 layer_off(L_FN);
84 }
85 if (state->count >= 2) {
86 unregister_code(KC_RCTL);
87 }
88 td_fn_rctrl_data.started = false;
89}
90
91#define ACTION_TAP_DANCE_DOUBLE_MODS(mod1, mod2) { \
92 .fn = { td_double_mods_each, NULL, td_double_mods_reset }, \
93 .user_data = &(qk_tap_dance_pair_t){ mod1, mod2 }, \
94 }
95
96void td_double_mods_each(qk_tap_dance_state_t *state, void *user_data) {
97 qk_tap_dance_pair_t *mods = (qk_tap_dance_pair_t *)user_data;
98 // Single tap → mod1, double tap → mod2, triple tap etc. → mod1+mod2
99 if (state->count == 1 || state->count == 3) {
100 register_code(mods->kc1);
101 } else if (state->count == 2) {
102 unregister_code(mods->kc1);
103 register_code(mods->kc2);
104 }
105 // Prevent tap dance from sending kc1 and kc2 as weak mods
106 state->weak_mods &= ~(MOD_BIT(mods->kc1) | MOD_BIT(mods->kc2));
107}
108
109void td_double_mods_reset(qk_tap_dance_state_t *state, void *user_data) {
110 qk_tap_dance_pair_t *mods = (qk_tap_dance_pair_t *)user_data;
111 if (state->count == 1 || state->count > 2) {
112 unregister_code(mods->kc1);
113 }
114 if (state->count >= 2) {
115 unregister_code(mods->kc2);
116 }
117}
118
119enum tap_dance {
120 TD_DESKTOP,
121 TD_FN_RCTL,
122 TD_RAL_LAL,
123 TD_RAL_RGU,
124 TD_RCT_RSF,
125};
126
127qk_tap_dance_action_t tap_dance_actions[] = {
128 [TD_DESKTOP] = ACTION_TAP_DANCE_DOUBLE(LCTL(LGUI(KC_D)), LCTL(LGUI(KC_F4))), // Add/close virtual desktop
129 [TD_FN_RCTL] = ACTION_TAP_DANCE_FN_ADVANCED(td_fn_rctrl_each, NULL, td_fn_rctrl_reset),
130 [TD_RAL_LAL] = ACTION_TAP_DANCE_DOUBLE_MODS(KC_RALT, KC_LALT),
131 [TD_RAL_RGU] = ACTION_TAP_DANCE_DOUBLE_MODS(KC_RALT, KC_RGUI),
132 [TD_RCT_RSF] = ACTION_TAP_DANCE_DOUBLE_MODS(KC_RCTL, KC_RSFT),
133};
134 3
135const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { 4const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
136 /* Base layer 5 /* Base layer
@@ -141,9 +10,9 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
141 * ├─────┴┬──┴┬──┴┬──┴┬──┴┬──┴┬──┴┬──┴┬──┴┬──┴┬──┴┬──┴┬──┴─────┼───┤ 10 * ├─────┴┬──┴┬──┴┬──┴┬──┴┬──┴┬──┴┬──┴┬──┴┬──┴┬──┴┬──┴┬──┴─────┼───┤
142 * │FnCaps│ A │ S │ D │ F │ G │ H │ J │ K │ L │ ; │ ' │ Enter │PgU│ 11 * │FnCaps│ A │ S │ D │ F │ G │ H │ J │ K │ L │ ; │ ' │ Enter │PgU│
143 * ├──────┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴────┬───┼───┤ 12 * ├──────┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴────┬───┼───┤
144 * │ LShift │ Z │ X │ C │ V │ B │ N │ M │ , │ . │ / │CtlSft│ ↑ │PgD│ 13 * │ LShift │ Z │ X │ C │ V │ B │ N │ M │ , │ . │ / │RCtRSf│ ↑ │PgD│
145 * ├────┬───┴┬──┴─┬─┴───┴───┴───┴───┴───┴──┬┴───┼───┴┬─┬───┼───┼───┤ 14 * ├────┬───┴┬──┴─┬─┴───┴───┴───┴───┴───┴──┬┴───┼───┴┬─┬───┼───┼───┤
146 * │LCtl│LGui│LAlt│ Space │AlGu│FnLk│ │ ← │ ↓ │ → │ 15 * │LCtl│LGui│LAlt│ Space │RAlG│FnLk│ │ ← │ ↓ │ → │
147 * └────┴────┴────┴────────────────────────┴────┴────┘ └───┴───┴───┘ 16 * └────┴────┴────┴────────────────────────┴────┴────┘ └───┴───┴───┘
148 */ 17 */
149 [L_BASE] = LAYOUT_truefox( \ 18 [L_BASE] = LAYOUT_truefox( \
@@ -177,7 +46,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
177 46
178 /* Numpad layer 47 /* Numpad layer
179 * ┌───┬───┬───┬───┬───┬───┬───┬───┬───┬───┬───┬───┬───┬───┬───┬───┐ 48 * ┌───┬───┬───┬───┬───┬───┬───┬───┬───┬───┬───┬───┬───┬───┬───┬───┐
180 * │Num│ │ │ │ │ │ │P7 │P8 │P9 │P- │ − │ = │Num│ │ │ 49 * │ │ │ │ │ │ │ │P7 │P8 │P9 │P- │ − │ = │Num│ │ │
181 * ├───┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴───┼───┤ 50 * ├───┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴───┼───┤
182 * │ │ │ │ │ │ │ │P4 │P5 │P6 │P+ │ ( │ ) │ │ │ 51 * │ │ │ │ │ │ │ │P4 │P5 │P6 │P+ │ ( │ ) │ │ │
183 * ├─────┴┬──┴┬──┴┬──┴┬──┴┬──┴┬──┴┬──┴┬──┴┬──┴┬──┴┬──┴┬──┴─────┼───┤ 52 * ├─────┴┬──┴┬──┴┬──┴┬──┴┬──┴┬──┴┬──┴┬──┴┬──┴┬──┴┬──┴┬──┴─────┼───┤
@@ -189,7 +58,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
189 * └────┴────┴────┴────────────────────────┴────┴────┘ └───┴───┴───┘ 58 * └────┴────┴────┴────────────────────────┴────┴────┘ └───┴───┴───┘
190 */ 59 */
191 [L_NUMPAD] = LAYOUT_truefox( \ 60 [L_NUMPAD] = LAYOUT_truefox( \
192 NUMPAD, _______, _______, _______, _______, _______, _______, KC_P7, KC_P8, KC_P9, KC_PMNS, MINUS, EQUALS, NUMPAD, _______, _______, \ 61 _______, _______, _______, _______, _______, _______, _______, KC_P7, KC_P8, KC_P9, KC_PMNS, MINUS, EQUALS, NUMPAD, _______, _______, \
193 _______, _______, _______, _______, _______, _______, _______, KC_P4, KC_P5, KC_P6, KC_PPLS, L_PAREN, R_PAREN, _______, _______, \ 62 _______, _______, _______, _______, _______, _______, _______, KC_P4, KC_P5, KC_P6, KC_PPLS, L_PAREN, R_PAREN, _______, _______, \
194 _______, _______, _______, _______, _______, _______, _______, KC_P1, KC_P2, KC_P3, KC_PAST, TIMES, KC_PENT, _______, \ 63 _______, _______, _______, _______, _______, _______, _______, KC_P1, KC_P2, KC_P3, KC_PAST, TIMES, KC_PENT, _______, \
195 _______, _______, _______, _______, _______, _______, KC_P0, KC_P0, COMMA, KC_PDOT, KC_PSLS, DIVIDE, _______, _______, \ 64 _______, _______, _______, _______, _______, _______, KC_P0, KC_P0, COMMA, KC_PDOT, KC_PSLS, DIVIDE, _______, _______, \
diff --git a/keyboards/whitefox/keymaps/konstantin/rules.mk b/keyboards/whitefox/keymaps/konstantin/rules.mk
index 96722d1d5..1302f14ca 100644
--- a/keyboards/whitefox/keymaps/konstantin/rules.mk
+++ b/keyboards/whitefox/keymaps/konstantin/rules.mk
@@ -1,13 +1,2 @@
1BACKLIGHT_ENABLE = no 1BACKLIGHT_ENABLE = no
2BOOTMAGIC_ENABLE = no
3COMMAND_ENABLE = yes
4CONSOLE_ENABLE = yes
5EXTRAKEY_ENABLE = yes
6MOUSEKEY_ENABLE = yes
7NKRO_ENABLE = yes
8SLEEP_LED_ENABLE = no
9TAP_DANCE_ENABLE = yes
10UNICODE_ENABLE = yes
11VISUALIZER_ENABLE = no 2VISUALIZER_ENABLE = no
12
13EXTRAFLAGS += -flto