2013-09-05 15:02:48 +01:00
|
|
|
/**
|
|
|
|
* Copyright 2013 IBM Corp.
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
**/
|
2014-08-08 00:01:35 +01:00
|
|
|
RED.keyboard = (function() {
|
2014-05-14 14:17:26 +01:00
|
|
|
|
2013-09-05 15:02:48 +01:00
|
|
|
var active = true;
|
|
|
|
var handlers = {};
|
2014-05-14 14:17:26 +01:00
|
|
|
|
2013-09-05 15:02:48 +01:00
|
|
|
d3.select(window).on("keydown",function() {
|
|
|
|
if (!active) { return; }
|
|
|
|
var handler = handlers[d3.event.keyCode];
|
2014-04-16 13:39:16 +01:00
|
|
|
if (handler && handler.ondown) {
|
2013-09-05 15:02:48 +01:00
|
|
|
if (!handler.modifiers ||
|
2014-05-14 14:17:26 +01:00
|
|
|
((!handler.modifiers.shift || d3.event.shiftKey) &&
|
2014-10-29 08:49:07 +00:00
|
|
|
(!handler.modifiers.ctrl || d3.event.ctrlKey || d3.event.metaKey) &&
|
|
|
|
(!handler.modifiers.alt || d3.event.altKey) )) {
|
2014-04-16 13:39:16 +01:00
|
|
|
handler.ondown();
|
2013-09-05 15:02:48 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
2014-10-27 15:07:34 +00:00
|
|
|
|
2014-04-16 13:39:16 +01:00
|
|
|
d3.select(window).on("keyup",function() {
|
|
|
|
if (!active) { return; }
|
|
|
|
var handler = handlers[d3.event.keyCode];
|
|
|
|
if (handler && handler.onup) {
|
|
|
|
if (!handler.modifiers ||
|
2014-05-14 14:17:26 +01:00
|
|
|
((!handler.modifiers.shift || d3.event.shiftKey) &&
|
2014-10-29 08:49:07 +00:00
|
|
|
(!handler.modifiers.ctrl || d3.event.ctrlKey || d3.event.metaKey) &&
|
|
|
|
(!handler.modifiers.alt || d3.event.altKey) )) {
|
2014-04-16 13:39:16 +01:00
|
|
|
handler.onup();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
function addHandler(key,modifiers,ondown,onup) {
|
2013-09-05 15:02:48 +01:00
|
|
|
var mod = modifiers;
|
2014-04-16 13:39:16 +01:00
|
|
|
var cbdown = ondown;
|
|
|
|
var cbup = onup;
|
2013-09-05 15:02:48 +01:00
|
|
|
if (typeof modifiers == "function") {
|
|
|
|
mod = {};
|
2014-04-16 13:39:16 +01:00
|
|
|
cbdown = modifiers;
|
|
|
|
cbup = ondown;
|
2013-09-05 15:02:48 +01:00
|
|
|
}
|
2014-04-16 13:39:16 +01:00
|
|
|
handlers[key] = {modifiers:mod, ondown:cbdown, onup:cbup};
|
2013-09-05 15:02:48 +01:00
|
|
|
}
|
|
|
|
function removeHandler(key) {
|
|
|
|
delete handlers[key];
|
|
|
|
}
|
2015-03-14 22:16:07 +00:00
|
|
|
|
|
|
|
|
2015-04-13 13:55:17 +01:00
|
|
|
var dialog = null;
|
2015-03-14 22:16:07 +00:00
|
|
|
|
|
|
|
function showKeyboardHelp() {
|
2015-04-13 16:48:38 +01:00
|
|
|
if (!RED.settings.theme("menu.menu-item-keyboard-shortcuts",true)) {
|
2015-04-13 13:55:17 +01:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (!dialog) {
|
|
|
|
dialog = $('<div id="keyboard-help-dialog" class="hide">'+
|
|
|
|
'<div style="vertical-align: top;display:inline-block; box-sizing: border-box; width:50%; padding: 10px;">'+
|
|
|
|
'<table class="keyboard-shortcuts">'+
|
|
|
|
'<tr><td><span class="help-key">Ctrl/⌘</span> + <span class="help-key">a</span></td><td>Select all nodes</td></tr>'+
|
|
|
|
'<tr><td><span class="help-key">Shift</span> + <span class="help-key">Click</span></td><td>Select all connected nodes</td></tr>'+
|
|
|
|
'<tr><td><span class="help-key">Ctrl/⌘</span> + <span class="help-key">Click</span></td><td>Add/remove node from selection</td></tr>'+
|
|
|
|
'<tr><td><span class="help-key">Delete</span></td><td>Delete selected nodes or link</td></tr>'+
|
|
|
|
'<tr><td> </td><td></td></tr>'+
|
|
|
|
'<tr><td><span class="help-key">Ctrl/⌘</span> + <span class="help-key">i</span></td><td>Import nodes</td></tr>'+
|
|
|
|
'<tr><td><span class="help-key">Ctrl/⌘</span> + <span class="help-key">e</span></td><td>Export selected nodes</td></tr>'+
|
|
|
|
'</table>'+
|
|
|
|
'</div>'+
|
|
|
|
'<div style="vertical-align: top;display:inline-block; box-sizing: border-box; width:50%; padding: 10px;">'+
|
|
|
|
'<table class="keyboard-shortcuts">'+
|
|
|
|
'<tr><td><span class="help-key">Ctrl/⌘</span> + <span class="help-key">Space</span></td><td>Toggle sidebar</td></tr>'+
|
|
|
|
'<tr><td></td><td></td></tr>'+
|
|
|
|
'<tr><td><span class="help-key">Delete</span></td><td>Delete selected nodes or link</td></tr>'+
|
|
|
|
'<tr><td></td><td></td></tr>'+
|
|
|
|
'<tr><td><span class="help-key">Ctrl/⌘</span> + <span class="help-key">c</span></td><td>Copy selected nodes</td></tr>'+
|
|
|
|
'<tr><td><span class="help-key">Ctrl/⌘</span> + <span class="help-key">x</span></td><td>Cut selected nodes</td></tr>'+
|
|
|
|
'<tr><td><span class="help-key">Ctrl/⌘</span> + <span class="help-key">v</span></td><td>Paste nodes</td></tr>'+
|
|
|
|
'</table>'+
|
|
|
|
'</div>'+
|
|
|
|
'</div>')
|
|
|
|
.appendTo("body")
|
|
|
|
.dialog({
|
|
|
|
modal: true,
|
|
|
|
autoOpen: false,
|
|
|
|
width: "800",
|
|
|
|
title:"Keyboard shortcuts",
|
|
|
|
resizable: false,
|
|
|
|
open: function() {
|
|
|
|
RED.keyboard.disable();
|
|
|
|
},
|
|
|
|
close: function() {
|
|
|
|
RED.keyboard.enable();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2015-03-14 22:16:07 +00:00
|
|
|
dialog.dialog("open");
|
|
|
|
}
|
|
|
|
|
2013-09-05 15:02:48 +01:00
|
|
|
return {
|
|
|
|
add: addHandler,
|
|
|
|
remove: removeHandler,
|
|
|
|
disable: function(){ active = false;},
|
2015-03-14 22:16:07 +00:00
|
|
|
enable: function(){ active = true; },
|
|
|
|
|
|
|
|
showHelp: showKeyboardHelp
|
2013-09-05 15:02:48 +01:00
|
|
|
}
|
|
|
|
|
2014-08-08 00:01:35 +01:00
|
|
|
})();
|