From f2d27321d96cd31c63abceb3e09bfa97ca13b698 Mon Sep 17 00:00:00 2001 From: Stephen Blott Date: Wed, 22 Mar 2017 08:24:19 +0000 Subject: Move key handling to keydown and event.key. - For PDF tabs, we see keydown events but we don't see the corresponding keypress events, so this allows us to navigate through PDF tabs with J/K. - This relies on using `event.key` instead of `event.keyIdentifier` (which is no longer supported). - Also move mapkey handling into the keyboard utils. The effect of all of this is to simplify and unify much of our key handling. Fixes #1243 (for tab commands). There are known places where we can prune a considerable amount of key handling code. However, that code is left in place for now in case this change throws up some unexpected issues. --- lib/keyboard_utils.coffee | 15 +++++++-------- 1 file changed, 7 insertions(+), 8 deletions(-) diff --git a/lib/keyboard_utils.coffee b/lib/keyboard_utils.coffee index a4ddf47a..5ba47bff 100644 --- a/lib/keyboard_utils.coffee +++ b/lib/keyboard_utils.coffee @@ -91,8 +91,7 @@ KeyboardUtils = # TODO(smblott) Change this to use event.key. (event) -> event.keyCode == @keyCodes.ESC || do => - keyChar = @getKeyCharString event, true - keyChar = mapKeyRegistry[keyChar] ? keyChar + keyChar = @getKeyCharString event # is mapped to Escape in Vim by default. keyChar == "" @@ -109,7 +108,7 @@ KeyboardUtils = # Return the Vimium key representation for this keyboard event. Return a falsy value (the empty string or # undefined) when no Vimium representation is appropriate. - getKeyCharString: (event, allKeydownEvents = false) -> + getKeyCharString: (event) -> switch event.type when "keypress" # Ignore modifier keys by themselves. @@ -117,19 +116,19 @@ KeyboardUtils = String.fromCharCode event.charCode when "keydown" - # Handle special keys and normal input keys with modifiers being pressed. - keyChar = @getKeyChar event - if 1 < keyChar.length or (keyChar.length == 1 and (event.metaKey or event.ctrlKey or event.altKey)) or allKeydownEvents + if keyChar = @getKeyChar event modifiers = [] - keyChar = keyChar.toUpperCase() if event.shiftKey + keyChar = keyChar.toUpperCase() if event.shiftKey and keyChar.length == 1 # These must be in alphabetical order (to match the sorted modifier order in Commands.normalizeKey). modifiers.push "a" if event.altKey modifiers.push "c" if event.ctrlKey modifiers.push "m" if event.metaKey keyChar = [modifiers..., keyChar].join "-" - if 1 < keyChar.length then "<#{keyChar}>" else keyChar + keyChar = "<#{keyChar}>" if 1 < keyChar.length + keyChar = mapKeyRegistry[keyChar] ? keyChar + keyChar KeyboardUtils.init() -- cgit v1.2.3