stanrc85.c 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. #include "stanrc85.h"
  2. static td_state_t td_state;
  3. __attribute__ ((weak))
  4. bool process_record_keymap(uint16_t keycode, keyrecord_t *record) {
  5. return true;
  6. }
  7. // determine the tapdance state to return
  8. int cur_dance (qk_tap_dance_state_t *state) {
  9. if (state->count == 1) {
  10. if (state->interrupted || !state->pressed) { return SINGLE_TAP; }
  11. else { return SINGLE_HOLD; }
  12. }
  13. if (state->count == 2) { return DOUBLE_TAP; }
  14. else { return 3; } // any number higher than the maximum state value you return above
  15. }
  16. // handle the possible states for each tapdance keycode you define:
  17. void ctl_copy_finished (qk_tap_dance_state_t *state, void *user_data) {
  18. td_state = cur_dance(state);
  19. switch (td_state) {
  20. case SINGLE_TAP:
  21. SEND_STRING(SS_LCTL("c"));
  22. break;
  23. case SINGLE_HOLD:
  24. register_mods(MOD_BIT(KC_RCTL));
  25. break;
  26. case DOUBLE_TAP:
  27. SEND_STRING(SS_LCTL("v"));
  28. }
  29. }
  30. void ctl_copy_reset (qk_tap_dance_state_t *state, void *user_data) {
  31. switch (td_state) {
  32. case SINGLE_TAP:
  33. break;
  34. case SINGLE_HOLD:
  35. unregister_mods(MOD_BIT(KC_RCTL));
  36. break;
  37. case DOUBLE_TAP:
  38. break;
  39. }
  40. }
  41. #if defined(HAS_ROTARY)
  42. bool encoder_update_user(uint8_t index, bool clockwise) {
  43. if (index == 0) { /* First encoder */
  44. if (clockwise) {
  45. tap_code(KC_VOLD);
  46. } else {
  47. tap_code(KC_VOLU);
  48. }
  49. }
  50. return true;
  51. }
  52. #endif
  53. #if defined(HAS_INDICATORS)
  54. static uint8_t led_user = 0;
  55. #endif
  56. void lock_unlock (qk_tap_dance_state_t *state, void *user_data) {
  57. td_state = cur_dance(state);
  58. switch (td_state) {
  59. case SINGLE_TAP: // Ctl + Alt + Del to unlock workstation
  60. tap_code16(KC_CAD);
  61. #if defined(HAS_INDICATORS)
  62. led_user = 0;
  63. #if defined(KEYBOARD_sneakbox_aliceclone) || defined(KEYBOARD_mechlovin_adelais_standard_led_arm_rev4_stm32f303)
  64. led_user = 1;
  65. #endif
  66. writePin(INDICATOR_PIN_0, !led_user);
  67. wait_ms(200);
  68. writePin(INDICATOR_PIN_1, !led_user);
  69. wait_ms(200);
  70. writePin(INDICATOR_PIN_2, !led_user);
  71. #endif
  72. break;
  73. case SINGLE_HOLD:
  74. break;
  75. case DOUBLE_TAP: //Lock workstation
  76. tap_code16(KC_LOCK);
  77. #if defined(HAS_INDICATORS)
  78. led_user = 1;
  79. #if defined(KEYBOARD_sneakbox_aliceclone) || defined(KEYBOARD_mechlovin_adelais_standard_led_arm_rev4_stm32f303)
  80. led_user = 0;
  81. #endif
  82. writePin(INDICATOR_PIN_2, !led_user);
  83. wait_ms(200);
  84. writePin(INDICATOR_PIN_1, !led_user);
  85. wait_ms(200);
  86. writePin(INDICATOR_PIN_0, !led_user);
  87. #endif
  88. break;
  89. }
  90. }
  91. qk_tap_dance_action_t tap_dance_actions[] = {
  92. [TD_WIN] = ACTION_TAP_DANCE_FN(lock_unlock),
  93. [TD_ESC] = ACTION_TAP_DANCE_DOUBLE(KC_ESC, KC_GRV),
  94. [TD_RCTL] = ACTION_TAP_DANCE_FN_ADVANCED(NULL, ctl_copy_finished, ctl_copy_reset)
  95. };
  96. bool process_record_user(uint16_t keycode, keyrecord_t *record) {
  97. switch (keycode) {
  98. case KC_MAKE:
  99. if (!record->event.pressed) {
  100. uint8_t mods = get_mods();
  101. clear_mods();
  102. if (mods & MOD_MASK_SHIFT) {
  103. send_string_with_delay_P(PSTR("qmk flash -j 6 -kb " QMK_KEYBOARD " -km " QMK_KEYMAP "\n"), 10); //New way
  104. reset_keyboard();
  105. }
  106. else
  107. send_string_with_delay_P(PSTR("qmk compile -j 6 -kb " QMK_KEYBOARD " -km " QMK_KEYMAP "\n"), 10); //New way
  108. set_mods(mods);
  109. }
  110. break;
  111. case KC_RDP: //Opens Windows RDP
  112. if (!record->event.pressed) {
  113. register_code(KC_LGUI);
  114. tap_code(KC_R);
  115. unregister_code(KC_LGUI);
  116. wait_ms(200);
  117. send_string_with_delay_P(PSTR("mstsc"), 10);
  118. send_string_with_delay_P(PSTR(SS_TAP(X_ENTER)), 10);
  119. }
  120. break;
  121. }
  122. return process_record_keymap(keycode, record);
  123. }