diff options
| author | Stephen Blott | 2017-03-22 08:24:19 +0000 | 
|---|---|---|
| committer | Stephen Blott | 2017-03-22 09:43:03 +0000 | 
| commit | f2d27321d96cd31c63abceb3e09bfa97ca13b698 (patch) | |
| tree | 6aed83205eb16209d0e58e1a3fd97309a58ad7b1 /lib | |
| parent | a8f44aa35d4a9735637e07b48a3b40654b3f0f65 (diff) | |
| download | vimium-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.
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/keyboard_utils.coffee | 15 | 
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() | 
