custom_tap_dance.c 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  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. [TD_DOT - TD_MIN] = { KC_DOT, KC_GRAVE }
  19. };
  20. void run_tap_dance_double(uint8_t i)
  21. {
  22. tap_code16(pgm_read_word(&td_keymaps[td_keycode - TD_MIN][i]));
  23. td_keycode = KC_TRANSPARENT;
  24. td_timer = timer_read() + TAPPING_TERM;
  25. }
  26. bool process_tap_dance_double(uint16_t keycode, keyrecord_t *record)
  27. {
  28. if (TD_MIN <= keycode && keycode < TD_MAX)
  29. {
  30. if (record->event.pressed)
  31. {
  32. if (td_keycode != keycode || timer_expired(td_timer))
  33. {
  34. td_keycode = keycode;
  35. td_timer = timer_read() + TAPPING_TERM;
  36. }
  37. else
  38. run_tap_dance_double(1);
  39. }
  40. return false;
  41. }
  42. if (td_keycode != KC_TRANSPARENT)
  43. run_tap_dance_double(0);
  44. return true;
  45. }
  46. void matrix_scan_user(void)
  47. {
  48. if (td_keycode != KC_TRANSPARENT && timer_expired(td_timer))
  49. run_tap_dance_double(0);
  50. }
  51. #endif