Migrate actionHandler to new commands
This commit is contained in:
parent
74fe85f3a2
commit
5a04c2eeee
@ -5,6 +5,7 @@ import Logger from './Logger';
|
|||||||
import PageInfo from './video-data/PageInfo';
|
import PageInfo from './video-data/PageInfo';
|
||||||
import Settings from './Settings';
|
import Settings from './Settings';
|
||||||
import VideoData from './video-data/VideoData';
|
import VideoData from './video-data/VideoData';
|
||||||
|
import EventBus from './EventBus';
|
||||||
|
|
||||||
if(process.env.CHANNEL !== 'stable'){
|
if(process.env.CHANNEL !== 'stable'){
|
||||||
console.info("Loading ActionHandler");
|
console.info("Loading ActionHandler");
|
||||||
@ -12,131 +13,48 @@ if(process.env.CHANNEL !== 'stable'){
|
|||||||
|
|
||||||
class ActionHandler {
|
class ActionHandler {
|
||||||
logger: Logger;
|
logger: Logger;
|
||||||
pageInfo: PageInfo;
|
|
||||||
settings: Settings;
|
settings: Settings;
|
||||||
|
eventBus: EventBus;
|
||||||
|
|
||||||
|
|
||||||
inputs: string[] = ['input', 'select', 'button', 'textarea'];
|
inputs: string[] = ['input', 'select', 'button', 'textarea'];
|
||||||
keyboardLocalDisabled: boolean = false;
|
keyboardLocalDisabled: boolean = false;
|
||||||
|
|
||||||
keyUpActions: any[] = [];
|
|
||||||
keyDownActions: any[] = [];
|
|
||||||
mouseMoveActions: any[] = [];
|
mouseMoveActions: any[] = [];
|
||||||
mouseScrollUpActions: any[] = [];
|
|
||||||
mouseScrollDownActions: any[] = [];
|
commands: any[] = [];
|
||||||
mouseEnterActions: any[] = [];
|
|
||||||
mouseLeaveActions: any[] = [];
|
|
||||||
|
|
||||||
|
|
||||||
constructor(pageInfo) {
|
constructor(eventBus, settings, logger) {
|
||||||
this.logger = pageInfo.logger;
|
this.logger = logger;
|
||||||
this.pageInfo = pageInfo;
|
this.settings = settings;
|
||||||
this.settings = pageInfo.settings;
|
this.eventBus = eventBus;
|
||||||
|
|
||||||
|
this.init();
|
||||||
}
|
}
|
||||||
|
|
||||||
init() {
|
init() {
|
||||||
this.logger.log('info', 'debug', "[ActionHandler::init] starting init");
|
this.logger.log('info', 'debug', "[ActionHandler::init] starting init");
|
||||||
|
|
||||||
this.keyUpActions = [];
|
// build the action list — but only from actions that have shortcuts assigned
|
||||||
this.keyDownActions = [];
|
for (const key in this.settings.active.commands) {
|
||||||
this.mouseMoveActions = [];
|
for (const command of this.settings.active.commands[key]) {
|
||||||
this.mouseScrollUpActions = [];
|
if (command.shortcut) {
|
||||||
this.mouseScrollDownActions = [];
|
this.commands.push(command);
|
||||||
this.mouseEnterActions = [];
|
}
|
||||||
this.mouseLeaveActions = [];
|
|
||||||
|
|
||||||
var ths = this;
|
|
||||||
|
|
||||||
var actions;
|
|
||||||
try {
|
|
||||||
if (this.settings.active.sites[window.location.hostname].actions) {
|
|
||||||
actions = this.settings.active.sites[window.location.hostname].actions;
|
|
||||||
} else {
|
|
||||||
actions = this.settings.active.actions;
|
|
||||||
}
|
}
|
||||||
} catch (e) {
|
|
||||||
actions = this.settings.active.actions;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
for (var action of actions) {
|
|
||||||
if (!action.scopes) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
for (var scope in action.scopes) {
|
|
||||||
if (! action.scopes[scope].shortcut) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
var shortcut = action.scopes[scope].shortcut[0];
|
|
||||||
if (shortcut.onKeyDown) {
|
|
||||||
this.keyDownActions.push({
|
|
||||||
shortcut: shortcut,
|
|
||||||
cmd: action.cmd,
|
|
||||||
scope: scope,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
if (shortcut.onKeyUp) {
|
|
||||||
this.keyUpActions.push({
|
|
||||||
shortcut: shortcut,
|
|
||||||
cmd: action.cmd,
|
|
||||||
scope: scope,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
if (shortcut.onScrollUp) {
|
|
||||||
this.mouseScrollUpActions.push({
|
|
||||||
shortcut: shortcut,
|
|
||||||
cmd: action.cmd,
|
|
||||||
scope: scope,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
if (shortcut.onScrollDown) {
|
|
||||||
this.mouseScrollDownActions.push({
|
|
||||||
shortcut: shortcut,
|
|
||||||
cmd: action.cmd,
|
|
||||||
scope: scope,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
if (shortcut.onMouseEnter) {
|
|
||||||
this.mouseEnterActions.push({
|
|
||||||
shortcut: shortcut,
|
|
||||||
cmd: action.cmd,
|
|
||||||
scope: scope,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
if (shortcut.onMouseLeave) {
|
|
||||||
this.mouseLeaveActions.push({
|
|
||||||
shortcut: shortcut,
|
|
||||||
cmd: action.cmd,
|
|
||||||
scope: scope,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
if (shortcut.onMouseMove) {
|
|
||||||
this.mouseMoveActions.push({
|
|
||||||
shortcut: shortcut,
|
|
||||||
cmd: action.cmd,
|
|
||||||
scope: scope,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// events should be handled in handleEvent function. We need to do things this
|
// events should be handled in handleEvent function. We need to do things this
|
||||||
// way, otherwise we can't remove event listener
|
// way, otherwise we can't remove event listener
|
||||||
// https://stackoverflow.com/a/19507086
|
// https://stackoverflow.com/a/19507086
|
||||||
document.addEventListener('keydown', this );
|
|
||||||
document.addEventListener('keyup', this );
|
document.addEventListener('keyup', this );
|
||||||
|
|
||||||
this.pageInfo.setActionHandler(this);
|
|
||||||
|
|
||||||
this.logger.log('info', 'debug', "[ActionHandler::init] initialization complete");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
handleEvent(event) {
|
handleEvent(event) {
|
||||||
switch(event.type) {
|
switch(event.type) {
|
||||||
case 'keydown':
|
|
||||||
this.handleKeydown(event);
|
|
||||||
break;
|
|
||||||
case 'keyup':
|
case 'keyup':
|
||||||
this.handleKeyup(event);
|
this.handleKeyup(event);
|
||||||
break;
|
break;
|
||||||
@ -147,7 +65,6 @@ class ActionHandler {
|
|||||||
}
|
}
|
||||||
|
|
||||||
destroy() {
|
destroy() {
|
||||||
document.removeEventListener('keydown', this);
|
|
||||||
document.removeEventListener('keyup', this);
|
document.removeEventListener('keyup', this);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -223,8 +140,29 @@ class ActionHandler {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ghettoLocalizeKeyboardEvent(event: KeyboardEvent) {
|
||||||
|
const realKey = event.key.toLocaleUpperCase();
|
||||||
|
const isLatin = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890'.indexOf(realKey) !== -1;
|
||||||
|
|
||||||
|
if (!isLatin) {
|
||||||
|
return event;
|
||||||
|
}
|
||||||
|
|
||||||
|
const nativeKey = event.code.substring(3);
|
||||||
|
|
||||||
|
if (nativeKey !== realKey) {
|
||||||
|
return {
|
||||||
|
...event,
|
||||||
|
code: `Key${realKey}`
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
return event;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
isLatin(key) {
|
isLatin(key) {
|
||||||
return 'abcdefghijklmnopqrstuvwxyz,.-+1234567890'.indexOf(key.toLocaleLowerCase()) !== -1;
|
return 'abcdefghijklmnopqrstuvwxyz1234567890'.indexOf(key.toLocaleLowerCase()) !== -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
isActionMatchStandard(shortcut, event) {
|
isActionMatchStandard(shortcut, event) {
|
||||||
@ -250,104 +188,37 @@ class ActionHandler {
|
|||||||
this.isActionMatchStandard(shortcut, event) || this.isActionMatchKeyCode(shortcut, event);
|
this.isActionMatchStandard(shortcut, event) || this.isActionMatchKeyCode(shortcut, event);
|
||||||
}
|
}
|
||||||
|
|
||||||
execAction(actions, event, videoData?: VideoData) {
|
|
||||||
this.logger.log('info', 'keyboard', "%c[ActionHandler::execAction] Trying to find and execute action for event. Actions/event: ", "color: #ff0", actions, event);
|
|
||||||
|
|
||||||
const isLatin = event.key ? this.isLatin(event.key) : true;
|
|
||||||
|
|
||||||
console.warn('You need to migrate this to new commands');
|
|
||||||
|
|
||||||
// for (var action of actions) {
|
|
||||||
// if (this.isActionMatch(action.shortcut, event, isLatin)) {
|
|
||||||
// this.logger.log('info', 'keyboard', "%c[ActionHandler::execAction] found an action associated with keypress/event: ", "color: #ff0", action);
|
|
||||||
|
|
||||||
// for (var cmd of action.cmd) {
|
|
||||||
// if (action.scope === 'page') {
|
|
||||||
// if (cmd.action === "set-ar") {
|
|
||||||
// // the entirety of this function should be moved to new command bus
|
|
||||||
// // this.pageInfo.setAr({type: cmd.arg, ratio: cmd.customArg});
|
|
||||||
// } else if (cmd.action === "change-zoom") {
|
|
||||||
// this.pageInfo.zoomStep(cmd.arg);
|
|
||||||
// } else if (cmd.action === "set-zoom") {
|
|
||||||
// this.pageInfo.setZoom(cmd.arg);
|
|
||||||
// } else if (cmd.action === "set-stretch") {
|
|
||||||
// this.pageInfo.setStretchMode(cmd.arg);
|
|
||||||
// } else if (cmd.action === "toggle-pan") {
|
|
||||||
// this.pageInfo.setPanMode(cmd.arg)
|
|
||||||
// } else if (cmd.action === "pan") {
|
|
||||||
// if (videoData) {
|
|
||||||
// videoData.panHandler(event, true);
|
|
||||||
// }
|
|
||||||
// } else if (cmd.action === 'set-keyboard') {
|
|
||||||
// this.setKeyboardLocal(cmd.arg);
|
|
||||||
// }
|
|
||||||
// } else {
|
|
||||||
// let site = action.scope === 'site' ? window.location.hostname : '@global';
|
|
||||||
|
|
||||||
// if (cmd.action === "set-stretch") {
|
|
||||||
// this.settings.active.sites[site].stretch = cmd.arg;
|
|
||||||
// } else if (cmd.action === "set-alignment") {
|
|
||||||
// this.settings.active.sites[site].videoAlignment = cmd.arg;
|
|
||||||
// } else if (cmd.action === "set-extension-mode") {
|
|
||||||
// this.settings.active.sites[site].mode = cmd.arg;
|
|
||||||
// } else if (cmd.action === "set-autoar-mode") {
|
|
||||||
// this.settings.active.sites[site].autoar = cmd.arg;
|
|
||||||
// } else if (cmd.action === 'set-keyboard') {
|
|
||||||
// this.settings.active.sites[site].keyboardShortcutsEnabled = cmd.arg;
|
|
||||||
// } else if (cmd.action === 'set-ar-persistence') {
|
|
||||||
// this.settings.active.sites[site]['cropModePersistence'] = cmd.arg;
|
|
||||||
// this.pageInfo.setArPersistence(cmd.arg);
|
|
||||||
// this.settings.saveWithoutReload();
|
|
||||||
// }
|
|
||||||
|
|
||||||
// if (cmd.action !== 'set-ar-persistence') {
|
|
||||||
// this.settings.save();
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
|
|
||||||
// // če smo našli dejanje za to tipko, potem ne preiskujemo naprej
|
|
||||||
// // if we found an action for this key, we stop searching for a match
|
|
||||||
// return;
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
handleKeyup(event) {
|
handleKeyup(event) {
|
||||||
this.logger.log('info', 'keyboard', "%c[ActionHandler::handleKeyup] we pressed a key: ", "color: #ff0", event.key , " | keyup: ", event.keyup, "event:", event);
|
this.logger.log('info', 'keyboard', "%c[ActionHandler::handleKeyup] we pressed a key: ", "color: #ff0", event.key , " | keyup: ", event.keyup, "event:", event);
|
||||||
|
|
||||||
try {
|
try {
|
||||||
if (this.preventAction(event)) {
|
if (this.preventAction(event)) {
|
||||||
|
console.log('action is being prevented!');
|
||||||
this.logger.log('info', 'keyboard', "[ActionHandler::handleKeyup] we are in a text box or something. Doing nothing.");
|
this.logger.log('info', 'keyboard', "[ActionHandler::handleKeyup] we are in a text box or something. Doing nothing.");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
this.execAction(this.keyUpActions, event);
|
this.logger.log('info', 'keyboard', "%c[ActionHandler::handleKeyup] Trying to find and execute action for event. Actions/event: ", "color: #ff0", this.commands, event);
|
||||||
|
|
||||||
|
const isLatin = this.isLatin(event.key);
|
||||||
|
|
||||||
|
for (const command of this.commands) {
|
||||||
|
if (this.isActionMatch(command.shortcut, event, isLatin)) {
|
||||||
|
this.eventBus.sendGlobal(command.action, command.arguments);
|
||||||
|
}
|
||||||
|
}
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
this.logger.log('info', 'debug', '[ActionHandler::handleKeyup] Failed to handle keyup!', e);
|
this.logger.log('info', 'debug', '[ActionHandler::handleKeyup] Failed to handle keyup!', e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
handleKeydown(event) {
|
|
||||||
this.logger.log('info', 'keyboard', "%c[ActionHandler::handleKeydown] we pressed a key: ", "color: #ff0", event.key , " | keydown: ", event.keydown, "event:", event)
|
|
||||||
|
|
||||||
try {
|
|
||||||
if (this.preventAction(event)) {
|
|
||||||
this.logger.log('info', 'keyboard', "[ActionHandler::handleKeydown] we are in a text box or something. Doing nothing.");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
this.execAction(this.keyDownActions, event);
|
|
||||||
} catch (e) {
|
|
||||||
this.logger.log('info', 'debug', '[ActionHandler::handleKeydown] Failed to handle keydown!', e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
handleMouseMove(event, videoData?: VideoData) {
|
handleMouseMove(event, videoData?: VideoData) {
|
||||||
this.logger.log('info', 'keyboard', "[ActionHandler::handleMouseMove] mouse move is being handled.\nevent:", event, "\nvideo data:", videoData);
|
this.logger.log('info', 'keyboard', "[ActionHandler::handleMouseMove] mouse move is being handled.\nevent:", event, "\nvideo data:", videoData);
|
||||||
videoData?.panHandler(event);
|
console.info('mousemove must be migrated!');
|
||||||
this.execAction(this.mouseMoveActions, event, videoData)
|
// videoData?.panHandler(event);
|
||||||
|
// this.execAction(this.mouseMoveActions, event, videoData)
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user