1 /* Copyright 2018 Christon DeWan (Xton)
3 * This program is free software: you can redistribute it and/or modify
4 * it under the terms of the GNU General Public License as published by
5 * the Free Software Foundation, either version 2 of the License, or
6 * (at your option) any later version.
8 * This program is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
13 * You should have received a copy of the GNU General Public License
14 * along with this program. If not, see <http://www.gnu.org/licenses/>.
16 #include QMK_KEYBOARD_H
18 #include "xtonhasvim.h"
19 #include "fancylighting.h"
21 #define _______ KC_TRNS
31 enum layout_key_codes {
32 IND_BRI = VIM_SAFE_RANGE,
36 extern uint8_t vim_cmd_layer(void) { return _CMD; }
38 const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
39 [_QWERTY] = LAYOUT_all(
40 KC_ESC, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL, X_____X, KC_BSPC, \
41 KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS, \
42 LT(_MOVE, KC_CAPS), KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_ENT, \
43 KC_LSFT, X_____X, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RSFT, X_____X, \
44 KC_LCTL, KC_LALT, KC_LGUI, KC_SPC, KC_RGUI, KC_RALT, VIM_START, MO(_FUN)),
48 X_____X, X_____X, X_____X, X_____X, X_____X, X_____X, X_____X, X_____X, X_____X, X_____X, X_____X, X_____X, X_____X, X_____X, X_____X,
49 X_____X, X_____X, X_____X, X_____X, X_____X, X_____X, KC_HOME, KC_PGDN, KC_PGUP, KC_END, X_____X, X_____X, X_____X, X_____X,
50 _______, X_____X, LGUI(KC_LBRC), LGUI(LSFT(KC_LBRC)), LGUI(LSFT(KC_RBRC)), LGUI(KC_RBRC), KC_LEFT, KC_DOWN, KC_UP, KC_RGHT, X_____X, X_____X, VIM_START,
51 _______, X_____X, X_____X, X_____X, X_____X, X_____X, X_____X, X_____X, X_____X, X_____X, X_____X, X_____X, X_____X, _______,
52 _______, _______, _______, _______, _______, _______, _______, _______),
56 KC_GRV, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, X_____X, KC_DEL, \
57 X_____X, X_____X, KC_UP, RGB_TOG, IND_BRI, X_____X, X_____X, X_____X, KC_PSCR, KC_SLCK, KC_PAUS, KC_UP, X_____X, KC_INS, \
58 X_____X, KC_LEFT, KC_DOWN, KC_RIGHT, IND_DIM, X_____X, X_____X, X_____X, KC_HOME, KC_PGUP, KC_LEFT, KC_RIGHT, FIREY_RETURN, \
59 _______, X_____X, BL_INC, BL_STEP, BL_DEC, X_____X, KC_VOLD, KC_VOLU, KC_MUTE, KC_END, KC_PGDN, KC_DOWN, _______, X_____X, \
60 _______, _______, _______, X_____X, _______, _______, X_____X, _______
64 VIM_ESC, X_____X, X_____X, X_____X, X_____X, X_____X, X_____X, X_____X, X_____X, X_____X, X_____X, X_____X, X_____X, X_____X, X_____X,
65 X_____X, X_____X, VIM_W, VIM_E, X_____X, X_____X, VIM_Y, VIM_U, VIM_I, VIM_O, VIM_P, X_____X, X_____X, X_____X,
66 _______, VIM_A, VIM_S, VIM_D, X_____X, VIM_G, VIM_H, VIM_J, VIM_K, VIM_L, X_____X, X_____X, X_____X,
67 VIM_SHIFT, X_____X, X_____X, VIM_X, VIM_C, VIM_V, VIM_B, X_____X, X_____X, VIM_COMMA, VIM_PERIOD, X_____X, VIM_SHIFT,X_____X,
68 _______, _______, _______, _______, _______, _______, _______, TO(_QWERTY)
73 void led_set_user(uint8_t usb_led) {
74 if (usb_led & (1<<USB_LED_CAPS_LOCK)) {
86 #define C_RED 0xFF, 0x00, 0x00
87 #define C_GRN 0x00, 0xFF, 0x00
88 #define C_BLU 0x00, 0x00, 0xFF
90 #define C_YAN 0x00, 0xFF, 0xFF
91 #define C_PRP 0x7A, 0x00, 0xFF
92 #define C_ORG 0xFF, 0x93, 0x00
94 float rgb_brightness = 1.0;
96 /** the underglow LEDs aren't individually addressable, sadly */
97 void rgbflag(uint8_t r, uint8_t g, uint8_t b) {
98 float rgb_brightness = ((float)rgblight_get_val())/256;
99 if(rgb_brightness == 0) rgb_brightness = 0.05;
100 LED_TYPE *target_led = user_rgb_mode ? shadowed_led : led;
101 target_led[0].r = (uint8_t)(r*rgb_brightness);
102 target_led[0].g = (uint8_t)(g*rgb_brightness);
103 target_led[0].b = (uint8_t)(b*rgb_brightness);
104 rgblight_set(); // just to handle turning off if that's required
107 void set_state_leds(void) {
108 switch (biton32(layer_state)) {
138 default: // for any other layers, or the default layer
144 #define RGBLIGHT_LIMIT_VAL 255
145 #define RGBLIGHT_BASE_VAL 3
146 extern rgblight_config_t rgblight_config;
147 extern backlight_config_t backlight_config;
149 bool process_record_keymap(uint16_t keycode, keyrecord_t *record) {
150 if (record->event.pressed) {
153 if (rgblight_config.val + RGBLIGHT_VAL_STEP > RGBLIGHT_LIMIT_VAL) {
154 rgblight_config.val = RGBLIGHT_LIMIT_VAL;
156 rgblight_config.val = rgblight_config.val + RGBLIGHT_VAL_STEP;
158 eeconfig_update_rgblight(rgblight_config.raw);
162 if (rgblight_config.val - RGBLIGHT_VAL_STEP < RGBLIGHT_BASE_VAL) {
163 rgblight_config.val = RGBLIGHT_BASE_VAL;
165 rgblight_config.val = rgblight_config.val - RGBLIGHT_VAL_STEP;
167 eeconfig_update_rgblight(rgblight_config.raw);
175 void suspend_power_down_user(void)
178 rgblight_config.enable = false;
182 /** I don't know why, but 3 means "off" and down is up */
183 backlight_config.level = 3;
184 backlight_config.enable = false;
188 void suspend_wakeup_init_user(void)
190 rgblight_config.raw = eeconfig_read_rgblight();
191 backlight_config.raw = eeconfig_read_backlight();
193 backlight_set(backlight_config.level);