2017-12-18 05:04:50 +01:00
|
|
|
/*
|
|
|
|
Copyright 2018 Cole Markham
|
|
|
|
|
|
|
|
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/>.
|
|
|
|
*/
|
|
|
|
|
2018-05-29 12:53:03 +02:00
|
|
|
#include QMK_KEYBOARD_H
|
|
|
|
|
2017-12-18 05:04:50 +01:00
|
|
|
|
|
|
|
extern rgblight_config_t rgblight_config;
|
|
|
|
|
|
|
|
enum custom_keycodes {
|
|
|
|
BL = SAFE_RANGE
|
|
|
|
};
|
|
|
|
|
|
|
|
enum custom_layers {
|
|
|
|
BASE = 0,
|
|
|
|
LED
|
|
|
|
};
|
|
|
|
|
|
|
|
//Tap Dance Declarations
|
|
|
|
enum {
|
|
|
|
TD_TOGGLE = 0
|
|
|
|
};
|
|
|
|
|
|
|
|
void dance_toggle (qk_tap_dance_state_t *state, void *user_data) {
|
|
|
|
if (state->count >= 2) {
|
|
|
|
println("Double tapped, switching layers");
|
|
|
|
if (layer_state_is(LED)) {
|
|
|
|
layer_off(LED);
|
|
|
|
} else {
|
|
|
|
layer_on(LED);
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
print("Single tapped: ");
|
|
|
|
if (layer_state_is(LED)) {
|
|
|
|
#ifdef RGBLIGHT_ENABLE
|
|
|
|
if (!rgblight_config.enable) {
|
|
|
|
rgblight_enable();
|
|
|
|
}
|
|
|
|
rgblight_step();
|
|
|
|
#endif
|
|
|
|
} else {
|
|
|
|
println("Base layer, sending string");
|
|
|
|
SEND_STRING("This thing is BIG!!\n");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//Tap Dance Definitions
|
|
|
|
qk_tap_dance_action_t tap_dance_actions[] = {
|
|
|
|
[TD_TOGGLE] = ACTION_TAP_DANCE_FN(dance_toggle)
|
|
|
|
// Other declarations would go here, separated by commas, if you have them
|
|
|
|
};
|
|
|
|
|
|
|
|
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
|
|
|
|
2018-05-29 12:53:03 +02:00
|
|
|
[BASE] = LAYOUT(
|
2017-12-18 05:04:50 +01:00
|
|
|
TD(TD_TOGGLE)),
|
2018-05-29 12:53:03 +02:00
|
|
|
[LED] = LAYOUT(
|
2017-12-18 05:04:50 +01:00
|
|
|
TD(TD_TOGGLE)
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt) {
|
|
|
|
return MACRO_NONE ;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void matrix_init_user(void) {
|
|
|
|
}
|
|
|
|
|
|
|
|
void matrix_scan_user(void) {
|
|
|
|
}
|
|
|
|
|
|
|
|
bool process_record_user(uint16_t keycode, keyrecord_t *record) {
|
|
|
|
// Nothing here, see dance_toggle
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
void led_set_user(uint8_t usb_led) {
|
|
|
|
|
|
|
|
if (usb_led & (1 << USB_LED_NUM_LOCK)) {
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if (usb_led & (1 << USB_LED_CAPS_LOCK)) {
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if (usb_led & (1 << USB_LED_SCROLL_LOCK)) {
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if (usb_led & (1 << USB_LED_COMPOSE)) {
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if (usb_led & (1 << USB_LED_KANA)) {
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|