qmk-firmware/users/bocaj/process_records.c

150 lines
4.6 KiB
C

#include "bocaj.h"
#include QMK_KEYBOARD_H
uint16_t copy_paste_timer;
uint16_t grave_layer_timer;
uint16_t heal_layer_timer;
__attribute__ ((weak))
bool process_record_keymap(uint16_t keycode, keyrecord_t *record) {
return true;
}
// Defines actions tor my global custom keycodes. Defined in bocaj.h file
// Then runs the _keymap's record handler if not processed here
bool process_record_user(uint16_t keycode, keyrecord_t *record) {
switch (keycode) {
case KC_MWRK:
if (!record->event.pressed) {
set_single_persistent_default_layer(_WORKMAN);
#if (defined(UNICODE_ENABLE) || defined(UNICODEMAP_ENABLE) || defined(UCIS_ENABLE))
set_unicode_input_mode(0);
#endif
layer_move(0);
ergodox_blink_all_leds();
}
break;
case KC_WWRK:
if (!record->event.pressed) {
set_single_persistent_default_layer(_WINWORKMAN);
#if (defined(UNICODE_ENABLE) || defined(UNICODEMAP_ENABLE) || defined(UCIS_ENABLE))
set_unicode_input_mode(4);
#endif
layer_move(0);
ergodox_blink_all_leds();
}
break;
case KC_MQWR:
if (!record->event.pressed) {
set_single_persistent_default_layer(_QWERTY);
#if (defined(UNICODE_ENABLE) || defined(UNICODEMAP_ENABLE) || defined(UCIS_ENABLE))
set_unicode_input_mode(0);
#endif
layer_move(0);
ergodox_blink_all_leds();
}
break;
case MC_LOCK:
if (!record->event.pressed) {
layer_move(0);
SEND_STRING(SS_LCTRL(SS_LGUI("q")));
}
break;
case KC_MAKE: // Compiles the firmware, and adds the flash command based on keyboard bootloader
if (!record->event.pressed) {
uint8_t temp_mod = get_mods();
uint8_t temp_osm = get_oneshot_mods();
clear_mods();
clear_oneshot_mods();
if (biton32(default_layer_state) == _WINWORKMAN) {
send_string_with_delay_P(PSTR("make " QMK_KEYBOARD ":" QMK_KEYMAP), 10);
} else {
send_string_with_delay_P(PSTR("util/docker_build.sh " QMK_KEYBOARD ":" QMK_KEYMAP), 10);
}
if (temp_mod & MODS_SHIFT_MASK) {
send_string_with_delay_P(PSTR(":teensy"), 10);
}
if (temp_mod & MODS_CTRL_MASK) {
send_string_with_delay_P(PSTR(" -j8 --output-sync"), 10);
}
send_string_with_delay_P(PSTR(SS_TAP(X_ENTER)), 10);
set_mods(temp_mod);
layer_move(0);
}
break;
case KC_DCLR: // reset all Diablo timers, disabling them
#ifdef TAP_DANCE_ENABLE
if (record->event.pressed) {
uint8_t dtime;
for (dtime = 0; dtime < 4; dtime++) {
diablo_key_time[dtime] = diablo_times[0];
}
}
#endif // TAP_DANCE_ENABLE
break;
case JJ_ARRW:
if (!record->event.pressed) {
SEND_STRING("->");
}
return false;
break;
case LM_GRAVE:
if (record->event.pressed) {
grave_layer_timer = timer_read();
} else {
if (timer_elapsed(grave_layer_timer) < TAPPING_TERM) {
uint8_t temp_mod = get_mods();
uint8_t one_shot = get_oneshot_mods();
clear_mods();
if (temp_mod & MODS_SHIFT_MASK || one_shot & MODS_SHIFT_MASK) {
register_code(KC_LSFT);
tap(KC_GRAVE);
unregister_code(KC_LSFT);
} else {
tap(KC_GRAVE);
}
set_mods(temp_mod);
} else {
layer_move(0);
}
}
return false;
break;
case KC_CCCV:
if (record->event.pressed) {
copy_paste_timer = timer_read();
} else {
if (timer_elapsed(copy_paste_timer) > TAPPING_TERM) { // Hold, copy
SEND_STRING(SS_LGUI("c"));
} else {
SEND_STRING(SS_LGUI("v"));
}
}
return false;
break;
#ifdef UNICODE_ENABLE
case UC_FLIP: // (ノಠ痊ಠ)ノ彡┻━┻
if (record->event.pressed) {
send_unicode_hex_string("0028 30CE 0CA0 75CA 0CA0 0029 30CE 5F61 253B 2501 253B");
}
break;
case UC_TABL: // ┬─┬ノ( º _ ºノ)
if (record->event.pressed) {
send_unicode_hex_string("252C 2500 252C 30CE 0028 0020 00BA 0020 005F 0020 00BA 30CE 0029");
}
break;
case UC_SHRG: // ¯\_(ツ)_/¯
if (record->event.pressed) {
send_unicode_hex_string("00AF 005C 005F 0028 30C4 0029 005F 002F 00AF");
}
break;
case UC_DISA: // ಠ_ಠ
if (record->event.pressed) {
send_unicode_hex_string("0CA0 005F 0CA0");
}
break;
#endif
}
return process_record_keymap(keycode, record);
}