| Age | Commit message (Collapse) | Author | 
|---|
|  | Co-authored-by: jrhrsmit <jasper.770@gmail.com> | 
|  | * Add ZMK_HID_CONSUMER_REPORT_USAGES choice to allow choosing
  between full consumer usage range, with poor OS compat,
  or basic consumer usage range, with broader compat. | 
|  | * Add Kconfig settings for NKRO or HKRO (boot compatible), HID
  report types for keyboard page.
* Updated report storage and set/unset for each config. | 
|  | * Only select fonts for the default built in status screen
* Leverage theme default fonts, instead of hardcoding theme
  details in each component. | 
|  | * Submit widget updates to display queue.
* Use mutex to control access to shared state for widgets. | 
|  | * Add new Kconfig settingsx to allow selecting system or dedicated
  work queue for performing UI updates.
* Allow UI updates to not block other system tasks when display is
  updating, especially important for e-ink displays. | 
|  |  | 
|  | * Workaround for ensuring macOS pairing happens early enough,
  for their stack, we require encryption for the hids report map and
  report ref characteristics as well, to trigger pairing ealier in the
  connection process for macOS. | 
|  |  | 
|  |  | 
|  |  | 
|  | * Use a `k_work` to send usb status events from the system
  workqueue thread, not the USB work thread. | 
|  |  | 
|  |  | 
|  | * Increment the tick from within the ISR itself.
* Don't call task handler until in the display callback.
PR: https://github.com/zmkfirmware/zmk/pull/736 | 
|  | * Move to `DEVICE_DT_INST_DEFINE` everywhere.
See: https://docs.zephyrproject.org/2.5.0/releases/release-notes-2.5.html#deprecated-in-this-release
PR: https://github.com/zmkfirmware/zmk/pull/736 | 
|  | See: https://github.com/zephyrproject-rtos/zephyr/pull/29410
PR: https://github.com/zmkfirmware/zmk/pull/736 | 
|  | A hold-tap timer event would be triggered too soon if the hold-tap
was delayed for longer than its tapping-term. This may cause
accidental hold behavior when the correct behavior would be tap.
By queuing the timer event instead of executing it immediately,
other delayed events get a chance to be processed properly. | 
|  | The current combo completion check only makes sure the last key in the
combo is set. This works when the combo is typed correctly initially, or
when reraising events in a combo of length two. However, it fails for
longer combos since the last event in pressed_keys might be set, but the
first (or subsequent) event in pressed_keys can be NULL thanks to
release_pressed_keys.
Also added a regression test. | 
|  | Don't allow selecting a BLE profile that is out of range to avoid
reading/writing past the end of the profiles array. | 
|  | Quick release for sticky keys failed for non-layer keys. The sticky key
was released just before the key that was supposed to be modified was
handled.
The issue was caused by an error in the sticky key logic, which released
the sticky key before handling the key up event.
Fixes #696. | 
|  | To properly retrigger hold-taps when a combo is not activated, some
position down events are reraised instead of released. The corresponding
position up events were never reraised, causing a potential stuck key. | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | A hold-tap trigger was missing in the scenario where a hold-tap behavior
was queued for a while and it's timer should've run out. | 
|  | This is an improvement on retro-tap, solving the 'flashing hold' issue
users people experience.
When the tapping-term expires, the hold key is normally pressed. When
retro-tap is enabled, this is undesirable; only an interrupted hold-tap
should trigger the hold behavior.
This change disables the hold behavior for the 'STATUS_HOLD_TIMER'
state when retro-tap is enabled, and makes sure the
'STATUS_HOLD_INTERRUPT' state will be triggered when appropriate. | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | Co-authored-by: Pete Johanson <peter@peterjohanson.com> | 
|  |  | 
|  | * Closes #679 | 
|  | tapping_term_ms -> tapping-term-ms
quick_tap_ms -> quick-tap-ms
The old style works, although it's deprecated. | 
|  | * Public type for HSB led color.
* New API for calculating "next" HSB based on current
  state.
* Update behavior to convert the increment/decrement
  commands to absolute command as well. | 
|  | * Allow each behavior to map a relative binding, e.g. "toggle",
  to an absolute one, e.g. "on", before being invoked. | 
|  |  | 
|  | * Use lesser-known DT features to skip behaviors not referenced
  in the user keymap
* Update the behaviors to skip code if no nodes found.
* Remove some empty config/data structs where unused in
  behaviors. | 
|  | feat(combos): add layer filtering
Co-authored-by: KemoNine <mcrosson@kemonine.info> | 
|  | Tap-and-hold a hold-tap to hold the tap behavior so it can repeat.
After a tap, if the same key is pressed within `quick_tap_ms`, the
tap behavior is always picked.
This is useful for things like `&ht LSHFT BACKSPACE` where holding
the backspace is required.
Implements #288. | 
|  |  | 
|  |  | 
|  |  | 
|  |  |