diff options
author | Maxim Devaev <[email protected]> | 2022-08-21 15:35:11 +0300 |
---|---|---|
committer | Maxim Devaev <[email protected]> | 2022-08-21 15:35:11 +0300 |
commit | 7bd690b4db5a2f075c2b13432a983dad8fc86622 (patch) | |
tree | 653983d556d11da4958d63e3cd38eacc177334e1 /web/share/js/keypad.js | |
parent | 614d02a74d6e2816dc620d4f04ec64cd9a008183 (diff) |
refactoring
Diffstat (limited to 'web/share/js/keypad.js')
-rw-r--r-- | web/share/js/keypad.js | 22 |
1 files changed, 10 insertions, 12 deletions
diff --git a/web/share/js/keypad.js b/web/share/js/keypad.js index 6c5ef006..39c4ab25 100644 --- a/web/share/js/keypad.js +++ b/web/share/js/keypad.js @@ -26,7 +26,7 @@ import {tools, $$$} from "./tools.js"; -export function Keypad(keys_parent, key_callback) { +export function Keypad(__keys_parent, __sendKey, __fix_mac_cmd=false) { var self = this; /************************************************************************/ @@ -36,7 +36,7 @@ export function Keypad(keys_parent, key_callback) { var __modifiers = {}; var __init__ = function() { - for (let el_key of $$$(`${keys_parent} div.key`)) { + for (let el_key of $$$(`${__keys_parent} div.key`)) { let code = el_key.getAttribute("data-code"); tools.setDefault(__keys, code, []); @@ -54,7 +54,7 @@ export function Keypad(keys_parent, key_callback) { }; } - for (let el_key of $$$(`${keys_parent} div.modifier`)) { + for (let el_key of $$$(`${__keys_parent} div.modifier`)) { let code = el_key.getAttribute("data-code"); tools.setDefault(__modifiers, code, []); @@ -79,10 +79,10 @@ export function Keypad(keys_parent, key_callback) { } }; - self.emit = function(code, state, fix_mac_cmd=false) { + self.emit = function(code, state, apply_fixes=true) { if (code in __merged) { __commonHandler(__merged[code][0], state, false); - if (fix_mac_cmd) { + if (__fix_mac_cmd && apply_fixes) { __fixMacCmd(); } __unholdModifiers(); @@ -90,21 +90,19 @@ export function Keypad(keys_parent, key_callback) { }; var __fixMacCmd = function() { - if (__isMacCmdActive()) { + // https://bugs.chromium.org/p/chromium/issues/detail?id=28089 + // https://bugzilla.mozilla.org/show_bug.cgi?id=1299553 + if (__isActive(__modifiers["MetaLeft"][0]) || __isActive(__modifiers["MetaRight"][0])) { for (let code in __keys) { setTimeout(function() { if (__isActive(__keys[code][0])) { - self.emit(code, false); + self.emit(code, false, false); } }, 100); } } }; - var __isMacCmdActive = function() { - return (__isActive(__modifiers["MetaLeft"][0]) || __isActive(__modifiers["MetaRight"][0])); - }; - var __clickHandler = function(el_key, state) { __commonHandler(el_key, state, false); __unholdModifiers(); @@ -184,7 +182,7 @@ export function Keypad(keys_parent, key_callback) { var __process = function(el_key, state) { let code = el_key.getAttribute("data-code"); - key_callback(code, state); + __sendKey(code, state); }; __init__(); |