keymap.c 45 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194
  1. /*
  2. * algernon's ErgoDox EZ layout, please see the readme.md file!
  3. */
  4. #include <stdarg.h>
  5. #include QMK_KEYBOARD_H
  6. #include "led.h"
  7. #include "debug.h"
  8. #include "action_layer.h"
  9. #include "action_util.h"
  10. #include "timer.h"
  11. #include "keymap_plover.h"
  12. #include "eeconfig.h"
  13. #include "wait.h"
  14. #include "version.h"
  15. /* Layers */
  16. enum {
  17. BASE = 0,
  18. ADORE,
  19. ARRW,
  20. APPSEL,
  21. HUN,
  22. NMDIA,
  23. PLVR,
  24. };
  25. /* Macros */
  26. enum {
  27. NONE = 0,
  28. // Buttons that do extra stuff
  29. A_GUI,
  30. A_PLVR,
  31. A_MPN,
  32. // Application select keys
  33. APP_SLK, // Slack
  34. APP_EMCS, // Emacs
  35. APP_TERM, // Terminal
  36. APP_CHRM, // Chrome
  37. APP_MSIC, // Music
  38. APP_SOCL, // Social
  39. APP_PMGR, // Password manager
  40. APP_SCL2, // Social #2
  41. // Hungarian layer keys
  42. HU_AA, // Á
  43. HU_OO, // Ó
  44. HU_EE, // É
  45. HU_UU, // Ú
  46. HU_II, // Í
  47. HU_OE, // Ö
  48. HU_UE, // Ü
  49. HU_OEE, // Ő
  50. HU_UEE, // Ű
  51. // number/symbol keys
  52. A_1, // 1
  53. A_2, // 2
  54. A_3, // ...
  55. A_4,
  56. A_5,
  57. A_6,
  58. A_7,
  59. A_8,
  60. A_9,
  61. A_0,
  62. // Fx
  63. Fx,
  64. };
  65. /* Fn keys */
  66. enum {
  67. F_BSE = 0,
  68. F_HUN,
  69. F_GUI,
  70. F_SFT,
  71. F_ALT,
  72. F_CTRL
  73. };
  74. /* Custom keycodes */
  75. enum {
  76. CT_CLN = 0,
  77. CT_TA,
  78. CT_LBP,
  79. CT_RBP,
  80. CT_TMUX,
  81. CT_TPS,
  82. CT_SR,
  83. };
  84. /* States & timers */
  85. uint16_t gui_timer = 0;
  86. #if KEYLOGGER_ENABLE
  87. # ifdef AUTOLOG_ENABLE
  88. bool log_enable = true;
  89. # else
  90. bool log_enable = false;
  91. # endif
  92. #endif
  93. bool time_travel = false;
  94. bool skip_leds = false;
  95. static uint8_t is_adore = 0;
  96. /* The Keymap */
  97. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  98. /* Keymap 0: Base Layer
  99. *
  100. * ,-----------------------------------------------------. ,-----------------------------------------------------.
  101. * | Next/Prev | 9 | 7 @ | 5 * | 3 ^ | 1 $ | F11 | | Fx | 0 % | 2 ! | 4 # | 6 & | 8 | Plover |
  102. * |-----------+------+------+------+------+-------------| |------+------+------+------+------+------+-----------|
  103. * | ~ | ' | , | . | P | Y | ( | | ) | F | G | C | R | L | \ |
  104. * |-----------+------+------+------+------+------| [ | | ] |------+------+------+------+------+-----------|
  105. * | Tab/ARROW | A | O | E | U | I |------| |------| D | H | T | N | S | = / Arrow |
  106. * |-----------+------+------+------+------+------| tmux | | tmux |------+------+------+------+------+-----------|
  107. * | Play/Pause| / | Q | J | K | X | | | Pane | B | M | W | V | Z | Stop/Reset|
  108. * `-----------+------+------+------+------+-------------' `-------------+------+------+------+------+-----------'
  109. * | | | | | : | | - | | | | |
  110. * `-----------------------------------' `-----------------------------------'
  111. * ,-------------. ,-------------.
  112. * | LAlt | GUI | | MDIA | Del |
  113. * ,------|------|------| |------+------+------.
  114. * | | | Ctrl | | LEAD | | |
  115. * |Backsp|LShift|------| |------| Enter| Space|
  116. * | | | ESC | | HUN | | |
  117. * `--------------------' `--------------------'
  118. */
  119. [BASE] = LAYOUT_ergodox(
  120. // left hand
  121. M(A_MPN) ,M(A_9) ,M(A_7) ,M(A_5) ,M(A_3) ,M(A_1) ,KC_F11
  122. ,KC_GRV ,KC_QUOT ,KC_COMM ,KC_DOT ,KC_P ,KC_Y ,TD(CT_LBP)
  123. ,TD(CT_TA) ,KC_A ,KC_O ,KC_E ,KC_U ,KC_I
  124. ,KC_MPLY ,KC_SLSH ,KC_Q ,KC_J ,KC_K ,KC_X ,TD(CT_TMUX)
  125. ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,TD(CT_CLN)
  126. ,F(F_ALT),F(F_GUI)
  127. ,F(F_CTRL)
  128. ,KC_BSPC,F(F_SFT),KC_ESC
  129. // right hand
  130. ,M(Fx) ,M(A_0) ,M(A_2) ,M(A_4) ,M(A_6) ,M(A_8) ,M(A_PLVR)
  131. ,TD(CT_RBP),KC_F ,KC_G ,KC_C ,KC_R ,KC_L ,KC_BSLS
  132. ,KC_D ,KC_H ,KC_T ,KC_N ,KC_S ,KC_EQL
  133. ,TD(CT_TPS),KC_B ,KC_M ,KC_W ,KC_V ,KC_Z ,TD(CT_SR)
  134. ,KC_MINS ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  135. ,OSL(NMDIA),KC_DEL
  136. ,KC_LEAD
  137. ,F(F_HUN) ,KC_ENT ,KC_SPC
  138. ),
  139. /* Keymap 1: Adore layer
  140. *
  141. * ,-----------------------------------------------------. ,-----------------------------------------------------.
  142. * | Play/Pause| 9 | 7 @ | 5 * | 3 ^ | 1 $ | F11 | | Fx | 0 % | 2 ! | 4 # | 6 & | 8 | Plover |
  143. * |-----------+------+------+------+------+-------------| |------+------+------+------+------+------+-----------|
  144. * | \ | X | W | C | H | F | ( | | ) | M | G | L | P | / | `~ |
  145. * |-----------+------+------+------+------+------| [ | | ] |------+------+------+------+------+-----------|
  146. * | Tab/Arrow | A | O | E | I | U |------| |------| D | R | T | N | S | = |
  147. * |-----------+------+------+------+------+------| tmux | | tmux |------+------+------+------+------+-----------|
  148. * | | Z | Q | ' | , | . | | | pane | B | K | V | Y | J | |
  149. * `-----------+------+------+------+------+-------------' `-------------+------+------+------+------+-----------'
  150. * | | | | | : | | - | | | | |
  151. * `-----------------------------------' `-----------------------------------'
  152. * ,-------------. ,-------------.
  153. * | LAlt | GUI | | MDIA | Del |
  154. * ,------|------|------| |------+------+------.
  155. * | | | Ctrl | | HUN | | |
  156. * |Backsp|LShift|------| |------| Enter| Space|
  157. * | | | ESC | | LEAD | | |
  158. * `--------------------' `--------------------'
  159. */
  160. [ADORE] = LAYOUT_ergodox(
  161. // left hand
  162. KC_MPLY ,M(A_9) ,M(A_7) ,M(A_5) ,M(A_3) ,M(A_1) ,KC_F11
  163. ,KC_BSLS ,KC_X ,KC_W ,KC_C ,KC_H ,KC_F ,TD(CT_LBP)
  164. ,TD(CT_TA) ,KC_A ,KC_O ,KC_E ,KC_I ,KC_U
  165. ,KC_NO ,KC_Z ,KC_Q ,KC_QUOT ,KC_COMM ,KC_DOT ,TD(CT_TMUX)
  166. ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,TD(CT_CLN)
  167. ,F(F_ALT),F(F_GUI)
  168. ,F(F_CTRL)
  169. ,KC_BSPC,F(F_SFT),KC_ESC
  170. // right hand
  171. ,M(Fx) ,M(A_0) ,M(A_2) ,M(A_4) ,M(A_6) ,M(A_8) ,M(A_PLVR)
  172. ,TD(CT_RBP),KC_M ,KC_G ,KC_L ,KC_P ,KC_SLSH ,KC_GRV
  173. ,KC_D ,KC_R ,KC_T ,KC_N ,KC_S ,KC_EQL
  174. ,TD(CT_TPS),KC_B ,KC_K ,KC_V ,KC_Y ,KC_J ,KC_NO
  175. ,KC_MINS ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  176. ,OSL(NMDIA),KC_DEL
  177. ,F(F_HUN)
  178. ,KC_LEAD ,KC_ENT ,KC_SPC
  179. ),
  180. /* Keymap 2: Arrow layer
  181. *
  182. * ,-----------------------------------------------------. ,-----------------------------------------------------.
  183. * | | | | | | | | | | | | | | | |
  184. * |-----------+------+------+------+------+-------------| |------+------+------+------+------+------+-----------|
  185. * | | | | | | | | | | | Home | Up | End | | |
  186. * |-----------+------+------+------+------+------| | | |------+------+------+------+------+-----------|
  187. * | | | | | | |------| |------| | Left | Down | Rght | | |
  188. * |-----------+------+------+------+------+------| | | |------+------+------+------+------+-----------|
  189. * | | | | | | | | | | | | | | | |
  190. * `-----------+------+------+------+------+-------------' `-------------+------+------+------+------+-----------'
  191. * | | | | | | | | | | | |
  192. * `----------------------------------' `----------------------------------'
  193. * ,-------------. ,-------------.
  194. * | | | | | |
  195. * ,------|------|------| |------+------+------.
  196. * | | | | | | | |
  197. * | Enter| |------| |------| PgUp | PgDn |
  198. * | | | | | | | |
  199. * `--------------------' `--------------------'
  200. */
  201. [ARRW] = LAYOUT_ergodox(
  202. // left hand
  203. KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  204. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  205. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  206. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  207. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  208. ,KC_TRNS ,KC_TRNS
  209. ,KC_TRNS
  210. ,KC_ENT ,KC_TRNS ,KC_TRNS
  211. // right hand
  212. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  213. ,KC_TRNS ,KC_TRNS ,KC_HOME ,KC_UP ,KC_END ,KC_TRNS ,KC_TRNS
  214. ,KC_TRNS ,KC_LEFT ,KC_DOWN ,KC_RGHT ,KC_TRNS ,KC_TRNS
  215. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  216. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  217. ,KC_TRNS ,KC_TRNS
  218. ,KC_TRNS
  219. ,KC_TRNS ,KC_PGUP ,KC_PGDN
  220. ),
  221. /* Keymap 3: Application select layer
  222. *
  223. * ,-----------------------------------------------------. ,-----------------------------------------------------.
  224. * | |Music |Slack |Emacs |Term |Chrome| | | |Social|PWMgr |Scl2 | | | |
  225. * |-----------+------+------+------+------+-------------| |------+------+------+------+------+------+-----------|
  226. * | | | | | | | | | | | | | | | |
  227. * |-----------+------+------+------+------+------| | | |------+------+------+------+------+-----------|
  228. * | | | | | | |------| |------| | | | | | |
  229. * |-----------+------+------+------+------+------| | | |------+------+------+------+------+-----------|
  230. * | | | | | | | | | | | | | | | |
  231. * `-----------+------+------+------+------+-------------' `-------------+------+------+------+------+-----------'
  232. * | | | | | | | | | | | |
  233. * `----------------------------------' `----------------------------------'
  234. * ,-------------. ,-------------.
  235. * | | | | | |
  236. * ,------|------|------| |------+------+------.
  237. * | | | | | | | |
  238. * | | |------| |------| | |
  239. * | | | | | | | |
  240. * `--------------------' `--------------------'
  241. */
  242. [APPSEL] = LAYOUT_ergodox(
  243. // left hand
  244. KC_TRNS ,M(APP_MSIC),M(APP_SLK),M(APP_EMCS),M(APP_TERM),M(APP_CHRM),KC_TRNS
  245. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  246. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  247. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  248. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  249. ,KC_TRNS ,KC_TRNS
  250. ,KC_TRNS
  251. ,KC_TRNS ,KC_TRNS ,KC_TRNS
  252. // right hand
  253. ,KC_TRNS ,M(APP_SOCL) ,M(APP_PMGR) ,M(APP_SCL2) ,KC_NO ,KC_NO ,KC_TRNS
  254. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  255. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  256. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  257. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  258. ,KC_TRNS ,KC_TRNS
  259. ,KC_TRNS
  260. ,KC_TRNS ,KC_TRNS ,KC_TRNS
  261. ),
  262. /* Keymap 4: Hungarian Layer
  263. *
  264. * ,-----------------------------------------------------. ,-----------------------------------------------------.
  265. * | | | | | | | | | | | | | | | |
  266. * |-----------+------+------+------+------+-------------| |------+------+------+------+------+------+-----------|
  267. * | | | Ő | | Ű | | | | | | | | | | |
  268. * |-----------+------+------+------+------+------| | | |------+------+------+------+------+-----------|
  269. * | | Á | Ó | É | Ú | Í |------| |------| | | | | | |
  270. * |-----------+------+------+------+------+------| | | |------+------+------+------+------+-----------|
  271. * | | | Ö | | Ü | | | | | | | | | | |
  272. * `-----------+------+------+------+------+-------------' `-------------+------+------+------+------+-----------'
  273. * | | | | | | | | | | | |
  274. * `----------------------------------' `----------------------------------'
  275. * ,-------------. ,-------------.
  276. * | | | | | |
  277. * ,------|------|------| |------+------+------.
  278. * | | | | | | | |
  279. * | | |------| |------| | |
  280. * | | | | | BASE | | |
  281. * `--------------------' `--------------------'
  282. */
  283. [HUN] = LAYOUT_ergodox(
  284. // left hand
  285. KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  286. ,KC_NO ,KC_NO ,M(HU_OEE),KC_NO ,M(HU_UEE),KC_NO ,KC_NO
  287. ,KC_NO ,M(HU_AA),M(HU_OO) ,M(HU_EE),M(HU_UU) ,M(HU_II)
  288. ,KC_NO ,KC_NO ,M(HU_OE) ,KC_NO ,M(HU_UE) ,KC_NO ,KC_NO
  289. ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  290. ,KC_NO ,KC_NO
  291. ,KC_NO
  292. ,KC_NO ,KC_TRNS ,KC_TRNS
  293. // right hand
  294. ,KC_TRNS ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  295. ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  296. ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  297. ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  298. ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  299. ,KC_NO ,KC_NO
  300. ,KC_NO
  301. ,F(F_BSE),KC_TRNS ,KC_TRNS
  302. ),
  303. /* Keymap 5: Navigation & Media layer
  304. *
  305. * ,-----------------------------------------------------. ,-----------------------------------------------------.
  306. * | | F9 | F7 | F5 | F3 | F1 |ScrLCK| | | F10 | F2 | F4 | F6 | F8 | |
  307. * |-----------+------+------+------+------+-------------| |------+------+------+------+------+------+-----------|
  308. * | | | | | | | | | | | | | | | |
  309. * |-----------+------+------+------+------+------| | | |------+------+------+------+------+-----------|
  310. * | | | | | | |------| |------| | | | | | |
  311. * |-----------+------+------+------+------+------| | | |------+------+------+------+------+-----------|
  312. * | | | | | | | | | | | | | | | |
  313. * `-----------+------+------+------+------+-------------' `-------------+------+------+------+------+-----------'
  314. * | | | | | | | | | | | |
  315. * `----------------------------------' `----------------------------------'
  316. * ,-------------. ,-------------.
  317. * | Mute | VlUp | | BASE | |
  318. * ,------|------|------| |------+------+------.
  319. * | | | VlDn | | | | |
  320. * | | |------| |------| | |
  321. * | | | | | | | |
  322. * `--------------------' `--------------------'
  323. */
  324. [NMDIA] = LAYOUT_ergodox(
  325. // left hand
  326. KC_NO ,KC_F9 ,KC_F7 ,KC_F5 ,KC_F3 ,KC_F1 ,LGUI(KC_L)
  327. ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  328. ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  329. ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  330. ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  331. ,KC_MUTE ,KC_VOLU
  332. ,KC_VOLD
  333. ,KC_NO ,KC_NO ,KC_TRNS
  334. // right hand
  335. ,KC_TRNS ,KC_F10 ,KC_F2 ,KC_F4 ,KC_F6 ,KC_F8 ,KC_NO
  336. ,KC_NO ,KC_NO ,KC_NO ,KC_UP ,KC_NO ,KC_NO ,KC_NO
  337. ,KC_NO ,KC_LEFT ,KC_DOWN ,KC_RGHT ,KC_NO ,KC_NO
  338. ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  339. ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  340. ,KC_TRNS ,KC_NO
  341. ,KC_NO
  342. ,KC_NO ,KC_NO ,KC_NO
  343. ),
  344. /* Keymap 6: Steno for Plover
  345. *
  346. * ,--------------------------------------------------. ,--------------------------------------------------.
  347. * | | | | | | | | | | | | | | | BASE |
  348. * |--------+------+------+------+------+-------------| |------+------+------+------+------+------+--------|
  349. * | | # | # | # | # | # | # | | # | # | # | # | # | # | # |
  350. * |--------+------+------+------+------+------| | | |------+------+------+------+------+--------|
  351. * | | | T | P | H | |------| |------| | F | P | L | T | D |
  352. * |--------+ S +------+------+------+ * | * | | * | * +------+------+------+------+--------|
  353. * | | | K | W | R | | | | | | R | B | G | S | Z |
  354. * `--------+------+------+------+------+-------------' `-------------+------+------+------+------+--------'
  355. * | | | | | | | | | | | |
  356. * `----------------------------------' `----------------------------------'
  357. * ,-------------. ,-------------.
  358. * | | | | | |
  359. * ,------|------|------| |------+------+------.
  360. * | | | | | | | |
  361. * | A | O |------| |------| E | U |
  362. * | | | | | | | |
  363. * `--------------------' `--------------------'
  364. */
  365. [PLVR] = LAYOUT_ergodox(
  366. // left hand
  367. KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO,
  368. KC_NO, PV_NUM, PV_NUM, PV_NUM, PV_NUM, PV_NUM, PV_NUM,
  369. KC_NO, PV_LS, PV_LT, PV_LP, PV_LH, PV_STAR,
  370. KC_NO, PV_LS, PV_LK, PV_LW, PV_LR, PV_STAR, PV_STAR,
  371. KC_NO, KC_NO, KC_NO, KC_NO, KC_NO,
  372. KC_NO, KC_NO,
  373. KC_NO,
  374. PV_A, PV_O, KC_NO,
  375. // right hand
  376. KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, M(A_PLVR),
  377. PV_NUM, PV_NUM, PV_NUM, PV_NUM, PV_NUM, PV_NUM, PV_NUM,
  378. PV_STAR, PV_RF, PV_RP, PV_RL, PV_RT, PV_RD,
  379. PV_STAR, PV_STAR, PV_RR, PV_RB, PV_RG, PV_RS, PV_RZ,
  380. KC_NO, KC_NO, KC_NO, KC_NO, KC_NO,
  381. KC_NO, KC_NO,
  382. KC_NO,
  383. KC_NO,PV_E, PV_U
  384. ),
  385. };
  386. const uint16_t PROGMEM fn_actions[] = {
  387. [F_BSE] = ACTION_LAYER_CLEAR(ON_PRESS)
  388. ,[F_HUN] = ACTION_LAYER_INVERT(HUN, ON_PRESS)
  389. ,[F_GUI] = ACTION_MACRO_TAP(A_GUI)
  390. ,[F_SFT] = ACTION_MODS_ONESHOT (MOD_LSFT)
  391. ,[F_ALT] = ACTION_MODS_ONESHOT (MOD_LALT)
  392. ,[F_CTRL] = ACTION_MODS_ONESHOT (MOD_LCTL)
  393. };
  394. static void toggle_steno(int pressed)
  395. {
  396. uint8_t layer = biton32(layer_state);
  397. if (pressed) {
  398. if (layer != PLVR) layer_on(PLVR); else layer_off(PLVR);
  399. register_code(PV_LP);
  400. register_code(PV_LH);
  401. register_code(PV_LR);
  402. register_code(PV_O);
  403. register_code(PV_RL);
  404. register_code(PV_RG);
  405. } else {
  406. unregister_code(PV_LP);
  407. unregister_code(PV_LH);
  408. unregister_code(PV_LR);
  409. unregister_code(PV_O);
  410. unregister_code(PV_RL);
  411. unregister_code(PV_RG);
  412. }
  413. }
  414. static macro_t *ang_do_hun (keyrecord_t *record, uint16_t accent, uint16_t hun_char)
  415. {
  416. uint8_t need_shift = 0;
  417. uint8_t hold_shift = 0;
  418. if (!record->event.pressed)
  419. return MACRO_NONE;
  420. layer_off (HUN);
  421. if (keyboard_report->mods & MOD_BIT (KC_LSFT)) {
  422. hold_shift = 1;
  423. need_shift = 1;
  424. unregister_code (KC_LSFT);
  425. }
  426. if ((get_oneshot_mods () & MOD_BIT(KC_LSFT)) && !has_oneshot_mods_timed_out ()) {
  427. need_shift = 1;
  428. hold_shift = 0;
  429. unregister_code (KC_LSFT);
  430. }
  431. clear_oneshot_mods ();
  432. register_code (KC_RALT);
  433. unregister_code (KC_RALT);
  434. if (accent == (KC_DQT)) {
  435. register_code (KC_RSFT);
  436. }
  437. register_code (accent);
  438. unregister_code (accent);
  439. if (need_shift && accent != (KC_DQT)) {
  440. register_code (KC_RSFT);
  441. } else if (accent == (KC_DQT) && !need_shift) {
  442. unregister_code (KC_RSFT);
  443. }
  444. register_code (hun_char);
  445. unregister_code (hun_char);
  446. if (need_shift || accent == (KC_DQT))
  447. unregister_code (KC_RSFT);
  448. if (hold_shift)
  449. register_code (KC_LSFT);
  450. return MACRO_NONE;
  451. }
  452. static void ang_handle_num_row(uint8_t id, keyrecord_t *record) {
  453. uint8_t idx = id - A_1;
  454. uint8_t kc;
  455. static bool shifted[10];
  456. if (keyboard_report->mods & MOD_BIT(KC_LSFT) ||
  457. ((get_oneshot_mods() & MOD_BIT(KC_LSFT)) && !has_oneshot_mods_timed_out())) {
  458. if (record->event.pressed)
  459. shifted[idx] = true;
  460. }
  461. if (!shifted[idx]) {
  462. kc = idx + KC_1;
  463. } else {
  464. switch (id) {
  465. case A_8:
  466. case A_9:
  467. shifted[idx] = false;
  468. return;
  469. case A_7:
  470. kc = KC_2;
  471. break;
  472. case A_5:
  473. kc = KC_8;
  474. break;
  475. case A_3:
  476. kc = KC_4;
  477. break;
  478. case A_1:
  479. kc = KC_6;
  480. break;
  481. case A_0:
  482. kc = KC_5;
  483. break;
  484. case A_2:
  485. kc = KC_1;
  486. break;
  487. case A_4:
  488. kc = KC_3;
  489. break;
  490. case A_6:
  491. kc = KC_7;
  492. break;
  493. }
  494. }
  495. if (record->event.pressed) {
  496. register_code (kc);
  497. } else {
  498. unregister_code (kc);
  499. shifted[idx] = false;
  500. }
  501. }
  502. const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt)
  503. {
  504. switch(id) {
  505. case A_MPN:
  506. if (record->event.pressed) {
  507. if (keyboard_report->mods & MOD_BIT(KC_LSFT) ||
  508. ((get_oneshot_mods() & MOD_BIT(KC_LSFT)) && !has_oneshot_mods_timed_out())) {
  509. int oneshot = ((get_oneshot_mods() & MOD_BIT(KC_LSFT)) && !has_oneshot_mods_timed_out());
  510. if (oneshot)
  511. clear_oneshot_mods ();
  512. unregister_code (KC_LSFT);
  513. register_code (KC_MPRV);
  514. unregister_code (KC_MPRV);
  515. if (!oneshot)
  516. register_code (KC_LSFT);
  517. } else {
  518. return MACRO (T(MNXT), END);
  519. }
  520. }
  521. break;
  522. /* Hungarian layer */
  523. case HU_AA:
  524. return ang_do_hun (record, KC_QUOT, KC_A);
  525. case HU_OO:
  526. return ang_do_hun (record, KC_QUOT, KC_O);
  527. case HU_EE:
  528. return ang_do_hun (record, KC_QUOT, KC_E);
  529. case HU_UU:
  530. return ang_do_hun (record, KC_QUOT, KC_U);
  531. case HU_II:
  532. return ang_do_hun (record, KC_QUOT, KC_I);
  533. case HU_OE:
  534. return ang_do_hun (record, KC_DQT, KC_O);
  535. case HU_UE:
  536. return ang_do_hun (record, KC_DQT, KC_U);
  537. case HU_OEE:
  538. return ang_do_hun (record, KC_EQL, KC_O);
  539. case HU_UEE:
  540. return ang_do_hun (record, KC_EQL, KC_U);
  541. /* Plover base */
  542. case A_PLVR:
  543. toggle_steno(record->event.pressed);
  544. break;
  545. /* Fx */
  546. case Fx:
  547. if (record->event.pressed) {
  548. set_oneshot_mods (MOD_LALT);
  549. layer_on (NMDIA);
  550. set_oneshot_layer (NMDIA, ONESHOT_START);
  551. } else {
  552. clear_oneshot_layer_state (ONESHOT_PRESSED);
  553. }
  554. break;
  555. /* GUI & AppSel */
  556. case A_GUI:
  557. if (record->event.pressed) {
  558. register_code (KC_LGUI);
  559. if (record->tap.count && !record->tap.interrupted) {
  560. if (record->tap.count == 2) {
  561. uprintf("CMD:appsel_start\n");
  562. layer_on (APPSEL);
  563. set_oneshot_layer (APPSEL, ONESHOT_START);
  564. } else if (record->tap.count >= 3) {
  565. uprintf("CMD:appsel_helper\n");
  566. layer_off (APPSEL);
  567. clear_oneshot_layer_state (ONESHOT_PRESSED);
  568. }
  569. } else {
  570. record->tap.count = 0;
  571. }
  572. gui_timer = 0;
  573. } else {
  574. if (record->tap.count >= 2)
  575. {
  576. clear_oneshot_layer_state (ONESHOT_PRESSED);
  577. }
  578. gui_timer = timer_read ();
  579. }
  580. break;
  581. case APP_SLK:
  582. if (record->event.pressed)
  583. uprintf("CMD:appsel_slack\n");
  584. break;
  585. case APP_EMCS:
  586. if (record->event.pressed)
  587. uprintf("CMD:appsel_emacs\n");
  588. break;
  589. case APP_TERM:
  590. if (record->event.pressed)
  591. uprintf("CMD:appsel_term\n");
  592. break;
  593. case APP_CHRM:
  594. if (record->event.pressed)
  595. uprintf("CMD:appsel_chrome\n");
  596. break;
  597. case APP_MSIC:
  598. if (record->event.pressed)
  599. uprintf("CMD:appsel_music\n");
  600. break;
  601. case APP_SOCL:
  602. if (record->event.pressed)
  603. uprintf("CMD:appsel_social\n");
  604. break;
  605. case APP_PMGR:
  606. if (record->event.pressed)
  607. uprintf("CMD:appsel_pwmgr\n");
  608. break;
  609. case APP_SCL2:
  610. if (record->event.pressed)
  611. uprintf("CMD:appsel_social2\n");
  612. break;
  613. // number row and symbols
  614. case A_1 ... A_0:
  615. ang_handle_num_row(id, record);
  616. break;
  617. }
  618. return MACRO_NONE;
  619. };
  620. // Runs just one time when the keyboard initializes.
  621. void matrix_init_user(void) {
  622. uint8_t dl;
  623. set_unicode_input_mode(UC_LNX);
  624. ergodox_led_all_on();
  625. for (int i = LED_BRIGHTNESS_HI; i > LED_BRIGHTNESS_LO; i--) {
  626. ergodox_led_all_set (i);
  627. wait_ms (5);
  628. }
  629. wait_ms(1000);
  630. for (int i = LED_BRIGHTNESS_LO; i > 0; i--) {
  631. ergodox_led_all_set (i);
  632. wait_ms (10);
  633. }
  634. ergodox_led_all_off();
  635. if (!eeconfig_is_enabled())
  636. eeconfig_init();
  637. dl = eeconfig_read_default_layer ();
  638. if (dl == (1UL << ADORE)) {
  639. is_adore = 1;
  640. }
  641. };
  642. LEADER_EXTERNS();
  643. static void ang_tap (uint16_t code, ...) {
  644. uint16_t kc = code;
  645. va_list ap;
  646. va_start(ap, code);
  647. do {
  648. register_code16(kc);
  649. unregister_code16(kc);
  650. wait_ms(50);
  651. kc = va_arg(ap, int);
  652. } while (kc != 0);
  653. va_end(ap);
  654. }
  655. #define TAP_ONCE(code) \
  656. register_code (code); \
  657. unregister_code (code)
  658. typedef struct {
  659. bool layer_toggle;
  660. bool sticky;
  661. } td_ta_state_t;
  662. static void ang_tap_dance_ta_finished (qk_tap_dance_state_t *state, void *user_data) {
  663. td_ta_state_t *td_ta = (td_ta_state_t *) user_data;
  664. if (td_ta->sticky) {
  665. td_ta->sticky = false;
  666. td_ta->layer_toggle = false;
  667. layer_off (ARRW);
  668. return;
  669. }
  670. if (state->count == 1 && !state->pressed) {
  671. register_code (KC_TAB);
  672. td_ta->sticky = false;
  673. td_ta->layer_toggle = false;
  674. } else {
  675. td_ta->layer_toggle = true;
  676. layer_on (ARRW);
  677. td_ta->sticky = (state->count == 2);
  678. }
  679. }
  680. static void ang_tap_dance_ta_reset (qk_tap_dance_state_t *state, void *user_data) {
  681. td_ta_state_t *td_ta = (td_ta_state_t *) user_data;
  682. if (!td_ta->layer_toggle)
  683. unregister_code (KC_TAB);
  684. if (!td_ta->sticky)
  685. layer_off (ARRW);
  686. }
  687. static void ang_tap_dance_tmux_finished (qk_tap_dance_state_t *state, void *user_data) {
  688. if (state->count == 1) {
  689. register_code(KC_LALT);
  690. register_code(KC_SPC);
  691. unregister_code(KC_SPC);
  692. unregister_code(KC_LALT);
  693. } else {
  694. register_code(KC_LCTL);
  695. register_code(KC_A);
  696. unregister_code(KC_A);
  697. unregister_code(KC_LCTL);
  698. }
  699. }
  700. static void ang_tap_dance_tmux_pane_select (qk_tap_dance_state_t *state, void *user_data) {
  701. uint8_t kc = KC_P;
  702. if (state->count >= 2) {
  703. kc = KC_Z;
  704. }
  705. register_code(KC_LALT);
  706. register_code(KC_SPC);
  707. unregister_code(KC_SPC);
  708. unregister_code(KC_LALT);
  709. register_code(kc);
  710. unregister_code(kc);
  711. }
  712. static void
  713. _td_sr_each (qk_tap_dance_state_t *state, void *user_data) {
  714. skip_leds = true;
  715. switch (state->count) {
  716. case 1:
  717. ergodox_right_led_3_on ();
  718. break;
  719. case 2:
  720. ergodox_right_led_2_on ();
  721. break;
  722. case 3:
  723. ergodox_right_led_1_on ();
  724. break;
  725. case 4:
  726. ergodox_right_led_3_off ();
  727. wait_ms (50);
  728. ergodox_right_led_2_off ();
  729. wait_ms (50);
  730. ergodox_right_led_1_off ();
  731. break;
  732. }
  733. }
  734. static void
  735. _td_sr_finished (qk_tap_dance_state_t *state, void *user_data) {
  736. if (state->count == 1) {
  737. register_code (KC_MSTP);
  738. }
  739. if (state->count >= 4) {
  740. uprintf("CMD:reflash\n");
  741. wait_ms (1000);
  742. reset_keyboard ();
  743. reset_tap_dance (state);
  744. }
  745. }
  746. static void
  747. _td_sr_reset (qk_tap_dance_state_t *state, void *user_data) {
  748. ergodox_right_led_1_off ();
  749. wait_ms (50);
  750. ergodox_right_led_2_off ();
  751. wait_ms (50);
  752. ergodox_right_led_3_off ();
  753. if (state->count == 1) {
  754. unregister_code (KC_MSTP);
  755. }
  756. }
  757. static void
  758. _td_brackets_finished (qk_tap_dance_state_t *state, void *user_data) {
  759. if (state->count == 1) {
  760. if (state->keycode == TD(CT_LBP))
  761. register_code16 (KC_LBRC);
  762. else
  763. register_code16 (KC_RBRC);
  764. } else if (state->count == 2) {
  765. if (state->keycode == TD(CT_LBP))
  766. register_code16 (KC_LPRN);
  767. else
  768. register_code16 (KC_RPRN);
  769. } else if (state->count == 3) {
  770. unicode_input_start();
  771. if (state->keycode == TD(CT_LBP))
  772. register_hex (0x300c);
  773. else
  774. register_hex (0x300d);
  775. unicode_input_finish();
  776. }
  777. }
  778. static void
  779. _td_brackets_reset (qk_tap_dance_state_t *state, void *user_data) {
  780. if (state->count == 1) {
  781. if (state->keycode == TD(CT_LBP))
  782. unregister_code16 (KC_LBRC);
  783. else
  784. unregister_code16 (KC_RBRC);
  785. } else if (state->count == 2) {
  786. if (state->keycode == TD(CT_LBP))
  787. unregister_code16 (KC_LPRN);
  788. else
  789. unregister_code16 (KC_RPRN);
  790. }
  791. }
  792. qk_tap_dance_action_t tap_dance_actions[] = {
  793. [CT_CLN] = ACTION_TAP_DANCE_DOUBLE (KC_COLN, KC_SCLN)
  794. ,[CT_TA] = {
  795. .fn = { NULL, ang_tap_dance_ta_finished, ang_tap_dance_ta_reset },
  796. .user_data = (void *)&((td_ta_state_t) { false, false })
  797. }
  798. ,[CT_LBP] = ACTION_TAP_DANCE_FN_ADVANCED (NULL, _td_brackets_finished, _td_brackets_reset)
  799. ,[CT_RBP] = ACTION_TAP_DANCE_FN_ADVANCED (NULL, _td_brackets_finished, _td_brackets_reset)
  800. ,[CT_TMUX]= ACTION_TAP_DANCE_FN (ang_tap_dance_tmux_finished)
  801. ,[CT_TPS] = ACTION_TAP_DANCE_FN (ang_tap_dance_tmux_pane_select)
  802. ,[CT_SR] = ACTION_TAP_DANCE_FN_ADVANCED (_td_sr_each, _td_sr_finished, _td_sr_reset)
  803. };
  804. // Runs constantly in the background, in a loop.
  805. void matrix_scan_user(void) {
  806. uint8_t layer = biton32(layer_state);
  807. bool is_arrow = false;
  808. if (gui_timer && timer_elapsed (gui_timer) > TAPPING_TERM)
  809. unregister_code (KC_LGUI);
  810. if (!skip_leds) {
  811. if (layer == HUN) {
  812. ergodox_right_led_2_on();
  813. ergodox_right_led_3_on();
  814. } else if (layer == NMDIA) {
  815. ergodox_right_led_1_on();
  816. ergodox_right_led_2_on();
  817. } else if (layer == PLVR) {
  818. ergodox_right_led_1_on ();
  819. ergodox_right_led_2_on ();
  820. ergodox_right_led_3_on ();
  821. } else if (layer == ADORE) {
  822. ergodox_right_led_1_on ();
  823. ergodox_right_led_2_on ();
  824. ergodox_right_led_3_on ();
  825. ergodox_right_led_2_set (LED_BRIGHTNESS_HI);
  826. }
  827. }
  828. if (layer_state & (1UL << ARRW)) {
  829. if (!skip_leds) {
  830. ergodox_right_led_1_on ();
  831. ergodox_right_led_3_on ();
  832. }
  833. is_arrow = true;
  834. }
  835. if (!skip_leds) {
  836. if (keyboard_report->mods & MOD_BIT(KC_LSFT) ||
  837. ((get_oneshot_mods() & MOD_BIT(KC_LSFT)) && !has_oneshot_mods_timed_out())) {
  838. ergodox_right_led_1_set (LED_BRIGHTNESS_HI);
  839. ergodox_right_led_1_on ();
  840. } else {
  841. ergodox_right_led_1_set (LED_BRIGHTNESS_LO);
  842. if (layer != NMDIA && layer != PLVR && layer != ADORE && !is_arrow)
  843. ergodox_right_led_1_off ();
  844. }
  845. if (keyboard_report->mods & MOD_BIT(KC_LALT) ||
  846. ((get_oneshot_mods() & MOD_BIT(KC_LALT)) && !has_oneshot_mods_timed_out())) {
  847. ergodox_right_led_2_set (LED_BRIGHTNESS_HI);
  848. ergodox_right_led_2_on ();
  849. } else {
  850. ergodox_right_led_2_set (LED_BRIGHTNESS_LO);
  851. if (layer != HUN && layer != NMDIA && layer != PLVR && layer != ADORE)
  852. ergodox_right_led_2_off ();
  853. }
  854. if (keyboard_report->mods & MOD_BIT(KC_LCTRL) ||
  855. ((get_oneshot_mods() & MOD_BIT(KC_LCTRL)) && !has_oneshot_mods_timed_out())) {
  856. ergodox_right_led_3_set (LED_BRIGHTNESS_HI);
  857. ergodox_right_led_3_on ();
  858. } else {
  859. ergodox_right_led_3_set (LED_BRIGHTNESS_LO);
  860. if (layer != HUN && layer != PLVR && layer != ADORE && !is_arrow)
  861. ergodox_right_led_3_off ();
  862. }
  863. }
  864. LEADER_DICTIONARY() {
  865. leading = false;
  866. leader_end ();
  867. SEQ_ONE_KEY (KC_C) {
  868. ang_tap (LSFT(KC_C), KC_S, KC_I, KC_L, KC_L, KC_RALT, KC_QUOT, KC_A, KC_M, KC_A, KC_S,
  869. KC_S, KC_Z, KC_O, KC_N, KC_Y, KC_K, KC_RALT, KC_QUOT, KC_A, KC_M, 0);
  870. }
  871. SEQ_ONE_KEY (KC_K) {
  872. ang_tap (KC_SPC, LSFT(KC_7), KC_SPC, 0);
  873. register_code(KC_LCTL);
  874. register_code(KC_LSFT);
  875. register_code(KC_U);
  876. unregister_code(KC_U);
  877. unregister_code(KC_LSFT);
  878. unregister_code(KC_LCTL);
  879. ang_tap (KC_1, KC_F, KC_4, KC_7, KC_6, 0);
  880. register_code (KC_ENT);
  881. unregister_code (KC_ENT);
  882. ang_tap (KC_END, 0);
  883. register_code(KC_LCTL);
  884. register_code(KC_LSFT);
  885. register_code(KC_U);
  886. unregister_code(KC_U);
  887. unregister_code(KC_LSFT);
  888. unregister_code(KC_LCTL);
  889. ang_tap (KC_1, KC_F, KC_4, KC_7, KC_6, 0);
  890. register_code (KC_SPC);
  891. unregister_code (KC_SPC);
  892. }
  893. SEQ_ONE_KEY (KC_G) {
  894. ang_tap (LSFT(KC_G), KC_E, KC_J, KC_G, KC_RALT, KC_EQL, KC_O,
  895. KC_RALT, KC_EQL, KC_O,
  896. KC_RALT, KC_EQL, KC_O, 0);
  897. }
  898. #if KEYLOGGER_ENABLE
  899. SEQ_ONE_KEY (KC_D) {
  900. ergodox_led_all_on();
  901. wait_ms(100);
  902. ergodox_led_all_off();
  903. log_enable = !log_enable;
  904. }
  905. #endif
  906. SEQ_ONE_KEY (KC_T) {
  907. time_travel = !time_travel;
  908. }
  909. SEQ_ONE_KEY (KC_U) {
  910. qk_ucis_start();
  911. }
  912. SEQ_ONE_KEY (KC_V) {
  913. SEND_STRING (QMK_KEYBOARD "/" QMK_KEYMAP " @ (" QMK_VERSION "/" LAYOUT_ergodox_VERSION ")");
  914. }
  915. SEQ_ONE_KEY (KC_L) {
  916. /* λ */
  917. unicode_input_start();
  918. register_hex(0x03bb);
  919. unicode_input_finish();
  920. }
  921. SEQ_ONE_KEY (KC_Y) {
  922. ang_tap (KC_BSLS, KC_O, KC_SLSH, 0);
  923. }
  924. SEQ_ONE_KEY (KC_S) {
  925. unicode_input_start(); register_hex(0xaf); unicode_input_finish();
  926. TAP_ONCE (KC_BSLS);
  927. register_code (KC_RSFT); TAP_ONCE (KC_MINS); TAP_ONCE (KC_9); unregister_code (KC_RSFT);
  928. unicode_input_start (); register_hex(0x30c4); unicode_input_finish();
  929. register_code (KC_RSFT); TAP_ONCE (KC_0); TAP_ONCE (KC_MINS); unregister_code (KC_RSFT);
  930. TAP_ONCE (KC_SLSH);
  931. unicode_input_start (); register_hex(0xaf); unicode_input_finish();
  932. }
  933. SEQ_TWO_KEYS (KC_W, KC_M) {
  934. uprintf("CMD:wm\n");
  935. }
  936. SEQ_ONE_KEY (KC_A) {
  937. if (is_adore == 0) {
  938. default_layer_and (0);
  939. default_layer_or ((1UL << ADORE));
  940. eeconfig_update_default_layer ((1UL << ADORE));
  941. is_adore = 1;
  942. ergodox_led_all_off ();
  943. ergodox_right_led_3_on ();
  944. wait_ms (100);
  945. ergodox_right_led_2_on ();
  946. wait_ms (100);
  947. ergodox_right_led_3_off ();
  948. ergodox_right_led_1_on ();
  949. wait_ms (100);
  950. ergodox_right_led_2_off ();
  951. wait_ms (100);
  952. ergodox_right_led_1_off ();
  953. } else {
  954. is_adore = 0;
  955. default_layer_and (0);
  956. default_layer_or (1UL << BASE);
  957. eeconfig_update_default_layer ((1UL << BASE));
  958. ergodox_led_all_off ();
  959. ergodox_right_led_1_on ();
  960. wait_ms (100);
  961. ergodox_right_led_2_on ();
  962. wait_ms (100);
  963. ergodox_right_led_1_off ();
  964. ergodox_right_led_3_on ();
  965. wait_ms (100);
  966. ergodox_right_led_2_off ();
  967. wait_ms (100);
  968. ergodox_right_led_3_off ();
  969. }
  970. }
  971. }
  972. }
  973. static uint16_t last4[4];
  974. const qk_ucis_symbol_t ucis_symbol_table[] = UCIS_TABLE
  975. (
  976. UCIS_SYM("poop", 0x1f4a9),
  977. UCIS_SYM("rofl", 0x1f923),
  978. UCIS_SYM("kiss", 0x1f619),
  979. UCIS_SYM("snowman", 0x2603),
  980. UCIS_SYM("coffee", 0x2615),
  981. UCIS_SYM("heart", 0x2764),
  982. UCIS_SYM("bolt", 0x26a1),
  983. UCIS_SYM("pi", 0x03c0),
  984. UCIS_SYM("mouse", 0x1f401),
  985. UCIS_SYM("micro", 0x00b5),
  986. UCIS_SYM("tm", 0x2122),
  987. UCIS_SYM("child", 0x1f476),
  988. UCIS_SYM("family", 0x1F46A)
  989. );
  990. bool process_record_user (uint16_t keycode, keyrecord_t *record) {
  991. #if KEYLOGGER_ENABLE
  992. if (log_enable) {
  993. uint8_t layer = biton32(layer_state);
  994. if ((layer == ADORE) || (layer == BASE))
  995. uprintf ("KL: col=%02d, row=%02d, pressed=%d, layer=%s\n", record->event.key.col,
  996. record->event.key.row, record->event.pressed, (is_adore) ? "ADORE" : "Dvorak");
  997. }
  998. #endif
  999. if (keycode == KC_ESC && record->event.pressed) {
  1000. bool queue = true;
  1001. if ((get_oneshot_mods ()) && !has_oneshot_mods_timed_out ()) {
  1002. clear_oneshot_mods ();
  1003. queue = false;
  1004. }
  1005. if (layer_state & (1UL<<HUN)) {
  1006. layer_off (HUN);
  1007. queue = false;
  1008. }
  1009. return queue;
  1010. }
  1011. if (time_travel && !record->event.pressed) {
  1012. uint8_t p;
  1013. // shift cache one to the left
  1014. for (p = 0; p < 3; p++) {
  1015. last4[p] = last4[p + 1];
  1016. }
  1017. last4[3] = keycode;
  1018. if (last4[0] == KC_D && last4[1] == KC_A && last4[2] == KC_T && last4[3] == KC_E) {
  1019. ang_tap (KC_E, KC_SPC, KC_MINS, KC_D, KC_SPC, KC_QUOT, 0);
  1020. register_code (KC_RSFT);
  1021. register_code (KC_EQL);
  1022. unregister_code (KC_EQL);
  1023. unregister_code (KC_RSFT);
  1024. ang_tap (KC_4, KC_SPC, KC_D, KC_A, KC_Y, KC_S, KC_QUOT, 0);
  1025. return false;
  1026. }
  1027. }
  1028. return true;
  1029. }
  1030. void qk_ucis_symbol_fallback (void) {
  1031. for (uint8_t i = 0; i < qk_ucis_state.count - 1; i++) {
  1032. uint8_t code;
  1033. if ((qk_ucis_state.codes[i] >= M(A_1)) && (qk_ucis_state.codes[i] <= M(A_0)))
  1034. code = qk_ucis_state.codes[i] - M(A_1) + KC_1;
  1035. else
  1036. code = qk_ucis_state.codes[i];
  1037. register_code(code);
  1038. unregister_code(code);
  1039. wait_ms (10);
  1040. }
  1041. }