mirror of
https://github.com/Karaka-Management/jsOMS.git
synced 2026-01-11 09:58:39 +00:00
113 lines
2.8 KiB
JavaScript
113 lines
2.8 KiB
JavaScript
/**
|
|
* Keyboard manager class.
|
|
*
|
|
* @author OMS Development Team <dev@oms.com>
|
|
* @copyright 2013 Dennis Eichhorn
|
|
* @license OMS License 1.0
|
|
* @version 1.0.0
|
|
* @since 1.0.0
|
|
*/
|
|
(function (jsOMS)
|
|
{
|
|
"use strict";
|
|
|
|
/** @namespace jsOMS.UI.Input.Keyboard */
|
|
jsOMS.Autoloader.defineNamespace('jsOMS.UI.Input.Keyboard');
|
|
|
|
/**
|
|
* @constructor
|
|
*
|
|
* @since 1.0.0
|
|
*/
|
|
jsOMS.UI.Input.Keyboard.KeyboardManager = function ()
|
|
{
|
|
this.elements = {};
|
|
this.down = [];
|
|
};
|
|
|
|
/**
|
|
* Add input listener.
|
|
*
|
|
* @param {string} element Container id
|
|
* @param {Array} keys Keyboard keys
|
|
* @param {callback} callback Callback
|
|
*
|
|
* @since 1.0.0
|
|
*/
|
|
jsOMS.UI.Input.Keyboard.KeyboardManager.prototype.add = function (element, keys, callback)
|
|
{
|
|
if (typeof this.elements[element] === 'undefined') {
|
|
this.elements[element] = [];
|
|
|
|
this.bind(element);
|
|
}
|
|
|
|
this.elements[element].push({keys: keys, callback: callback});
|
|
};
|
|
|
|
/**
|
|
* Bind container for keyboard input.
|
|
*
|
|
* @param {string} element Container id
|
|
*
|
|
* @since 1.0.0
|
|
*/
|
|
jsOMS.UI.Input.Keyboard.KeyboardManager.prototype.bind = function (element)
|
|
{
|
|
const self = this;
|
|
|
|
// todo: implement keyboard for selected elements right now only global hotkeys possible
|
|
document.addEventListener('keydown', function keyBind(event)
|
|
{
|
|
self.down.push(event.keyCode);
|
|
});
|
|
|
|
document.addEventListener('keyup', function keyBind(event)
|
|
{
|
|
if (self.down.length > 0) {
|
|
self.run(element, event);
|
|
self.down = [];
|
|
}
|
|
});
|
|
};
|
|
|
|
/**
|
|
* Execute callback based on key presses.
|
|
*
|
|
* @param {string} element Container id
|
|
* @param {Object} event Key event
|
|
*
|
|
* @since 1.0.0
|
|
*/
|
|
jsOMS.UI.Input.Keyboard.KeyboardManager.prototype.run = function (element, event)
|
|
{
|
|
if (typeof this.elements[element] === 'undefined') {
|
|
throw 'Unexpected elmenet!';
|
|
}
|
|
|
|
const actions = this.elements[element],
|
|
length = actions.length,
|
|
keyLength = this.down.length;
|
|
let match = false;
|
|
|
|
for (let i = 0; i < length; i++) {
|
|
for (let j = 0; j < keyLength; j++) {
|
|
if (actions[i].keys.indexOf(this.down[j]) === -1) {
|
|
match = false;
|
|
|
|
break;
|
|
} else {
|
|
match = true;
|
|
}
|
|
}
|
|
|
|
if (match) {
|
|
jsOMS.preventAll(event);
|
|
actions[i].callback();
|
|
|
|
break;
|
|
}
|
|
}
|
|
};
|
|
}(window.jsOMS = window.jsOMS || {}));
|