diff options
| author | Conrad Irwin | 2010-05-29 03:28:36 +0100 |
|---|---|---|
| committer | Phil Crosby | 2010-06-01 21:55:48 -0700 |
| commit | 9d0061dca6101926da760e159d50151984ae24f8 (patch) | |
| tree | 4405a8015e4526e68b98886c0c3f99fc16ec1d7d | |
| parent | 3b412ce951643214f5e0f943e10ff9302fe001b9 (diff) | |
| download | vimium-9d0061dca6101926da760e159d50151984ae24f8.tar.bz2 | |
Allow mapping to arrow keys and f-keys
Conflicts:
commands.js
| -rw-r--r-- | background_page.html | 10 | ||||
| -rw-r--r-- | commands.js | 9 | ||||
| -rw-r--r-- | lib/keyboardUtils.js | 19 | ||||
| -rw-r--r-- | vimiumFrontend.js | 2 |
4 files changed, 29 insertions, 11 deletions
diff --git a/background_page.html b/background_page.html index e85dd7d6..9e43fecd 100644 --- a/background_page.html +++ b/background_page.html @@ -15,7 +15,7 @@ var validFirstKeys = {}; var singleKeyCommands = []; - var hasModifierRegex = /^<[amc]-.>/; + var namedKeyRegex = /^(<[amc-].|(?:[amc]-)?[a-z]{2,5}>)(.*)$/; var defaultSettings = { scrollStepSize: 60, @@ -407,15 +407,15 @@ } function splitKeyIntoFirstAndSecond(key) { - if (key.search(hasModifierRegex) == 0) - return { first: key.slice(0, 5), second: key.slice(5) }; + if (key.search(namedKeyRegex) == 0) + return { first: RegExp.$1, second: RegExp.$2 }; else return { first: key[0], second: key.slice(1) }; } function getActualKeyStrokeLength(key) { - if (key.search(hasModifierRegex) == 0) - return 1 + getActualKeyStrokeLength(key.slice(5)); + if (key.search(namedKeyRegex) == 0) + return 1 + getActualKeyStrokeLength(RegExp.$2); else return key.length; } diff --git a/commands.js b/commands.js index 08481280..8e4922f3 100644 --- a/commands.js +++ b/commands.js @@ -23,6 +23,11 @@ function mapKeyToCommand(key, command) { function unmapKey(key) { delete keyToCommandRegistry[key]; } +function normalizeKey(key) { + return key.replace(/<[amc]-/i, function(m){return m.toLowerCase();}) + .replace(/<([acm]-)?([a-zA-Z0-9]+)>/, function(m, p, k){return "<" + (p ? p : "") + k.toLowerCase() + ">";}); +} + function parseCustomKeyMappings(customKeyMappings) { lines = customKeyMappings.split("\n"); @@ -34,7 +39,7 @@ function parseCustomKeyMappings(customKeyMappings) { if (lineCommand == "map") { if (split_line.length != 3) { continue; } - var key = split_line[1]; + var key = normalizeKey(split_line[1]); var vimiumCommand = split_line[2]; if (!availableCommands[vimiumCommand]) { continue } @@ -45,7 +50,7 @@ function parseCustomKeyMappings(customKeyMappings) { else if (lineCommand == "unmap") { if (split_line.length != 2) { continue; } - var key = split_line[1]; + var key = normalizeKey(split_line[1]); console.log("Unmapping", key); unmapKey(key); diff --git a/lib/keyboardUtils.js b/lib/keyboardUtils.js index a47d273f..27ad5e42 100644 --- a/lib/keyboardUtils.js +++ b/lib/keyboardUtils.js @@ -1,4 +1,6 @@ -var keyCodes = { ESC: 27, backspace: 8, deleteKey: 46, enter: 13, space: 32 }; +var keyCodes = { ESC: 27, backspace: 8, deleteKey: 46, enter: 13, space: 32, f1: 112, f12: 123}; +var keyNames = { 37: "left", 38: "up", 39: "right", 40: "down" } + // This is a mapping of the incorrect keyIdentifiers generated by Webkit on Windows during keydown events to // the correct identifiers, which are correctly generated on Mac. We require this mapping to properly handle @@ -26,7 +28,18 @@ else platform = "Windows"; function getKeyChar(event) { - if (event.keyIdentifier.slice(0, 2) != "U+") { return ""; } + // Not a letter + if (event.keyIdentifier.slice(0, 2) != "U+") { + // Named key + if (keyNames[event.keyCode]) { + return keyNames[event.keyCode]; + } + // F-key + if (event.keyCode >= keyCodes.f1 && event.keyCode <= keyCodes.f12) { + return "f" + (1 + event.keyCode - keyCodes.f1); + } + return ""; + } var keyIdentifier = event.keyIdentifier; // On Windows, the keyIdentifiers for non-letter keys are incorrect. See // https://bugs.webkit.org/show_bug.cgi?id=19906 for more details. @@ -48,4 +61,4 @@ function isPrimaryModifierKey(event) { function isEscape(event) { return event.keyCode == keyCodes.ESC || (event.ctrlKey && getKeyChar(event) == '['); // c-[ is mapped to ESC in Vim by default. -}
\ No newline at end of file +} diff --git a/vimiumFrontend.js b/vimiumFrontend.js index 2d30c2cf..4346d18f 100644 --- a/vimiumFrontend.js +++ b/vimiumFrontend.js @@ -263,7 +263,7 @@ function onKeydown(event) { for (var i in modifiers) keyChar = modifiers[i] + "-" + keyChar; - if (modifiers.length > 0) + if (modifiers.length > 0 || keyChar.length > 1) keyChar = "<" + keyChar + ">"; } } |
