aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorStephen Blott2017-03-22 08:24:19 +0000
committerStephen Blott2017-03-22 09:43:03 +0000
commitf2d27321d96cd31c63abceb3e09bfa97ca13b698 (patch)
tree6aed83205eb16209d0e58e1a3fd97309a58ad7b1
parenta8f44aa35d4a9735637e07b48a3b40654b3f0f65 (diff)
downloadvimium-f2d27321d96cd31c63abceb3e09bfa97ca13b698.tar.bz2
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.
-rw-r--r--lib/keyboard_utils.coffee15
1 files 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
# <c-[> is mapped to Escape in Vim by default.
keyChar == "<c-[>"
@@ -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()