summaryrefslogtreecommitdiff
path: root/keyboards/dtisaac/dosa40rgb/keymaps/default/keymap.c
blob: e25bd59708a39137bb574570b6abc30e45673730 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
/* Copyright 2021 DTIsaac
 *
 * 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 "spi_master.h"
#include "wait.h"

// Defines names for use in layer keycodes and the keymap
enum layer_names {
    _BASE,
    _L1,
	_L2
};

// Defines the keycodes used by our macros in process_record_user
enum custom_keycodes {
    BASE,
	L1,
	BLE_DIS, // Disconnect BLE
	LED_EN, // Toggle LED
};

#define L1 MO(_L1)
const uint8_t cm1[] = "AT+GAPSTOPADV";
const uint8_t cm2[] = "AT+GAPDISCONNECT";
const uint8_t cm3[] = "ATZ";

const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
    /* Base */
	[_BASE] = LAYOUT(
				 KC_ESC,          KC_Q,     KC_W,      KC_E,      KC_R,     KC_T,     KC_Y,     KC_U,     KC_I,     KC_O,     KC_P,   KC_BSPC,
                 LT(_L2,KC_CAPS), KC_A,     KC_S,      KC_D,      KC_F,     KC_G,     KC_H,     KC_J,     KC_K,     KC_L,     KC_ENT,
                 KC_LSFT,         KC_Z,     KC_X,      KC_C,      KC_V,     KC_B,     KC_N,     KC_M,     KC_COMM,  KC_DOT,   KC_RSFT,
                 KC_LCTL,         KC_LGUI,  KC_LALT,   			  KC_SPACE,           KC_SPACE,			  KC_RALT,  L1,		  KC_RCTL
    ),
    [_L1] = LAYOUT(
				 RESET,           KC_1,     KC_2,      KC_3,      KC_4,     KC_5,     KC_6,     KC_7,     KC_8,     KC_9,     KC_0,    KC_DEL,
                 KC_TRNS,         KC_F1,    KC_F2,     KC_F3,     KC_F4,    KC_F5,    KC_F6,    KC_MINS,  KC_EQL,   KC_SCLN,  KC_QUOT,
                 KC_TRNS,         KC_F7,    KC_F8,     KC_F9,     KC_F10,   KC_F11,   KC_F12,   KC_TRNS,  KC_TRNS,  KC_SLSH,  KC_TRNS,
                 KC_TRNS,         KC_TRNS,  KC_TRNS,   			  KC_TRNS,            KC_TRNS,   		  KC_TRNS,  KC_TRNS,  KC_TRNS
	),
    [_L2] = LAYOUT(
                 LED_EN,          RGB_RMOD, KC_UP,     RGB_MOD,   RGB_HUI,  RGB_VAI,  RGB_SAI,  RGB_SPI,  KC_TRNS,  OUT_USB,  OUT_BT,  BLE_DIS,
                 KC_TRNS,         KC_LEFT,  KC_DOWN,   KC_RGHT,   RGB_HUD,  RGB_VAD,  RGB_SAD,  RGB_SPD,  KC_TRNS,  KC_TRNS,  KC_BSLS,
                 KC_TRNS,         KC_TRNS,  KC_TRNS,   KC_TRNS,   KC_TRNS,  KC_TRNS,  KC_TRNS,  KC_TRNS,  KC_TRNS,  KC_TRNS,  KC_TRNS,
                 KC_TRNS,         KC_TRNS,  KC_TRNS,   			  KC_TAB,             KC_TRNS,  		  KC_TRNS,  KC_TRNS,  KC_TRNS
    ),
};

void rgb_matrix_indicators_user(void)
{
 	if (host_keyboard_led_state().caps_lock)
	{
		rgb_matrix_set_color(22, 200, 200, 200);
	}
	if (IS_LAYER_ON(_L1))
	{
		rgb_matrix_set_color(35, 0, 200, 200);
	}
	if (IS_LAYER_ON(_L2))
	{
		rgb_matrix_set_color(22, 200, 0, 200);
	}
}

void sdep_send(const uint8_t *cmd, uint8_t len) {
	
    spi_start(ADAFRUIT_BLE_CS_PIN, false, 0, 2);
    uint8_t cnt = 200;
    bool     ready      = false;

    do {
        ready = spi_write(0x10) != 0xFE;
        if (ready) {
            break;
        }
        spi_stop();
        wait_us(25);
        spi_start(ADAFRUIT_BLE_CS_PIN, false, 0, 2);
    } while (cnt--);

    if (ready) {
		spi_write(0x00);
		spi_write(0x0A);
		spi_write(len);
        spi_transmit(cmd, len);
    }

    spi_stop();
}

bool process_record_user(uint16_t keycode, keyrecord_t *record) {
	
    switch (keycode) {
        case LED_EN:
            if (record->event.pressed) {
				DDRB = DDRB ^ 0x20;
				PORTB &= ~(1 << 5);
            }
            return false;
		case BLE_DIS:
            if (record->event.pressed) {
				sdep_send(cm1,sizeof(cm1));
				sdep_send(cm2,sizeof(cm2));
				sdep_send(cm3,sizeof(cm3));
            }
            return false;
    }
    return true;
}