2021-07-12 12:36:30 +03:00
|
|
|
class Input {
|
2021-07-18 23:44:31 +03:00
|
|
|
/** Used to programmatically create an input event
|
|
|
|
*
|
|
|
|
* @param {*} keyCode KeyCode of the key to press
|
|
|
|
* @param {*} ctrl Is ctrl pressed?
|
|
|
|
* @param {*} alt Is alt pressed?
|
|
|
|
* @param {*} shift Is shift pressed?
|
|
|
|
*/
|
|
|
|
static simulateInput(keyCode, ctrl, alt, shift) {
|
|
|
|
// I just copy pasted this from stack overflow lol please have mercy
|
|
|
|
let keyboardEvent = document.createEvent("KeyboardEvent");
|
|
|
|
let initMethod = typeof keyboardEvent.initKeyboardEvent !== 'undefined' ? "initKeyboardEvent" : "initKeyEvent";
|
|
|
|
|
|
|
|
keyboardEvent[initMethod](
|
|
|
|
"keydown", // event type: keydown, keyup, keypress
|
|
|
|
true, // bubbles
|
|
|
|
true, // cancelable
|
|
|
|
window, // view: should be window
|
|
|
|
ctrl, // ctrlKey
|
|
|
|
alt, // altKey
|
|
|
|
shift, // shiftKey
|
|
|
|
false, // metaKey
|
|
|
|
keyCode, // keyCode: unsigned long - the virtual key code, else 0
|
|
|
|
keyCode // charCode: unsigned long - the Unicode character associated with the depressed key, else 0
|
|
|
|
);
|
|
|
|
document.dispatchEvent(keyboardEvent);
|
|
|
|
}
|
|
|
|
|
2021-07-12 12:36:30 +03:00
|
|
|
static on(event, elementId, functionCallback, ...args) {
|
|
|
|
//if element provided is string, get the actual element
|
|
|
|
const element = Util.getElement(elementId);
|
|
|
|
|
|
|
|
element.addEventListener(event,
|
|
|
|
function (e) {
|
2021-07-15 23:21:19 +03:00
|
|
|
functionCallback(...args, e);
|
2021-07-12 12:36:30 +03:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
static onChildren(event, parentElement, functionCallback, ...args) {
|
|
|
|
parentElement = Util.getElement(parentElement);
|
|
|
|
const children = parentElement.children;
|
|
|
|
|
|
|
|
//loop through children and add onClick listener
|
|
|
|
for (var i = 0; i < children.length; i++) {
|
2021-07-15 19:33:19 +03:00
|
|
|
on(event, children[i], functionCallback, ...args);
|
2021-07-12 12:36:30 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|