aboutsummaryrefslogtreecommitdiffstats
path: root/keyboards/ferris/keymaps/quotengrote
diff options
context:
space:
mode:
Diffstat (limited to 'keyboards/ferris/keymaps/quotengrote')
-rw-r--r--keyboards/ferris/keymaps/quotengrote/config.h68
-rw-r--r--keyboards/ferris/keymaps/quotengrote/keymap.c146
-rw-r--r--keyboards/ferris/keymaps/quotengrote/readme.md11
-rw-r--r--keyboards/ferris/keymaps/quotengrote/rules.mk11
4 files changed, 236 insertions, 0 deletions
diff --git a/keyboards/ferris/keymaps/quotengrote/config.h b/keyboards/ferris/keymaps/quotengrote/config.h
new file mode 100644
index 0000000000..cffa10de2e
--- /dev/null
+++ b/keyboards/ferris/keymaps/quotengrote/config.h
@@ -0,0 +1,68 @@
+// tap and hold
+#define TAPPING_TERM 175 //in milliseconds
+#define PERMISSIVE_HOLD
+// autoshift
+#define NO_AUTO_SHIFT_TAB
+#define NO_AUTO_SHIFT_NUMERIC
+#define NO_AUTO_SHIFT_ALPHA
+// Handedness
+// https://docs.qmk.fm/#/feature_split_keyboard?id=handedness-by-eeprom
+// https://www.reddit.com/r/ErgoMechKeyboards/comments/rcq6u9/just_finished_configuring_my_ferris_one_half_have/
+#define EE_HANDS
+// disable any LED modes
+#undef RGBLIGHT_ANIMATIONS
+#undef RGBLIGHT_EFFECT_BREATHING
+#undef RGBLIGHT_EFFECT_RAINBOW_MOOD
+#undef RGBLIGHT_EFFECT_RAINBOW_SWIRL
+#undef RGBLIGHT_EFFECT_SNAKE
+#undef RGBLIGHT_EFFECT_KNIGHT
+#undef RGBLIGHT_EFFECT_CHRISTMAS
+#undef RGBLIGHT_EFFECT_STATIC_GRADIENT
+#undef RGBLIGHT_EFFECT_RGB_TEST
+#undef RGBLIGHT_EFFECT_ALTERNATING
+#undef RGBLIGHT_EFFECT_TWINKLE
+#undef ENABLE_RGB_MATRIX_ALPHAS_MODS
+#undef ENABLE_RGB_MATRIX_GRADIENT_UP_DOWN
+#undef ENABLE_RGB_MATRIX_GRADIENT_LEFT_RIGHT
+#undef ENABLE_RGB_MATRIX_BREATHING
+#undef ENABLE_RGB_MATRIX_BAND_SAT
+#undef ENABLE_RGB_MATRIX_BAND_VAL
+#undef ENABLE_RGB_MATRIX_BAND_PINWHEEL_SAT
+#undef ENABLE_RGB_MATRIX_BAND_PINWHEEL_VAL
+#undef ENABLE_RGB_MATRIX_BAND_SPIRAL_SAT
+#undef ENABLE_RGB_MATRIX_BAND_SPIRAL_VAL
+#undef ENABLE_RGB_MATRIX_CYCLE_ALL
+#undef ENABLE_RGB_MATRIX_CYCLE_LEFT_RIGHT
+#undef ENABLE_RGB_MATRIX_CYCLE_UP_DOWN
+#undef ENABLE_RGB_MATRIX_RAINBOW_MOVING_CHEVRON
+#undef ENABLE_RGB_MATRIX_CYCLE_OUT_IN
+#undef ENABLE_RGB_MATRIX_CYCLE_OUT_IN_DUAL
+#undef ENABLE_RGB_MATRIX_CYCLE_PINWHEEL
+#undef ENABLE_RGB_MATRIX_CYCLE_SPIRAL
+#undef ENABLE_RGB_MATRIX_DUAL_BEACON
+#undef ENABLE_RGB_MATRIX_RAINBOW_BEACON
+#undef ENABLE_RGB_MATRIX_RAINBOW_PINWHEELS
+#undef ENABLE_RGB_MATRIX_RAINDROPS
+#undef ENABLE_RGB_MATRIX_JELLYBEAN_RAINDROPS
+#undef ENABLE_RGB_MATRIX_HUE_BREATHING
+#undef ENABLE_RGB_MATRIX_HUE_PENDULUM
+#undef ENABLE_RGB_MATRIX_HUE_WAVE
+#undef ENABLE_RGB_MATRIX_PIXEL_FRACTAL
+#undef ENABLE_RGB_MATRIX_PIXEL_FLOW
+#undef ENABLE_RGB_MATRIX_PIXEL_RAIN
+
+#undef ENABLE_RGB_MATRIX_TYPING_HEATMAP
+#undef ENABLE_RGB_MATRIX_DIGITAL_RAIN
+
+#undef ENABLE_RGB_MATRIX_SOLID_REACTIVE_SIMPLE
+#undef ENABLE_RGB_MATRIX_SOLID_REACTIVE
+#undef ENABLE_RGB_MATRIX_SOLID_REACTIVE_WIDE
+#undef ENABLE_RGB_MATRIX_SOLID_REACTIVE_MULTIWIDE
+#undef ENABLE_RGB_MATRIX_SOLID_REACTIVE_CROSS
+#undef ENABLE_RGB_MATRIX_SOLID_REACTIVE_MULTICROSS
+#undef ENABLE_RGB_MATRIX_SOLID_REACTIVE_NEXUS
+#undef ENABLE_RGB_MATRIX_SOLID_REACTIVE_MULTINEXUS
+#undef ENABLE_RGB_MATRIX_SPLASH
+#undef ENABLE_RGB_MATRIX_MULTISPLASH
+#undef ENABLE_RGB_MATRIX_SOLID_SPLASH
+#undef ENABLE_RGB_MATRIX_SOLID_MULTISPLASH
diff --git a/keyboards/ferris/keymaps/quotengrote/keymap.c b/keyboards/ferris/keymaps/quotengrote/keymap.c
new file mode 100644
index 0000000000..33d0b3ffc4
--- /dev/null
+++ b/keyboards/ferris/keymaps/quotengrote/keymap.c
@@ -0,0 +1,146 @@
+#include QMK_KEYBOARD_H
+#include "keymap_german.h"
+
+// layers
+enum layers {
+ _BASE,
+ _NUM,
+ _SYM,
+ _MOV,
+ _MEDIA
+};
+
+// combos; https://github.com/qmk/qmk_firmware/blob/master/docs/feature_combo.md
+enum combos {
+ C_ALT,
+ C_KA,
+ C_KK,
+ C_ESC,
+ C_MED,
+ C_SV, // Strg + S
+ C_WE // Windows Explorer
+};
+
+const uint16_t PROGMEM alt_combo[] = {LCTL_T(KC_E), KC_I, COMBO_END};
+const uint16_t PROGMEM ka_combo[] = {KC_R, LSFT_T(KC_T), COMBO_END};
+const uint16_t PROGMEM kk_combo[] = {LSFT_T(KC_N), KC_I, COMBO_END};
+const uint16_t PROGMEM esc_combo[] = {LCTL_T(KC_S), LSFT_T(KC_T), COMBO_END};
+const uint16_t PROGMEM med_combo[] = {LT(_MOV, KC_DEL), MO(_MOV), COMBO_END};
+const uint16_t PROGMEM sv_combo[] = {LCTL_T(KC_S), LT(_BASE,KC_C), COMBO_END};
+const uint16_t PROGMEM we_combo[] = {LT(_BASE,KC_W), LCTL_T(KC_E), COMBO_END};
+
+combo_t key_combos[] = {
+ [C_ALT] = COMBO(alt_combo, KC_LALT),
+ [C_KA] = COMBO(ka_combo, LCTL(LALT(KC_A))),
+ [C_KK] = COMBO(kk_combo, LCTL(LALT(KC_K))),
+ [C_ESC] = COMBO(esc_combo, KC_ESC),
+ [C_MED] = COMBO(med_combo, MO(_MEDIA)),
+ [C_SV] = COMBO(sv_combo, LCTL(KC_S)),
+ [C_WE] = COMBO(we_combo, LGUI(KC_E)),
+};
+
+// keymap
+const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
+ // white
+ [_BASE] = LAYOUT_split_3x5_2(
+ LT(_BASE,KC_Q), LT(_BASE,KC_W), LT(_BASE,KC_F), KC_P, KC_B, KC_J, KC_L, LT(_BASE,KC_U), DE_Z, KC_BSPC,
+ LT(_BASE,KC_A), KC_R, LCTL_T(KC_S), LSFT_T(KC_T), KC_G, KC_M, LSFT_T(KC_N), LCTL_T(KC_E), KC_I, LT(_BASE,KC_O),
+ LT(_BASE,DE_Y), LT(_BASE,KC_X), LT(_BASE,KC_C), LSFT_T(KC_D), LT(_BASE,KC_V), KC_K, LSFT_T(KC_H), DE_COMM, DE_DOT, DE_MINS,
+ LT(_MOV, KC_DEL), LT(_SYM, KC_ENT), LT(_NUM, KC_SPC), MO(_MOV)
+ ),
+ // orange
+ [_NUM] = LAYOUT_split_3x5_2(
+ KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_BSPC,
+ KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0,
+ QK_CAPS_WORD_TOGGLE, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, KC_F10, KC_F11, _______, _______, KC_F12,
+ _______, _______, _______, _______
+ ),
+ // blue
+ [_SYM] = LAYOUT_split_3x5_2(
+ DE_CIRC, DE_LBRC, DE_LPRN, DE_LPRN, DE_SECT, DE_PERC, DE_RCBR, DE_RPRN, DE_RBRC, KC_BSPC,
+ DE_EXLM, DE_DQUO, DE_SS, DE_QUOT, DE_SLSH, RALT(DE_SS), DE_DLR, DE_AMPR, DE_ASTR, DE_QUES,
+ DE_TILD, DE_ACUT, XXXXXXX, LSFT(DE_ACUT), DE_LABK , DE_RABK , XXXXXXX, DE_PLUS, DE_EQL, DE_HASH,
+ _______, _______, _______, _______
+ ),
+ // green
+ [_MOV] = LAYOUT_split_3x5_2(
+ XXXXXXX, KC_HOME, KC_UP, KC_PGUP, XXXXXXX, XXXXXXX, KC_PGUP, KC_UP, KC_HOME, KC_BSPC,
+ KC_TAB, KC_LEFT, KC_DOWN, KC_RIGHT, XXXXXXX, XXXXXXX, KC_LEFT, KC_DOWN, KC_RIGHT, KC_DEL,
+ XXXXXXX, KC_END, KC_PGDN, XXXXXXX, XXXXXXX, XXXXXXX, KC_PGDN, XXXXXXX, KC_END, XXXXXXX,
+ _______, _______, _______, _______
+ ),
+ // yellow
+ [_MEDIA] = LAYOUT_split_3x5_2(
+ RGB_TOG, RGB_HUI, RGB_HUD, KC_PSCR, KC_VOLU, KC_VOLU, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX,
+ RGB_MOD, RGB_SAI, RGB_SAD, XXXXXXX, KC_MUTE, KC_MUTE, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX,
+ RGB_RMOD, RGB_VAI, RGB_VAD, KC_MPLY, KC_VOLD, KC_VOLD, KC_MPLY, XXXXXXX, XXXXXXX, XXXXXXX,
+ _______, _______, _______, _______
+ )
+};
+// https://github.com/qmk/qmk_firmware/blob/master/docs/mod_tap.md#changing-hold-function
+bool process_record_user(uint16_t keycode, keyrecord_t *record) {
+ switch (keycode) {
+ // "Tap and Hold"
+ case LT(_BASE,KC_X): // "LT(_BASE,KC_X)" is the keycode that must be mapped
+ if (!record->tap.count && record->event.pressed) {
+ tap_code16(LCTL(KC_X)); // Intercept hold function to send Ctrl-X
+ return false;
+ }
+ return true; // Return true for normal processing of tap keycode
+ case LT(_BASE,DE_Y):
+ if (!record->tap.count && record->event.pressed) {
+ tap_code16(DE_PIPE);
+ return false;
+ }
+ return true;
+ case LT(_BASE,KC_C):
+ if (!record->tap.count && record->event.pressed) {
+ tap_code16(LCTL(KC_C));
+ return false;
+ }
+ return true;
+ case LT(_BASE,KC_V):
+ if (!record->tap.count && record->event.pressed) {
+ tap_code16(LCTL(KC_V));
+ return false;
+ }
+ return true;
+ case LT(_BASE,KC_Q):
+ if (!record->tap.count && record->event.pressed) {
+ tap_code16(RALT(KC_Q));
+ return false;
+ }
+ return true;
+ case LT(_BASE,KC_F):
+ if (!record->tap.count && record->event.pressed) {
+ tap_code16(RALT(KC_E));
+ return false;
+ }
+ return true;
+ case LT(_BASE,KC_A):
+ if (!record->tap.count && record->event.pressed) {
+ tap_code16(DE_ADIA);
+ return false;
+ }
+ return true;
+ case LT(_BASE,KC_O):
+ if (!record->tap.count && record->event.pressed) {
+ tap_code16(DE_ODIA);
+ return false;
+ }
+ return true;
+ case LT(_BASE,KC_U):
+ if (!record->tap.count && record->event.pressed) {
+ tap_code16(DE_UDIA);
+ return false;
+ }
+ return true;
+ case LT(_BASE,KC_W):
+ if (!record->tap.count && record->event.pressed) {
+ tap_code16(KC_LGUI);
+ return false;
+ }
+ return true;
+ }
+ return true;
+}
diff --git a/keyboards/ferris/keymaps/quotengrote/readme.md b/keyboards/ferris/keymaps/quotengrote/readme.md
new file mode 100644
index 0000000000..2de8880600
--- /dev/null
+++ b/keyboards/ferris/keymaps/quotengrote/readme.md
@@ -0,0 +1,11 @@
+# Readme
+
+## Compiling
+
+`qmk compile -kb ferris/sweep -km quotengrote`
+
+## Flashing
+
+1. Reset-Button
+2. QMK-Toolbox
+3. Wiederholen auf der anderen Seite
diff --git a/keyboards/ferris/keymaps/quotengrote/rules.mk b/keyboards/ferris/keymaps/quotengrote/rules.mk
new file mode 100644
index 0000000000..b782fad97e
--- /dev/null
+++ b/keyboards/ferris/keymaps/quotengrote/rules.mk
@@ -0,0 +1,11 @@
+CAPS_WORD_ENABLE = yes
+AUTO_SHIFT_ENABLE = yes
+COMBO_ENABLE = yes
+# Optimizing build size
+# https://docs.qmk.fm/#/squeezing_avr?id=squeezing-the-most-out-of-avr
+LTO_ENABLE = yes
+CONSOLE_ENABLE = no
+MUSIC_ENABLE = no
+SPACE_CADET_ENABLE = no
+GRAVE_ESC_ENABLE = no
+COMMAND_ENABLE = no