aboutsummaryrefslogtreecommitdiffstats
path: root/keyboards/ploopyco/madromys/keymaps/bjc/keymap.c
blob: 3b76c0acc0ff7ed0e514c83747c928bb58bf2404 (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
/* Copyright 2023 Colin Lam (Ploopy Corporation)
 * Copyright 2020 Christopher Courtney, aka Drashna Jael're  (@drashna) <drashna@live.com>
 * Copyright 2019 Sunjun Kim
 *
 * 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

enum {
  DEFAULT = 0,
  FN1,
  FN2
};

enum {
  KC_TOG_HOLD = QK_USER
};

// if the layer hold button is released before this timeout, it
// becomes a toggle.
const uint32_t layer_hold_timeout = 200;

// top left left, top left, top right, top right right, bottom left, bottom right
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  [DEFAULT] = LAYOUT(MS_BTN4, MS_BTN5, MS_BTN3, MS_BTN2, MS_BTN1, KC_TOG_HOLD),
  [FN1]     = LAYOUT(KC_TRNS, LCTL(KC_MINUS), LCTL(KC_EQL), KC_TRNS, KC_TRNS, KC_TRNS),
  [FN2]     = LAYOUT(KC_BRID, KC_BRIU, QK_BOOT, DPI_CONFIG, KC_MYCM, KC_TRNS),
};

// probably shouldn't be doing this, but beats trying to keep track of
// it myself and getting out of sync.
//extern bool is_drag_scroll;

bool drag_scroll = false;

layer_state_t layer_state_set_user(layer_state_t state) {
  if (IS_LAYER_ON_STATE(state, FN1)
      || IS_LAYER_ON_STATE(state, FN2)) {
    drag_scroll = true;
  } else {
    drag_scroll = false;
  }
  return state;
}

/* report_mouse_t pointing_device_task_user(report_mouse_t report) { */
/*   return report; */
/* } */

/*
 * use deferred execution to turn on a layer aften n ms of the key
 * being held down.
 */
/*
  uinst32_t callback(uint32_t trigger_time, void *cb_arg) {
  return 0;
  }
  token = defer_exec(layer_hold_timeout, callback, NULL);
  cancel_deferred_exec(token);
 */

static bool fn1_up = false;
static uint16_t fn1_release_timer = 0;
bool process_record_user(uint16_t keycode, keyrecord_t *record) {
  switch (keycode) {
  case KC_TOG_HOLD:
    if (record->event.pressed) {
      fn1_release_timer = timer_read();
      layer_off(FN1);
      layer_on(FN2);
    } else {
      layer_off(FN2);

      if (timer_elapsed(fn1_release_timer) < layer_hold_timeout) {
        fn1_up = !fn1_up;
        if (fn1_up) {
          layer_on(FN1);
        } else {
          layer_off(FN1);
        }
      }

    }
    break;
  }
  return true;
}

#define DRAGSCROLL_SHIFT_H 0
#define DRAGSCROLL_SHIFT_V 0

// rejiggering ploopyco's version to not use floats
report_mouse_t pointing_device_task_user(report_mouse_t mouse_report) {
  if (drag_scroll) {
    mouse_report.h = mouse_report.x >> DRAGSCROLL_SHIFT_H;
#ifdef PLOOPY_DRAGSCROLL_INVERT
    mouse_report.v = -(mouse_report.y >> DRAGSCROLL_SHIFT_V);
#else
    mouse_report.v = mouse_report.y >> DRAGSCROLL_SHIFT_V;
#endif

    // Clear the X and Y values of the mouse report
    mouse_report.x = 0;
    mouse_report.y = 0;
  }

  return mouse_report;
}