keymap.c 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321
  1. #include QMK_KEYBOARD_H
  2. #include "debug.h"
  3. #include "action_layer.h"
  4. #include "version.h"
  5. // to build this keymap
  6. // make ergodox_ez:dvorak_42_key:teensy
  7. static bool mouse_lock = false;
  8. enum custom_keycodes {
  9. PLACEHOLDER = SAFE_RANGE, // can always be here
  10. EPRM,
  11. VRSN,
  12. RGB_SLD,
  13. };
  14. #define BASE 0 // base dvorak layer
  15. #define KEYNAV 1 // arrow navigation (right hand)
  16. #define KEYSEL 2 // arrow navigation + shift (allow text selection)
  17. #define SHELL_NAV 3 // bash shortcuts
  18. #define MOUSE 4 // mouse layer (can be locked with lock key)
  19. #define COMBINED 5 // combined numbers and symbols layer
  20. // macros
  21. #define MOUSE_TOGGLE 1
  22. #define MOUSE_LOCK 2
  23. #define SCREEN_TAB_LEFT 4
  24. #define SCREEN_TAB_RIGHT 5
  25. #define SCREEN_NEW_TAB 6
  26. #define SWITCH_NDS 7
  27. #define SCREEN_COPY_MODE 8
  28. #define SCREEN_PASTE 9
  29. #define SHELL_RECALL_LAST_ARG_REMOVE_FIRST_COMMAND 15
  30. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  31. [BASE] = KEYMAP(
  32. // left hand
  33. KC_ESC, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6,
  34. KC_TAB, KC_QUOTE, KC_COMMA, KC_DOT, KC_P, KC_Y, MEH(KC_2),
  35. MO(SHELL_NAV), KC_A, KC_O, KC_E, KC_U, KC_I,
  36. MEH(KC_0), KC_SCOLON, KC_Q, KC_J, KC_K, KC_X, MEH(KC_3),
  37. MEH(KC_1), OSM(MOD_LSFT), OSM(MOD_LCTL), M(MOUSE_TOGGLE), MO(KEYSEL),
  38. // left thumb cluster
  39. MEH(KC_4), MEH(KC_5),
  40. MEH(KC_6),
  41. MO(COMBINED),MO(KEYNAV), OSM(MOD_LALT),
  42. // right hand
  43. KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, MEH(KC_9),
  44. MEH(KC_7), KC_F, KC_G, KC_C, KC_R, KC_L, MEH(KC_F1),
  45. KC_D, KC_H, KC_T, KC_N, KC_S, MEH(KC_F2),
  46. MEH(KC_8), KC_B, KC_M, KC_W, KC_V, KC_Z, MEH(KC_F3),
  47. KC_BSPC, RCTL(KC_BSPC), KC_CAPSLOCK, OSM(MOD_LSFT),MEH(KC_F4),
  48. // right thumb cluster
  49. MEH(KC_F5),MEH(KC_F6),MEH(KC_F7),MEH(KC_F8),KC_ENTER,KC_SPACE
  50. ),
  51. [KEYNAV] = KEYMAP(
  52. // left hand
  53. KC_TRNS,KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
  54. KC_TRNS,KC_ESC, MEH(KC_F9), RCTL(KC_Z), RCTL(KC_S), MEH(KC_F10), KC_TRNS,
  55. KC_TRNS,MEH(KC_F11), MEH(KC_F12), RSFT(KC_TAB), KC_TAB, MEH(KC_A),
  56. KC_TRNS,MEH(KC_B), MEH(KC_C), MEH(KC_D), MEH(KC_E), MEH(KC_F), KC_TRNS,
  57. KC_TRNS,KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
  58. // left thumb cluster
  59. KC_TRNS,KC_TRNS,KC_TRNS,TO(MOUSE),KC_TRNS,KC_TRNS,
  60. // right hand
  61. KC_TRNS,KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, MEH(KC_G),
  62. KC_TRNS,KC_NO, KC_HOME, KC_UP, KC_END, KC_PGUP, MEH(KC_H),
  63. LCTL(KC_LEFT), KC_LEFT, KC_DOWN, KC_RIGHT, LCTL(KC_RIGHT), MEH(KC_I),
  64. KC_TRNS,KC_NO, RCTL(KC_C), RCTL(KC_X), RCTL(KC_V), KC_PGDOWN, MEH(KC_J),
  65. KC_BSPC, RCTL(KC_BSPC), KC_DELETE, LCTL(KC_DELETE), MEH(KC_K),
  66. // right thumb cluster
  67. KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS
  68. ),
  69. // key selection layer
  70. [KEYSEL] = KEYMAP(
  71. // left hand
  72. KC_TRNS,KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
  73. KC_TRNS,MEH(KC_G), MEH(KC_H),MEH(KC_I), MEH(KC_J), MEH(KC_K), KC_TRNS,
  74. KC_TRNS,MEH(KC_L), MEH(KC_M),MEH(KC_N), MEH(KC_O), MEH(KC_P),
  75. KC_TRNS,MEH(KC_Q), MEH(KC_R),MEH(KC_S), MEH(KC_T), MEH(KC_U), KC_TRNS,
  76. // bottom row
  77. KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
  78. // thumb cluster
  79. KC_TRNS,KC_TRNS,
  80. KC_TRNS,
  81. KC_TRNS,KC_TRNS,KC_TRNS,
  82. // right hand
  83. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, MEH(KC_Q),
  84. RSFT(KC_PGUP), KC_TRNS, RSFT(KC_HOME), RSFT(KC_UP), RSFT(KC_END), RSFT(KC_PGUP), MEH(KC_R),
  85. RSFT(RCTL(KC_LEFT)), RSFT(KC_LEFT), RSFT(KC_DOWN), RSFT(KC_RIGHT), RSFT(RCTL(KC_RIGHT)), MEH(KC_S),
  86. RSFT(KC_PGDN), KC_TRNS, RCTL(KC_C), RCTL(KC_X), RCTL(KC_V), RSFT(KC_PGDN), MEH(KC_T),
  87. // bottom row
  88. KC_BSPC, RCTL(KC_BSPC), KC_DELETE, LCTL(KC_DELETE), MEH(KC_U),
  89. // thumb cluster
  90. KC_TRNS, KC_TRNS,
  91. KC_TRNS,
  92. KC_TRNS, KC_TRNS, KC_TRNS
  93. ),
  94. // shell navigation layer
  95. [SHELL_NAV] = KEYMAP(
  96. // left hand
  97. KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
  98. KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
  99. KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
  100. KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
  101. // bottom row
  102. KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
  103. // thumb cluster
  104. KC_TRNS,KC_TRNS,
  105. LALT(KC_D),
  106. KC_TRNS,RCTL(KC_W),KC_TRNS,
  107. // right hand
  108. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, M(SWITCH_NDS),
  109. RCTL(KC_L), RCTL(KC_W), KC_HOME, KC_UP, KC_END, LALT(KC_D), RCTL(KC_R),
  110. LALT(KC_B), KC_LEFT, KC_DOWN, KC_RIGHT, LALT(KC_F), LALT(KC_DOT),
  111. RCTL(KC_C), RCTL(KC_U), M(SCREEN_COPY_MODE), M(SCREEN_PASTE), MEH(KC_V), RCTL(KC_K), M(SHELL_RECALL_LAST_ARG_REMOVE_FIRST_COMMAND),
  112. // bottom row
  113. M(SCREEN_TAB_LEFT), M(SCREEN_TAB_RIGHT), M(SCREEN_NEW_TAB), KC_TRNS, KC_TRNS,
  114. // thumb cluster
  115. KC_TRNS, KC_TRNS,
  116. KC_TRNS,
  117. KC_TRNS, KC_TRNS, KC_TRNS
  118. ),
  119. [COMBINED] = KEYMAP(
  120. // left hand
  121. KC_NO, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,KC_TRNS,
  122. KC_TRNS,KC_ESC, KC_LABK, KC_RABK, KC_DQUO, KC_GRAVE,KC_TRNS,
  123. KC_TRNS,KC_LPRN, KC_RPRN, KC_LBRACKET, KC_RBRACKET, KC_UNDS,
  124. KC_TRNS,KC_LCBR, KC_RCBR, KC_BSLS, KC_PIPE, KC_TILD,KC_TRNS,
  125. // bottom row
  126. KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
  127. // thumb cluster
  128. KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
  129. // right hand
  130. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, MEH(KC_L),
  131. KC_TRNS, KC_PLUS, KC_7, KC_8, KC_9, KC_ASTR, MEH(KC_M),
  132. KC_MINS, KC_4, KC_5, KC_6, KC_SLSH, MEH(KC_N),
  133. KC_TRNS, KC_EQUAL, KC_1, KC_2, KC_3, KC_QUES, MEH(KC_O),
  134. // bottom row
  135. KC_0, KC_DOT, KC_TRNS, KC_TRNS, MEH(KC_P),
  136. // thumb cluster
  137. KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS),
  138. [MOUSE] = KEYMAP(
  139. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
  140. KC_TRNS, KC_TRNS, KC_PGUP, KC_MS_WH_UP, KC_UP, KC_TRNS, KC_TRNS,
  141. KC_TRNS, KC_MS_ACCEL0, KC_PGDN, KC_MS_WH_DOWN, KC_DOWN, KC_TRNS,
  142. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
  143. KC_TRNS, KC_TRNS, M(MOUSE_LOCK), KC_TRNS, KC_MS_ACCEL0,
  144. KC_TRNS, KC_TRNS,
  145. KC_TRNS,
  146. KC_TRNS, KC_BTN3, KC_TRNS,
  147. // right hand
  148. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
  149. KC_TRNS, KC_UP, KC_HOME, KC_MS_U, KC_END, KC_MS_WH_UP, KC_TRNS,
  150. KC_DOWN, KC_MS_L, KC_MS_D, KC_MS_R, KC_MS_WH_DOWN, KC_TRNS,
  151. KC_TRNS, MEH(KC_X), MEH(KC_Y), MEH(KC_Z), KC_F5, RCTL(KC_W), KC_TRNS,
  152. // browser tab control
  153. RSFT(RCTL(KC_TAB)), RCTL(KC_TAB), RCTL(KC_T), LALT(KC_LEFT), KC_TRNS,
  154. KC_TRNS, KC_TRNS,
  155. KC_TRNS,
  156. KC_TRNS, KC_BTN1, KC_BTN2
  157. ),
  158. };
  159. const uint16_t PROGMEM fn_actions[] = {
  160. [1] = ACTION_LAYER_TAP_TOGGLE(1)
  161. };
  162. // leaving this in place for compatibilty with old keymaps cloned and re-compiled.
  163. const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt)
  164. {
  165. switch(id) {
  166. case MOUSE_TOGGLE:
  167. if (record->event.pressed) {
  168. layer_on(MOUSE);
  169. } else {
  170. if(!mouse_lock)
  171. layer_off(MOUSE);
  172. }
  173. break;
  174. case MOUSE_LOCK:
  175. if (record->event.pressed)
  176. {
  177. if(mouse_lock)
  178. {
  179. mouse_lock = false;
  180. layer_off(MOUSE);
  181. }
  182. else
  183. mouse_lock = true;
  184. }
  185. break;
  186. case SCREEN_TAB_LEFT:
  187. if (record->event.pressed) {
  188. return MACRO( D(LCTL), T(A), U(LCTL), T(P), END);
  189. }
  190. break;
  191. case SCREEN_TAB_RIGHT:
  192. if (record->event.pressed) {
  193. return MACRO( D(LCTL), T(A), U(LCTL), T(N), END);
  194. }
  195. break;
  196. case SCREEN_NEW_TAB:
  197. if (record->event.pressed) {
  198. return MACRO( D(LCTL), T(A), U(LCTL), T(C), END);
  199. }
  200. break;
  201. case SCREEN_COPY_MODE:
  202. if (record->event.pressed) {
  203. return MACRO( D(LCTL), T(A), U(LCTL), T(ESC), END);
  204. }
  205. break;
  206. case SCREEN_PASTE:
  207. if (record->event.pressed) {
  208. return MACRO( D(LCTL), T(A), U(LCTL), T(RBRC), END);
  209. }
  210. break;
  211. case SWITCH_NDS:
  212. if (record->event.pressed) {
  213. return MACRO( D(LSFT),
  214. T(F11),
  215. U(LSFT),
  216. W(255),
  217. D(LALT),
  218. T(TAB),
  219. U(LALT),
  220. END);
  221. }
  222. break;
  223. case SHELL_RECALL_LAST_ARG_REMOVE_FIRST_COMMAND:
  224. if (record->event.pressed) {
  225. return MACRO( T(UP), T(HOME), D(LALT), T(D), U(LALT), END);
  226. }
  227. break;
  228. }
  229. return MACRO_NONE;
  230. };
  231. bool process_record_user(uint16_t keycode, keyrecord_t *record) {
  232. switch (keycode) {
  233. // dynamically generate these.
  234. case EPRM:
  235. if (record->event.pressed) {
  236. eeconfig_init();
  237. }
  238. return false;
  239. break;
  240. case VRSN:
  241. if (record->event.pressed) {
  242. SEND_STRING (QMK_KEYBOARD "/" QMK_KEYMAP " @ " QMK_VERSION);
  243. }
  244. return false;
  245. break;
  246. case RGB_SLD:
  247. if (record->event.pressed) {
  248. rgblight_mode(1);
  249. }
  250. return false;
  251. break;
  252. }
  253. return true;
  254. }
  255. void led_set_user(uint8_t usb_led) {
  256. if (usb_led & (1<<USB_LED_CAPS_LOCK)) {
  257. ergodox_right_led_1_on();
  258. } else {
  259. ergodox_right_led_1_off();
  260. }
  261. }
  262. void matrix_scan_user(void) {
  263. uint8_t layer = biton32(layer_state);
  264. ergodox_board_led_off();
  265. ergodox_right_led_2_off();
  266. ergodox_right_led_3_off();
  267. switch (layer) {
  268. case COMBINED:
  269. ergodox_right_led_2_on();
  270. break;
  271. case KEYNAV:
  272. case KEYSEL:
  273. ergodox_right_led_3_on();
  274. break;
  275. case MOUSE:
  276. ergodox_right_led_2_on();
  277. ergodox_right_led_3_on();
  278. break;
  279. default:
  280. break;
  281. }
  282. };