UNPKG

handsontable

Version:

Handsontable is a JavaScript Spreadsheet Component available for React, Angular and Vue.

103 lines (89 loc) 2.55 kB
import "core-js/modules/es.array.iterator.js"; import "core-js/modules/es.object.to-string.js"; import "core-js/modules/es.set.js"; import "core-js/modules/es.string.iterator.js"; import "core-js/modules/web.dom-collections.iterator.js"; import "core-js/modules/es.array.from.js"; import EventManager from "../eventManager.mjs"; import { isCtrlMetaKey, isKey } from "../helpers/unicode.mjs"; var eventManager = new EventManager(); var pressedKeys = new Set(); var refCount = 0; /** * Begins observing keyboard keys states. * * @param {Document} rootDocument The document owner. */ function startObserving(rootDocument) { if (refCount === 0) { eventManager.addEventListener(rootDocument, 'keydown', function (event) { if (!pressedKeys.has(event.keyCode)) { pressedKeys.add(event.keyCode); } }); eventManager.addEventListener(rootDocument, 'keyup', function (event) { if (pressedKeys.has(event.keyCode)) { pressedKeys.delete(event.keyCode); } }); eventManager.addEventListener(rootDocument, 'visibilitychange', function () { if (rootDocument.hidden) { pressedKeys.clear(); } }); eventManager.addEventListener(rootDocument.defaultView, 'blur', function () { pressedKeys.clear(); }); } refCount += 1; } /** * Stops observing keyboard keys states and clear all previously saved states. */ function stopObserving() { if (refCount > 0) { refCount -= 1; } if (refCount === 0) { _resetState(); } } /** * Remove all listeners attached to the DOM and clear all previously saved states. */ function _resetState() { eventManager.clearEvents(); pressedKeys.clear(); refCount = 0; } /** * Checks if provided keyCode or keyCodes are pressed. * * @param {string} keyCodes The key codes passed as a string defined in helpers/unicode.js file delimited with '|'. * @returns {boolean} */ function isPressed(keyCodes) { return Array.from(pressedKeys.values()).some(function (_keyCode) { return isKey(_keyCode, keyCodes); }); } /** * Checks if ctrl keys are pressed. * * @returns {boolean} */ function isPressedCtrlKey() { var values = Array.from(pressedKeys.values()); return values.some(function (_keyCode) { return isCtrlMetaKey(_keyCode); }); } /** * Returns reference count. Useful for debugging and testing purposes. * * @returns {number} */ function _getRefCount() { return refCount; } export { _getRefCount, _resetState, isPressed, isPressedCtrlKey, startObserving, stopObserving };