keymap.c 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132
  1. #include "frosty_flake.h"
  2. #include "action_layer.h"
  3. #include "eeconfig.h"
  4. #include "process_unicode.h"
  5. #include "quantum.h"
  6. #define _______ KC_TRNS
  7. //Tap Dance Declarations
  8. enum {
  9. TD_CTCPS = 0
  10. };
  11. //Tap Dance Definitions
  12. qk_tap_dance_action_t tap_dance_actions[] = {
  13. //Tap once for CTRL, twice for Caps Lock
  14. [TD_CTCPS] = ACTION_TAP_DANCE_DOUBLE(KC_LCTL, KC_CAPS)
  15. // Other declarations would go here, separated by commas, if you have them
  16. };
  17. enum my_macros {
  18. NEWDESK = 0,
  19. LEFTDESK,
  20. RIGHTDESK,
  21. CLOSEDESK
  22. };
  23. const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt) // this is the function signature -- just copy/paste it into your keymap file as it is.
  24. {
  25. switch(id) {
  26. case NEWDESK: // this would trigger when you hit a key mapped as M(0)
  27. if (record->event.pressed) {
  28. return MACRO( I(1), D(LGUI), D(LCTL), D(D), U(LGUI), U(LCTL), U(D), END ); // NEW DESKTOP
  29. }
  30. break;
  31. case LEFTDESK: // this would trigger when you hit a key mapped as M(0)
  32. if (record->event.pressed) {
  33. return MACRO( I(1), D(LGUI), D(LCTL), D(LEFT), U(LGUI), U(LCTL), U(LEFT), END ); // LEFT DESKTOP
  34. }
  35. break;
  36. case RIGHTDESK: // this would trigger when you hit a key mapped as M(0)
  37. if (record->event.pressed) {
  38. return MACRO( I(1), D(LGUI), D(LCTL), D(RGHT), U(LGUI), U(LCTL), U(RGHT), END ); // RIGHT DESKTOP
  39. }
  40. break;
  41. case CLOSEDESK: // this would trigger when you hit a key mapped as M(0)
  42. if (record->event.pressed) {
  43. return MACRO( I(1), D(LGUI), D(LCTL), D(F4), U(LGUI), U(LCTL), U(F4), END ); // CLOSE DESKTOP
  44. }
  45. break;
  46. }
  47. return MACRO_NONE;
  48. };
  49. enum unicode_name {
  50. THINK, // thinking face 🤔
  51. GRIN, // grinning face 😊
  52. BBB, // dat B 🅱
  53. POO, // poop 💩
  54. HUNDR, // 100 💯
  55. SMRK, // smirk 😏
  56. WEARY, // good shit 😩
  57. EGGPL, // EGGPLANT 🍆
  58. WATER, // wet 💦
  59. LIT, // fire 🔥
  60. UNAMU, // unamused 😒
  61. SNEK // snke 🐍
  62. };
  63. const uint32_t PROGMEM unicode_map[] = {
  64. [THINK] = 0x1F914,
  65. [GRIN] = 0x1F600,
  66. [BBB] = 0x1F171,
  67. [POO] = 0x1F4A9,
  68. [HUNDR] = 0x1F4AF,
  69. [SMRK] = 0x1F60F,
  70. [WEARY] = 0x1F629,
  71. [EGGPL] = 0x1F346,
  72. [WATER] = 0x1F4A6,
  73. [LIT] = 0x1F525,
  74. [UNAMU] = 0x1F612,
  75. [SNEK] = 0x1F40D
  76. };
  77. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  78. [0] = KEYMAP(\
  79. KC_ESC, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, KC_PSCR,KC_SLCK,KC_PAUS, \
  80. KC_GRV, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0,KC_MINS, KC_EQL,KC_BSPC, KC_INS,KC_HOME,KC_PGUP, KC_NLCK,KC_PSLS,KC_PAST,KC_PMNS, \
  81. KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P,KC_LBRC,KC_RBRC,KC_BSLS, KC_DEL, KC_END,KC_PGDN, KC_P7, KC_P8, KC_P9,KC_PPLS, \
  82. KC_LCTL, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L,KC_SCLN,KC_QUOT, KC_ENT, KC_P4, KC_P5, KC_P6, \
  83. KC_LSPO,KC_NUBS, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M,KC_COMM, KC_DOT,KC_SLSH, KC_RSPC, KC_UP, KC_P1, KC_P2, KC_P3,KC_PENT, \
  84. TD(TD_CTCPS),KC_LGUI,KC_LALT, KC_SPC, KC_LEAD,KC_RGUI, KC_APP,MO(1) , KC_LEFT,KC_DOWN,KC_RGHT, KC_P0,KC_PDOT),
  85. [1] = KEYMAP(\
  86. KC_ESC, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, KC_PSCR,KC_SLCK,KC_PAUS, \
  87. KC_GRV, X(GRIN),X(THINK),X(SMRK),X(WEARY),X(UNAMU), KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL,KC_BSPC, KC_MPRV,KC_MPLY,KC_MNXT, KC_NLCK,KC_PSLS,KC_PAST,KC_PMNS, \
  88. KC_TAB, KC_Q, M(0), KC_E, KC_R,X(EGGPL),X(WATER), KC_U, KC_I, KC_O, KC_P, KC_UP ,KC_RBRC,KC_BSLS, KC_MUTE,KC_VOLD,KC_VOLU, KC_P7, KC_P8, KC_P9,KC_PPLS, \
  89. KC_LCTL, M(1), M(3), M(2), KC_F, X(LIT), X(SNEK), KC_J, KC_K, KC_L,KC_LEFT,KC_RGHT, KC_ENT, KC_P4, KC_P5, KC_P6, \
  90. KC_LSFT,KC_NUBS, KC_Z, KC_X, KC_C, X(HUNDR), X(BBB), X(POO), KC_M,KC_COMM, KC_DOT,KC_DOWN, KC_RSFT, KC_MS_U, KC_P1, KC_P2, KC_P3,KC_PENT, \
  91. KC_BTN1,KC_BTN3,KC_BTN2, KC_SPC, KC_RALT,KC_RGUI, TG(2),_______ , KC_MS_L,KC_MS_D,KC_MS_R, KC_P0,KC_PDOT),
  92. [2] = KEYMAP(\
  93. KC_ESC, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, KC_PSCR,KC_SLCK,KC_PAUS, \
  94. KC_GRV, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0,KC_MINS, KC_EQL,KC_BSPC, KC_MPRV,KC_MPLY,KC_MNXT, KC_NLCK,KC_PSLS,KC_PAST,KC_PMNS, \
  95. KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P,KC_LBRC,KC_RBRC,KC_BSLS, KC_MUTE,KC_VOLD,KC_VOLU, KC_P7, KC_P8, KC_P9,KC_PPLS, \
  96. KC_LCTL, KC_D, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L,KC_SCLN,KC_QUOT, KC_ENT, KC_P4, KC_P5, KC_P6, \
  97. KC_LSFT,KC_NUBS, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M,KC_COMM, KC_DOT,KC_SLSH, KC_RSFT, KC_MS_U, KC_P1, KC_P2, KC_P3,KC_PENT, \
  98. KC_BTN1,KC_BTN3,KC_BTN2, KC_SPC, KC_RALT,KC_RGUI, _______, _______, KC_MS_L,KC_MS_D,KC_MS_R, KC_P0,KC_PDOT),
  99. };
  100. LEADER_EXTERNS();
  101. void matrix_scan_user(void) {
  102. LEADER_DICTIONARY() {
  103. leading = false;
  104. leader_end();
  105. SEQ_TWO_KEYS(KC_A, KC_A) {
  106. register_code(KC_LCTL);
  107. register_code(KC_A);
  108. unregister_code(KC_A);
  109. register_code(KC_C);
  110. unregister_code(KC_C);
  111. unregister_code(KC_LCTL);
  112. }
  113. }
  114. }
  115. void matrix_init_user(void) {
  116. _delay_ms(500);
  117. set_unicode_input_mode(UC_WINC);
  118. };