custom_tap_dance.c 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. #include "custom_tap_dance.h"
  2. #include "custom_keycodes.h"
  3. #include "timer_utils.h"
  4. #ifdef TAP_DANCE_ENABLE
  5. //Tap Dance Definitions
  6. qk_tap_dance_action_t tap_dance_actions[] = {
  7. [COMM_QUOT] = ACTION_TAP_DANCE_DOUBLE(KC_COMM, KC_QUOT),
  8. [BACKSPACE] = ACTION_TAP_DANCE_DOUBLE (KC_BSPACE, LCTL(KC_BSPACE)),
  9. [DELETE] = ACTION_TAP_DANCE_DOUBLE (KC_DELETE, LCTL(KC_DELETE))
  10. };
  11. #else
  12. static uint16_t td_keycode;
  13. static uint16_t td_timer;
  14. const uint16_t PROGMEM td_keymaps[TD_MAX - TD_MIN][2] = {
  15. [TD_COMM - TD_MIN] = { KC_COMM, KC_QUOT },
  16. [TD_BSPC - TD_MIN] = { KC_BSPACE, LCTL(KC_BSPACE) },
  17. [TD_DEL - TD_MIN] = { KC_DELETE, LCTL(KC_DELETE) }
  18. };
  19. static void run_custom_tap_dance(uint8_t i)
  20. {
  21. tap_code16(pgm_read_word(&td_keymaps[td_keycode - TD_MIN][i]));
  22. td_keycode = KC_TRANSPARENT;
  23. td_timer = timer_read() + TAPPING_TERM;
  24. }
  25. bool process_custom_tap_dance(uint16_t keycode, keyrecord_t *record)
  26. {
  27. if (TD_MIN <= keycode && keycode < TD_MAX)
  28. {
  29. if (record->event.pressed)
  30. {
  31. if (td_keycode != keycode || timer_expired(td_timer))
  32. {
  33. td_keycode = keycode;
  34. td_timer = timer_read() + TAPPING_TERM;
  35. }
  36. else
  37. run_custom_tap_dance(1);
  38. }
  39. return false;
  40. }
  41. if (td_keycode != KC_TRANSPARENT)
  42. run_custom_tap_dance(0);
  43. return true;
  44. }
  45. void matrix_scan_user(void)
  46. {
  47. if (td_keycode != KC_TRANSPARENT && timer_expired(td_timer))
  48. run_custom_tap_dance(0);
  49. }
  50. #endif