mirror of
				https://github.com/mfulz/qmk_firmware.git
				synced 2025-10-26 11:10:05 +01:00 
			
		
		
		
	 674fcc474c
			
		
	
	
		674fcc474c
		
	
	
	
	
		
			
			* Add Plover layer, remove unused layers * Add rgb indicator for success/failed sequences * Add RGB effects * Add RGB * Add effects for start and end of a leader sequence * Add PLOVER layer * Add RGB * Add RBG * Minor clean up * Minor clean up * Minor clean up * Minor clean up * Rename rgb_light to rgblight_user and fix all references to it * Remove unnecessary guards Remove unnecessary matrix_scan in rgb post_init function * remove trailing newline
		
			
				
	
	
		
			117 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			117 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #include "leader.h"
 | |
| #ifdef RGBLIGHT_ENABLE
 | |
| extern rgblight_config_t rgblight_config;
 | |
| #endif
 | |
| bool leader_succeed;
 | |
| 
 | |
| LEADER_EXTERNS();
 | |
| 
 | |
| void matrix_scan_user(void) {
 | |
|   static bool has_ran_yet;
 | |
|   if (!has_ran_yet) {
 | |
|     has_ran_yet = true;
 | |
|     startup_user();
 | |
|   }
 | |
| #ifdef TAP_DANCE_ENABLE  // Run Diablo 3 macro checking code.
 | |
| //  run_diablo_macro_check();
 | |
| #endif 
 | |
| #ifdef RGBLIGHT_ENABLE
 | |
|   matrix_scan_rgb();
 | |
| #endif
 | |
|   LEADER_DICTIONARY() {
 | |
|     leader_succeed = leading = false;
 | |
| 
 | |
|     SEQ_ONE_KEY(KC_W) {
 | |
|       // vim/tmux: Use in command mode in vim: write to file, switch tmux pane in the current session window and repeat the last command
 | |
|       SEND_STRING(":w" SS_TAP(X_ENTER));
 | |
|       tmux_pane_switch_repeat();
 | |
|       leader_succeed = true;
 | |
|     } else
 | |
|     SEQ_ONE_KEY(KC_T) {
 | |
|       // Send the Tmux Prefix
 | |
|       tmux_prefix();
 | |
|       leader_succeed = true;
 | |
|     } else
 | |
|     SEQ_ONE_KEY(KC_A) {
 | |
|        // tmux: Send the prefix and press 'right' arrow
 | |
|       tmux_prefix();
 | |
|       tap_code(KC_RIGHT);
 | |
|       leader_succeed = true;
 | |
|     } else
 | |
|     SEQ_TWO_KEYS(KC_T, KC_T) {
 | |
|       // tmux: Send the prefix to a nested session
 | |
|       tmux_prefix();
 | |
|       tmux_prefix();
 | |
|       leader_succeed = true;
 | |
|     } else
 | |
|     SEQ_TWO_KEYS(KC_T, KC_R) {
 | |
|       // tmux: Switch pane and repeat last action
 | |
|       tmux_pane_switch_repeat();
 | |
|       leader_succeed = true;
 | |
|     } else
 | |
|     SEQ_TWO_KEYS(KC_V, KC_Z){
 | |
|       // vim: Zoom pane
 | |
|       tap_code16(LCTL(KC_W));
 | |
|       tap_code16(LSFT(KC_BSLS));
 | |
|       leader_succeed = true;
 | |
|     } else
 | |
|     SEQ_TWO_KEYS(KC_V, KC_R) {
 | |
|       // vim: Substitute and place cursor
 | |
|       SEND_STRING(":%s///g" SS_TAP(X_LEFT));
 | |
|       tap_code(KC_LEFT);
 | |
|       tap_code(KC_LEFT);
 | |
|       leader_succeed = true;
 | |
|     } else
 | |
|     SEQ_TWO_KEYS(KC_V, KC_T) {
 | |
|       // vim: move current pane to new tab
 | |
|       tap_code16(LCTL(KC_W));
 | |
|       tap_code16(LSFT(KC_T));
 | |
|       leader_succeed = true;
 | |
|     } else
 | |
|     SEQ_ONE_KEY(KC_R){
 | |
|       // Toggle RGB Layer indicator
 | |
|       tap_code16(KC_RGB_T);
 | |
|       leader_succeed = true;
 | |
|     } else
 | |
|     SEQ_ONE_KEY(KC_SPC){
 | |
|       // One Shot Unicode layer
 | |
| //TODO      tap_code16(OS_UNI);
 | |
|       leader_succeed = true;
 | |
|     } else
 | |
|     SEQ_TWO_KEYS(KC_SPC, KC_SPC){
 | |
|       // Toggle _MODS
 | |
|       tap_code16(TG_MODS);
 | |
|       leader_succeed = true;
 | |
|     } else
 | |
|     SEQ_THREE_KEYS(KC_BSPC, KC_BSPC, KC_BSPC){
 | |
|       // Reset the keyboard
 | |
|       reset_keyboard();
 | |
|       leader_succeed = true;
 | |
|     }
 | |
|   leader_end();
 | |
|   }
 | |
| //  matrix_scan_keymap();
 | |
| }
 | |
| 
 | |
| void leader_start(void) {
 | |
| #ifdef RGBLIGHT_ENABLE
 | |
|  rgblight_savebase();
 | |
|  rgblight_mode_noeeprom(1);
 | |
|  rgblight_sethsv_noeeprom_goldenrod();
 | |
| #endif
 | |
| }
 | |
| 
 | |
| void leader_end(void) {
 | |
| // pick color depending of success /fail
 | |
| // fade leader_start from 100 to 0
 | |
| // fade new color from  0 to 100 to 0
 | |
| // fade old color from 0 to 100
 | |
| #ifdef RGBLIGHT_ENABLE
 | |
|   if (leader_succeed) {
 | |
|     fadeflash_leds(HSV_GREEN);
 | |
|   } else {
 | |
|     fadeflash_leds(HSV_RED);
 | |
|   }
 | |
| #endif
 | |
| }
 |