2019-02-15 02:09:27 +06:00
|
|
|
#include "tap_dance.h"
|
|
|
|
|
|
|
|
#define ACTION_TAP_DANCE_DOUBLE_MODS(mod1, mod2) { \
|
|
|
|
.fn = { td_double_mods_each, NULL, td_double_mods_reset }, \
|
2022-12-15 02:40:25 +06:00
|
|
|
.user_data = &(tap_dance_pair_t){ mod1, mod2 }, \
|
2019-02-15 02:09:27 +06:00
|
|
|
}
|
|
|
|
|
2022-12-15 02:40:25 +06:00
|
|
|
void td_double_mods_each(tap_dance_state_t *state, void *user_data) {
|
|
|
|
tap_dance_pair_t *mods = (tap_dance_pair_t *)user_data;
|
2019-02-15 02:09:27 +06:00
|
|
|
// Single tap → mod1, double tap → mod2, triple tap etc. → mod1+mod2
|
|
|
|
if (state->count == 1 || state->count == 3) {
|
|
|
|
register_code(mods->kc1);
|
|
|
|
} else if (state->count == 2) {
|
|
|
|
unregister_code(mods->kc1);
|
|
|
|
register_code(mods->kc2);
|
|
|
|
}
|
|
|
|
// Prevent tap dance from sending kc1 and kc2 as weak mods
|
|
|
|
state->weak_mods &= ~(MOD_BIT(mods->kc1) | MOD_BIT(mods->kc2));
|
|
|
|
}
|
|
|
|
|
2022-12-15 02:40:25 +06:00
|
|
|
void td_double_mods_reset(tap_dance_state_t *state, void *user_data) {
|
|
|
|
tap_dance_pair_t *mods = (tap_dance_pair_t *)user_data;
|
2019-02-15 02:09:27 +06:00
|
|
|
if (state->count == 1 || state->count >= 3) {
|
|
|
|
unregister_code(mods->kc1);
|
|
|
|
}
|
|
|
|
if (state->count >= 2) {
|
|
|
|
unregister_code(mods->kc2);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-12-15 02:40:25 +06:00
|
|
|
tap_dance_action_t tap_dance_actions[] = {
|
2019-02-15 02:09:27 +06:00
|
|
|
[TD_RSF_RCT] = ACTION_TAP_DANCE_DOUBLE_MODS(KC_RSFT, KC_RCTL),
|
|
|
|
};
|