start splitting kbmHandler into keyboard and mouse handler
This commit is contained in:
parent
27b6ca824d
commit
a2f0617d5a
@ -1,7 +1,7 @@
|
|||||||
import Debug from './conf/Debug';
|
import Debug from './conf/Debug';
|
||||||
import ExtensionMode from '../common/enums/ExtensionMode.enum';
|
import ExtensionMode from '../common/enums/ExtensionMode.enum';
|
||||||
import Settings from './lib/Settings';
|
import Settings from './lib/Settings';
|
||||||
import KbmHandler from './lib/KbmHandler';
|
import KeyboardHandler from '../../../../KeyboardHandler';
|
||||||
import Comms from './lib/comms/Comms';
|
import Comms from './lib/comms/Comms';
|
||||||
import CommsClient from './lib/comms/CommsClient';
|
import CommsClient from './lib/comms/CommsClient';
|
||||||
import PageInfo from './lib/video-data/PageInfo';
|
import PageInfo from './lib/video-data/PageInfo';
|
||||||
@ -13,7 +13,7 @@ export default class UWContent {
|
|||||||
pageInfo: PageInfo;
|
pageInfo: PageInfo;
|
||||||
comms: CommsClient;
|
comms: CommsClient;
|
||||||
settings: Settings;
|
settings: Settings;
|
||||||
kbmHandler: KbmHandler;
|
keyboardHandler: KeyboardHandler;
|
||||||
logger: Logger;
|
logger: Logger;
|
||||||
eventBus: EventBus;
|
eventBus: EventBus;
|
||||||
|
|
||||||
@ -133,17 +133,17 @@ export default class UWContent {
|
|||||||
this.pageInfo = new PageInfo(this.eventBus, this.settings, this.logger, extensionMode, isSiteDisabled);
|
this.pageInfo = new PageInfo(this.eventBus, this.settings, this.logger, extensionMode, isSiteDisabled);
|
||||||
this.logger.log('info', 'debug', "[uw.js::setup] pageInfo initialized.");
|
this.logger.log('info', 'debug', "[uw.js::setup] pageInfo initialized.");
|
||||||
|
|
||||||
this.logger.log('info', 'debug', "[uw.js::setup] will try to initate KbmHandler.");
|
this.logger.log('info', 'debug', "[uw.js::setup] will try to initate KeyboardHandler.");
|
||||||
|
|
||||||
// start action handler only if extension is enabled for this site
|
// start action handler only if extension is enabled for this site
|
||||||
if (!isSiteDisabled) {
|
if (!isSiteDisabled) {
|
||||||
if (this.kbmHandler) {
|
if (this.keyboardHandler) {
|
||||||
this.kbmHandler.destroy();
|
this.keyboardHandler.destroy();
|
||||||
}
|
}
|
||||||
this.kbmHandler = new KbmHandler(this.eventBus, this.settings, this.logger);
|
this.keyboardHandler = new KeyboardHandler(this.eventBus, this.settings, this.logger);
|
||||||
this.kbmHandler.init();
|
this.keyboardHandler.init();
|
||||||
|
|
||||||
this.logger.log('info', 'debug', "[uw.js::setup] KbmHandler initiated.");
|
this.logger.log('info', 'debug', "[uw.js::setup] KeyboardHandler initiated.");
|
||||||
}
|
}
|
||||||
|
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
@ -156,8 +156,8 @@ export default class UWContent {
|
|||||||
if (this.pageInfo) {
|
if (this.pageInfo) {
|
||||||
this.pageInfo.destroy();
|
this.pageInfo.destroy();
|
||||||
}
|
}
|
||||||
if (this.kbmHandler) {
|
if (this.keyboardHandler) {
|
||||||
this.kbmHandler.destroy();
|
this.keyboardHandler.destroy();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -150,7 +150,7 @@ const ExtensionConf: SettingsInterface = {
|
|||||||
maxLogZoom: 3,
|
maxLogZoom: 3,
|
||||||
announceDebounce: 200 // we wait this long before announcing new zoom
|
announceDebounce: 200 // we wait this long before announcing new zoom
|
||||||
},
|
},
|
||||||
kbmHandler: {
|
keyboardHandler: {
|
||||||
enabled: true,
|
enabled: true,
|
||||||
keyboardEnabled: true,
|
keyboardEnabled: true,
|
||||||
mouseEnabled: true
|
mouseEnabled: true
|
||||||
|
@ -1,14 +1,14 @@
|
|||||||
import Debug from '../conf/Debug';
|
import Debug from '../../conf/Debug';
|
||||||
import PlayerData from './video-data/PlayerData';
|
import PlayerData from '../video-data/PlayerData';
|
||||||
import ExtensionMode from '../../common/enums/ExtensionMode.enum';
|
import ExtensionMode from '../../../common/enums/ExtensionMode.enum';
|
||||||
import Logger from './Logger';
|
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, { EventBusCommand } from './EventBus';
|
import EventBus, { EventBusCommand } from '../EventBus';
|
||||||
|
|
||||||
if(process.env.CHANNEL !== 'stable'){
|
if(process.env.CHANNEL !== 'stable'){
|
||||||
console.info("Loading KbmHandler");
|
console.info("Loading KeyboardHandler");
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -19,20 +19,20 @@ if(process.env.CHANNEL !== 'stable'){
|
|||||||
* kbm-disable disables keyboard shortcuts and mouse panning
|
* kbm-disable disables keyboard shortcuts and mouse panning
|
||||||
* kbm-set-config sets configuration for this module.
|
* kbm-set-config sets configuration for this module.
|
||||||
*/
|
*/
|
||||||
class KbmHandler {
|
class KeyboardHandler {
|
||||||
logger: Logger;
|
logger: Logger;
|
||||||
settings: Settings;
|
settings: Settings;
|
||||||
eventBus: EventBus;
|
eventBus: EventBus;
|
||||||
|
|
||||||
|
playerElements: HTMLElement[] = [];
|
||||||
|
|
||||||
|
|
||||||
allowShortcuts: boolean = true;
|
allowShortcuts: boolean = true;
|
||||||
|
|
||||||
|
|
||||||
inputs: string[] = ['input', 'select', 'button', 'textarea'];
|
inputs: string[] = ['input', 'select', 'button', 'textarea'];
|
||||||
keyboardLocalDisabled: boolean = false;
|
keyboardLocalDisabled: boolean = false;
|
||||||
|
|
||||||
keyboardEnabled: boolean = false;
|
|
||||||
mouseEnabled: boolean = false;
|
|
||||||
|
|
||||||
mouseMoveActions: any[] = [];
|
mouseMoveActions: any[] = [];
|
||||||
keypressActions: any[] = [];
|
keypressActions: any[] = [];
|
||||||
|
|
||||||
@ -46,6 +46,12 @@ class KbmHandler {
|
|||||||
'kbm-set-config': {
|
'kbm-set-config': {
|
||||||
function: (data: {config: any, temporary?: boolean}) => this.setConfig(data.config, data.temporary),
|
function: (data: {config: any, temporary?: boolean}) => this.setConfig(data.config, data.temporary),
|
||||||
},
|
},
|
||||||
|
'uw-enable': {
|
||||||
|
function: () => this.load()
|
||||||
|
},
|
||||||
|
'uw-disable': {
|
||||||
|
function: () => this.disable()
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
//#region lifecycle
|
//#region lifecycle
|
||||||
@ -58,7 +64,7 @@ class KbmHandler {
|
|||||||
}
|
}
|
||||||
|
|
||||||
init() {
|
init() {
|
||||||
this.logger.log('info', 'debug', "[KbmHandler::init] starting init");
|
this.logger.log('info', 'debug', "[KeyboardHandler::init] starting init");
|
||||||
|
|
||||||
// build the action list — but only from actions that have shortcuts assigned
|
// build the action list — but only from actions that have shortcuts assigned
|
||||||
for (const key in this.settings.active.commands) {
|
for (const key in this.settings.active.commands) {
|
||||||
@ -73,9 +79,10 @@ class KbmHandler {
|
|||||||
}
|
}
|
||||||
|
|
||||||
load() {
|
load() {
|
||||||
this.settings.active.kbmHandler.enabled ? this.addListener() : this.removeListener();
|
if (!this.settings.isEnabledForSite() || this.settings.active.kbmHandler.enabled) {
|
||||||
this.keyboardEnabled = this.settings.active.kbmHandler.keyboardEnabled;
|
return;
|
||||||
this.mouseEnabled = this.settings.active.kbmHandler.mouseEnabled;
|
}
|
||||||
|
this.addListener();
|
||||||
}
|
}
|
||||||
|
|
||||||
destroy() {
|
destroy() {
|
||||||
@ -88,21 +95,39 @@ class KbmHandler {
|
|||||||
// 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
|
||||||
|
|
||||||
|
if (this.settings.active.kbmHandler.keyboardEnabled) {
|
||||||
document.addEventListener('keyup', this );
|
document.addEventListener('keyup', this );
|
||||||
}
|
}
|
||||||
|
}
|
||||||
removeListener() {
|
removeListener() {
|
||||||
document.removeEventListener('keyup', this);
|
document.removeEventListener('keyup', this);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adds listeners for mouse events, for all player elements associated with the KeyboardHandler instance.
|
||||||
|
* @param element
|
||||||
|
*/
|
||||||
|
addMouseListeners(element?: HTMLElement) {
|
||||||
|
if (element) {
|
||||||
|
this.playerElements.push(element);
|
||||||
|
|
||||||
|
if (this.settings.active.kbmHandler.mouseEnabled) {
|
||||||
|
element.addEventListener('mousemove', this);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (this.settings.active.kbmHandler.mouseEnabled) {
|
||||||
|
for (const playerElement of this.playerElements) {
|
||||||
|
playerElement.addEventListener('mousemove', this);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
//#endregion
|
//#endregion
|
||||||
|
|
||||||
enable() {
|
/**
|
||||||
this.addListener();
|
* Current instance needs this method for document.addEventListener('keyup', this) to work
|
||||||
}
|
* @param event
|
||||||
|
*/
|
||||||
disable() {
|
|
||||||
this.removeListener();
|
|
||||||
}
|
|
||||||
|
|
||||||
handleEvent(event) {
|
handleEvent(event) {
|
||||||
switch(event.type) {
|
switch(event.type) {
|
||||||
case 'keyup':
|
case 'keyup':
|
||||||
@ -115,7 +140,21 @@ class KbmHandler {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets configuration parameter for KbmHandler
|
* Enables KeyboardHandler
|
||||||
|
*/
|
||||||
|
enable() {
|
||||||
|
this.addListener();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Disables KeyboardHandler
|
||||||
|
*/
|
||||||
|
disable() {
|
||||||
|
this.removeListener();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets configuration parameter for KeyboardHandler
|
||||||
* @param config
|
* @param config
|
||||||
*/
|
*/
|
||||||
setConfig(config, temporary = false) {
|
setConfig(config, temporary = false) {
|
||||||
@ -146,7 +185,7 @@ class KbmHandler {
|
|||||||
|
|
||||||
|
|
||||||
registerHandleMouse(videoData) {
|
registerHandleMouse(videoData) {
|
||||||
this.logger.log('info', ['KbmHandler', 'mousemove'], "[KbmHandler::registerHandleMouse] registering handle mouse for videodata:", videoData.id)
|
this.logger.log('info', ['KeyboardHandler', 'mousemove'], "[KeyboardHandler::registerHandleMouse] registering handle mouse for videodata:", videoData.id)
|
||||||
|
|
||||||
var ths = this;
|
var ths = this;
|
||||||
if (videoData.player && videoData.player.element) {
|
if (videoData.player && videoData.player.element) {
|
||||||
@ -178,7 +217,7 @@ class KbmHandler {
|
|||||||
const preventAction = this.preventAction(event);
|
const preventAction = this.preventAction(event);
|
||||||
this.logger.resume(); // undisable
|
this.logger.resume(); // undisable
|
||||||
|
|
||||||
this.logger.log('info', 'keyboard', "[KbmHandler::preventAction] Testing whether we're in a textbox or something. Detailed rundown of conditions:\n" +
|
this.logger.log('info', 'keyboard', "[KeyboardHandler::preventAction] Testing whether we're in a textbox or something. Detailed rundown of conditions:\n" +
|
||||||
"\nis tag one of defined inputs? (yes->prevent):", this.inputs.indexOf(activeElement.tagName.toLocaleLowerCase()) !== -1,
|
"\nis tag one of defined inputs? (yes->prevent):", this.inputs.indexOf(activeElement.tagName.toLocaleLowerCase()) !== -1,
|
||||||
"\nis role = textbox? (yes -> prevent):", activeElement.getAttribute("role") === "textbox",
|
"\nis role = textbox? (yes -> prevent):", activeElement.getAttribute("role") === "textbox",
|
||||||
"\nis type === 'text'? (yes -> prevent):", activeElement.getAttribute("type") === "text",
|
"\nis type === 'text'? (yes -> prevent):", activeElement.getAttribute("type") === "text",
|
||||||
@ -268,18 +307,18 @@ class KbmHandler {
|
|||||||
|
|
||||||
handleKeyup(event) {
|
handleKeyup(event) {
|
||||||
if (!this.keyboardEnabled) {
|
if (!this.keyboardEnabled) {
|
||||||
this.logger.log('info', 'keyboard', "%c[KbmHandler::handleKeyup] kbmHandler.keyboardEnabled is set to false. Doing nothing.");
|
this.logger.log('info', 'keyboard', "%c[KeyboardHandler::handleKeyup] kbmHandler.keyboardEnabled is set to false. Doing nothing.");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
this.logger.log('info', 'keyboard', "%c[KbmHandler::handleKeyup] we pressed a key: ", "color: #ff0", event.key , " | keyup: ", event.keyup, "event:", event);
|
this.logger.log('info', 'keyboard', "%c[KeyboardHandler::handleKeyup] we pressed a key: ", "color: #ff0", event.key , " | keyup: ", event.keyup, "event:", event);
|
||||||
|
|
||||||
try {
|
try {
|
||||||
if (this.preventAction(event)) {
|
if (this.preventAction(event)) {
|
||||||
this.logger.log('info', 'keyboard', "[KbmHandler::handleKeyup] we are in a text box or something. Doing nothing.");
|
this.logger.log('info', 'keyboard', "[KeyboardHandler::handleKeyup] we are in a text box or something. Doing nothing.");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
this.logger.log('info', 'keyboard', "%c[KbmHandler::handleKeyup] Trying to find and execute action for event. Actions/event: ", "color: #ff0", this.keypressActions, event);
|
this.logger.log('info', 'keyboard', "%c[KeyboardHandler::handleKeyup] Trying to find and execute action for event. Actions/event: ", "color: #ff0", this.keypressActions, event);
|
||||||
|
|
||||||
const isLatin = this.isLatin(event.key);
|
const isLatin = this.isLatin(event.key);
|
||||||
|
|
||||||
@ -289,18 +328,18 @@ class KbmHandler {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
this.logger.log('info', 'debug', '[KbmHandler::handleKeyup] Failed to handle keyup!', e);
|
this.logger.log('info', 'debug', '[KeyboardHandler::handleKeyup] Failed to handle keyup!', e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
handleMouseMove(event, videoData?: VideoData) {
|
handleMouseMove(event, videoData?: VideoData) {
|
||||||
if (!this.mouseEnabled) {
|
if (!this.mouseEnabled) {
|
||||||
this.logger.log('info', 'keyboard', "%c[KbmHandler::handleKeyup] kbmHandler.keyboardEnabled is set to false. Doing nothing.");
|
this.logger.log('info', 'keyboard', "%c[KeyboardHandler::handleKeyup] kbmHandler.keyboardEnabled is set to false. Doing nothing.");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
this.logger.log('info', 'keyboard', "[KbmHandler::handleMouseMove] mouse move is being handled.\nevent:", event, "\nvideo data:", videoData);
|
this.logger.log('info', 'keyboard', "[KeyboardHandler::handleMouseMove] mouse move is being handled.\nevent:", event, "\nvideo data:", videoData);
|
||||||
console.info('mousemove must be migrated!');
|
console.info('mousemove must be migrated!');
|
||||||
// videoData?.panHandler(event);
|
// videoData?.panHandler(event);
|
||||||
// this.execAction(this.mouseMoveActions, event, videoData)
|
// this.execAction(this.mouseMoveActions, event, videoData)
|
||||||
@ -309,7 +348,7 @@ class KbmHandler {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if(process.env.CHANNEL !== 'stable'){
|
if(process.env.CHANNEL !== 'stable'){
|
||||||
console.info("KbmHandler loaded");
|
console.info("KeyboardHandler loaded");
|
||||||
}
|
}
|
||||||
|
|
||||||
export default KbmHandler;
|
export default KeyboardHandler;
|
@ -64,7 +64,7 @@ class PageInfo {
|
|||||||
kbmHandlerInitQueue: any[] = [];
|
kbmHandlerInitQueue: any[] = [];
|
||||||
currentZoomScale: number = 1;
|
currentZoomScale: number = 1;
|
||||||
|
|
||||||
kbmHandler: any;
|
keyboardHandler: any;
|
||||||
//#endregion
|
//#endregion
|
||||||
|
|
||||||
constructor(eventBus: EventBus, settings: Settings, logger: Logger, extensionMode, readOnly = false){
|
constructor(eventBus: EventBus, settings: Settings, logger: Logger, extensionMode, readOnly = false){
|
||||||
@ -125,10 +125,10 @@ class PageInfo {
|
|||||||
}
|
}
|
||||||
|
|
||||||
initMouseActionHandler(videoData) {
|
initMouseActionHandler(videoData) {
|
||||||
if (this.kbmHandler) {
|
if (this.keyboardHandler) {
|
||||||
this.kbmHandler.registerHandleMouse(videoData);
|
this.keyboardHandler.registerHandleMouse(videoData);
|
||||||
} else {
|
} else {
|
||||||
this.kbmHandlerInitQueue.push(videoData);
|
this.keyboardHandlerInitQueue.push(videoData);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user