aboutsummaryrefslogtreecommitdiffstats
path: root/keyboards/ckeys/handwire_101/keymaps
diff options
context:
space:
mode:
authorGravatar Branden Byers <branden@brandenbyers.com>2019-01-15 14:06:35 -0800
committerGravatar Drashna Jaelre <drashna@live.com>2019-01-15 14:06:35 -0800
commit57fbf072f145bcf560c812a7976ba0f4f702f946 (patch)
treeffd44617d8bc13971bc1db0199865a264ed74cac /keyboards/ckeys/handwire_101/keymaps
parentc768ffeb33e8635f1ef6fa46928a5b992ee8aae9 (diff)
downloadqmk_firmware-57fbf072f145bcf560c812a7976ba0f4f702f946.tar.gz
[Keyboard] Add cKeys Handwire 101 Keyboard (#4848)
* Update general README * Add handwire_101 * Update keyboards/ckeys/handwire_101/keymaps/default/keymap.c Co-Authored-By: brandenbyers <branden@brandenbyers.com> * Use Pragma once Co-Authored-By: brandenbyers <branden@brandenbyers.com> * Update keyboards/ckeys/handwire_101/config.h Co-Authored-By: brandenbyers <branden@brandenbyers.com> * Update keyboards/ckeys/handwire_101/config.h Co-Authored-By: brandenbyers <branden@brandenbyers.com> * Update keyboards/ckeys/handwire_101/handwire_101.h Co-Authored-By: brandenbyers <branden@brandenbyers.com> * Update keyboards/ckeys/handwire_101/handwire_101.h Co-Authored-By: brandenbyers <branden@brandenbyers.com> * Update keyboards/ckeys/handwire_101/keymaps/default/keymap.c Co-Authored-By: brandenbyers <branden@brandenbyers.com> * Update keyboards/ckeys/handwire_101/keymaps/default/keymap.c Co-Authored-By: brandenbyers <branden@brandenbyers.com> * Update keyboards/ckeys/handwire_101/keymaps/default/keymap.c Co-Authored-By: brandenbyers <branden@brandenbyers.com> * Update keyboards/ckeys/handwire_101/keymaps/default/keymap.c Co-Authored-By: brandenbyers <branden@brandenbyers.com> * Change KEYMAP to LAYOUT and remove endif * Apply suggestions from code review Co-Authored-By: brandenbyers <branden@brandenbyers.com> * Move layers to enum and remove KC_TRNS
Diffstat (limited to 'keyboards/ckeys/handwire_101/keymaps')
-rwxr-xr-xkeyboards/ckeys/handwire_101/keymaps/default/config.h3
-rwxr-xr-xkeyboards/ckeys/handwire_101/keymaps/default/keymap.c178
-rwxr-xr-xkeyboards/ckeys/handwire_101/keymaps/default/readme.md1
3 files changed, 182 insertions, 0 deletions
diff --git a/keyboards/ckeys/handwire_101/keymaps/default/config.h b/keyboards/ckeys/handwire_101/keymaps/default/config.h
new file mode 100755
index 000000000..9935accb0
--- /dev/null
+++ b/keyboards/ckeys/handwire_101/keymaps/default/config.h
@@ -0,0 +1,3 @@
+#pragma once
+
+// Add overrides here
diff --git a/keyboards/ckeys/handwire_101/keymaps/default/keymap.c b/keyboards/ckeys/handwire_101/keymaps/default/keymap.c
new file mode 100755
index 000000000..383b3355d
--- /dev/null
+++ b/keyboards/ckeys/handwire_101/keymaps/default/keymap.c
@@ -0,0 +1,178 @@
+#include QMK_KEYBOARD_H
+
+enum layers {
+ _BASE, // base layer
+ _LAYERS, // layer of all layers
+ _MUSIC, // music mode
+ _MUSIC_4_LIFE, // music mode until unplugged
+ _MOUSE, // mousekeys
+ _TERMINAL, // terminal
+ _ADMIN // admin duties
+};
+
+enum custom_keycodes {
+ TERM_ABOUT = SAFE_RANGE,
+ TERM_PRINT,
+ TERM_FLUSH,
+ TERM_HELP,
+ CKEYS_ABOUT,
+};
+
+extern keymap_config_t keymap_config;
+
+const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
+ /* BASE (numpad)
+ * ,-----------------------.
+ * | 7 | 8 | 9 | / | <-- Hold for LAYERS
+ * |-----+-----+-----+-----|
+ * | 4 | 5 | 6 | * |
+ * |-----+-----+-----+-----|
+ * | 1 | 2 | 3 | - |
+ * |-----+-----+-----+-----|
+ * | 0 | . | = | + |
+ * `---------------------- '
+ */
+ [_BASE] = LAYOUT(
+ KC_KP_7, KC_KP_8, KC_KP_9, LT(MO(_LAYERS), KC_PSLS), \
+ KC_KP_4, KC_KP_5, KC_KP_6, KC_PAST, \
+ KC_KP_1, KC_KP_2, KC_KP_3, KC_PMNS, \
+ KC_KP_0, KC_KP_DOT, KC_KP_EQUAL, KC_PPLS \
+ ),
+ /* LAYERS
+ * ,---------------------------.
+ * | MUSIC | | | X |
+ * |---------+-----+-----+-----|
+ * | MOUSE | | | |
+ * |---------+-----+-----+-----|
+ * |TERMINAL | | | |
+ * |---------+-----+-----+-----|
+ * | ADMIN | | | |
+ * `---------------------------'
+ */
+ [_LAYERS] = LAYOUT(
+ TG(_MUSIC), _______, _______, _______, \
+ TG(_MOUSE), _______, _______, _______, \
+ TG(_TERMINAL), _______, _______, _______, \
+ TG(_ADMIN), _______, _______, _______\
+ ),
+ /* MUSIC
+ * ,-----------------------.
+ * | X | | | X |
+ * |-----+-----+-----+-----|
+ * | | | |4EVER|
+ * |-----+-----+-----+-----|
+ * | OFF | | | |
+ * |-----+-----+-----+-----|
+ * | ON | | |MODES|
+ * `---------------------- '
+ */
+ // TODO: Make this music layer the one to jump to other music layers (different octaves)
+ [_MUSIC] = LAYOUT(
+ _______, _______, _______, _______, \
+ _______, _______, _______, TG(_MUSIC_4_LIFE), \
+ MU_OFF, _______, _______, _______, \
+ MU_ON, _______, _______, MU_MOD \
+ ),
+ /* MUSIC_4_LIFE
+ * ,-----------------------.
+ * | ♫ | ♫ | ♫ | ♫ |
+ * |-----+-----+-----+-----|
+ * | ♫ | ♫ | ♫ | ♫ |
+ * |-----+-----+-----+-----|
+ * | ♫ | ♫ | ♫ | ♫ |
+ * |-----+-----+-----+-----|
+ * | ♫ | ♫ | ♫ | ♫ |
+ * `---------------------- '
+ */
+ [_MUSIC_4_LIFE] = LAYOUT(
+ KC_M, KC_M, KC_M, KC_M, \
+ KC_M, KC_M, KC_M, KC_M, \
+ KC_M, KC_M, KC_M, KC_M, \
+ KC_M, KC_M, KC_M, KC_M \
+ ),
+ /* MOUSE
+ * ,-------------------------------------------------.
+ * | BUTTON 5 | | SCROLL UP | X |
+ * |-----------+-----------+------------+------------|
+ * | X |LEFT CLICK | UP |RIGHT CLICK |
+ * |-----------+-----------+------------+------------|
+ * | BUTTON 4 | LEFT | DOWN | RIGHT |
+ * |-----------+-----------+------------+------=-----|
+ * | BUTTON 3 |SCROLL LEFT|SCROLL DOWN |SCROLL RIGHT|
+ * `-------------------------------------------------'
+ */
+ [_MOUSE] = LAYOUT(
+ KC_MS_BTN5, _______, KC_MS_WH_UP, _______, \
+ _______, KC_MS_BTN1, KC_MS_UP, KC_MS_BTN2, \
+ KC_MS_BTN4, KC_MS_LEFT, KC_MS_DOWN, KC_MS_RIGHT, \
+ KC_MS_BTN3, KC_MS_WH_LEFT, KC_MS_WH_DOWN, KC_MS_WH_RIGHT \
+ ),
+ /* TERMINAL
+ * ,---------------------------------------.
+ * | |ABOUT| | X |
+ * |------------+-----+----------+---------|
+ * |TERMINAL OFF|PRINT| | |
+ * |------------+-----+----------+---------|
+ * | X |FLUSH| | |
+ * |------------+-----+----------+---------|
+ * |TERMINAL ON |HELP | | |
+ * `--------=======------------------------'
+ */
+ [_TERMINAL] = LAYOUT(
+ _______, TERM_ABOUT, _______, _______, \
+ TERM_OFF, TERM_PRINT, _______, _______, \
+ _______, TERM_FLUSH, _______, _______, \
+ TERM_ON, TERM_HELP , _______, _______\
+ ),
+ /* ADMIN
+ * ,-----------------------------------------.
+ * | RESET | | | X |
+ * |------------+-----+-----------+----------|
+ * |ABOUT CKEYS | | | |
+ * |------------+-----+-----------+----------|
+ * | | |CLICKY UP |CLICKY OFF|
+ * |------------+-----+-----------+----------|
+ * | X | |CLICKY DOWN|CLICKY ON |
+ * `-----------------------------------------'
+ */
+ [_ADMIN] = LAYOUT(
+ RESET, _______, _______, _______, \
+ CKEYS_ABOUT, _______, _______, _______, \
+ _______, _______, _______, CK_OFF, \
+ _______, _______, _______, CK_ON \
+ ),
+};
+
+bool process_record_user(uint16_t keycode, keyrecord_t *record) {
+ switch (keycode) {
+ case TERM_ABOUT:
+ if (record->event.pressed) {
+ // when keycode TERM_ABOUT is pressed
+ SEND_STRING("about"SS_TAP(X_ENTER));
+ } else {
+ // when keycode TERM_ABOUT is released
+ }
+ break;
+ case TERM_PRINT:
+ if (record->event.pressed) {
+ SEND_STRING("print"SS_TAP(X_ENTER));
+ } else { }
+ break;
+ case TERM_FLUSH:
+ if (record->event.pressed) {
+ SEND_STRING("flush"SS_TAP(X_ENTER));
+ } else { }
+ break;
+ case TERM_HELP:
+ if (record->event.pressed) {
+ SEND_STRING("help"SS_TAP(X_ENTER));
+ } else { }
+ break;
+ case CKEYS_ABOUT:
+ if (record->event.pressed) {
+ SEND_STRING("https://cKeys.org"SS_TAP(X_ENTER)"Making people smile one keyboard at a time."SS_TAP(X_ENTER)"cKeys is a volunteer-run 501(c)(3) nonprofit organization."SS_TAP(X_ENTER));
+ } else { }
+ break;
+ }
+ return true;
+};
diff --git a/keyboards/ckeys/handwire_101/keymaps/default/readme.md b/keyboards/ckeys/handwire_101/keymaps/default/readme.md
new file mode 100755
index 000000000..4594bdfe3
--- /dev/null
+++ b/keyboards/ckeys/handwire_101/keymaps/default/readme.md
@@ -0,0 +1 @@
+# The default keymap for the cKeys Handwire 101 4x4 keyboard. \ No newline at end of file