#include QMK_KEYBOARD_H #include "version.h" #include "keymap_german.h" #include "keymap_nordic.h" #include "keymap_french.h" #include "keymap_spanish.h" #include "keymap_hungarian.h" #include "keymap_swedish.h" #include "keymap_br_abnt2.h" #include "keymap_canadian_multilingual.h" #include "keymap_german_ch.h" #include "keymap_jp.h" #include "keymap_korean.h" #include "keymap_bepo.h" #include "keymap_italian.h" #include "keymap_slovenian.h" #include "keymap_lithuanian_azerty.h" #include "keymap_danish.h" #include "keymap_norwegian.h" #include "keymap_portuguese.h" #include "keymap_contributions.h" #include "keymap_czech.h" #include "keymap_romanian.h" #include "keymap_russian.h" #include "keymap_uk.h" #include "keymap_estonian.h" #include "keymap_belgian.h" #include "keymap_us_international.h" #define KC_MAC_UNDO LGUI(KC_Z) #define KC_MAC_CUT LGUI(KC_X) #define KC_MAC_COPY LGUI(KC_C) #define KC_MAC_PASTE LGUI(KC_V) #define KC_PC_UNDO LCTL(KC_Z) #define KC_PC_CUT LCTL(KC_X) #define KC_PC_COPY LCTL(KC_C) #define KC_PC_PASTE LCTL(KC_V) #define ES_LESS_MAC KC_GRAVE #define ES_GRTR_MAC LSFT(KC_GRAVE) #define ES_BSLS_MAC ALGR(KC_6) #define NO_PIPE_ALT KC_GRAVE #define NO_BSLS_ALT KC_EQUAL #define LSA_T(kc) MT(MOD_LSFT | MOD_LALT, kc) #define BP_NDSH_MAC ALGR(KC_8) enum custom_keycodes { RGB_SLD = EZ_SAFE_RANGE, HSV_172_255_255, HSV_86_255_128, HSV_27_255_255, NS_0, NS_1, NS_2, NS_3, NS_4, NS_5, NS_6, NS_7, NS_8, NS_9, NS_GRAVE, }; const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { [0] = LAYOUT_ergodox_pretty( KC_AMPR, KC_LBRACKET, KC_LCBR, KC_RCBR, KC_LPRN, KC_EQUAL, KC_TRANSPARENT, KC_TRANSPARENT, KC_ASTR, KC_RPRN, KC_PLUS, KC_RBRACKET, KC_EXLM, KC_HASH, KC_TAB, KC_SCOLON, KC_COMMA, KC_DOT, KC_P, KC_Y, KC_TRANSPARENT, RESET, KC_F, KC_G, KC_C, KC_R, KC_L, KC_SLASH, KC_BSPACE, KC_A, KC_O, KC_E, KC_U, KC_I, KC_D, KC_H, KC_T, KC_N, KC_S, KC_MINUS, LM(1, MOD_LSFT), KC_QUOTE, KC_Q, KC_J, KC_K, KC_X, KC_TRANSPARENT, TG(2), KC_B, KC_M, KC_W, KC_V, KC_Z, KC_BSLASH, KC_RGUI, MO(3), KC_DLR, KC_LALT, KC_LGUI, KC_AT, KC_LEFT, KC_DOWN, KC_UP, KC_RIGHT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_HOME, KC_PGUP, LCTL_T(KC_ESCAPE),KC_DELETE, KC_END, KC_PGDOWN, KC_ENTER, KC_SPACE ), [1] = LAYOUT_ergodox_pretty( KC_PERC, NS_7, NS_5, NS_3, NS_1, NS_9, KC_TRANSPARENT, KC_TRANSPARENT, NS_0, NS_2, NS_4, NS_6, NS_8, NS_GRAVE, LSFT(KC_TAB), KC_COLN, KC_LABK, KC_RABK, LSFT(KC_P), LSFT(KC_Y), KC_TRANSPARENT, KC_TRANSPARENT, LSFT(KC_F), LSFT(KC_G), LSFT(KC_C), LSFT(KC_R), LSFT(KC_L), KC_QUES, LSFT(KC_BSPACE),LSFT(KC_A), LSFT(KC_O), LSFT(KC_E), LSFT(KC_U), LSFT(KC_I), LSFT(KC_D), LSFT(KC_H), LSFT(KC_T), LSFT(KC_N), LSFT(KC_S), KC_UNDS, KC_TRANSPARENT, KC_DQUO, LSFT(KC_Q), LSFT(KC_J), LSFT(KC_K), LSFT(KC_X), KC_TRANSPARENT, KC_TRANSPARENT, LSFT(KC_B), LSFT(KC_M), LSFT(KC_W), LSFT(KC_V), LSFT(KC_Z), KC_PIPE, KC_TRANSPARENT, KC_TRANSPARENT, KC_TILD, LSFT(KC_LALT), LSFT(KC_LGUI), KC_CIRC, LSFT(KC_LEFT), LSFT(KC_DOWN), LSFT(KC_UP), LSFT(KC_RIGHT), KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, LSFT(KC_HOME), LSFT(KC_PGUP), LCTL_T(KC_ESCAPE),LSFT(KC_DELETE),LSFT(KC_END), LSFT(KC_PGDOWN),LSFT(KC_ENTER), LSFT(KC_SPACE) ), [2] = LAYOUT_ergodox_pretty( KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_8, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_LSHIFT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_9, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_LCTRL, KC_TRANSPARENT, KC_LGUI, KC_TRANSPARENT, KC_SPACE, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_ESCAPE, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT ), [3] = LAYOUT_ergodox_pretty( KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_TRANSPARENT, KC_TRANSPARENT, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_7, KC_8, KC_9, KC_PLUS, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_4, KC_5, KC_6, KC_MINUS, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_1, KC_2, KC_3, KC_ASTR, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_TRANSPARENT, KC_DOT, KC_0, KC_EQUAL, KC_SLASH, KC_TRANSPARENT, RGB_MOD, HSV_172_255_255,KC_MEDIA_PREV_TRACK,KC_MEDIA_NEXT_TRACK, HSV_86_255_128, KC_AUDIO_VOL_UP, KC_TRANSPARENT, RGB_VAI, HSV_27_255_255, KC_AUDIO_VOL_DOWN,KC_AUDIO_MUTE, KC_MEDIA_PLAY_PAUSE ), }; bool activate(uint16_t keycode, keyrecord_t *record) { static uint16_t registered; uint8_t mod_state = get_mods(); if (record->event.pressed) { // Detect the activation of either shift keys if (mod_state & MOD_MASK_SHIFT) { if (registered) unregister_code(registered); // First temporarily canceling both shifts so that // shift isn't applied to the KC_DEL keycode del_mods(MOD_MASK_SHIFT); register_code(keycode); // Update the boolean variable to reflect the status of KC_DEL registered = keycode; // Reapplying modifier state so that the held shift key(s) // still work even after having tapped the Backspace/Delete key. set_mods(mod_state); return false; } } else { // on release of KC_BSPC // In case KC_DEL is still being sent even after the release of KC_BSPC if (registered) { unregister_code(registered); registered = 0; return false; } } // Let QMK process the KC_BSPC keycode as usual outside of shift return true; } // Initialize variable holding the binary // representation of active modifiers. bool process_record_user(uint16_t keycode, keyrecord_t *record) { // Store the current modifier state in the variable for later reference switch (keycode) { case NS_0: return activate(KC_0, record); case NS_1: return activate(KC_1, record); case NS_2: return activate(KC_2, record); case NS_3: return activate(KC_3, record); case NS_4: return activate(KC_4, record); case NS_5: return activate(KC_5, record); case NS_6: return activate(KC_6, record); case NS_7: return activate(KC_7, record); case NS_8: return activate(KC_8, record); case NS_9: return activate(KC_9, record); case NS_GRAVE: return activate(KC_GRAVE, record); } return true; } uint32_t layer_state_set_user(uint32_t state) { uint8_t layer = biton32(state); ergodox_board_led_off(); ergodox_right_led_1_off(); ergodox_right_led_2_off(); ergodox_right_led_3_off(); switch (layer) { case 1: ergodox_right_led_1_on(); break; case 2: ergodox_right_led_2_on(); break; case 3: ergodox_right_led_3_on(); break; case 4: ergodox_right_led_1_on(); ergodox_right_led_2_on(); break; case 5: ergodox_right_led_1_on(); ergodox_right_led_3_on(); break; case 6: ergodox_right_led_2_on(); ergodox_right_led_3_on(); break; case 7: ergodox_right_led_1_on(); ergodox_right_led_2_on(); ergodox_right_led_3_on(); break; default: break; } return state; };