keymap.c 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392
  1. #include QMK_KEYBOARD_H
  2. #include "no_keycodes.h"
  3. #if __has_include("secrets.h")
  4. # include "secrets.h"
  5. #else
  6. # define mail_str ""
  7. # define pwd_str ""
  8. #endif
  9. // layer definitions
  10. enum planck_layers {
  11. _DEFAULT,
  12. _LOWER,
  13. _RAISE,
  14. _GAME,
  15. _GLOW
  16. };
  17. // sounds
  18. #ifdef AUDIO_ENABLE
  19. float gamesong[][2] = SONG(MARIO_MUSHROOM);
  20. float defsong[][2] = SONG(PLOVER_GOODBYE_SOUND);
  21. float failed[][2] = SONG(TERMINAL_SOUND);
  22. #endif
  23. // leader key
  24. bool leader_succeed;
  25. bool leader_layer_game;
  26. bool leader_layer_def;
  27. LEADER_EXTERNS();
  28. void matrix_scan_user(void) {
  29. LEADER_DICTIONARY() {
  30. leader_succeed = leading = false;
  31. leader_layer_game = false;
  32. leader_layer_def = false;
  33. SEQ_TWO_KEYS(KC_P, KC_P) {
  34. SEND_STRING(pwd_str);
  35. leader_succeed = true;
  36. }
  37. SEQ_TWO_KEYS(KC_P, KC_M) {
  38. SEND_STRING(mail_str);
  39. leader_succeed = true;
  40. }
  41. SEQ_TWO_KEYS(KC_B, KC_B) {
  42. SEND_STRING("build"SS_TAP(X_ENTER));
  43. leader_succeed = true;
  44. }
  45. SEQ_TWO_KEYS(KC_B, KC_F) {
  46. SEND_STRING("flash"SS_TAP(X_ENTER));
  47. reset_keyboard();
  48. leader_succeed = true;
  49. }
  50. SEQ_TWO_KEYS(KC_L, KC_G) {
  51. layer_on(_GAME);
  52. leader_layer_game = true;
  53. }
  54. SEQ_TWO_KEYS(KC_L, KC_D) {
  55. layer_off(_GAME);
  56. leader_layer_def = true;
  57. }
  58. leader_end();
  59. }
  60. }
  61. void leader_end(void) {
  62. if (leader_succeed) {
  63. // do nothing
  64. } else if (leader_layer_game) {
  65. #ifdef AUDIO_ENABLE
  66. PLAY_SONG(gamesong);
  67. #endif
  68. } else if (leader_layer_def) {
  69. #ifdef AUDIO_ENABLE
  70. PLAY_SONG(defsong);
  71. #endif
  72. } else {
  73. #ifdef AUDIO_ENABLE
  74. PLAY_SONG(failed);
  75. #endif
  76. }
  77. }
  78. // tap dance definitions
  79. typedef struct {
  80. bool is_press_action;
  81. int state;
  82. } tap;
  83. enum {
  84. SINGLE_TAP = 1,
  85. SINGLE_HOLD = 2,
  86. DOUBLE_TAP = 3,
  87. DOUBLE_HOLD = 4,
  88. DOUBLE_SINGLE_TAP = 5,
  89. TRIPLE_TAP = 6,
  90. TRIPLE_HOLD = 7
  91. };
  92. enum {
  93. TD_LSFT = 0,
  94. TD_LCTL,
  95. TD_RSFT,
  96. TD_RCTL
  97. };
  98. int cur_dance (qk_tap_dance_state_t *state);
  99. void lsft_finished (qk_tap_dance_state_t *state, void *user_data);
  100. void lsft_reset (qk_tap_dance_state_t *state, void *user_data);
  101. void rsft_finished (qk_tap_dance_state_t *state, void *user_data);
  102. void rsft_reset (qk_tap_dance_state_t *state, void *user_data);
  103. void lctl_finished (qk_tap_dance_state_t *state, void *user_data);
  104. void lctl_reset (qk_tap_dance_state_t *state, void *user_data);
  105. void rctl_finished (qk_tap_dance_state_t *state, void *user_data);
  106. void rctl_reset (qk_tap_dance_state_t *state, void *user_data);
  107. // layer declarations
  108. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  109. /* Default
  110. * ,-----------------------------------------------------------------------------------.
  111. * | Tab | Q | W | E | R | T | Y | U | I | O | Å | BkSp |
  112. * |------+------+------+------+------+-------------+------+------+------+------+------|
  113. * | Esc | A | S | D | F | G | H | J | K | L | Ø | Æ |
  114. * |------+------+------+------+------+------+------+------+------+------+------+------|
  115. * | Shift| Z | X | C | V | B | N | M | P | , | . | Shift|
  116. * |------+------+------+------+------+------+------+------+------+------+------+------|
  117. * | Ctrl | Lead | Win | Alt | Lower| Space| Enter| Raise| AltGr| App | Lead | Ctrl |
  118. * `-----------------------------------------------------------------------------------'
  119. */
  120. [_DEFAULT] = LAYOUT_planck_grid(
  121. KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, NO_AA, KC_BSPC,
  122. KC_ESC, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, NO_OE, NO_AE,
  123. TD(TD_LSFT), KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_P, KC_COMM, KC_DOT, TD(TD_RSFT),
  124. TD(TD_LCTL), KC_LEAD, KC_LGUI, KC_LALT, MO(_LOWER), KC_SPC, KC_ENT, MO(_RAISE), KC_ALGR, KC_APP, KC_LEAD, TD(TD_RCTL)
  125. ),
  126. /* Lower
  127. * ,-----------------------------------------------------------------------------------.
  128. * | Tab | <Word| Up | Word>| PgUp | | | | F7 | F8 | F9 | Del |
  129. * |------+------+------+------+------+-------------+------+------+------+------+------|
  130. * | BkSp | Left | Down | Right| PgDn | | | | F4 | F5 | F6 | |
  131. * |------+------+------+------+------+------|------+------+------+------+------+------|
  132. * | Shift| Home | | End | | | | | F1 | F2 | F3 | Shift|
  133. * |------+------+------+------+------+------+------+------+------+------+------+------|
  134. * | Ctrl | | Win | Alt | Lower| M_PP |M_Next| | | Mute | VolD | VolUp|
  135. * `-----------------------------------------------------------------------------------'
  136. */
  137. [_LOWER] = LAYOUT_planck_grid(
  138. KC_TRNS, LCTL(KC_LEFT), KC_UP, LCTL(KC_RIGHT), KC_PGUP, KC_NO, KC_NO, KC_NO, KC_F7, KC_F8, KC_F9, KC_DEL,
  139. KC_BSPC, KC_LEFT, KC_DOWN, KC_RIGHT, KC_PGDN, KC_NO, KC_NO, KC_NO, KC_F4, KC_F5, KC_F6, KC_NO,
  140. KC_TRNS, KC_HOME, KC_NO, KC_END, KC_NO, KC_NO, KC_NO, KC_NO, KC_F1, KC_F2, KC_F3, KC_TRNS,
  141. KC_TRNS, KC_NO, KC_TRNS, KC_TRNS, KC_TRNS, KC_MPLY, KC_MNXT, KC_NO, KC_NO, KC_MUTE, KC_VOLD, KC_VOLU
  142. ),
  143. /* Raise
  144. * ,-----------------------------------------------------------------------------------.
  145. * | Tab | ! | ? | # | * | | | = | / | 7 | 8 | 9 | Ins |
  146. * |------+------+------+------+------+-------------+------+------+------+------+------|
  147. * | BkSp | @ | & | $ | % | ~ | + | \ | 4 | 5 | 6 | |
  148. * |------+------+------+------+------+------+------+------+------+------+------+------|
  149. * | Shift| ' | " | ¨ | | | - | 0 | 1 | 2 | 3 | Shift|
  150. * |------+------+------+------+------+------+------+------+------+------+------+------|
  151. * | Ctrl | | Win | Alt | | Space| Enter| Raise| AltGr| | | |
  152. * `-----------------------------------------------------------------------------------'
  153. */
  154. [_RAISE] = LAYOUT_planck_grid(
  155. KC_TRNS, NO_EXCL, NO_QEST, NO_HASH, NO_ASTE, NO_PIPE, NO_EQUA, NO_FSLS, KC_7, KC_8, KC_9, KC_INS,
  156. KC_BSPC, NO_ALFA, NO_AMPE, NO_USDO, NO_PERC, NO_TILD, NO_PLUS, NO_BSLS, KC_4, KC_5, KC_6, KC_NO,
  157. KC_TRNS, NO_APOS, NO_QUOT, NO_UMLA, KC_NO, KC_NO, NO_DASH, KC_0, KC_1, KC_2, KC_3, KC_TRNS,
  158. KC_TRNS, KC_NO, KC_TRNS, KC_TRNS, KC_NO, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_NO, KC_NO, KC_NO
  159. ),
  160. /* Game
  161. * ,-----------------------------------------------------------------------------------.
  162. * | Tab | Q | W | E | R | T | Y | U | I | O | | BkSp |
  163. * |------+------+------+------+------+-------------+------+------+------+------+------|
  164. * | Esc | A | S | D | F | G | H | J | K | L | | |
  165. * |------+------+------+------+------+------+------+------+------+------+------+------|
  166. * | Shift| Z | X | C | V | B | N | M | P | , | . | |
  167. * |------+------+------+------+------+------+------+------+------+------+------+------|
  168. * | Ctrl | Lead | | Alt | Lower| Space| Enter| Lower| | | Lead | |
  169. * `-----------------------------------------------------------------------------------'
  170. */
  171. [_GAME] = LAYOUT_planck_grid(
  172. KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_NO, KC_BSPC,
  173. KC_ESC, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_NO, KC_NO,
  174. KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_P, KC_COMM, KC_DOT, KC_NO,
  175. KC_LCTL, KC_LEAD, KC_NO, KC_LALT, MO(_GLOW), KC_SPC, KC_ENT, MO(_GLOW), KC_NO, KC_NO, KC_LEAD, KC_NO
  176. ),
  177. /* Game lower
  178. * ,-----------------------------------------------------------------------------------.
  179. * | Tab | 1 | 2 | 3 | | | | | | | | Steam|
  180. * |------+------+------+------+------+-------------+------+------+------+------+------|
  181. * | Esc | 4 | 5 | 6 | | | | | | | | F12 |
  182. * |------+------+------+------+------+------+------+------+------+------+------+------|
  183. * | Shift| 7 | 8 | 9 | 0 | | | | | | | |
  184. * |------+------+------+------+------+------+------+------+------+------+------+------|
  185. * | Ctrl | | | Alt | | PlyPa| Next | | | Mute | VolD | VolUp|
  186. * `-----------------------------------------------------------------------------------'
  187. */
  188. [_GLOW] = LAYOUT_planck_grid(
  189. KC_TRNS, KC_1, KC_2, KC_3, KC_PPLS, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, LSFT(KC_F7),
  190. KC_TRNS, KC_4, KC_5, KC_6, KC_PMNS, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_F12,
  191. KC_TRNS, KC_7, KC_8, KC_9, KC_0, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_MUTE,
  192. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_MPLY, KC_MNXT, KC_NO, KC_TRNS, KC_MUTE, KC_VOLD, KC_VOLU
  193. )
  194. };
  195. // tap dance declarations
  196. int cur_dance (qk_tap_dance_state_t *state) {
  197. if (state->count == 1) {
  198. if (state->interrupted || !state->pressed) return SINGLE_TAP;
  199. else return SINGLE_HOLD;
  200. }
  201. else if (state->count == 2) {
  202. if (state->interrupted) return DOUBLE_SINGLE_TAP;
  203. else if (state->pressed) return DOUBLE_HOLD;
  204. else return DOUBLE_TAP;
  205. }
  206. if (state->count == 3) {
  207. if (state->interrupted || !state->pressed) return TRIPLE_TAP;
  208. else return TRIPLE_HOLD;
  209. }
  210. else return 8;
  211. }
  212. static tap xtap_state = {
  213. .is_press_action = true,
  214. .state = 0
  215. };
  216. void lsft_finished (qk_tap_dance_state_t *state, void *user_data) {
  217. xtap_state.state = cur_dance(state);
  218. switch (xtap_state.state) {
  219. case SINGLE_TAP:
  220. register_code16(LSFT(KC_8));
  221. break;
  222. case SINGLE_HOLD:
  223. register_code(KC_LSFT);
  224. break;
  225. case DOUBLE_TAP:
  226. register_code(KC_NUBS);
  227. break;
  228. case DOUBLE_SINGLE_TAP:
  229. register_code(KC_NUBS);
  230. break;
  231. }
  232. }
  233. void lsft_reset (qk_tap_dance_state_t *state, void *user_data) {
  234. switch (xtap_state.state) {
  235. case SINGLE_TAP:
  236. unregister_code16(LSFT(KC_8));
  237. break;
  238. case SINGLE_HOLD:
  239. unregister_code(KC_LSFT);
  240. break;
  241. case DOUBLE_TAP:
  242. unregister_code(KC_NUBS);
  243. break;
  244. case DOUBLE_SINGLE_TAP:
  245. unregister_code(KC_NUBS);
  246. break;
  247. }
  248. xtap_state.state = 0;
  249. }
  250. void rsft_finished (qk_tap_dance_state_t *state, void *user_data) {
  251. xtap_state.state = cur_dance(state);
  252. switch (xtap_state.state) {
  253. case SINGLE_TAP:
  254. register_code16(LSFT(KC_9));
  255. break;
  256. case SINGLE_HOLD:
  257. register_code(KC_RSFT);
  258. break;
  259. case DOUBLE_TAP:
  260. register_code16(LSFT(KC_NUBS));
  261. break;
  262. case DOUBLE_SINGLE_TAP:
  263. register_code16(LSFT(KC_NUBS));
  264. break;
  265. }
  266. }
  267. void rsft_reset (qk_tap_dance_state_t *state, void *user_data) {
  268. switch (xtap_state.state) {
  269. case SINGLE_TAP:
  270. unregister_code16(LSFT(KC_9));
  271. break;
  272. case SINGLE_HOLD:
  273. unregister_code(KC_RSFT);
  274. break;
  275. case DOUBLE_TAP:
  276. unregister_code16(LSFT(KC_NUBS));
  277. break;
  278. case DOUBLE_SINGLE_TAP:
  279. unregister_code16(LSFT(KC_NUBS));
  280. break;
  281. }
  282. xtap_state.state = 0;
  283. }
  284. void lctl_finished (qk_tap_dance_state_t *state, void *user_data) {
  285. xtap_state.state = cur_dance(state);
  286. switch (xtap_state.state) {
  287. case SINGLE_TAP:
  288. register_mods(MOD_BIT(KC_ALGR));
  289. register_code(KC_7);
  290. break;
  291. case SINGLE_HOLD:
  292. register_code(KC_LCTL);
  293. break;
  294. case DOUBLE_TAP:
  295. register_mods(MOD_BIT(KC_ALGR));
  296. register_code(KC_8);
  297. break;
  298. case DOUBLE_SINGLE_TAP:
  299. register_mods(MOD_BIT(KC_ALGR));
  300. register_code(KC_8);
  301. break;
  302. }
  303. }
  304. void lctl_reset (qk_tap_dance_state_t *state, void *user_data) {
  305. switch (xtap_state.state) {
  306. case SINGLE_TAP:
  307. unregister_code(KC_7);
  308. unregister_mods(MOD_BIT(KC_ALGR));
  309. break;
  310. case SINGLE_HOLD:
  311. unregister_code(KC_LCTL);
  312. break;
  313. case DOUBLE_TAP:
  314. unregister_code(KC_8);
  315. unregister_mods(MOD_BIT(KC_ALGR));
  316. break;
  317. case DOUBLE_SINGLE_TAP:
  318. unregister_code(KC_8);
  319. unregister_mods(MOD_BIT(KC_ALGR));
  320. break;
  321. }
  322. xtap_state.state = 0;
  323. }
  324. void rctl_finished (qk_tap_dance_state_t *state, void *user_data) {
  325. xtap_state.state = cur_dance(state);
  326. switch (xtap_state.state) {
  327. case SINGLE_TAP:
  328. register_mods(MOD_BIT(KC_ALGR));
  329. register_code(KC_0);
  330. break;
  331. case SINGLE_HOLD:
  332. register_code(KC_RCTL);
  333. break;
  334. case DOUBLE_TAP:
  335. register_mods(MOD_BIT(KC_ALGR));
  336. register_code(KC_9);
  337. break;
  338. case DOUBLE_SINGLE_TAP:
  339. register_mods(MOD_BIT(KC_ALGR));
  340. register_code(KC_9);
  341. break;
  342. }
  343. }
  344. void rctl_reset (qk_tap_dance_state_t *state, void *user_data) {
  345. switch (xtap_state.state) {
  346. case SINGLE_TAP:
  347. unregister_code(KC_0);
  348. unregister_mods(MOD_BIT(KC_ALGR));
  349. break;
  350. case SINGLE_HOLD:
  351. unregister_code(KC_RCTL);
  352. break;
  353. case DOUBLE_TAP:
  354. unregister_code(KC_9);
  355. unregister_mods(MOD_BIT(KC_ALGR));
  356. break;
  357. case DOUBLE_SINGLE_TAP:
  358. unregister_code(KC_9);
  359. unregister_mods(MOD_BIT(KC_ALGR));
  360. break;
  361. }
  362. xtap_state.state = 0;
  363. }
  364. qk_tap_dance_action_t tap_dance_actions[] = {
  365. [TD_LSFT] = ACTION_TAP_DANCE_FN_ADVANCED(NULL, lsft_finished, lsft_reset),
  366. [TD_RSFT] = ACTION_TAP_DANCE_FN_ADVANCED(NULL, rsft_finished, rsft_reset),
  367. [TD_LCTL] = ACTION_TAP_DANCE_FN_ADVANCED(NULL, lctl_finished, lctl_reset),
  368. [TD_RCTL] = ACTION_TAP_DANCE_FN_ADVANCED(NULL, rctl_finished, rctl_reset),
  369. };