/** Modified from original Node-Red source, for audio system visualization * vim: set ts=4: * 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. **/ RED.keyboard = (function() { var active = true; var handlers = {}; d3.select(window).on("keydown",function() { if (!active) { return; } var handler = handlers[d3.event.keyCode]; if (handler && handler.ondown) { if (!handler.modifiers || ((!handler.modifiers.shift || d3.event.shiftKey) && (!handler.modifiers.ctrl || d3.event.ctrlKey ) && (!handler.modifiers.alt || d3.event.altKey ) )) { handler.ondown(); } } }); d3.select(window).on("keyup",function() { if (!active) { return; } var handler = handlers[d3.event.keyCode]; if (handler && handler.onup) { if (!handler.modifiers || ((!handler.modifiers.shift || d3.event.shiftKey) && (!handler.modifiers.ctrl || d3.event.ctrlKey ) && (!handler.modifiers.alt || d3.event.altKey ) )) { handler.onup(); } } }); function addHandler(key,modifiers,ondown,onup) { var mod = modifiers; var cbdown = ondown; var cbup = onup; if (typeof modifiers == "function") { mod = {}; cbdown = modifiers; cbup = ondown; } handlers[key] = {modifiers:mod, ondown:cbdown, onup:cbup}; } function removeHandler(key) { delete handlers[key]; } return { add: addHandler, remove: removeHandler, disable: function(){ active = false;}, enable: function(){ active = true; } } })();