From f056360378b4fa82f69cce75fb978212e93e6aa6 Mon Sep 17 00:00:00 2001 From: "A. Hassan" Date: Tue, 22 Apr 2025 08:43:31 +0700 Subject: [PATCH] feat: initialize keymap --- keyboards/.keep | 0 keyboards/sofle/keymaps/hasssan/config.h | 11 ++ keyboards/sofle/keymaps/hasssan/keymap.c | 171 ++++++++++++++++++++++ keyboards/sofle/keymaps/hasssan/readme.md | 15 ++ keyboards/sofle/keymaps/hasssan/rules.mk | 7 + 5 files changed, 204 insertions(+) delete mode 100644 keyboards/.keep create mode 100644 keyboards/sofle/keymaps/hasssan/config.h create mode 100644 keyboards/sofle/keymaps/hasssan/keymap.c create mode 100644 keyboards/sofle/keymaps/hasssan/readme.md create mode 100644 keyboards/sofle/keymaps/hasssan/rules.mk diff --git a/keyboards/.keep b/keyboards/.keep deleted file mode 100644 index e69de29b..00000000 diff --git a/keyboards/sofle/keymaps/hasssan/config.h b/keyboards/sofle/keymaps/hasssan/config.h new file mode 100644 index 00000000..59d3d3f0 --- /dev/null +++ b/keyboards/sofle/keymaps/hasssan/config.h @@ -0,0 +1,11 @@ +// Copyright 2024 Santosh Kumar (@santosh) +// SPDX-License-Identifier: GPL-2.0-or-later + +#pragma once + +#define TRI_LAYER_LOWER_LAYER 2 +#define TRI_LAYER_UPPER_LAYER 3 +#define TRI_LAYER_ADJUST_LAYER 4 + +#define TAPPING_TERM 175 +#define TAPPING_TERM_PER_KEY diff --git a/keyboards/sofle/keymaps/hasssan/keymap.c b/keyboards/sofle/keymaps/hasssan/keymap.c new file mode 100644 index 00000000..68a0d89c --- /dev/null +++ b/keyboards/sofle/keymaps/hasssan/keymap.c @@ -0,0 +1,171 @@ +// Copyright 2023 QMK +// SPDX-License-Identifier: GPL-2.0-or-later +#include QMK_KEYBOARD_H + +enum sofle_layers { + /* _M_XYZ = Mac Os, _W_XYZ = Win/Linux */ + _BASE, + _LOWER, + _RAISE, +}; + +enum custom_keycodes { + KC_PRVWD = QK_USER, + KC_NXTWD, + KC_LSTRT, + KC_LEND +}; + +const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { +/* + * Hands Down Promethium (Inverted) + * ,-----------------------------------------. ,-----------------------------------------. + * | ` | 1 | 2 | 3 | 4 | 5 | | 6 | 7 | 8 | 9 | 0 | - | + * |------+------+------+------+------+------| |------+------+------+------+------+------| + * | Tab | V | W | G | M | J | | ; | . | ' | = | / | Z | + * |------+------+------+------+------+------| |------+------+------+------+------+------| + * | ESC | S | N | T | H | K |-------. ,-------| , | A | E | I | C | Q | + * |------+------+------+------+------+------| MUTE | | |------+------+------+------+------+------| + * |LShift| F | P | D | L | X |-------| |-------| - | U | O | Y | B |ENTER | + * `-----------------------------------------/ / \ \-----------------------------------------' + * | LGUI | LAlt | R | SPC | / LOWER / \ RAISE \ |BKSPC | RCTR | RAlt | RGUI | + * | | | | |/ / \ \ | | | | | + * `----------------------------------' '------''---------------------------' + */ + +[_BASE] = LAYOUT( + KC_GRV, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS, + KC_TAB, KC_V, KC_W, KC_G, KC_M, KC_J, KC_SCLN, KC_DOT, KC_QUOT, KC_EQL, KC_SLSH, KC_Z, + KC_ESC, KC_S, KC_N, KC_T, KC_H, KC_K, KC_COMM, KC_A, KC_E, KC_I, KC_C, KC_Q, + KC_LSFT, KC_F, KC_P, KC_D, KC_L, KC_X, KC_MUTE, XXXXXXX,KC_MINS, KC_U, KC_O, KC_Y, KC_B, KC_ENT, + KC_LGUI,KC_LALT, KC_R, KC_SPC, MO(_LOWER), LT(_RAISE, KC_ENT), KC_BSPC, KC_RCTL, KC_RALT, KC_RGUI +), +/* LOWER + * ,-----------------------------------------. ,-----------------------------------------. + * | | F1 | F2 | F3 | F4 | F5 | | F6 | F7 | F8 | F9 | F10 | F11 | + * |------+------+------+------+------+------| |------+------+------+------+------+------| + * | ` | ' | < | > | " | . | | & | :: | [ | ] | % | F12 | + * |------+------+------+------+------+------| |------+------+------+------+------+------| + * | Tab | ! | - | + | = | # |-------. ,-------| | | : | ( | ) | ? | | | + * |------+------+------+------+------+------| MUTE | | |------+------+------+------+------+------| + * | Shift| ^ | / | * | \ | ../ |-------| |-------| ~ | $ | { | } | @ | Shift| + * `-----------------------------------------/ / \ \-----------------------------------------' + * | LGUI | LAlt | LCTR |LOWER | /Enter / \Space \ |RAISE | RCTR | RAlt | RGUI | + * | | | | |/ / \ \ | | | | | + * `----------------------------------' '------''---------------------------' + */ +[_LOWER] = LAYOUT( + _______, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_F12, + _______, KC_QUOT, KC_LT, KC_GT, KC_DQT, KC_DOT, KC_AMPR, KC_COLN, KC_LBRC, KC_RBRC, KC_PERC, _______, + _______, KC_EXLM, KC_MINS, KC_PLUS, KC_EQL, KC_HASH, KC_PIPE, KC_COLN, KC_LPRN, KC_RPRN, KC_QUES, _______, + _______, KC_CIRC, KC_SLSH, KC_ASTR, KC_BSLS, _______, _______, _______, KC_TILD, KC_DLR, KC_LCBR, KC_RCBR,KC_AT, _______, + _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ +), +/* RAISE + * ,----------------------------------------. ,-----------------------------------------. + * | | | | | | | | | | | | | | + * |------+------+------+------+------+------| |------+------+------+------+------+------| + * | Esc | Ins | Pscr | Menu | | | | | PWrd | Up | NWrd | DLine| Bspc | + * |------+------+------+------+------+------| |------+------+------+------+------+------| + * | Tab | LAt | LCtl |LShift| | Caps |-------. ,-------| | Left | Down | Rigth| Del | Bspc | + * |------+------+------+------+------+------| MUTE | | |------+------+------+------+------+------| + * |Shift | Undo | Cut | Copy | Paste| |-------| |-------| | LStr | | LEnd | | Shift| + * `-----------------------------------------/ / \ \-----------------------------------------' + * | LGUI | LAlt | LCTR |LOWER | /Enter / \Space \ |RAISE | RCTR | RAlt | RGUI | + * | | | | |/ / \ \ | | | | | + * `----------------------------------' '------''---------------------------' + */ +[_RAISE] = LAYOUT( + _______, _______ , _______ , _______ , _______ , _______, _______, _______ , _______, _______ , _______ ,_______, + _______, KC_INS, KC_PSCR, KC_APP, XXXXXXX, XXXXXXX, KC_PGUP, KC_PRVWD, KC_UP, KC_NXTWD,C(KC_BSPC), KC_BSPC, + _______, KC_LALT, KC_LCTL, KC_LSFT, XXXXXXX, KC_CAPS, KC_PGDN, KC_LEFT, KC_DOWN, KC_RGHT, KC_DEL, KC_BSPC, + _______, C(KC_Z), C(KC_X), C(KC_C), C(KC_V), XXXXXXX, _______, _______, XXXXXXX, KC_LSTRT, XXXXXXX, KC_LEND, XXXXXXX, _______, + _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ +) +}; + +bool process_record_user(uint16_t keycode, keyrecord_t *record) { + switch (keycode) { + case KC_PRVWD: + if (record->event.pressed) { + if (keymap_config.swap_lctl_lgui) { + register_mods(mod_config(MOD_LALT)); + register_code(KC_LEFT); + } else { + register_mods(mod_config(MOD_LCTL)); + register_code(KC_LEFT); + } + } else { + if (keymap_config.swap_lctl_lgui) { + unregister_mods(mod_config(MOD_LALT)); + unregister_code(KC_LEFT); + } else { + unregister_mods(mod_config(MOD_LCTL)); + unregister_code(KC_LEFT); + } + } + break; + case KC_NXTWD: + if (record->event.pressed) { + if (keymap_config.swap_lctl_lgui) { + register_mods(mod_config(MOD_LALT)); + register_code(KC_RIGHT); + } else { + register_mods(mod_config(MOD_LCTL)); + register_code(KC_RIGHT); + } + } else { + if (keymap_config.swap_lctl_lgui) { + unregister_mods(mod_config(MOD_LALT)); + unregister_code(KC_RIGHT); + } else { + unregister_mods(mod_config(MOD_LCTL)); + unregister_code(KC_RIGHT); + } + } + break; + case KC_LSTRT: + if (record->event.pressed) { + if (keymap_config.swap_lctl_lgui) { + //CMD-arrow on Mac, but we have CTL and GUI swapped + register_mods(mod_config(MOD_LCTL)); + register_code(KC_LEFT); + } else { + register_code(KC_HOME); + } + } else { + if (keymap_config.swap_lctl_lgui) { + unregister_mods(mod_config(MOD_LCTL)); + unregister_code(KC_LEFT); + } else { + unregister_code(KC_HOME); + } + } + break; + case KC_LEND: + if (record->event.pressed) { + if (keymap_config.swap_lctl_lgui) { + //CMD-arrow on Mac, but we have CTL and GUI swapped + register_mods(mod_config(MOD_LCTL)); + register_code(KC_RIGHT); + } else { + register_code(KC_END); + } + } else { + if (keymap_config.swap_lctl_lgui) { + unregister_mods(mod_config(MOD_LCTL)); + unregister_code(KC_RIGHT); + } else { + unregister_code(KC_END); + } + } + break; + } + return true; +} + +const uint16_t PROGMEM encoder_map[][NUM_ENCODERS][2] = { + [0] = { ENCODER_CCW_CW(KC_VOLD, KC_VOLU), ENCODER_CCW_CW(MS_WHLU, MS_WHLD) }, + [1] = { ENCODER_CCW_CW(KC_VOLD, KC_VOLU), ENCODER_CCW_CW(MS_WHLU, MS_WHLD) }, + [2] = { ENCODER_CCW_CW(KC_VOLD, KC_VOLU), ENCODER_CCW_CW(MS_WHLU, MS_WHLD) }, +}; diff --git a/keyboards/sofle/keymaps/hasssan/readme.md b/keyboards/sofle/keymaps/hasssan/readme.md new file mode 100644 index 00000000..879513af --- /dev/null +++ b/keyboards/sofle/keymaps/hasssan/readme.md @@ -0,0 +1,15 @@ +![SofleKeyboard default keymap](https://i.imgur.com/MZxVvm9.png) +![SofleKeyboard adjust layer](https://i.imgur.com/f5sKy0I.png) + +# Default keymap for Sofle Keyboard + +Layout in [Keyboard Layout Editor](http://www.keyboard-layout-editor.com/#/gists/76efb423a46cbbea75465cb468eef7ff) and [adjust layer](http://www.keyboard-layout-editor.com/#/gists/4bcf66f922cfd54da20ba04905d56bd4) + +Features: + +- Symmetric modifiers (CMD/Super, Alt/Opt, Ctrl, Shift) +- Various modes, can be switched (using Adjust layer and the selected one is stored in EEPROM. +- Modes for Qwerty and Colemak support +- Modes for Mac vs Linux/Win support -> different order of modifiers and different action shortcuts on the "UPPER" layer (the red one in the image). Designed to simplify transtions when switching between operating systems often. +- The OLED on master half shows selected mode and caps lock state and is rotated. +- Left encoder controls volume up/down/mute. Right encoder PGUP/PGDOWN. diff --git a/keyboards/sofle/keymaps/hasssan/rules.mk b/keyboards/sofle/keymaps/hasssan/rules.mk new file mode 100644 index 00000000..5cd5a08d --- /dev/null +++ b/keyboards/sofle/keymaps/hasssan/rules.mk @@ -0,0 +1,7 @@ +TRI_LAYER_ENABLE = yes +VIA_ENABLE = yes + +ENCODER_ENABLE = yes +ENCODER_MAP_ENABLE = yes + +# TAP_DANCE_ENABLE = yes