2 #include QMK_KEYBOARD_H
4 uint16_t copy_paste_timer;
5 uint16_t grave_layer_timer;
6 uint16_t heal_layer_timer;
9 bool process_record_keymap(uint16_t keycode, keyrecord_t *record) {
13 // Defines actions tor my global custom keycodes. Defined in bocaj.h file
14 // Then runs the _keymap's record handler if not processed here
15 bool process_record_user(uint16_t keycode, keyrecord_t *record) {
18 if (!record->event.pressed) {
19 set_single_persistent_default_layer(_WORKMAN);
20 #if (defined(UNICODE_ENABLE) || defined(UNICODEMAP_ENABLE) || defined(UCIS_ENABLE))
21 set_unicode_input_mode(0);
24 ergodox_blink_all_leds();
28 if (!record->event.pressed) {
29 set_single_persistent_default_layer(_WINWORKMAN);
30 #if (defined(UNICODE_ENABLE) || defined(UNICODEMAP_ENABLE) || defined(UCIS_ENABLE))
31 set_unicode_input_mode(4);
34 ergodox_blink_all_leds();
38 if (!record->event.pressed) {
39 set_single_persistent_default_layer(_QWERTY);
40 #if (defined(UNICODE_ENABLE) || defined(UNICODEMAP_ENABLE) || defined(UCIS_ENABLE))
41 set_unicode_input_mode(0);
44 ergodox_blink_all_leds();
48 if (!record->event.pressed) {
50 SEND_STRING(SS_LCTRL(SS_LGUI("q")));
53 case KC_MAKE: // Compiles the firmware, and adds the flash command based on keyboard bootloader
54 if (!record->event.pressed) {
55 uint8_t temp_mod = get_mods();
56 uint8_t temp_osm = get_oneshot_mods();
59 if (biton32(default_layer_state) == _WINWORKMAN) {
60 send_string_with_delay_P(PSTR("make " QMK_KEYBOARD ":" QMK_KEYMAP), 10);
62 send_string_with_delay_P(PSTR("util/docker_build.sh " QMK_KEYBOARD ":" QMK_KEYMAP), 10);
64 if (temp_mod & MODS_SHIFT_MASK) {
65 send_string_with_delay_P(PSTR(":teensy"), 10);
67 if (temp_mod & MODS_CTRL_MASK) {
68 send_string_with_delay_P(PSTR(" -j8 --output-sync"), 10);
70 send_string_with_delay_P(PSTR(SS_TAP(X_ENTER)), 10);
75 case KC_DCLR: // reset all Diablo timers, disabling them
76 #ifdef TAP_DANCE_ENABLE
77 if (record->event.pressed) {
79 for (dtime = 0; dtime < 4; dtime++) {
80 diablo_key_time[dtime] = diablo_times[0];
83 #endif // TAP_DANCE_ENABLE
86 if (!record->event.pressed) {
92 if (record->event.pressed) {
93 grave_layer_timer = timer_read();
95 if (timer_elapsed(grave_layer_timer) < TAPPING_TERM) {
96 uint8_t temp_mod = get_mods();
97 uint8_t one_shot = get_oneshot_mods();
99 if (temp_mod & MODS_SHIFT_MASK || one_shot & MODS_SHIFT_MASK) {
100 register_code(KC_LSFT);
102 unregister_code(KC_LSFT);
114 if (record->event.pressed) {
115 copy_paste_timer = timer_read();
117 if (timer_elapsed(copy_paste_timer) > TAPPING_TERM) { // Hold, copy
118 SEND_STRING(SS_LGUI("c"));
120 SEND_STRING(SS_LGUI("v"));
125 #ifdef UNICODE_ENABLE
126 case UC_FLIP: // (ノಠ痊ಠ)ノ彡┻━┻
127 if (record->event.pressed) {
128 send_unicode_hex_string("0028 30CE 0CA0 75CA 0CA0 0029 30CE 5F61 253B 2501 253B");
131 case UC_TABL: // ┬─┬ノ( º _ ºノ)
132 if (record->event.pressed) {
133 send_unicode_hex_string("252C 2500 252C 30CE 0028 0020 00BA 0020 005F 0020 00BA 30CE 0029");
136 case UC_SHRG: // ¯\_(ツ)_/¯
137 if (record->event.pressed) {
138 send_unicode_hex_string("00AF 005C 005F 0028 30C4 0029 005F 002F 00AF");
142 if (record->event.pressed) {
143 send_unicode_hex_string("0CA0 005F 0CA0");
148 return process_record_keymap(keycode, record);