summaryrefslogtreecommitdiff
path: root/keyboards/geekboards/macropad_v2/keymaps/via
diff options
context:
space:
mode:
Diffstat (limited to 'keyboards/geekboards/macropad_v2/keymaps/via')
-rw-r--r--keyboards/geekboards/macropad_v2/keymaps/via/config.h2
-rw-r--r--keyboards/geekboards/macropad_v2/keymaps/via/keymap.c83
-rw-r--r--keyboards/geekboards/macropad_v2/keymaps/via/readme.md3
-rw-r--r--keyboards/geekboards/macropad_v2/keymaps/via/rules.mk2
4 files changed, 90 insertions, 0 deletions
diff --git a/keyboards/geekboards/macropad_v2/keymaps/via/config.h b/keyboards/geekboards/macropad_v2/keymaps/via/config.h
new file mode 100644
index 0000000000..9d75edbe74
--- /dev/null
+++ b/keyboards/geekboards/macropad_v2/keymaps/via/config.h
@@ -0,0 +1,2 @@
+#define DYNAMIC_KEYMAP_LAYER_COUNT 4
+#define VIA_QMK_RGBLIGHT_ENABLE
diff --git a/keyboards/geekboards/macropad_v2/keymaps/via/keymap.c b/keyboards/geekboards/macropad_v2/keymaps/via/keymap.c
new file mode 100644
index 0000000000..6ca3402c3f
--- /dev/null
+++ b/keyboards/geekboards/macropad_v2/keymaps/via/keymap.c
@@ -0,0 +1,83 @@
+/* Copyright 2020 Geekboards ltd. (geekboards.ru / geekboards.de)
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+#include QMK_KEYBOARD_H
+#include "string.h"
+
+bool is_alt_tab_active = false;
+uint16_t alt_tab_timer = 0;
+
+enum custom_keycodes {
+ ALT_TAB = USER00,
+};
+
+const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
+ [0] = LAYOUT_ortho_2x4(
+ LT(1, KC_MUTE), KC_VOLD, KC_VOLU, MACRO00,
+ ALT_TAB, KC_MPRV, KC_MNXT, KC_MPLY
+ ),
+ [1] = LAYOUT_ortho_2x4(
+ KC_TRNS, RGB_VAI, RGB_HUI, RGB_SPI,
+ RGB_MOD, RGB_VAD, RGB_HUD, RGB_SPD
+ ),
+ [2] = LAYOUT_ortho_2x4(
+ KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
+ KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS
+ ),
+ [3] = LAYOUT_ortho_2x4(
+ KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
+ KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS
+ )
+};
+
+//------------ SUPER ALTTAB ---------------
+bool process_record_user(uint16_t keycode, keyrecord_t *record) {
+ switch (keycode) {
+ case ALT_TAB:
+ if (record->event.pressed) {
+ if (!is_alt_tab_active) {
+ is_alt_tab_active = true;
+ register_code(KC_LALT);
+ }
+ alt_tab_timer = timer_read();
+ register_code(KC_TAB);
+ } else {
+ unregister_code(KC_TAB);
+ }
+ break;
+ }
+ return true;
+}
+
+void matrix_scan_user(void) {
+ if (is_alt_tab_active) {
+ if (timer_elapsed(alt_tab_timer) > 1000) {
+ unregister_code(KC_LALT);
+ is_alt_tab_active = false;
+ }
+ }
+}
+
+void keyboard_post_init_user(void) {
+ // set default macro after reset (alt-tab)
+ uint8_t get[16] = {0};
+ uint8_t zero[16] = {0};
+ dynamic_keymap_macro_get_buffer(0,16,get);
+ if(memcmp(get, zero, 16) == 0)
+ {
+ uint8_t set[] = {2, 0xe2, 2, 0xe1, 3, 0xe1, 3, 0xe2, 0};
+ dynamic_keymap_macro_set_buffer(0, 9, set);
+ }
+} \ No newline at end of file
diff --git a/keyboards/geekboards/macropad_v2/keymaps/via/readme.md b/keyboards/geekboards/macropad_v2/keymaps/via/readme.md
new file mode 100644
index 0000000000..79130f4d11
--- /dev/null
+++ b/keyboards/geekboards/macropad_v2/keymaps/via/readme.md
@@ -0,0 +1,3 @@
+# Geekboards Macropad v2 - VIA layout
+
+Flash with this layout to use [VIA](https://caniusevia.com/) for customising layout.
diff --git a/keyboards/geekboards/macropad_v2/keymaps/via/rules.mk b/keyboards/geekboards/macropad_v2/keymaps/via/rules.mk
new file mode 100644
index 0000000000..f2208a3b97
--- /dev/null
+++ b/keyboards/geekboards/macropad_v2/keymaps/via/rules.mk
@@ -0,0 +1,2 @@
+VIA_ENABLE = yes
+# LTO_ENABLE = yes