2013-12-04 17:24:04 +00:00
|
|
|
define([
|
|
|
|
"settings!keys",
|
|
|
|
"command",
|
|
|
|
"editor",
|
|
|
|
"util/dom2"
|
|
|
|
], function(Settings, command, editor) {
|
2013-08-31 20:23:41 +00:00
|
|
|
|
2013-09-01 04:21:21 +00:00
|
|
|
var keycodes = {
|
2013-09-05 15:11:19 +00:00
|
|
|
9: "TAB",
|
|
|
|
13: "RETURN",
|
|
|
|
32: "SPACE",
|
2013-12-13 16:25:10 +00:00
|
|
|
33: "PAGEUP",
|
|
|
|
34: "PAGEDOWN",
|
|
|
|
35: "END",
|
|
|
|
36: "HOME",
|
2013-09-05 15:11:19 +00:00
|
|
|
37: "LEFT",
|
|
|
|
39: "RIGHT",
|
|
|
|
38: "UP",
|
2013-11-19 16:20:05 +00:00
|
|
|
40: "DOWN",
|
|
|
|
187: "=",
|
|
|
|
189: "-"
|
2013-09-03 15:47:59 +00:00
|
|
|
};
|
2013-09-01 04:21:21 +00:00
|
|
|
|
2013-12-16 22:47:25 +00:00
|
|
|
//back-compat: we now use Ace-style bindings (Ctrl-X) instead of Vim-style (^-x)
|
|
|
|
var upgradeKeys = function(config) {
|
|
|
|
var converted = {};
|
|
|
|
for (var key in config) {
|
|
|
|
var value = config[key];
|
|
|
|
//detect old syntax
|
|
|
|
if (key.indexOf("^-") > -1 || key.indexOf("M-") > -1) {
|
|
|
|
key = key
|
|
|
|
.replace(/\^-/g, "Ctrl-")
|
|
|
|
.replace(/M-/g, "Alt-")
|
|
|
|
.replace(/-([A-Z]+)$/, "-Shift-$1")
|
|
|
|
.replace(/-([a-z]+)$/, function(match) { return match.toUpperCase() });
|
|
|
|
}
|
|
|
|
converted[key] = value;
|
|
|
|
}
|
|
|
|
return converted;
|
|
|
|
};
|
|
|
|
|
|
|
|
//need to remove existing Ace conflicts
|
2013-09-06 02:07:01 +00:00
|
|
|
var bindAce = function() {
|
|
|
|
var handler = editor.getKeyboardHandler();
|
2013-12-16 22:47:25 +00:00
|
|
|
var bindings = upgradeKeys(Settings.get("keys"));
|
2013-09-06 02:07:01 +00:00
|
|
|
for (var k in bindings) {
|
|
|
|
var action = bindings[k];
|
|
|
|
if (!action.ace) continue;
|
|
|
|
handler.bindKey(k, action.ace);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
command.on("init:startup", bindAce);
|
|
|
|
command.on("init:restart", bindAce);
|
|
|
|
|
2013-09-05 15:24:46 +00:00
|
|
|
|
2013-09-01 04:21:21 +00:00
|
|
|
//we have to listen on keydown, because keypress will get caught by the window manager
|
2013-08-31 20:23:41 +00:00
|
|
|
window.on("keydown", function(e) {
|
|
|
|
var char = String.fromCharCode(e.keyCode);
|
2013-09-01 04:21:21 +00:00
|
|
|
if (e.keyCode in keycodes) {
|
|
|
|
char = keycodes[e.keyCode];
|
|
|
|
}
|
2013-12-16 22:47:25 +00:00
|
|
|
var prefixes = [];
|
|
|
|
if (e.ctrlKey) prefixes.push("Ctrl");
|
|
|
|
if (e.altKey) prefixes.push("Alt");
|
|
|
|
if (e.shiftKey) prefixes.push("Shift");
|
|
|
|
var combo = prefixes.length ? prefixes.join("-") + "-" + char : char;
|
|
|
|
var keyConfig = upgradeKeys(Settings.get("keys"));
|
2013-08-31 20:23:41 +00:00
|
|
|
if (combo in keyConfig) {
|
|
|
|
e.preventDefault();
|
2013-09-05 15:11:19 +00:00
|
|
|
var action = keyConfig[combo];
|
|
|
|
if (typeof action == "string") {
|
|
|
|
action = {
|
|
|
|
command: action
|
|
|
|
};
|
|
|
|
}
|
2013-09-05 15:24:46 +00:00
|
|
|
if (action.ace) {
|
2013-09-06 02:07:01 +00:00
|
|
|
//we're going to bind these directly on startup
|
|
|
|
//so we shouldn't act on them
|
|
|
|
return;// editor.execCommand(action.ace);
|
2013-09-05 15:24:46 +00:00
|
|
|
}
|
2013-09-05 15:11:19 +00:00
|
|
|
command.fire(action.command, action.argument);
|
2013-08-31 20:23:41 +00:00
|
|
|
}
|
|
|
|
});
|
2013-08-20 00:53:03 +00:00
|
|
|
|
|
|
|
});
|