keymap.c 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411
  1. #include "drashna.h"
  2. #ifdef RGBLIGHT_ENABLE
  3. extern rgblight_config_t rgblight_config;
  4. #endif
  5. #ifdef BACKLIGHT_ENABLE
  6. enum planck_keycodes {
  7. BACKLIT = NEW_SAFE_RANGE,
  8. TH_LVL,
  9. };
  10. #else
  11. # define BACKLIT OSM(MOD_LSFT)
  12. enum planck_keycodes {
  13. TH_LVL = NEW_SAFE_RANGE,
  14. };
  15. #endif
  16. #ifdef KEYBOARD_planck_ez
  17. # define PLNK_1 BK_LWER
  18. # define PLNK_2 SP_LWER
  19. # define PLNK_3 KC_NO
  20. # define PLNK_4 ET_RAIS
  21. #else
  22. # define PLNK_1 SP_LWER
  23. # define PLNK_2 BK_LWER
  24. # define PLNK_3 DL_RAIS
  25. # define PLNK_4 ET_RAIS
  26. #endif
  27. /*
  28. * The `LAYOUT_ortho_4x12_base` macro is a template to allow the use of identical
  29. * modifiers for the default layouts (eg QWERTY, Colemak, Dvorak, etc), so
  30. * that there is no need to set them up for each layout, and modify all of
  31. * them if I want to change them. This helps to keep consistency and ease
  32. * of use. K## is a placeholder to pass through the individual keycodes
  33. */
  34. // clang-format off
  35. #define LAYOUT_ortho_4x12_base( \
  36. K01, K02, K03, K04, K05, K06, K07, K08, K09, K0A, \
  37. K11, K12, K13, K14, K15, K16, K17, K18, K19, K1A, \
  38. K21, K22, K23, K24, K25, K26, K27, K28, K29, K2A \
  39. ) \
  40. LAYOUT_ortho_4x12_wrapper( \
  41. KC_ESC, K01, K02, K03, K04, K05, K06, K07, K08, K09, K0A, KC_DEL, \
  42. LALT_T(KC_TAB), K11, K12, K13, K14, K15, K16, K17, K18, K19, K1A, RALT_T(KC_QUOT), \
  43. KC_MLSF, CTL_T(K21), K22, K23, K24, K25, K26, K27, K28, K29, RCTL_T(K2A), KC_ENT, \
  44. BACKLIT, OS_LCTL, OS_LALT, OS_LGUI, PLNK_1, PLNK_2, PLNK_3, PLNK_4, KC_LEFT, KC_DOWN, KC_UP, KC_RGHT \
  45. )
  46. #define LAYOUT_ortho_4x12_base_wrapper(...) LAYOUT_ortho_4x12_base(__VA_ARGS__)
  47. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  48. [_QWERTY] = LAYOUT_ortho_4x12_base_wrapper(
  49. _________________QWERTY_L1_________________, _________________QWERTY_R1_________________,
  50. _________________QWERTY_L2_________________, _________________QWERTY_R2_________________,
  51. _________________QWERTY_L3_________________, _________________QWERTY_R3_________________
  52. ),
  53. [_COLEMAK] = LAYOUT_ortho_4x12_base_wrapper(
  54. _________________COLEMAK_L1________________, _________________COLEMAK_R1________________,
  55. _________________COLEMAK_L2________________, _________________COLEMAK_R2________________,
  56. _________________COLEMAK_L3________________, _________________COLEMAK_R3________________
  57. ),
  58. [_DVORAK] = LAYOUT_ortho_4x12_base_wrapper(
  59. _________________DVORAK_L1_________________, _________________DVORAK_R1_________________,
  60. _________________DVORAK_L2_________________, _________________DVORAK_R2_________________,
  61. _________________DVORAK_L3_________________, _________________DVORAK_R3_________________
  62. ),
  63. [_WORKMAN] = LAYOUT_ortho_4x12_base_wrapper(
  64. _________________WORKMAN_L1________________, _________________WORKMAN_R1________________,
  65. _________________WORKMAN_L2________________, _________________WORKMAN_R2________________,
  66. _________________WORKMAN_L3________________, _________________WORKMAN_R3________________
  67. ),
  68. [_NORMAN] = LAYOUT_ortho_4x12_base_wrapper(
  69. _________________NORMAN_L1_________________, _________________NORMAN_L1_________________,
  70. _________________NORMAN_L2_________________, _________________NORMAN_R2_________________,
  71. _________________NORMAN_L3_________________, _________________NORMAN_R3_________________
  72. ),
  73. [_MALTRON] = LAYOUT_ortho_4x12_base_wrapper(
  74. _________________MALTRON_L1________________, _________________MALTRON_R1________________,
  75. _________________MALTRON_L2________________, _________________MALTRON_R2________________,
  76. _________________MALTRON_L3________________, _________________MALTRON_R3________________
  77. ),
  78. [_EUCALYN] = LAYOUT_ortho_4x12_base_wrapper(
  79. _________________EUCALYN_L1________________, _________________EUCALYN_R1________________,
  80. _________________EUCALYN_L2________________, _________________EUCALYN_R2________________,
  81. _________________EUCALYN_L3________________, _________________EUCALYN_R3________________
  82. ),
  83. [_CARPLAX] = LAYOUT_ortho_4x12_base_wrapper(
  84. _____________CARPLAX_QFMLWY_L1_____________, _____________CARPLAX_QFMLWY_R1_____________,
  85. _____________CARPLAX_QFMLWY_L2_____________, _____________CARPLAX_QFMLWY_R2_____________,
  86. _____________CARPLAX_QFMLWY_L3_____________, _____________CARPLAX_QFMLWY_R3_____________
  87. ),
  88. [_MODS] = LAYOUT_ortho_4x12_wrapper(
  89. _______, ___________________BLANK___________________, ___________________BLANK___________________, _______,
  90. _______, ___________________BLANK___________________, ___________________BLANK___________________, _______,
  91. KC_LSFT, ___________________BLANK___________________, ___________________BLANK___________________, _______,
  92. _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______
  93. ),
  94. [_LOWER] = LAYOUT_ortho_4x12_wrapper(
  95. KC_TILD, _________________LOWER_L1__________________, _________________LOWER_R1__________________, KC_BSPC,
  96. KC_DEL, _________________LOWER_L2__________________, _________________LOWER_R2__________________, KC_PIPE,
  97. _______, _________________LOWER_L3__________________, _________________LOWER_R3__________________, _______,
  98. _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______
  99. ),
  100. [_RAISE] = LAYOUT_ortho_4x12_wrapper(
  101. KC_GRV, _________________RAISE_L1__________________, _________________RAISE_R1__________________, KC_BSPC,
  102. KC_DEL, _________________RAISE_L2__________________, _________________RAISE_R2__________________, KC_BSLS,
  103. _______, _________________RAISE_L3__________________, _________________RAISE_R3__________________, _______,
  104. _______, _______, _______, _______, _______, _______, _______, _________________RAISE_R3__________________
  105. ),
  106. [_ADJUST] = LAYOUT_ortho_4x12_wrapper(
  107. KC_MAKE, _________________ADJUST_L1_________________, _________________ADJUST_R1_________________, KC_RST,
  108. VRSN, _________________ADJUST_L2_________________, _________________ADJUST_R2_________________, EEP_RST,
  109. TH_LVL, _________________ADJUST_L3_________________, _________________ADJUST_R3_________________, RGB_IDL,
  110. HPT_TOG, _______, _______, _______, _______, KC_NUKE, _______, _______, _______, _______, _______, TG_MODS
  111. )
  112. };
  113. // clang-format on
  114. bool process_record_keymap(uint16_t keycode, keyrecord_t *record) {
  115. switch (keycode) {
  116. #ifdef BACKLIGHT_ENABLE
  117. case BACKLIT:
  118. if (record->event.pressed) {
  119. register_code(KC_RSFT);
  120. # ifdef BACKLIGHT_ENABLE
  121. backlight_step();
  122. # endif
  123. } else {
  124. unregister_code(KC_RSFT);
  125. }
  126. break;
  127. #endif
  128. #ifdef KEYBOARD_planck_ez
  129. case TH_LVL:
  130. if (record->event.pressed) {
  131. keyboard_config.led_level++;
  132. if (keyboard_config.led_level > 4) {
  133. keyboard_config.led_level = 0;
  134. }
  135. planck_ez_right_led_level((uint8_t)keyboard_config.led_level * 255 / 4);
  136. planck_ez_left_led_level((uint8_t)keyboard_config.led_level * 255 / 4);
  137. eeconfig_update_kb(keyboard_config.raw);
  138. layer_state_set_kb(layer_state);
  139. }
  140. break;
  141. #endif
  142. }
  143. return true;
  144. }
  145. bool music_mask_user(uint16_t keycode) {
  146. switch (keycode) {
  147. case RAISE:
  148. case LOWER:
  149. case BK_LWER:
  150. case SP_LWER:
  151. case DL_RAIS:
  152. case ET_RAIS:
  153. return false;
  154. default:
  155. return true;
  156. }
  157. }
  158. #ifdef RGB_MATRIX_ENABLE
  159. # ifdef KEYBOARD_planck_rev6
  160. // clang-format off
  161. led_config_t g_led_config = {
  162. {
  163. // Key Matrix to LED Index
  164. { NO_LED, 6, NO_LED, NO_LED, 5, NO_LED },
  165. { NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED },
  166. { NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, 0 },
  167. { NO_LED, 7, NO_LED, NO_LED, 2, NO_LED },
  168. { NO_LED, 4, NO_LED, NO_LED, 3, NO_LED },
  169. { NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED },
  170. { NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED },
  171. { NO_LED, 1, NO_LED, NO_LED, 8, NO_LED }
  172. }, {
  173. // LED Index to Physical Position
  174. {112, 39}, {148, 60}, {206, 53}, {206, 3}, {150, 3}, {74, 3}, {18, 3}, {18, 54}, {77, 60}
  175. }, {
  176. // LED Index to Flag
  177. LED_FLAG_ALL, LED_FLAG_ALL, LED_FLAG_ALL, LED_FLAG_ALL, LED_FLAG_ALL,
  178. LED_FLAG_ALL, LED_FLAG_ALL, LED_FLAG_ALL, LED_FLAG_ALL
  179. }
  180. };
  181. // clange-format on
  182. # endif
  183. // clang-format off
  184. void suspend_power_down_keymap(void) {
  185. rgb_matrix_set_suspend_state(true);
  186. }
  187. void suspend_wakeup_init_keymap(void) {
  188. rgb_matrix_set_suspend_state(false);
  189. }
  190. // clang-format on
  191. void rgb_matrix_indicators_user(void) {
  192. uint8_t this_mod = get_mods();
  193. uint8_t this_led = host_keyboard_leds();
  194. uint8_t this_osm = get_oneshot_mods();
  195. bool is_ez;
  196. # ifdef KEYBOARD_planck_ez
  197. is_ez = true;
  198. # endif
  199. if (g_suspend_state || !rgb_matrix_config.enable) return;
  200. # if defined(RGBLIGHT_ENABLE)
  201. if (!userspace_config.rgb_layer_change)
  202. # else
  203. if (userspace_config.rgb_layer_change)
  204. # endif
  205. {
  206. switch (get_highest_layer(layer_state)) {
  207. case _GAMEPAD:
  208. rgb_matrix_layer_helper(HSV_ORANGE, 1, rgb_matrix_config.speed, LED_FLAG_MODIFIER);
  209. break;
  210. case _DIABLO:
  211. rgb_matrix_layer_helper(HSV_RED, 1, rgb_matrix_config.speed * 8, LED_FLAG_MODIFIER);
  212. break;
  213. case _RAISE:
  214. rgb_matrix_layer_helper(HSV_YELLOW, 1, rgb_matrix_config.speed, LED_FLAG_MODIFIER);
  215. break;
  216. case _LOWER:
  217. rgb_matrix_layer_helper(HSV_GREEN, 1, rgb_matrix_config.speed, LED_FLAG_MODIFIER);
  218. break;
  219. case _ADJUST:
  220. rgb_matrix_layer_helper(HSV_RED, 1, rgb_matrix_config.speed, LED_FLAG_MODIFIER);
  221. break;
  222. default: {
  223. bool mods_enabled = IS_LAYER_ON(_MODS);
  224. switch (get_highest_layer(default_layer_state)) {
  225. case _QWERTY:
  226. rgb_matrix_layer_helper(HSV_CYAN, mods_enabled, rgb_matrix_config.speed, LED_FLAG_MODIFIER);
  227. break;
  228. case _COLEMAK:
  229. rgb_matrix_layer_helper(HSV_MAGENTA, mods_enabled, rgb_matrix_config.speed, LED_FLAG_MODIFIER);
  230. break;
  231. case _DVORAK:
  232. rgb_matrix_layer_helper(HSV_SPRINGGREEN, mods_enabled, rgb_matrix_config.speed, LED_FLAG_MODIFIER);
  233. break;
  234. case _WORKMAN:
  235. rgb_matrix_layer_helper(HSV_GOLDENROD, mods_enabled, rgb_matrix_config.speed, LED_FLAG_MODIFIER);
  236. break;
  237. case _NORMAN:
  238. rgb_matrix_layer_helper(HSV_CORAL, mods_enabled, rgb_matrix_config.speed, LED_FLAG_MODIFIER);
  239. break;
  240. case _MALTRON:
  241. rgb_matrix_layer_helper(HSV_YELLOW, mods_enabled, rgb_matrix_config.speed, LED_FLAG_MODIFIER);
  242. break;
  243. case _EUCALYN:
  244. rgb_matrix_layer_helper(HSV_PINK, mods_enabled, rgb_matrix_config.speed, LED_FLAG_MODIFIER);
  245. break;
  246. case _CARPLAX:
  247. rgb_matrix_layer_helper(HSV_BLUE, mods_enabled, rgb_matrix_config.speed, LED_FLAG_MODIFIER);
  248. break;
  249. }
  250. break;
  251. }
  252. }
  253. }
  254. switch (get_highest_layer(default_layer_state)) {
  255. case _QWERTY:
  256. rgb_matrix_set_color(is_ez ? 41 : 42, 0x00, 0xFF, 0xFF);
  257. break;
  258. case _COLEMAK:
  259. rgb_matrix_set_color(is_ez ? 41 : 42, 0xFF, 0x00, 0xFF);
  260. break;
  261. case _DVORAK:
  262. rgb_matrix_set_color(is_ez ? 41 : 42, 0x00, 0xFF, 0x00);
  263. break;
  264. case _WORKMAN:
  265. rgb_matrix_set_color(is_ez ? 41 : 42, 0xD9, 0xA5, 0x21);
  266. break;
  267. }
  268. if ((this_mod | this_osm) & MOD_MASK_SHIFT || this_led & (1 << USB_LED_CAPS_LOCK)) {
  269. if (!layer_state_cmp(layer_state, _ADJUST)) {
  270. rgb_matrix_set_color(24, 0x00, 0xFF, 0x00);
  271. }
  272. rgb_matrix_set_color(36, 0x00, 0xFF, 0x00);
  273. }
  274. if ((this_mod | this_osm) & MOD_MASK_CTRL) {
  275. rgb_matrix_set_color(25, 0xFF, 0x00, 0x00);
  276. rgb_matrix_set_color(34, 0xFF, 0x00, 0x00);
  277. rgb_matrix_set_color(37, 0xFF, 0x00, 0x00);
  278. }
  279. if ((this_mod | this_osm) & MOD_MASK_GUI) {
  280. rgb_matrix_set_color(39, 0xFF, 0xD9, 0x00);
  281. }
  282. if ((this_mod | this_osm) & MOD_MASK_ALT) {
  283. rgb_matrix_set_color(38, 0x00, 0x00, 0xFF);
  284. }
  285. }
  286. void matrix_init_keymap(void) {
  287. # ifdef KEYBOARD_planck_light
  288. writePinLow(D6);
  289. # endif
  290. // rgblight_mode(RGB_MATRIX_MULTISPLASH);
  291. }
  292. #else // RGB_MATRIX_INIT
  293. void matrix_init_keymap(void) {
  294. # if !defined(CONVERT_TO_PROTON_C) && !defined(KEYBOARD_planck)
  295. setPinOutput(D5);
  296. writePinHigh(D5);
  297. setPinOutput(B0);
  298. writePinHigh(B0);
  299. # endif
  300. }
  301. #endif // RGB_MATRIX_INIT
  302. #ifdef ENCODER_ENABLE
  303. void encoder_update(bool clockwise) {
  304. switch (get_highest_layer(layer_state)) {
  305. case _RAISE:
  306. clockwise ? tap_code(KC_VOLD) : tap_code(KC_VOLU);
  307. break;
  308. case _LOWER:
  309. # ifdef RGB_MATRIX_ENABLE
  310. clockwise ? rgb_matrix_step() : rgb_matrix_step_reverse();
  311. # else
  312. clockwise ? tap_code(KC_PGDN) : tap_code(KC_PGUP);
  313. # endif
  314. break;
  315. case _ADJUST:
  316. # ifdef AUDIO_CLICKY
  317. clockwise ? clicky_freq_up() : clicky_freq_down();
  318. # endif
  319. break;
  320. default:
  321. clockwise ? tap_code(KC_DOWN) : tap_code(KC_UP);
  322. }
  323. # ifdef AUDIO_CLICKY
  324. clicky_play();
  325. # endif
  326. }
  327. #endif // ENCODER_ENABLE
  328. #ifdef KEYBOARD_planck_rev6
  329. void dip_update(uint8_t index, bool active) {
  330. switch (index) {
  331. case 0:
  332. if (active) {
  333. audio_on();
  334. } else {
  335. audio_off();
  336. }
  337. break;
  338. case 1:
  339. if (active) {
  340. clicky_on();
  341. } else {
  342. clicky_off();
  343. }
  344. break;
  345. case 2:
  346. keymap_config.swap_lctl_lgui = keymap_config.swap_rctl_rgui = active;
  347. break;
  348. case 3:
  349. userspace_config.nuke_switch = active;
  350. break;
  351. }
  352. }
  353. #endif // KEYBOARD_planck_rev6
  354. #ifdef KEYBOARD_planck_ez
  355. layer_state_t layer_state_set_keymap(layer_state_t state) {
  356. planck_ez_left_led_off();
  357. planck_ez_right_led_off();
  358. switch (get_highest_layer(state)) {
  359. case _LOWER:
  360. planck_ez_left_led_on();
  361. break;
  362. case _RAISE:
  363. planck_ez_right_led_on();
  364. break;
  365. case _ADJUST:
  366. planck_ez_right_led_on();
  367. planck_ez_left_led_on();
  368. break;
  369. default:
  370. break;
  371. }
  372. return state;
  373. }
  374. #endif