|
|
|
@ -20,6 +20,13 @@
|
|
|
|
|
#define KC_WWWB KC_WWW_BACK
|
|
|
|
|
#define KC_WWWF KC_WWW_FORWARD
|
|
|
|
|
|
|
|
|
|
enum glow_modes {
|
|
|
|
|
GLOW_NONE,
|
|
|
|
|
GLOW_MIN,
|
|
|
|
|
GLOW_FULL
|
|
|
|
|
};
|
|
|
|
|
uint8_t glow_mode = GLOW_MIN;
|
|
|
|
|
|
|
|
|
|
extern keymap_config_t keymap_config;
|
|
|
|
|
|
|
|
|
|
enum layers {
|
|
|
|
@ -61,6 +68,10 @@ enum planck_keycodes {
|
|
|
|
|
LINUX,
|
|
|
|
|
WIN,
|
|
|
|
|
OSX,
|
|
|
|
|
|
|
|
|
|
// others
|
|
|
|
|
GLOW,
|
|
|
|
|
AUDIO
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
// unicode map
|
|
|
|
@ -317,6 +328,17 @@ const uint8_t PROGMEM LED_ALNUM[] = {
|
|
|
|
|
LED_RSPC
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
const uint8_t PROGMEM LED_HOMING[] = {
|
|
|
|
|
LED_A,
|
|
|
|
|
LED_S,
|
|
|
|
|
LED_D,
|
|
|
|
|
LED_F,
|
|
|
|
|
LED_J,
|
|
|
|
|
LED_K,
|
|
|
|
|
LED_L,
|
|
|
|
|
LED_SCLN
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
const uint8_t PROGMEM LED_MODS[] = {
|
|
|
|
|
LED_TAB,
|
|
|
|
|
LED_ESC,
|
|
|
|
@ -354,20 +376,50 @@ const uint8_t PROGMEM LED_TRACKPOINT[] = {
|
|
|
|
|
LED_TRACKPOINT3,
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
void led_reset(void) {
|
|
|
|
|
void led_turnoff_keys(void) {
|
|
|
|
|
for(uint8_t i = 0; i < COUNT(LED_ALNUM); i++) {
|
|
|
|
|
rgbsps_set(pgm_read_byte(&LED_ALNUM[i]), 0, 0, 0);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for(uint8_t i = 0; i < COUNT(LED_MODS); i++) {
|
|
|
|
|
rgbsps_set(pgm_read_byte(&LED_MODS[i]), 0, 0, 0);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for(uint8_t i = 0; i < COUNT(LED_FN); i++) {
|
|
|
|
|
rgbsps_set(pgm_read_byte(&LED_FN[i]), 0, 0, 0);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void led_reset(void) {
|
|
|
|
|
switch (glow_mode) {
|
|
|
|
|
case GLOW_NONE:
|
|
|
|
|
led_turnoff_keys();
|
|
|
|
|
break;
|
|
|
|
|
case GLOW_MIN:
|
|
|
|
|
led_turnoff_keys();
|
|
|
|
|
for(uint8_t i = 0; i < COUNT(LED_HOMING); i++) {
|
|
|
|
|
rgbsps_set(pgm_read_byte(&LED_HOMING[i]), 8, 8, 8);
|
|
|
|
|
}
|
|
|
|
|
rgbsps_set(LED_F, 15, 0, 0);
|
|
|
|
|
rgbsps_set(LED_J, 15, 0, 0);
|
|
|
|
|
break;
|
|
|
|
|
case GLOW_FULL:
|
|
|
|
|
for(uint8_t i = 0; i < COUNT(LED_ALNUM); i++) {
|
|
|
|
|
rgbsps_set(pgm_read_byte(&LED_ALNUM[i]), 8, 8, 8);
|
|
|
|
|
}
|
|
|
|
|
for(uint8_t i = 0; i < COUNT(LED_MODS); i++) {
|
|
|
|
|
rgbsps_set(pgm_read_byte(&LED_MODS[i]), 0, 15, 0);
|
|
|
|
|
}
|
|
|
|
|
for(uint8_t i = 0; i < COUNT(LED_FN); i++) {
|
|
|
|
|
rgbsps_set(pgm_read_byte(&LED_FN[i]), 0, 0, 15);
|
|
|
|
|
}
|
|
|
|
|
for(uint8_t i = 0; i < COUNT(LED_HOMING); i++) {
|
|
|
|
|
rgbsps_set(pgm_read_byte(&LED_HOMING[i]), 15, 0, 0);
|
|
|
|
|
}
|
|
|
|
|
rgbsps_set(LED_F, 15, 15, 0);
|
|
|
|
|
rgbsps_set(LED_J, 15, 15, 0);
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void led_layer_normal(void) {
|
|
|
|
|
rgbsps_set(LED_IND_FUNC, 0, 0, 0);
|
|
|
|
|
rgbsps_set(LED_IND_NUM, 0, 0, 0);
|
|
|
|
@ -385,35 +437,6 @@ void led_layer_func(void) {
|
|
|
|
|
|
|
|
|
|
led_reset();
|
|
|
|
|
|
|
|
|
|
for(uint8_t i = 0; i < COUNT(LED_ALNUM); i++) {
|
|
|
|
|
rgbsps_set(pgm_read_byte(&LED_ALNUM[i]), 0, 0, 0);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// rgbsps_set(LED_I, 15, 0, 15);
|
|
|
|
|
// rgbsps_set(LED_J, 15, 0, 15);
|
|
|
|
|
// rgbsps_set(LED_K, 15, 0, 15);
|
|
|
|
|
// rgbsps_set(LED_L, 15, 0, 15);
|
|
|
|
|
|
|
|
|
|
// rgbsps_set(LED_U, 15, 0, 0);
|
|
|
|
|
// rgbsps_set(LED_O, 15, 0, 0);
|
|
|
|
|
// rgbsps_set(LED_COMM, 15, 0, 0);
|
|
|
|
|
// rgbsps_set(LED_DOT, 15, 0, 0);
|
|
|
|
|
// rgbsps_set(LED_SCLN, 15, 0, 0);
|
|
|
|
|
// rgbsps_set(LED_P, 15, 0, 0);
|
|
|
|
|
|
|
|
|
|
// rgbsps_set(LED_Q, 0, 15, 0);
|
|
|
|
|
// rgbsps_set(LED_W, 0, 15, 0);
|
|
|
|
|
// rgbsps_set(LED_E, 0, 15, 0);
|
|
|
|
|
// rgbsps_set(LED_R, 0, 15, 0);
|
|
|
|
|
// rgbsps_set(LED_A, 0, 15, 0);
|
|
|
|
|
// rgbsps_set(LED_S, 0, 15, 0);
|
|
|
|
|
// rgbsps_set(LED_D, 0, 15, 0);
|
|
|
|
|
// rgbsps_set(LED_F, 0, 15, 0);
|
|
|
|
|
// rgbsps_set(LED_Z, 0, 15, 0);
|
|
|
|
|
// rgbsps_set(LED_X, 0, 15, 0);
|
|
|
|
|
// rgbsps_set(LED_C, 0, 15, 0);
|
|
|
|
|
// rgbsps_set(LED_V, 0, 15, 0);
|
|
|
|
|
|
|
|
|
|
rgbsps_send();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
@ -434,55 +457,10 @@ void led_layer_num(void) {
|
|
|
|
|
|
|
|
|
|
led_reset();
|
|
|
|
|
|
|
|
|
|
// for(uint8_t i = 0; i < COUNT(LED_ALNUM); i++) {
|
|
|
|
|
// rgbsps_set(pgm_read_byte(&LED_ALNUM[i]), 0, 0, 0);
|
|
|
|
|
// }
|
|
|
|
|
|
|
|
|
|
// rgbsps_set(LED_U, 0, 5, 15);
|
|
|
|
|
// rgbsps_set(LED_I, 0, 5, 15);
|
|
|
|
|
// rgbsps_set(LED_O, 0, 5, 15);
|
|
|
|
|
// rgbsps_set(LED_J, 0, 5, 15);
|
|
|
|
|
// rgbsps_set(LED_K, 0, 5, 15);
|
|
|
|
|
// rgbsps_set(LED_L, 0, 5, 15);
|
|
|
|
|
// rgbsps_set(LED_M, 0, 5, 15);
|
|
|
|
|
// rgbsps_set(LED_COMM, 0, 5, 15);
|
|
|
|
|
// rgbsps_set(LED_DOT, 0, 5, 15);
|
|
|
|
|
// rgbsps_set(LED_FUNC, 0, 5, 15);
|
|
|
|
|
|
|
|
|
|
// rgbsps_set(LED_EMOJI, 0, 10, 15);
|
|
|
|
|
// rgbsps_set(LED_RALT, 0, 10, 15);
|
|
|
|
|
|
|
|
|
|
// rgbsps_set(LED_Q, 0, 10, 15);
|
|
|
|
|
// rgbsps_set(LED_W, 0, 10, 15);
|
|
|
|
|
// rgbsps_set(LED_E, 0, 10, 15);
|
|
|
|
|
// rgbsps_set(LED_R, 0, 10, 15);
|
|
|
|
|
// rgbsps_set(LED_T, 0, 10, 15);
|
|
|
|
|
// rgbsps_set(LED_Y, 0, 10, 15);
|
|
|
|
|
// rgbsps_set(LED_P, 0, 10, 15);
|
|
|
|
|
|
|
|
|
|
// rgbsps_set(LED_A, 0, 15, 15);
|
|
|
|
|
// rgbsps_set(LED_S, 0, 15, 15);
|
|
|
|
|
// rgbsps_set(LED_D, 0, 15, 15);
|
|
|
|
|
// rgbsps_set(LED_F, 0, 15, 15);
|
|
|
|
|
// rgbsps_set(LED_Z, 0, 15, 15);
|
|
|
|
|
// rgbsps_set(LED_X, 0, 15, 15);
|
|
|
|
|
// rgbsps_set(LED_C, 0, 15, 15);
|
|
|
|
|
// rgbsps_set(LED_V, 0, 15, 15);
|
|
|
|
|
|
|
|
|
|
rgbsps_send();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void led_layer_emoji(void) {
|
|
|
|
|
// for(uint8_t i = 0; i < COUNT(LED_ALNUM); i++) {
|
|
|
|
|
// rgbsps_set(pgm_read_byte(&LED_ALNUM[i]), 15, 15, 0);
|
|
|
|
|
// }
|
|
|
|
|
// for(uint8_t i = 0; i < COUNT(LED_MODS); i++) {
|
|
|
|
|
// rgbsps_set(pgm_read_byte(&LED_MODS[i]), 15, 15, 0);
|
|
|
|
|
// }
|
|
|
|
|
// for(uint8_t i = 0; i < COUNT(LED_FN); i++) {
|
|
|
|
|
// rgbsps_set(pgm_read_byte(&LED_FN[i]), 15, 15, 0);
|
|
|
|
|
// }
|
|
|
|
|
|
|
|
|
|
rgbsps_set(LED_IND_FUNC, 0, 0, 0);
|
|
|
|
|
rgbsps_set(LED_IND_NUM, 0, 0, 0);
|
|
|
|
|
rgbsps_set(LED_IND_EMOJI, 15, 15, 0);
|
|
|
|
@ -769,7 +747,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
|
|
|
|
*/
|
|
|
|
|
[_SYS] = KEYMAP(
|
|
|
|
|
XXXXXXX, QWERTY, WIN, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, OUT_USB, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX,
|
|
|
|
|
XXXXXXX, XXXXXXX, XXXXXXX, DVORAK, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, WORKMAN, LINUX, XXXXXXX, XXXXXXX,
|
|
|
|
|
XXXXXXX, AUDIO, XXXXXXX, DVORAK, XXXXXXX, GLOW, XXXXXXX, XXXXXXX, WORKMAN, LINUX, XXXXXXX, XXXXXXX,
|
|
|
|
|
XXXXXXX, XXXXXXX, XXXXXXX, COLEMAK, XXXXXXX, OUT_BLE, NORMAN, OSX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX,
|
|
|
|
|
_______, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, _______
|
|
|
|
|
),
|
|
|
|
@ -968,6 +946,24 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) {
|
|
|
|
|
set_unicode_input_mode(UC_OSX);
|
|
|
|
|
return false;
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
// glow mode changer
|
|
|
|
|
case GLOW:
|
|
|
|
|
if (record->event.pressed) {
|
|
|
|
|
glow_mode++;
|
|
|
|
|
if (glow_mode > GLOW_FULL) {
|
|
|
|
|
glow_mode = GLOW_NONE;
|
|
|
|
|
}
|
|
|
|
|
led_reset();
|
|
|
|
|
rgbsps_send();
|
|
|
|
|
}
|
|
|
|
|
return false;
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
// faux clicky toggle, TBD
|
|
|
|
|
case AUDIO:
|
|
|
|
|
return false;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|