mirror of
https://github.com/qmk/qmk_userspace.git
synced 2025-05-05 15:14:17 -04:00
- increased combo timer to 35 - I removed all the unnecessary defines and associated methods for per keycode customizations like quick tap term, combo press in order, etc
61 lines
No EOL
1.2 KiB
C
61 lines
No EOL
1.2 KiB
C
#include "combo.h"
|
|
|
|
bool get_combo_must_tap(uint16_t index, combo_t *combo) {
|
|
|
|
switch (index) {
|
|
|
|
#if defined(MOUSEKEY_ENABLE)
|
|
case MOUSE_BUTTON3:
|
|
case MOUSE_BUTTON4:
|
|
case MOUSE_BUTTON5:
|
|
case MOUSE_DRGTOG:
|
|
#endif //MOUSEKEY_ENABLEdf
|
|
|
|
case KEY_ESC:
|
|
case KEY_ENT:
|
|
case KEY_TAB:
|
|
return true;
|
|
|
|
default:
|
|
return false;
|
|
}
|
|
}
|
|
|
|
bool combo_should_trigger(uint16_t combo_index, combo_t *combo, uint16_t keycode, keyrecord_t *record) {
|
|
|
|
// disable all combos on config layer
|
|
if ( get_highest_layer(layer_state) == _CONFIG ) {
|
|
return false;
|
|
}
|
|
|
|
switch (combo_index) {
|
|
|
|
case KEY_ENT:
|
|
if ( get_highest_layer(layer_state) == _SYMBOL ) {
|
|
return false;
|
|
}
|
|
break;
|
|
|
|
case KEY_ESC:
|
|
case KEY_TAB:
|
|
if ( get_highest_layer(layer_state) == _NAVIGATION ||
|
|
get_highest_layer(layer_state) == _SYMBOL ) {
|
|
return false;
|
|
}
|
|
break;
|
|
|
|
case MOUSE_BUTTON1:
|
|
case MOUSE_BUTTON2:
|
|
case MOUSE_BUTTON3:
|
|
case MOUSE_BUTTON4:
|
|
case MOUSE_BUTTON5:
|
|
case MOUSE_DRGTOG:
|
|
if ( get_highest_layer(layer_state) > _DEFAULT_LAYER_1 ) {
|
|
return false;
|
|
}
|
|
break;
|
|
|
|
}
|
|
|
|
return true;
|
|
} |