215 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			215 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* Copyright 2020 Brandon Schlack
 | |
|  *
 | |
|  * This program is free software: you can redistribute it and/or modify
 | |
|  * it under the terms of the GNU General Public License as published by
 | |
|  * the Free Software Foundation, either version 2 of the License, or
 | |
|  * (at your option) any later version.
 | |
|  *
 | |
|  * This program is distributed in the hope that it will be useful,
 | |
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
|  * GNU General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU General Public License
 | |
|  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | |
|  */
 | |
| #include "brandonschlack.h"
 | |
| 
 | |
| user_config_t user_config;
 | |
| #ifdef STOPLIGHT_LED
 | |
| static stoplight_led_t stoplight_led;
 | |
| #endif
 | |
| 
 | |
| /**
 | |
|  * Resets user config in EEPROM
 | |
|  *
 | |
|  * Default is use rgb for layer indication
 | |
|  */
 | |
| void eeconfig_init_user(void) {
 | |
|     user_config.raw = 0;
 | |
|     user_config.rgb_layer_change = true;
 | |
|     user_config.rgb_theme = 0;
 | |
|     eeconfig_update_user(user_config.raw);
 | |
| }
 | |
| 
 | |
| __attribute__((weak))
 | |
| void matrix_init_keymap(void){ }
 | |
| 
 | |
| void matrix_init_user(void) {
 | |
|     matrix_init_keymap();
 | |
| }
 | |
| 
 | |
| __attribute__((weak))
 | |
| void keyboard_post_init_keymap(void){ }
 | |
| 
 | |
| /**
 | |
|  * Reads user config from EEPROM,
 | |
|  * calls RGB init if RGBs enabled
 | |
|  */
 | |
| void keyboard_post_init_user(void){
 | |
|     // Read the user config from EEPROM
 | |
|     user_config.raw = eeconfig_read_user();
 | |
|     // Do Stoplight Animation if enabled
 | |
| #ifdef STOPLIGHT_LED
 | |
|     led_stoplight_start();
 | |
| #endif
 | |
|     // Do RGB things if RGBs enabled
 | |
| #if defined(RGBLIGHT_ENABLE) || defined(RGB_MATRIX_ENABLE)
 | |
|     keyboard_post_init_rgb();
 | |
| #endif
 | |
|     keyboard_post_init_keymap();
 | |
| }
 | |
| 
 | |
| __attribute__ ((weak))
 | |
| void shutdown_keymap(void) {}
 | |
| 
 | |
| /**
 | |
|  * On shutdown,
 | |
|  * If RGBs enabled,
 | |
|  * then set RGB color to Red
 | |
|  */
 | |
| void shutdown_user (void) {
 | |
| #ifdef RGBLIGHT_ENABLE
 | |
|     rgblight_enable_noeeprom();
 | |
|     rgblight_mode_noeeprom(RGBLIGHT_MODE_STATIC_LIGHT);
 | |
|     rgblight_sethsv_noeeprom(0, 255, 127);
 | |
| #endif // RGBLIGHT_ENABLE
 | |
| #ifdef RGB_MATRIX_ENABLE
 | |
|     rgb_matrix_set_color_all( 0xFF, 0x00, 0x00 );
 | |
| #endif //RGB_MATRIX_ENABLE
 | |
|     shutdown_keymap();
 | |
| }
 | |
| 
 | |
| __attribute__ ((weak))
 | |
| void suspend_power_down_keymap(void) {}
 | |
| 
 | |
| /**
 | |
|  * Set rgb_matrix suspend state to true if not already
 | |
|  */
 | |
| void suspend_power_down_user(void) {
 | |
| #ifdef RGB_MATRIX_ENABLE
 | |
|     if (!g_suspend_state) {
 | |
|         rgb_matrix_set_suspend_state(true);
 | |
|     }
 | |
| #endif //RGB_MATRIX_ENABLE
 | |
|     suspend_power_down_keymap();
 | |
| }
 | |
| 
 | |
| __attribute__ ((weak))
 | |
| void suspend_wakeup_init_keymap(void) {}
 | |
| 
 | |
| /**
 | |
|  * Set rgb_matrix suspend state to false if not already
 | |
|  */
 | |
| void suspend_wakeup_init_user(void) {
 | |
| #ifdef RGB_MATRIX_ENABLE
 | |
|     if (g_suspend_state) {
 | |
|         rgb_matrix_set_suspend_state(false);
 | |
|     }
 | |
| #endif //RGB_MATRIX_ENABLE
 | |
|     suspend_wakeup_init_keymap();
 | |
| }
 | |
| 
 | |
| __attribute__ ((weak))
 | |
| void matrix_scan_keymap(void) {}
 | |
| 
 | |
| /**
 | |
|  * Checks for Super CMD↯TAB
 | |
|  */
 | |
| void matrix_scan_user(void) {
 | |
|     matrix_scan_cmd_tab();
 | |
| #ifdef STOPLIGHT_LED
 | |
|     matrix_scan_led_stoplight();
 | |
| #endif
 | |
|     matrix_scan_keymap();
 | |
| }
 | |
| 
 | |
| __attribute__ ((weak))
 | |
| layer_state_t default_layer_state_set_keymap(layer_state_t state) {
 | |
|     return state;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * For macropads, if a new default layer is set from DF()
 | |
|  * then automatically set that layer with layer_move()
 | |
|  */
 | |
| layer_state_t default_layer_state_set_user(layer_state_t state) {
 | |
| #if defined(IS_MACROPAD)
 | |
|     layer_move(get_highest_layer(state));
 | |
| #endif
 | |
|     return default_layer_state_set_keymap(state);
 | |
| }
 | |
| 
 | |
| __attribute__ ((weak))
 | |
| layer_state_t layer_state_set_keymap(layer_state_t state) {
 | |
|     return state;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Do RGB things (like layer indication) on layer change
 | |
|  */
 | |
| layer_state_t layer_state_set_user(layer_state_t state) {
 | |
| #if defined(RGBLIGHT_ENABLE) || defined(RGB_MATRIX_ENABLE)
 | |
|     state = layer_state_set_rgb(state);
 | |
| #endif // RGBLIGHT_ENABLE
 | |
|     return layer_state_set_keymap(state);
 | |
| }
 | |
| 
 | |
| __attribute__((weak)) bool led_update_keymap(led_t led_state) { return true; }
 | |
| 
 | |
| bool led_update_user(led_t led_state) {
 | |
| #ifdef STOPLIGHT_LED
 | |
|     if (stoplight_led.is_active) {
 | |
|         return false;
 | |
|     }
 | |
| #endif
 | |
|     return led_update_keymap(led_state);
 | |
| }
 | |
| 
 | |
| #ifdef STOPLIGHT_LED
 | |
| void led_stoplight_start(void) {
 | |
|     writePin(TOP_LED, LED_ON(false));
 | |
|     writePin(MIDDLE_LED, LED_ON(false));
 | |
|     writePin(BOTTOM_LED, LED_ON(false));
 | |
| 
 | |
|     stoplight_led.is_active = true;
 | |
|     stoplight_led.timer = timer_read();
 | |
| };
 | |
| 
 | |
| void led_stoplight_set(pin_t pin) {
 | |
|     writePin(pin, LED_ON(true));
 | |
| };
 | |
| 
 | |
| void led_stoplight_end(void) {
 | |
|     // Reset timer and status variables
 | |
|     stoplight_led.is_active = false;
 | |
|     stoplight_led.index = 0;
 | |
|     stoplight_led.timer = 0;
 | |
|     led_update_kb(host_keyboard_led_state());
 | |
| };
 | |
| 
 | |
| void matrix_scan_led_stoplight(void) {
 | |
|     if (stoplight_led.is_active) {
 | |
|         if (timer_elapsed(stoplight_led.timer) > (1000 * (stoplight_led.index + 1))) {
 | |
|             switch (stoplight_led.index){
 | |
|                 case 0:
 | |
|                     led_stoplight_set(TOP_LED);
 | |
|                     stoplight_led.index++;
 | |
|                     break;
 | |
|                 case 1:
 | |
|                     led_stoplight_set(MIDDLE_LED);
 | |
|                     stoplight_led.index++;
 | |
|                     break;
 | |
|                 case 2:
 | |
|                     led_stoplight_set(BOTTOM_LED);
 | |
|                     stoplight_led.index++;
 | |
|                     break;
 | |
|                 default:
 | |
|                     led_stoplight_end();
 | |
|                     break;
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| };
 | |
| #endif
 |