keymap.c 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359
  1. #include QMK_KEYBOARD_H
  2. extern keymap_config_t keymap_config;
  3. // where the 'T_' communicates how the key does something different when tapped.
  4. enum planck_keycodes {
  5. //DVORAK = SAFE_RANGE,
  6. KC_T_LALT = SAFE_RANGE,
  7. KC_T_RALT,
  8. KC_T_LGUI,
  9. KC_T_RGUI,
  10. KC_T_LCTL,
  11. KC_T_RCTL,
  12. KC_T_LSFT,
  13. KC_T_RSFT,
  14. KC_T_LRSE,
  15. KC_T_RRSE,
  16. KC_EZRGHT,
  17. KC_EZLEFT,
  18. KC_EZUP,
  19. KC_EZDOWN,
  20. KC_EZUNDO,
  21. KC_EZCOPY,
  22. KC_EZCUT,
  23. KC_EZPSTE,
  24. KC_EZSHFT,
  25. KC_EZCTRL,
  26. KC_EZGUI,
  27. KC_EZALT,
  28. KC_DVORAK,
  29. KC_QWERTY,
  30. KC_USER,
  31. KC_EMAIL,
  32. KC_NAME,
  33. KC_DIR,
  34. KC_COM
  35. };
  36. enum planck_layers {
  37. _DVORAK,
  38. _QWERTY,
  39. _RISE,
  40. _COMMAND
  41. };
  42. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  43. [_DVORAK] =
  44. {{ KC_T_LRSE, KC_QUOT, KC_COMM, KC_DOT, KC_P, KC_Y, KC_F, KC_G, KC_C, KC_R, KC_L, KC_T_RRSE},
  45. { KC_T_LSFT, KC_A, KC_O, KC_E, KC_U, KC_I, KC_D, KC_H, KC_T, KC_N, KC_S, KC_T_RSFT},
  46. { KC_T_LCTL, KC_SCLN, KC_Q, KC_J, KC_K, KC_X, KC_B, KC_M, KC_W, KC_V, KC_Z, KC_T_RCTL},
  47. { KC_T_LGUI, KC_T_LALT, KC_UP, KC_DOWN, KC_BSPC, KC_TAB, KC_ENT, KC_SPC, KC_LEFT, KC_RIGHT, KC_T_RALT, KC_T_RGUI}
  48. },
  49. [_QWERTY] =
  50. {{ KC_T_LRSE, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_T_RRSE},
  51. { KC_T_LSFT, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_T_RSFT},
  52. { KC_T_LCTL, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_QUOT, KC_T_RCTL},
  53. { KC_T_LGUI, KC_T_LALT, KC_UP, KC_DOWN, KC_BSPC, KC_TAB, KC_ENT, KC_SPC, KC_LEFT, KC_RIGHT, KC_T_RALT, KC_DVORAK}
  54. },
  55. [_RISE] =
  56. {{ KC_TRANSPARENT, KC_EZUNDO, KC_EZCOPY, KC_EZCUT, KC_EZPSTE, KC_INS, KC_EQL, KC_7, KC_8, KC_9, KC_TRANSPARENT, KC_TRANSPARENT},
  57. { KC_EZSHFT, KC_ESC, KC_CAPS, KC_PGUP, KC_PGDN, KC_HOME, KC_ASTR, KC_4, KC_5, KC_6, KC_0, KC_EZSHFT},
  58. { KC_EZCTRL, KC_EXLM, KC_AT, KC_HASH, KC_DLR, KC_PERC, KC_CIRC, KC_1, KC_2, KC_3, KC_COM, KC_EZCTRL},
  59. { KC_EZGUI, KC_EZALT, KC_EZUP, KC_EZDOWN, KC_SPC, KC_AMPR, KC_PIPE, KC_END, KC_EZLEFT, KC_EZRGHT, KC_EZALT, KC_EZGUI}
  60. },
  61. [_COMMAND] =
  62. {{ KC_TRANSPARENT, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_TRANSPARENT},
  63. { KC_TRANSPARENT, KC_F11, KC_F12, KC_F13, KC_F14, KC_F15, KC_F16, KC_F17, KC_F18, KC_F19, KC_F20, KC_TRANSPARENT},
  64. { KC_TRANSPARENT, KC_F21, KC_F22, KC_F23, KC_F24, KC_QWERTY, KC_DVORAK, KC_USER, KC_EMAIL, KC_NAME, KC_TRANSPARENT, KC_TRANSPARENT},
  65. { KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_DIR, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT}
  66. },
  67. };
  68. static uint16_t tap_timer = 0;
  69. char last_mod = 10;
  70. void mod_press(uint16_t tap_code, uint16_t hold_code, int id) {
  71. // this first if body makes double modified keys impossible, but stops the
  72. // delay when modifying a tap key which would result in the tap key not
  73. // getting modified.
  74. if (last_mod != id && last_mod != 10) {
  75. tap_code16(tap_code);
  76. last_mod = 10;
  77. } else {
  78. tap_timer = timer_read();
  79. last_mod = id;
  80. register_code(hold_code);
  81. }
  82. }
  83. void mod_lift(uint16_t tap_code, uint16_t hold_code, int id) {
  84. unregister_code(hold_code);
  85. if (last_mod == id && timer_elapsed(tap_timer) < TAPPING_TERM) {
  86. tap_code16(tap_code);
  87. last_mod = 10;
  88. }
  89. }
  90. bool process_record_user(uint16_t keycode, keyrecord_t *record) {
  91. switch (keycode) {
  92. case KC_DVORAK:
  93. if (record->event.pressed) {
  94. set_single_persistent_default_layer(_DVORAK);
  95. }
  96. return true;
  97. break;
  98. case KC_QWERTY:
  99. if (record->event.pressed) {
  100. set_single_persistent_default_layer(_QWERTY);
  101. }
  102. return true;
  103. break;
  104. case KC_T_LALT:
  105. if (record->event.pressed) {
  106. mod_press(S(KC_9), KC_LALT, 0);
  107. } else {
  108. mod_lift(S(KC_9), KC_LALT, 0);
  109. }
  110. return false;
  111. break;
  112. case KC_T_RALT:
  113. if (record->event.pressed) {
  114. mod_press(S(KC_0), KC_RALT, 1);
  115. } else {
  116. mod_lift(S(KC_0), KC_RALT, 1);
  117. }
  118. return false;
  119. break;
  120. case KC_T_LGUI:
  121. if (record->event.pressed) {
  122. mod_press(KC_GRAVE, KC_LGUI, 2);
  123. } else {
  124. mod_lift(KC_GRAVE, KC_LGUI, 2);
  125. }
  126. return false;
  127. break;
  128. case KC_T_RGUI:
  129. if (record->event.pressed) {
  130. mod_press(KC_BSLASH, KC_RGUI, 3);
  131. } else {
  132. mod_lift(KC_BSLASH, KC_RGUI, 3);
  133. }
  134. return false;
  135. break;
  136. case KC_T_LCTL:
  137. if (record->event.pressed) {
  138. mod_press(KC_LBRACKET, KC_LCTL, 4);
  139. } else {
  140. mod_lift(KC_LBRACKET, KC_LCTL, 4);
  141. }
  142. return false;
  143. break;
  144. case KC_T_RCTL:
  145. if (record->event.pressed) {
  146. mod_press(KC_RBRACKET, KC_RCTL, 5);
  147. } else {
  148. mod_lift(KC_RBRACKET, KC_RCTL, 5);
  149. }
  150. return false;
  151. break;
  152. case KC_T_LSFT:
  153. if (record->event.pressed) {
  154. mod_press(KC_EQUAL, KC_LSFT, 6);
  155. } else {
  156. mod_lift(KC_EQUAL, KC_LSFT, 6);
  157. }
  158. return false;
  159. break;
  160. case KC_T_RSFT:
  161. if (record->event.pressed) {
  162. mod_press(KC_MINUS, KC_RSFT, 7);
  163. } else {
  164. mod_lift(KC_MINUS, KC_RSFT, 7);
  165. }
  166. return false;
  167. break;
  168. case KC_T_LRSE:
  169. if (record->event.pressed) {
  170. tap_timer = timer_read();
  171. last_mod = 8;
  172. layer_on(_RISE);
  173. } else {
  174. layer_off(_RISE);
  175. if (last_mod == 8 && timer_elapsed(tap_timer) < TAPPING_TERM) {
  176. tap_code16(KC_DELETE);
  177. last_mod = 10;
  178. }
  179. }
  180. return false;
  181. break;
  182. case KC_T_RRSE:
  183. if (record->event.pressed) {
  184. tap_timer = timer_read();
  185. last_mod = 9;
  186. layer_on(_RISE);
  187. } else {
  188. layer_off(_RISE);
  189. if (last_mod == 9 && timer_elapsed(tap_timer) < TAPPING_TERM) {
  190. tap_code16(KC_SLASH);
  191. last_mod = 10;
  192. }
  193. }
  194. return false;
  195. break;
  196. case KC_EZSHFT:
  197. if (record->event.pressed) {
  198. set_oneshot_mods(MOD_LSFT);
  199. last_mod = 10;
  200. }
  201. return false;
  202. break;
  203. case KC_EZCTRL:
  204. if (record->event.pressed) {
  205. set_oneshot_mods(MOD_LCTL);
  206. last_mod = 10;
  207. }
  208. return false;
  209. break;
  210. case KC_EZALT:
  211. if (record->event.pressed) {
  212. set_oneshot_mods(MOD_LALT);
  213. last_mod = 10;
  214. }
  215. return false;
  216. break;
  217. case KC_EZGUI:
  218. if (record->event.pressed) {
  219. set_oneshot_mods(MOD_LGUI);
  220. last_mod = 10;
  221. }
  222. return false;
  223. break;
  224. case KC_EZRGHT:
  225. if (record->event.pressed) {
  226. register_code(KC_LCTL);
  227. tap_code16(S(KC_RGHT));
  228. unregister_code(KC_LCTL);
  229. last_mod = 10;
  230. }
  231. return false;
  232. break;
  233. case KC_EZLEFT:
  234. if (record->event.pressed) {
  235. register_code(KC_LCTL);
  236. tap_code16(S(KC_LEFT));
  237. unregister_code(KC_LCTL);
  238. last_mod = 10;
  239. }
  240. return false;
  241. break;
  242. case KC_EZDOWN:
  243. if (record->event.pressed) {
  244. register_code(KC_LCTL);
  245. tap_code16(S(KC_DOWN));
  246. unregister_code(KC_LCTL);
  247. last_mod = 10;
  248. }
  249. return false;
  250. break;
  251. case KC_EZUP:
  252. if (record->event.pressed) {
  253. register_code(KC_LCTL);
  254. tap_code16(S(KC_UP));
  255. unregister_code(KC_LCTL);
  256. last_mod = 10;
  257. }
  258. return false;
  259. break;
  260. case KC_EZUNDO:
  261. if (record->event.pressed) {
  262. tap_code16(C(KC_Z));
  263. last_mod = 10;
  264. }
  265. return false;
  266. break;
  267. case KC_EZCOPY:
  268. if (record->event.pressed) {
  269. tap_code16(C(KC_C));
  270. last_mod = 10;
  271. }
  272. return false;
  273. break;
  274. case KC_EZCUT:
  275. if (record->event.pressed) {
  276. tap_code16(C(KC_X));
  277. last_mod = 10;
  278. }
  279. return false;
  280. break;
  281. case KC_EZPSTE:
  282. if (record->event.pressed) {
  283. tap_code16(C(KC_V));
  284. last_mod = 10;
  285. }
  286. return false;
  287. break;
  288. case KC_COM:
  289. if (record->event.pressed) {
  290. layer_on(_COMMAND);
  291. set_oneshot_layer(_COMMAND, ONESHOT_START);
  292. last_mod = 10;
  293. } else {
  294. clear_oneshot_layer_state (ONESHOT_PRESSED);
  295. }
  296. return false;
  297. break;
  298. case KC_USER:
  299. if (record->event.pressed) {
  300. send_string("mhostley");
  301. last_mod = 10;
  302. }
  303. return true;
  304. break;
  305. case KC_EMAIL:
  306. if (record->event.pressed) {
  307. send_string("mhostley@gmail.com");
  308. last_mod = 10;
  309. }
  310. return true;
  311. break;
  312. case KC_NAME:
  313. if (record->event.pressed) {
  314. send_string("Samuel Jahnke");
  315. last_mod = 10;
  316. }
  317. return true;
  318. break;
  319. case KC_DIR:
  320. if (record->event.pressed) {
  321. send_string("home/mhostley/");
  322. last_mod = 10;
  323. }
  324. return true;
  325. break;
  326. }
  327. last_mod = 10;
  328. return true;
  329. }