]> git.donarmstrong.com Git - qmk_firmware.git/blob - keyboards/atreus/keymaps/xyverz/keymap.c
Merge remote-tracking branch 'upstream/master'
[qmk_firmware.git] / keyboards / atreus / keymaps / xyverz / keymap.c
1 // This is the personal keymap of Ian Sterling (@xyverz). It is based on the keymap by
2 // Chris Gerber (@gerbercj), with the addition of persistent layers like the Planck and
3 // Preonic keyboards by Jack Humbert.
4
5 #include "atreus.h"
6 #include "action_layer.h"
7 #include "eeconfig.h"
8
9 extern keymap_config_t keymap_config;
10
11 // Each layer gets a name for readability, which is then used in the keymap matrix below.
12 // The underscores don't mean anything - you can have a layer called STUFF or any other name.
13 // Layer names don't all need to be of the same length, obviously, and you can also skip them
14 // entirely and just use numbers.
15 #define _DV 0
16 #define _QW 1
17 #define _CM 2
18 #define _L1 3
19 #define _L2 4
20
21 // Macro name shortcuts
22 #define DVORAK M(_DV)
23 #define QWERTY M(_QW)
24 #define COLEMAK M(_CM)
25
26
27 const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
28   [_DV] = { /* Dvorak */
29     {KC_QUOT, KC_COMM, KC_DOT,  KC_P,    KC_Y,    KC_NO,   KC_F,    KC_G,    KC_C,    KC_R,    KC_L   },
30     {KC_A,    KC_O,    KC_E,    KC_U,    KC_I,    KC_NO,   KC_D,    KC_H,    KC_T,    KC_N,    KC_S   },
31     {SFT_T(KC_SCLN), KC_Q, KC_J, KC_K, KC_X, CTL_T(KC_DEL),  KC_B,  KC_M,  KC_W,  KC_V,   SFT_T(KC_Z) },
32     {KC_ESC, KC_TAB, KC_LGUI, MO(_L2), KC_BSPC, ALT_T(KC_ENT), KC_SPC, MO(_L1), KC_MINS, KC_SLSH, KC_EQL}
33   },
34   [_QW] = { /* Qwerty */
35     {KC_Q,    KC_W,    KC_E,    KC_R,    KC_T,    KC_NO,   KC_Y,    KC_U,    KC_I,    KC_O,    KC_P   },
36     {KC_A,    KC_S,    KC_D,    KC_F,    KC_G,    KC_NO,   KC_H,    KC_J,    KC_K,    KC_L,    KC_SCLN},
37     {SFT_T(KC_Z), KC_X, KC_C, KC_V, KC_B, CTL_T(KC_DEL), KC_N, KC_M, KC_COMM, KC_DOT, SFT_T(KC_SLSH)  },
38     {KC_ESC, KC_TAB, KC_LGUI, MO(_L2), KC_BSPC, ALT_T(KC_ENT), KC_SPC, MO(_L1), KC_MINS, KC_QUOT, KC_ENT}
39   },
40   [_CM] = { /* Colemak */
41     {KC_Q,    KC_W,    KC_F,    KC_P,    KC_G,    KC_NO,   KC_J,    KC_L,    KC_U,    KC_Y,    KC_SCLN},
42     {KC_A,    KC_R,    KC_S,    KC_T,    KC_D,    KC_NO,   KC_H,    KC_N,    KC_E,    KC_I,    KC_O   },
43     {SFT_T(KC_Z), KC_X, KC_C, KC_V, KC_B, CTL_T(KC_DEL), KC_K, KC_M, KC_COMM, KC_DOT, SFT_T(KC_SLSH)  },
44     {KC_ESC, KC_TAB, KC_LGUI, MO(_L2), KC_BSPC, ALT_T(KC_ENT), KC_SPC, MO(_L1), KC_MINS, KC_QUOT, KC_ENT}
45   },
46   [_L1] = { /* LAYER 1 */
47     {KC_1,    KC_2,    KC_3,    KC_4,    KC_5,    KC_NO,   KC_6,    KC_7,    KC_8,    KC_9,    KC_0   },
48     {KC_TAB,  KC_INS,  KC_UP,   KC_DEL,  KC_HOME, KC_NO,   KC_PGUP, KC_MUTE, KC_VOLD, KC_VOLU, KC_EQL },
49     {KC_TRNS, KC_LEFT, KC_DOWN, KC_RGHT, KC_END,  KC_LCTL, KC_PGDN, KC_MPRV, KC_MPLY, KC_MNXT, KC_BSLS},
50     {KC_TRNS, KC_GRV,  KC_LGUI, KC_TRNS, KC_DEL,  KC_LALT, KC_SPC,  KC_TRNS, KC_LBRC, KC_RBRC, KC_ENT }
51   },
52   [_L2] = { /* LAYER 2 */
53     {KC_EXLM, KC_AT,   KC_HASH, KC_DLR,  KC_PERC, KC_NO,   KC_CIRC, KC_AMPR, KC_ASTR, KC_LPRN, KC_RPRN},
54     {KC_F1,   KC_F2,   KC_F3,   KC_F4,   KC_F5,   KC_NO,   KC_TRNS, KC_F6,   KC_F7,   KC_F8,   KC_PLUS},
55     {KC_TRNS, KC_TRNS, DVORAK,  QWERTY,  COLEMAK, KC_LCTL, KC_TRNS, KC_F9,   KC_F10,  KC_F11,  KC_F12 },
56     {KC_TRNS, KC_TRNS, KC_LGUI, KC_TRNS, KC_BSPC, KC_LALT, KC_SPC,  KC_TRNS, LSFT(KC_LBRC), LSFT(KC_RBRC), RESET}
57   }
58 };
59
60 const uint16_t PROGMEM fn_actions[] = {
61
62 };
63
64 void persistant_default_layer_set(uint16_t default_layer) {
65   eeconfig_update_default_layer(default_layer);
66   default_layer_set(default_layer);
67 }
68
69 const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt)
70 {
71       switch(id) {
72         case _DV:
73           if (record->event.pressed) {
74             persistant_default_layer_set(1UL<<_DV);
75           }
76           break;
77         case _QW:
78           if (record->event.pressed) {
79             persistant_default_layer_set(1UL<<_QW);
80           }
81           break;
82         case _CM:
83           if (record->event.pressed) {
84             persistant_default_layer_set(1UL<<_CM);
85           }
86           break;
87       }
88     return MACRO_NONE;
89 };