summaryrefslogtreecommitdiff
path: root/users/brandonschlack/brandonschlack.c
diff options
context:
space:
mode:
Diffstat (limited to 'users/brandonschlack/brandonschlack.c')
-rw-r--r--users/brandonschlack/brandonschlack.c214
1 files changed, 214 insertions, 0 deletions
diff --git a/users/brandonschlack/brandonschlack.c b/users/brandonschlack/brandonschlack.c
new file mode 100644
index 0000000000..1e52bd6452
--- /dev/null
+++ b/users/brandonschlack/brandonschlack.c
@@ -0,0 +1,214 @@
+/* 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