2017-12-29 23:34:40 +01:00
|
|
|
if(Debug.debug)
|
|
|
|
console.log("Loading: Keybinds.js");
|
|
|
|
|
2018-05-24 20:50:37 +02:00
|
|
|
class Keybinds {
|
|
|
|
constructor(pageInfo){
|
|
|
|
this.pageInfo = pageInfo;
|
2018-05-31 23:15:47 +02:00
|
|
|
this.inputs = ['input','select','button','textarea'];
|
2017-12-30 12:55:58 +01:00
|
|
|
}
|
2017-10-02 23:30:40 +02:00
|
|
|
|
2018-05-24 20:50:37 +02:00
|
|
|
setup(){
|
|
|
|
var ths = this;
|
|
|
|
document.addEventListener('keydown', (event) => ths.handleKeypress(event) );
|
2017-12-30 12:55:58 +01:00
|
|
|
}
|
2018-05-24 20:50:37 +02:00
|
|
|
|
|
|
|
handleKeypress(event) { // Tukaj ugotovimo, katero tipko smo pritisnili
|
2017-12-30 12:55:58 +01:00
|
|
|
|
2018-05-24 20:50:37 +02:00
|
|
|
if(Debug.debug && Debug.keyboard ){
|
|
|
|
console.log("%c[Keybinds::_kbd_process] we pressed a key: ", "color: #ff0", event.key , " | keydown: ", event.keydown, "event:", event);
|
|
|
|
}
|
2017-12-30 12:55:58 +01:00
|
|
|
|
2018-05-24 20:50:37 +02:00
|
|
|
// Tipke upoštevamo samo, če smo v celozaslonskem načinu oz. če ne pišemo komentarja
|
|
|
|
// v nasprotnem primeru ne naredimo nič.
|
|
|
|
// We only take actions if we're in full screen or not writing a comment
|
2018-05-31 23:15:47 +02:00
|
|
|
var activeElement = document.activeElement;
|
|
|
|
|
|
|
|
if( (! PlayerData.isFullScreen()) && (
|
|
|
|
(this.inputs.indexOf(activeElement.tagName.toLocaleLowerCase()) !== -1) ||
|
|
|
|
(activeElement.getAttribute("role") === "textbox") ||
|
|
|
|
(activeElement.getAttribute("type") === "text")
|
|
|
|
)){
|
2018-05-24 20:50:37 +02:00
|
|
|
if(Debug.debug && Debug.keyboard)
|
|
|
|
console.log("[Keybinds::_kbd_process] We're writing a comment or something. Doing nothing");
|
|
|
|
return;
|
|
|
|
}
|
2017-12-30 12:55:58 +01:00
|
|
|
|
|
|
|
|
2018-05-24 20:50:37 +02:00
|
|
|
// building modifiers list:
|
|
|
|
var modlist = "";
|
2018-05-27 01:29:02 +02:00
|
|
|
for(var mod of ExtensionConf.keyboard.modKeys){
|
2018-05-24 20:50:37 +02:00
|
|
|
if(event[mod])
|
|
|
|
modlist += (mod + "_")
|
2017-12-30 12:55:58 +01:00
|
|
|
}
|
2018-05-24 20:50:37 +02:00
|
|
|
|
|
|
|
if(Debug.debug && Debug.keyboard ){
|
|
|
|
if(modlist)
|
|
|
|
console.log("[Keybinds::_kbd_process] there's been modifier keys. Modlist:", modlist);
|
2017-12-30 12:55:58 +01:00
|
|
|
}
|
2017-10-02 23:30:40 +02:00
|
|
|
|
2018-05-24 20:50:37 +02:00
|
|
|
var keypress = modlist + event.key.toLowerCase();
|
2017-10-02 23:30:40 +02:00
|
|
|
|
2018-05-24 20:50:37 +02:00
|
|
|
if(Debug.debug && Debug.keyboard )
|
|
|
|
console.log("[Keybinds::_kbd_process] our full keypress is this", keypress );
|
|
|
|
|
|
|
|
|
2018-05-27 01:29:02 +02:00
|
|
|
if(ExtensionConf.keyboard.shortcuts[keypress]){
|
|
|
|
var conf = ExtensionConf.keyboard.shortcuts[keypress];
|
2018-05-24 20:50:37 +02:00
|
|
|
|
|
|
|
if(Debug.debug && Debug.keyboard)
|
|
|
|
console.log("[Keybinds::_kbd_process] there's an action associated with this keypress. conf:", conf);
|
|
|
|
|
|
|
|
if(conf.action === "crop"){
|
|
|
|
this.pageInfo.stopArDetection();
|
|
|
|
this.pageInfo.setAr(conf.arg);
|
|
|
|
}
|
|
|
|
if(conf.action === "zoom"){
|
|
|
|
this.pageInfo.stopArDetection();
|
|
|
|
this.pageInfo.zoomStep(conf.arg);
|
|
|
|
}
|
|
|
|
if(conf.action === "auto-ar"){
|
|
|
|
this.pageInfo.startArDetection();
|
|
|
|
}
|
|
|
|
}
|
2017-12-30 12:55:58 +01:00
|
|
|
}
|
2018-05-24 20:50:37 +02:00
|
|
|
}
|