diff options
| author | Stephen Blott | 2017-03-24 07:01:34 +0000 |
|---|---|---|
| committer | GitHub | 2017-03-24 07:01:34 +0000 |
| commit | 6d57b8a35b6c957bd610bc6895e637954638c585 (patch) | |
| tree | 5ac27578d07dde6e6e6fe00e3bad01236964e193 | |
| parent | e19f5c95c19eff13be96b8438711d37dc37884d1 (diff) | |
| parent | 1e6f5f7c2db2fc2a7da511c57a287f5165c8a835 (diff) | |
| download | vimium-6d57b8a35b6c957bd610bc6895e637954638c585.tar.bz2 | |
Merge pull request #2456 from smblott-github/always-keydown-and-event.key
Always use keydown and event.key (partial PDF-tab fix)
| -rw-r--r-- | content_scripts/mode_key_handler.coffee | 5 | ||||
| -rw-r--r-- | lib/keyboard_utils.coffee | 26 |
2 files changed, 15 insertions, 16 deletions
diff --git a/content_scripts/mode_key_handler.coffee b/content_scripts/mode_key_handler.coffee index 9b5a1fef..e206dbc6 100644 --- a/content_scripts/mode_key_handler.coffee +++ b/content_scripts/mode_key_handler.coffee @@ -33,9 +33,6 @@ class KeyHandlerMode extends Mode # We cannot track keyup events if we lose the focus. blur: (event) => @alwaysContinueBubbling => @keydownEvents = {} if event.target == window - @mapKeyRegistry = {} - Utils.monitorChromeStorage "mapKeyRegistry", (value) => @mapKeyRegistry = value - if options.exitOnEscape # If we're part way through a command's key sequence, then a first Escape should reset the key state, # and only a second Escape should actually exit this mode. @@ -50,7 +47,6 @@ class KeyHandlerMode extends Mode onKeydown: (event) -> keyChar = KeyboardUtils.getKeyCharString event - keyChar = @mapKeyRegistry[keyChar] ? keyChar isEscape = KeyboardUtils.isEscape event if isEscape and (@countPrefix != 0 or @keyState.length != 1) @keydownEvents[event.keyCode] = true @@ -77,7 +73,6 @@ class KeyHandlerMode extends Mode onKeypress: (event) -> keyChar = KeyboardUtils.getKeyCharString event - keyChar = @mapKeyRegistry[keyChar] ? keyChar if @isMappedKey keyChar @handleKeyChar keyChar else if @isCountKey keyChar diff --git a/lib/keyboard_utils.coffee b/lib/keyboard_utils.coffee index 22f37fb3..ead8c037 100644 --- a/lib/keyboard_utils.coffee +++ b/lib/keyboard_utils.coffee @@ -1,3 +1,7 @@ +mapKeyRegistry = {} +# NOTE: "?" here for the tests. +Utils?.monitorChromeStorage "mapKeyRegistry", (value) => mapKeyRegistry = value + KeyboardUtils = keyCodes: { ESC: 27, backspace: 8, deleteKey: 46, enter: 13, ctrlEnter: 10, space: 32, shiftKey: 16, ctrlKey: 17, f1: 112, @@ -83,15 +87,11 @@ KeyboardUtils = isPrimaryModifierKey: (event) -> if (@platform == "Mac") then event.metaKey else event.ctrlKey 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 + keyChar = @getKeyCharString event # <c-[> is mapped to Escape in Vim by default. keyChar == "<c-[>" @@ -108,27 +108,31 @@ 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. if 31 < event.keyCode String.fromCharCode event.charCode + # TODO(smblott). Currently all (almost?) keyhandling is being done on keydown. All legacy code related + # to key handling on keypress should be reviewed and probably removed. This is not being done right now + # (2017-03-22) because it is better to wait until we've verified that the change to keydown is indeed + # correct and reliable. 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() |
