2018-12-30 23:41:44 +01:00
|
|
|
import Debug from '../conf/Debug';
|
2018-12-31 03:34:26 +01:00
|
|
|
import PlayerData from './video-data/PlayerData';
|
2018-11-14 23:32:37 +01:00
|
|
|
|
|
|
|
class ActionHandler {
|
|
|
|
|
|
|
|
constructor(pageInfo) {
|
|
|
|
this.pageInfo = pageInfo;
|
|
|
|
this.settings = pageInfo.settings;
|
|
|
|
|
|
|
|
this.inputs = ['input', 'select', 'button', 'textarea'];
|
|
|
|
}
|
|
|
|
|
|
|
|
init() {
|
2018-11-18 18:44:44 +01:00
|
|
|
if (Debug.debug) {
|
|
|
|
console.log("[ActionHandler::init] starting init");
|
|
|
|
}
|
|
|
|
|
2018-11-14 23:32:37 +01:00
|
|
|
this.keyUpActions = [];
|
|
|
|
this.keyDownActions = [];
|
|
|
|
this.mouseMoveActions = [];
|
|
|
|
this.mouseScrollUpActions = [];
|
|
|
|
this.mouseScrollDownActions = [];
|
|
|
|
this.mouseEnterActions = [];
|
|
|
|
this.mouseLeaveActions = [];
|
|
|
|
|
|
|
|
var ths = this;
|
|
|
|
|
|
|
|
var actions;
|
|
|
|
try {
|
|
|
|
if (this.settings.active.sites[window.location.host].actions) {
|
|
|
|
actions = this.settings.active.sites[window.location.host].actions;
|
|
|
|
} else {
|
|
|
|
actions = this.settings.active.actions;
|
|
|
|
}
|
|
|
|
} catch (e) {
|
|
|
|
actions = this.settings.active.actions;
|
|
|
|
}
|
|
|
|
|
2018-12-31 03:34:26 +01:00
|
|
|
|
2018-11-14 23:32:37 +01:00
|
|
|
for (var action of actions) {
|
2018-12-31 03:34:26 +01:00
|
|
|
if (!action.scopes) {
|
2018-11-18 18:44:44 +01:00
|
|
|
continue;
|
|
|
|
}
|
2018-12-31 03:34:26 +01:00
|
|
|
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,
|
|
|
|
});
|
|
|
|
}
|
2018-11-14 23:32:37 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
document.addEventListener('keydown', (event) => ths.handleKeydown(event) );
|
|
|
|
document.addEventListener('keyup', (event) => ths.handleKeyup(event) );
|
2018-11-18 18:44:44 +01:00
|
|
|
|
2018-12-02 23:51:34 +01:00
|
|
|
this.pageInfo.setActionHandler(this);
|
2018-11-18 18:44:44 +01:00
|
|
|
if (Debug.debug) {
|
|
|
|
console.log("[ActionHandler::init] initialization complete");
|
|
|
|
}
|
2018-11-14 23:32:37 +01:00
|
|
|
}
|
|
|
|
|
2018-12-02 23:51:34 +01:00
|
|
|
registerHandleMouse(videoData) {
|
2019-02-15 00:00:22 +01:00
|
|
|
if (Debug.debug && Debug.mousemove) {
|
2018-12-02 23:51:34 +01:00
|
|
|
console.log("[ActionHandler::registerHandleMouse] registering handle mouse for videodata:", videoData)
|
|
|
|
}
|
|
|
|
var ths = this;
|
|
|
|
if (videoData.player && videoData.player.element) {
|
|
|
|
videoData.player.element.addEventListener('mousemove', (event) => ths.handleMouseMove(event, videoData));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2018-11-14 23:32:37 +01:00
|
|
|
preventAction() {
|
|
|
|
var activeElement = document.activeElement;
|
|
|
|
|
|
|
|
if(Debug.debug && Debug.keyboard) {
|
|
|
|
Debug.debug = false; // temp disable to avoid recursing;
|
|
|
|
|
|
|
|
console.log("[ActionHandler::preventAction] Testing whether we're in a textbox or something. Detailed rundown of conditions:\n" +
|
|
|
|
"is full screen? (yes->allow):", PlayerData.isFullScreen(),
|
2018-11-15 00:18:41 +01:00
|
|
|
"\nis tag one of defined inputs? (yes->prevent):", this.inputs.indexOf(activeElement.tagName.toLocaleLowerCase()) !== -1,
|
2018-11-14 23:32:37 +01:00
|
|
|
"\nis role = textbox? (yes -> prevent):", activeElement.getAttribute("role") === "textbox",
|
|
|
|
"\nis type === 'text'? (yes -> prevent):", activeElement.getAttribute("type") === "text",
|
|
|
|
"\nwill the action be prevented? (yes -> prevent)", this.preventAction(),
|
|
|
|
"\n-----------------{ extra debug info }-------------------",
|
|
|
|
"\ntag name? (lowercase):", activeElement.tagName, activeElement.tagName.toLocaleLowerCase(),
|
|
|
|
"\nrole:", activeElement.getAttribute('role'),
|
|
|
|
"\ntype:", activeElement.getAttribute('type'),
|
|
|
|
"insta-fail inputs:", this.inputs
|
|
|
|
);
|
|
|
|
|
|
|
|
Debug.debug = true; // undisable
|
|
|
|
}
|
|
|
|
|
2018-12-02 23:51:34 +01:00
|
|
|
// lately youtube has allowed you to read and write comments while watching video in
|
|
|
|
// fullscreen mode. We can no longer do this.
|
|
|
|
// if (PlayerData.isFullScreen()) {
|
|
|
|
// return false;
|
|
|
|
// }
|
2018-11-14 23:32:37 +01:00
|
|
|
if (this.inputs.indexOf(activeElement.tagName.toLocaleLowerCase()) !== -1) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
if (activeElement.getAttribute("role") === "textbox") {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
if (activeElement.getAttribute("type") === "text") {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
isActionMatch(shortcut, event) {
|
|
|
|
return shortcut.key === event.key &&
|
|
|
|
shortcut.ctrlKey === event.ctrlKey &&
|
|
|
|
shortcut.metaKey === event.metaKey &&
|
|
|
|
shortcut.altKey === event.altKey &&
|
|
|
|
shortcut.shiftKey === event.shiftKey
|
|
|
|
}
|
|
|
|
|
2018-12-31 03:34:26 +01:00
|
|
|
execAction(actions, event, videoData) {
|
2018-11-14 23:32:37 +01:00
|
|
|
if(Debug.debug && Debug.keyboard ){
|
2018-11-15 00:18:41 +01:00
|
|
|
console.log("%c[ActionHandler::execAction] Trying to find and execute action for event. Actions/event: ", "color: #ff0", actions, event);
|
2018-11-14 23:32:37 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
for (var action of actions) {
|
2018-12-31 03:34:26 +01:00
|
|
|
if (this.isActionMatch(action.shortcut, event)) {
|
2018-11-14 23:32:37 +01:00
|
|
|
if(Debug.debug && Debug.keyboard ){
|
|
|
|
console.log("%c[ActionHandler::execAction] found an action associated with keypress/event: ", "color: #ff0", action);
|
|
|
|
}
|
|
|
|
|
|
|
|
for (var cmd of action.cmd) {
|
2018-12-31 03:34:26 +01:00
|
|
|
if (action.scope === 'page') {
|
|
|
|
if (cmd.action === "set-ar") {
|
2019-03-10 23:27:50 +01:00
|
|
|
this.pageInfo.setAr({type: cmd.arg, ratio: cmd.customArg});
|
2019-01-03 02:07:16 +01:00
|
|
|
} else if (cmd.action === "change-zoom") {
|
2018-12-31 03:34:26 +01:00
|
|
|
this.pageInfo.zoomStep(cmd.arg);
|
2019-01-03 02:07:16 +01:00
|
|
|
} else if (cmd.action === "set-zoom") {
|
|
|
|
this.pageInfo.setZoom(cmd.arg);
|
2018-12-31 03:34:26 +01:00
|
|
|
} 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 (action.scope === 'site') {
|
|
|
|
if (cmd.action === "set-stretch") {
|
|
|
|
this.settings.active.sites[window.location.host].stretch = cmd.arg;
|
|
|
|
} else if (cmd.action === "set-alignment") {
|
|
|
|
this.settings.active.sites[window.location.host].videoAlignment = cmd.arg;
|
|
|
|
} else if (cmd.action === "set-extension-mode") {
|
|
|
|
this.settings.active.sites[window.location.host].status = cmd.arg;
|
|
|
|
} else if (cmd.action === "set-autoar-mode") {
|
|
|
|
this.settings.active.sites[window.location.host].arStatus = cmd.arg;
|
|
|
|
}
|
|
|
|
this.settings.save();
|
|
|
|
} else if (action.scope === 'global') {
|
|
|
|
if (cmd.action === "set-stretch") {
|
2019-01-20 23:36:08 +01:00
|
|
|
this.settings.active.stretch.initialMode = cmd.arg;
|
2018-12-31 03:34:26 +01:00
|
|
|
} else if (cmd.action === "set-alignment") {
|
2019-01-20 23:36:08 +01:00
|
|
|
this.settings.active.miscSettings.videoAlignment = cmd.arg;
|
2018-12-31 03:34:26 +01:00
|
|
|
} else if (cmd.action === "set-extension-mode") {
|
2019-01-20 22:59:06 +01:00
|
|
|
this.settings.active.sites['@global'] = cmd.arg;
|
2018-12-31 03:34:26 +01:00
|
|
|
} else if (cmd.action === "set-autoar-mode") {
|
2019-01-20 23:36:08 +01:00
|
|
|
this.settings.active.arDetect.mode.arStatus = cmd.arg;
|
2018-12-02 23:51:34 +01:00
|
|
|
}
|
2018-12-31 03:34:26 +01:00
|
|
|
this.settings.save();
|
2018-11-14 23:32:37 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-01-02 20:36:00 +01:00
|
|
|
// č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
|
2018-11-14 23:32:37 +01:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-12-02 23:51:34 +01:00
|
|
|
|
2018-11-14 23:32:37 +01:00
|
|
|
handleKeyup(event) {
|
|
|
|
if(Debug.debug && Debug.keyboard ){
|
2018-12-31 03:34:26 +01:00
|
|
|
console.log("%c[ActionHandler::handleKeyup] we pressed a key: ", "color: #ff0", event.key , " | keyup: ", event.keyup, "event:", event);
|
2018-11-14 23:32:37 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (this.preventAction()) {
|
2018-11-18 18:44:44 +01:00
|
|
|
if (Debug.debug && Debug.keyboard) {
|
|
|
|
console.log("[ActionHandler::handleKeyup] we are in a text box or something. Doing nothing.");
|
|
|
|
}
|
2018-11-14 23:32:37 +01:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2018-12-31 03:34:26 +01:00
|
|
|
this.execAction(this.keyUpActions, event);
|
2018-11-15 00:18:41 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
handleKeydown(event) {
|
|
|
|
if(Debug.debug && Debug.keyboard ){
|
|
|
|
console.log("%c[ActionHandler::handleKeydown] we pressed a key: ", "color: #ff0", event.key , " | keydown: ", event.keydown, "event:", event);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (this.preventAction()) {
|
2018-11-18 18:44:44 +01:00
|
|
|
if (Debug.debug && Debug.keyboard) {
|
|
|
|
console.log("[ActionHandler::handleKeydown] we are in a text box or something. Doing nothing.");
|
|
|
|
}
|
2018-11-15 00:18:41 +01:00
|
|
|
return;
|
|
|
|
}
|
2018-11-14 23:32:37 +01:00
|
|
|
|
2018-12-31 03:34:26 +01:00
|
|
|
this.execAction(this.keyDownActions, event);
|
2018-11-14 23:32:37 +01:00
|
|
|
}
|
|
|
|
|
2018-12-02 23:51:34 +01:00
|
|
|
handleMouseMove(event, videoData) {
|
|
|
|
if (Debug.debug && Debug.mousemove) {
|
|
|
|
console.log("[ActionHandler::handleMouseMove] mouse move is being handled.\nevent:", event, "\nvideo data:", videoData);
|
|
|
|
}
|
|
|
|
videoData.panHandler(event);
|
2018-12-31 03:34:26 +01:00
|
|
|
this.execAction(this.mouseMoveActions, event, videoData)
|
2018-12-02 23:51:34 +01:00
|
|
|
}
|
|
|
|
|
2018-12-30 23:41:44 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
export default ActionHandler;
|