aboutsummaryrefslogtreecommitdiffstats
path: root/lib/keyboard_utils.coffee
diff options
context:
space:
mode:
authorStephen Blott2016-10-10 13:55:47 +0100
committerGitHub2016-10-10 13:55:47 +0100
commit1eb6bfdcad6d7091911e395083afe1148b2a4c76 (patch)
tree0dc625f101fbd7d2e49b73c71f067fda628d97f4 /lib/keyboard_utils.coffee
parenta3c4b530f24ee8bc1f9a1219cf35fb87a1aa0402 (diff)
parent0346b2d971ffab26a8d37946aca1c550b316e317 (diff)
downloadvimium-1eb6bfdcad6d7091911e395083afe1148b2a4c76.tar.bz2
Merge pull request #2306 from smblott-github/add-key-translation
Add "mapkey" command for key mappings.
Diffstat (limited to 'lib/keyboard_utils.coffee')
-rw-r--r--lib/keyboard_utils.coffee20
1 files changed, 14 insertions, 6 deletions
diff --git a/lib/keyboard_utils.coffee b/lib/keyboard_utils.coffee
index f0e791d4..c49fb3f4 100644
--- a/lib/keyboard_utils.coffee
+++ b/lib/keyboard_utils.coffee
@@ -79,10 +79,18 @@ KeyboardUtils =
isPrimaryModifierKey: (event) -> if (@platform == "Mac") then event.metaKey else event.ctrlKey
- isEscape: (event) ->
- # c-[ is mapped to ESC in Vim by default.
- (event.keyCode == @keyCodes.ESC) ||
- (event.ctrlKey && @getKeyChar(event) == '[' and not event.metaKey and not event.altKey)
+ isEscape: do ->
+ mapKeyRegistry = {}
+ # NOTE: "?" here for the tests.
+ Utils?.monitorChromeStorage "mapKeyRegistry", (value) => mapKeyRegistry = value
+
+ # TODO(smblott) Change this to use event.key.
+ (event) ->
+ event.keyCode == @keyCodes.ESC || do =>
+ keyChar = @getKeyCharString event, true
+ keyChar = mapKeyRegistry[keyChar] ? keyChar
+ # <c-[> is mapped to Escape in Vim by default.
+ keyChar == "<c-[>"
# TODO. This is probably a poor way of detecting printable characters. However, it shouldn't incorrectly
# identify any of chrome's own keyboard shortcuts as printable.
@@ -97,7 +105,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) ->
+ getKeyCharString: (event, allKeydownEvents = false) ->
switch event.type
when "keypress"
# Ignore modifier keys by themselves.
@@ -107,7 +115,7 @@ KeyboardUtils =
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))
+ if 1 < keyChar.length or (keyChar.length == 1 and (event.metaKey or event.ctrlKey or event.altKey)) or allKeydownEvents
modifiers = []
keyChar = keyChar.toUpperCase() if event.shiftKey