2 #include "action_layer.h"
5 extern keymap_config_t keymap_config;
7 // Each layer gets a name for readability, which is then used in the keymap matrix below.
8 // The underscores don't mean anything - you can have a layer called STUFF or any other name.
9 // Layer names don't all need to be of the same length, obviously, and you can also skip them
10 // entirely and just use numbers.
15 // Macro name shortcuts
19 // Fillers to make layering more clear
20 #define _______ KC_TRNS
24 const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
26 SINGLES_KEYMAP(KC_KP_7, KC_KP_8, KC_KP_9, KC_KP_PLUS, \
27 KC_KP_4, KC_KP_5, KC_KP_6, KC_KP_MINUS, \
28 KC_KP_1, KC_KP_2, KC_KP_3, KC_KP_ENTER, \
29 KC_KP_0, KC_KP_DOT, TG(_L1), KC_BSPC),
31 SINGLES_KEYMAP(KC_NUMLOCK, KC_TRNS, KC_TRNS, KC_VOLU, \
32 KC_TRNS, KC_UP, KC_TRNS, KC_VOLD, \
33 KC_LEFT, KC_DOWN, KC_RIGHT, KC_TRNS, \
34 KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS)
37 const uint16_t PROGMEM fn_actions[] = {
41 void persistent_default_layer_set(uint16_t default_layer) {
42 eeconfig_update_default_layer(default_layer);
43 default_layer_set(default_layer);
46 const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt)
50 if (record->event.pressed) {
51 persistent_default_layer_set(1UL<<_L1);
55 if (record->event.pressed) {
56 persistent_default_layer_set(1UL<<_NP);