2
0

keymap.c 9.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342
  1. #include <stdarg.h>
  2. #include "atreus62.h"
  3. #include "led.h"
  4. #include "action_layer.h"
  5. #include "action_util.h"
  6. /*
  7. *WINDOWS SWEDISH
  8. */
  9. #define KN_HALF KC_GRV // 1/2
  10. #define KN_PLUS KC_MINS // +
  11. #define KN_ACUT KC_EQL // ´
  12. #define KN_AO KC_LBRC // Å
  13. #define KN_UMLA KC_RBRC // ¨
  14. #define KN_OE KC_SCLN // Ö
  15. #define KN_AE KC_QUOT // Ä
  16. #define KN_QUOT KC_NUHS // '
  17. #define KN_LABK KC_NUBS // <
  18. #define KN_MINS KC_SLSH // -
  19. #define KN_EXLM LSFT(KC_1) // !
  20. #define KN_DQT LSFT(KC_2) // "
  21. #define KN_AT RALT(KC_2) // @
  22. #define KN_HASH LSFT(KC_3) // #
  23. #define KN_DLR LALT(KC_4) // $
  24. #define KN_EUR LSFT(KC_4) // $
  25. #define KN_PERC LSFT(KC_5) // %
  26. #define KN_AMPR LSFT(KC_6) // &
  27. #define KN_SLSH LSFT(KC_7) // /
  28. #define KN_LPRN LSFT(KC_8) // (
  29. #define KN_RPRN LSFT(KC_9) // )
  30. #define KN_EQL LSFT(KC_0) // =
  31. #define KN_UNDS LSFT(KN_MINS) // _
  32. #define KN_QUES LSFT(KN_PLUS) // ?
  33. #define KN_GRAV LSFT(KN_ACUT) // `
  34. #define KN_LCBR LALT(KC_7) // {
  35. #define KN_RCBR LALT(KC_0) // }
  36. #define KN_LBRC LALT(KC_8) // [
  37. #define KN_RBRC LALT(KC_9) // ]
  38. #define KN_RABK LSFT(KN_LABK) // <
  39. #define KN_COLN LSFT(KC_DOT) // :
  40. #define KN_SCLN LSFT(KC_COMM) // :
  41. #define KN_PIPE LALT(KN_LABK) // |
  42. #define KN_QUES LSFT(KN_PLUS) // ?
  43. #define KN_CIRC LSFT(KN_UMLA) // ^
  44. #define KN_ASTR LSFT(KN_QUOT) // *
  45. #define KN_TILD LALT(KN_UMLA) // ~
  46. #define KN_BSLS LALT(KN_PLUS) //
  47. #define OSM_LCTL OSM(MOD_LCTL)
  48. #define OSM_LALT OSM(MOD_LALT)
  49. #define OSM_LSFT OSM(MOD_LSFT)
  50. #define KC_HYP LSFT(LALT(LCTL(KC_LGUI)))
  51. #define KC_COPY LCTL(KC_C)
  52. #define KC_PASTE LCTL(KC_V)
  53. #define KC_UNDO LCTL(KC_Z)
  54. #define KC_REDO LCTL(LSFT(KC_Z))
  55. // Layers
  56. enum {
  57. BASE = 0,
  58. NAV,
  59. SYM
  60. };
  61. //Macros
  62. enum {
  63. KF_1 = 0, // 1, F1
  64. KF_2, // ...
  65. KF_3,
  66. KF_4,
  67. KF_5,
  68. KF_6,
  69. KF_7,
  70. KF_8,
  71. KF_9,
  72. KF_10,
  73. KF_11,
  74. KF_12
  75. };
  76. // Tapdance
  77. enum {
  78. TD_FUN = 0,
  79. TD_EQ
  80. };
  81. //State and timers
  82. uint16_t kf_timers[12];
  83. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  84. [BASE] = {
  85. { M(KF_11) ,M(KF_1) ,M(KF_2) ,M(KF_3) ,M(KF_4) ,M(KF_5) ,KC_NO ,M(KF_6) ,M(KF_7) ,M(KF_8) ,M(KF_9) ,M(KF_10) ,M(KF_12) },
  86. { KC_TAB ,KC_Q ,KC_W ,KC_E ,KC_R ,KC_T ,KC_NO ,KC_Y ,KC_U ,KC_I ,KC_O ,KC_P ,KN_AO },
  87. { OSM_LCTL ,KC_A ,KC_S ,KC_D ,KC_F ,KC_G ,KC_NO ,KC_H ,KC_J ,KC_K ,KC_L ,KN_OE ,KN_AE },
  88. { OSM_LSFT ,KC_Z ,KC_X ,KC_C ,KC_V ,KC_B ,KC_DELT ,KC_N ,KC_M ,KC_COMM ,KC_DOT ,KN_MINS ,OSM_LSFT },
  89. { MO(NAV) ,OSM_LCTL ,OSM_LALT ,KC_LGUI ,KC_SPC ,LT(SYM,KC_BSPC) ,KC_HYP ,LT(SYM,KC_ENT) ,KC_SPC ,KC_LEAD ,KC_LALT ,KC_LCTRL ,MO(NAV) }
  90. },
  91. [NAV] = {
  92. { KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS },
  93. { KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_NO ,KC_HOME ,KC_PGDN ,KC_PGUP ,KC_END ,KC_TRNS ,KC_TRNS },
  94. { KC_TRNS ,KC_LSFT ,KC_LCTL ,KC_LALT ,KC_L ,KC_TRNS ,KC_NO ,KC_LEFT ,KC_DOWN ,KC_UP ,KC_RIGHT ,KC_TRNS ,KC_TRNS },
  95. { KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS },
  96. { KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_VOLD ,KC_VOLU }
  97. },
  98. [SYM] = {
  99. { KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,TD(TD_EQ) ,KC_NO ,TD(TD_FUN) ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS },
  100. { KC_TRNS ,KN_LABK ,KN_RABK ,KN_LCBR ,KN_RCBR ,KN_PLUS ,KC_NO ,KN_AT ,KN_DQT ,KN_QUOT ,KN_GRAV ,KN_SLSH ,KC_TRNS },
  101. { KC_TRNS ,KN_EXLM ,KN_EQL ,KN_LPRN ,KN_RPRN ,KN_MINS ,KC_NO ,KN_UNDS ,KN_CIRC ,KN_DLR ,KN_AMPR ,KN_PIPE ,KC_TRNS },
  102. { KC_TRNS ,KN_EUR ,KN_PERC ,KN_LBRC ,KN_RBRC ,KN_ASTR ,KC_TRNS ,KN_HASH ,KN_SCLN ,KN_COLN ,KN_QUES ,KN_BSLS ,KC_TRNS },
  103. { KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS }
  104. }
  105. };
  106. #define TAP_ONCE(code) \
  107. register_code (code); \
  108. unregister_code (code)
  109. static void m_tapn (uint8_t code, ...) {
  110. uint8_t kc = code;
  111. va_list ap;
  112. va_start(ap, code);
  113. do {
  114. register_code(kc);
  115. unregister_code(kc);
  116. wait_ms(50);
  117. kc = va_arg(ap, int);
  118. } while (kc != 0);
  119. va_end(ap);
  120. }
  121. static void m_handle_kf (keyrecord_t *record, uint8_t id) {
  122. uint8_t code = id - KF_1;
  123. if (record->event.pressed) {
  124. kf_timers[code] = timer_read ();
  125. } else {
  126. uint8_t kc_base;
  127. uint8_t long_press = (kf_timers[code] && timer_elapsed (kf_timers[code]) > TAPPING_TERM);
  128. kf_timers[code] = 0;
  129. switch(id){
  130. case KF_1 ... KF_10:
  131. if (long_press) {
  132. // Long press
  133. kc_base = KC_F1;
  134. } else {
  135. kc_base = KC_1;
  136. }
  137. code += kc_base;
  138. break;
  139. case KF_11:
  140. code = long_press ? KC_F11 : KC_ESC;
  141. break;
  142. case KF_12:
  143. code = long_press ? KC_F12 : KN_PLUS;
  144. break;
  145. }
  146. register_code (code);
  147. unregister_code (code);
  148. }
  149. }
  150. const uint16_t PROGMEM fn_actions[] = {
  151. };
  152. const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt)
  153. {
  154. switch (id) {
  155. case KF_1 ... KF_12:
  156. m_handle_kf(record, id);
  157. break;
  158. }
  159. return MACRO_NONE;
  160. };
  161. // Custom keycodes
  162. bool process_record_user(uint16_t keycode, keyrecord_t *record) {
  163. bool queue = true;
  164. //Cancle one-shot mods.
  165. switch (keycode) {
  166. case KC_ESC:
  167. if (record->event.pressed && get_oneshot_mods() && !has_oneshot_mods_timed_out()) {
  168. clear_oneshot_mods();
  169. queue = false;
  170. }
  171. break;
  172. }
  173. return queue;
  174. }
  175. // TAP DANCE SETTINGS
  176. void dance_eq (qk_tap_dance_state_t *state, void *user_data) {
  177. switch (state->count) {
  178. case 1: // ===
  179. register_code(KC_LSHIFT);
  180. m_tapn(KC_0, KC_0, KC_0, 0);
  181. unregister_code(KC_LSHIFT);
  182. break;
  183. case 2:
  184. register_code(KC_LSHIFT);
  185. m_tapn(KC_1, KC_0, KC_0, 0);
  186. unregister_code(KC_LSHIFT);
  187. break;
  188. default:
  189. reset_tap_dance(state);
  190. }
  191. }
  192. void dance_fun (qk_tap_dance_state_t *state, void *user_data) {
  193. switch (state->count) {
  194. case 1: // =>
  195. register_code(KC_LSHIFT);
  196. m_tapn(KC_0, KN_LABK, 0);
  197. unregister_code(KC_LSHIFT);
  198. break;
  199. case 2: // () => {}
  200. register_code(KC_LSHIFT);
  201. m_tapn(KC_8, KC_9, KC_SPC, KC_0, KN_LABK, KC_SPC, 0);
  202. unregister_code(KC_LSHIFT);
  203. register_code(KC_RALT);
  204. m_tapn(KC_7, 0);
  205. unregister_code(KC_RALT);
  206. TAP_ONCE(KC_ENT);
  207. break;
  208. default:
  209. reset_tap_dance(state);
  210. }
  211. }
  212. qk_tap_dance_action_t tap_dance_actions[] = {
  213. [TD_FUN] = ACTION_TAP_DANCE_FN (dance_fun)
  214. ,[TD_EQ] = ACTION_TAP_DANCE_FN (dance_eq)
  215. };
  216. // Runs just one time when the keyboard initializes.
  217. void matrix_init_user(void) {
  218. set_unicode_input_mode(UC_WINC);
  219. };
  220. LEADER_EXTERNS();
  221. // Runs constantly in the background, in a loop.
  222. void matrix_scan_user(void) {
  223. LEADER_DICTIONARY() {
  224. leading = false;
  225. leader_end();
  226. SEQ_ONE_KEY(KC_L){
  227. register_code(KC_RGUI);
  228. TAP_ONCE(KC_L);
  229. unregister_code(KC_RGUI);
  230. };
  231. SEQ_TWO_KEYS (KC_A, KC_W) {
  232. //Web - chrome
  233. register_code (KC_LGUI); TAP_ONCE (KC_1); unregister_code (KC_LGUI);
  234. }
  235. SEQ_TWO_KEYS (KC_A, KC_P) {
  236. //sPotify
  237. register_code (KC_LGUI); TAP_ONCE (KC_2); unregister_code (KC_LGUI);
  238. }
  239. SEQ_TWO_KEYS (KC_A, KC_T) {
  240. //Total Commander
  241. register_code (KC_LGUI); TAP_ONCE (KC_3); unregister_code (KC_LGUI);
  242. }
  243. SEQ_TWO_KEYS (KC_A, KC_A) {
  244. //Atom
  245. register_code (KC_LGUI); TAP_ONCE (KC_4); unregister_code (KC_LGUI);
  246. }
  247. SEQ_TWO_KEYS (KC_A, KC_E) {
  248. //Emacs
  249. register_code (KC_LGUI); TAP_ONCE (KC_5); unregister_code (KC_LGUI);
  250. }
  251. SEQ_TWO_KEYS (KC_A, KC_C) {
  252. //Cmdr
  253. register_code (KC_LGUI); TAP_ONCE (KC_6); unregister_code (KC_LGUI);
  254. }
  255. SEQ_TWO_KEYS (KC_A, KC_S) {
  256. //Slack
  257. register_code (KC_LGUI); TAP_ONCE (KC_7); unregister_code (KC_LGUI);
  258. }
  259. SEQ_TWO_KEYS (KC_U, KC_L) {
  260. set_unicode_input_mode(UC_LNX);
  261. }
  262. SEQ_TWO_KEYS (KC_U, KC_W) {
  263. set_unicode_input_mode(UC_WINC);
  264. }
  265. SEQ_TWO_KEYS (KC_S, KC_S) {
  266. // ¯\_(ツ)_/¯
  267. unicode_input_start(); register_hex(0xaf); unicode_input_finish();
  268. register_code (KC_LALT);
  269. register_code (KC_LCTL);
  270. TAP_ONCE (KN_PLUS);
  271. unregister_code (KC_LCTL);
  272. unregister_code (KC_LALT);
  273. register_code (KC_RSFT); TAP_ONCE (KC_8); unregister_code (KC_RSFT);
  274. unicode_input_start (); register_hex(0x30c4); unicode_input_finish();
  275. register_code (KC_RSFT); TAP_ONCE (KC_9); TAP_ONCE(KC_7); unregister_code (KC_RSFT);
  276. unicode_input_start (); register_hex(0xaf); unicode_input_finish();
  277. }
  278. SEQ_TWO_KEYS (KC_S, KC_F) {
  279. // 凸(ツ)凸
  280. unicode_input_start(); register_hex(0x51F8); unicode_input_finish();
  281. register_code (KC_RSFT); TAP_ONCE (KC_8); unregister_code (KC_RSFT);
  282. unicode_input_start (); register_hex(0x30c4); unicode_input_finish();
  283. register_code (KC_RSFT); TAP_ONCE (KC_9); unregister_code (KC_RSFT);
  284. unicode_input_start (); register_hex(0x51F8); unicode_input_finish();
  285. }
  286. SEQ_TWO_KEYS (KC_S, KC_L) {
  287. // λ
  288. unicode_input_start();
  289. register_hex(0x03bb);
  290. unicode_input_finish();
  291. }
  292. };
  293. };