summaryrefslogtreecommitdiff
path: root/keyboards/winry/winry315/keymaps/default/keymap.c
diff options
context:
space:
mode:
Diffstat (limited to 'keyboards/winry/winry315/keymaps/default/keymap.c')
-rw-r--r--keyboards/winry/winry315/keymaps/default/keymap.c79
1 files changed, 79 insertions, 0 deletions
diff --git a/keyboards/winry/winry315/keymaps/default/keymap.c b/keyboards/winry/winry315/keymaps/default/keymap.c
new file mode 100644
index 0000000000..a0bc2706ca
--- /dev/null
+++ b/keyboards/winry/winry315/keymaps/default/keymap.c
@@ -0,0 +1,79 @@
+// Copyright 2022 Sergey Vlasov (@sigprof)
+// SPDX-License-Identifier: GPL-2.0-or-later
+
+#include QMK_KEYBOARD_H
+
+// Defines names for use in layer keycodes and the keymap
+enum layer_names {
+ _BASE,
+ _RGB,
+};
+
+// Shorter defines for some QMK keycodes (to keep the keymap aligned)
+#define U_LTESC LT(_RGB, KC_ESC)
+
+// clang-format off
+const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
+ // Base
+ [_BASE] = LAYOUT_top(
+ KC_HOME, KC_MUTE, KC_MPLY,
+ KC_1, KC_2, KC_3, KC_4, KC_5,
+ KC_6, KC_7, KC_8, KC_9, KC_0,
+ U_LTESC, KC_TAB, KC_SPC, KC_BSPC, KC_ENT
+ ),
+
+ // RGB configuration
+ [_RGB] = LAYOUT_top(
+ RGB_M_P, RGB_M_B, RGB_M_R,
+ RGB_MOD, RGB_HUI, RGB_SAI, RGB_VAI, RGB_SPI,
+ RGB_RMOD,RGB_HUD, RGB_SAD, RGB_VAD, RGB_SPD,
+ KC_TRNS, RGB_TOG, RGB_M_P, RGB_M_B, RGB_M_R
+ ),
+};
+// clang-format on
+
+bool encoder_update_user(uint8_t index, bool clockwise) {
+ uint8_t layer = get_highest_layer(layer_state | default_layer_state);
+
+ switch (index) {
+ case 0:
+ // Left encoder
+ if (layer == _RGB) {
+ if (clockwise) {
+ rgblight_increase_hue();
+ } else {
+ rgblight_decrease_hue();
+ }
+ } else {
+ tap_code(clockwise ? KC_PGDN : KC_PGUP);
+ }
+ break;
+
+ case 1:
+ // Center encoder
+ if (layer == _RGB) {
+ if (clockwise) {
+ rgblight_increase_sat();
+ } else {
+ rgblight_decrease_sat();
+ }
+ } else {
+ tap_code_delay(clockwise ? KC_VOLU : KC_VOLD, 10);
+ }
+ break;
+
+ case 2:
+ // Right encoder
+ if (layer == _RGB) {
+ if (clockwise) {
+ rgblight_increase_val();
+ } else {
+ rgblight_decrease_val();
+ }
+ } else {
+ tap_code_delay(clockwise ? KC_MNXT : KC_MPRV, 10);
+ }
+ break;
+ }
+ return false;
+}