prepare holdtap for tapdance refactor
This commit is contained in:
		@@ -1,6 +1,8 @@
 | 
			
		||||
from micropython import const
 | 
			
		||||
 | 
			
		||||
from kmk.keys import make_argumented_key
 | 
			
		||||
from kmk.modules import Module
 | 
			
		||||
from kmk.types import HoldTapKeyMeta
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
class ActivationType:
 | 
			
		||||
@@ -24,6 +26,12 @@ class HoldTap(Module):
 | 
			
		||||
    def __init__(self):
 | 
			
		||||
        self.key_buffer = []
 | 
			
		||||
        self.key_states = {}
 | 
			
		||||
        make_argumented_key(
 | 
			
		||||
            validator=HoldTapKeyMeta,
 | 
			
		||||
            names=('HT',),
 | 
			
		||||
            on_press=self.ht_pressed,
 | 
			
		||||
            on_release=self.ht_released,
 | 
			
		||||
        )
 | 
			
		||||
 | 
			
		||||
    def during_bootup(self, keyboard):
 | 
			
		||||
        return
 | 
			
		||||
@@ -58,6 +66,9 @@ class HoldTap(Module):
 | 
			
		||||
 | 
			
		||||
                self.send_key_buffer(keyboard)
 | 
			
		||||
 | 
			
		||||
            if state.activated == ActivationType.INTERRUPTED:
 | 
			
		||||
                current_key = keyboard._find_key_in_map(int_coord)
 | 
			
		||||
 | 
			
		||||
            # if interrupt on release: store interrupting keys until one of them
 | 
			
		||||
            # is released.
 | 
			
		||||
            if key.meta.tap_interrupted:
 | 
			
		||||
@@ -140,16 +151,16 @@ class HoldTap(Module):
 | 
			
		||||
        self.key_buffer.clear()
 | 
			
		||||
 | 
			
		||||
    def ht_activate_hold(self, key, keyboard, *args, **kwargs):
 | 
			
		||||
        pass
 | 
			
		||||
        keyboard.process_key(key.meta.hold, True)
 | 
			
		||||
 | 
			
		||||
    def ht_deactivate_hold(self, key, keyboard, *args, **kwargs):
 | 
			
		||||
        pass
 | 
			
		||||
        keyboard.process_key(key.meta.hold, False)
 | 
			
		||||
 | 
			
		||||
    def ht_activate_tap(self, key, keyboard, *args, **kwargs):
 | 
			
		||||
        pass
 | 
			
		||||
        keyboard.process_key(key.meta.tap, True)
 | 
			
		||||
 | 
			
		||||
    def ht_deactivate_tap(self, key, keyboard, *args, **kwargs):
 | 
			
		||||
        pass
 | 
			
		||||
        keyboard.process_key(key.meta.tap, False)
 | 
			
		||||
 | 
			
		||||
    def ht_activate_on_interrupt(self, key, keyboard, *args, **kwargs):
 | 
			
		||||
        if key.meta.prefer_hold:
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										12
									
								
								kmk/types.py
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								kmk/types.py
									
									
									
									
									
								
							@@ -12,8 +12,16 @@ class AttrDict(dict):
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
class HoldTapKeyMeta:
 | 
			
		||||
    def __init__(self, kc=None, prefer_hold=True, tap_interrupted=False, tap_time=None):
 | 
			
		||||
        self.kc = kc
 | 
			
		||||
    def __init__(
 | 
			
		||||
        self,
 | 
			
		||||
        tap,
 | 
			
		||||
        hold,
 | 
			
		||||
        prefer_hold=True,
 | 
			
		||||
        tap_interrupted=False,
 | 
			
		||||
        tap_time=None,
 | 
			
		||||
    ):
 | 
			
		||||
        self.tap = tap
 | 
			
		||||
        self.hold = hold
 | 
			
		||||
        self.prefer_hold = prefer_hold
 | 
			
		||||
        self.tap_interrupted = tap_interrupted
 | 
			
		||||
        self.tap_time = tap_time
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user