Fixed basic stretching

This commit is contained in:
Tamius Han 2018-06-15 00:33:10 +02:00
parent 3e787be684
commit c5debb40a7
7 changed files with 472 additions and 373 deletions

View File

@ -29,7 +29,7 @@ class CommsClient {
ExtensionConf = message.conf; ExtensionConf = message.conf;
} else if (message.cmd === "set-stretch") { } else if (message.cmd === "set-stretch") {
this.pageInfo.setStretchMode(StretchMode[message.mode]); this.pageInfo.setStretchMode(StretchMode[message.mode]);
} else if (message.cmd === "autoar-enable") { } else if (message.cmd === "autoar-start") {
if (message.enabled !== false) { if (message.enabled !== false) {
this.pageInfo.initArDetection(); this.pageInfo.initArDetection();
this.pageInfo.startArDetection(); this.pageInfo.startArDetection();
@ -41,6 +41,9 @@ class CommsClient {
} else if (message.cmd === "resume-processing") { } else if (message.cmd === "resume-processing") {
// todo: autoArStatus // todo: autoArStatus
this.pageInfo.resumeProcessing(message.autoArStatus); this.pageInfo.resumeProcessing(message.autoArStatus);
} else if (message.cmd === "reload-settings") {
ExtensionConf = message.newConf;
this.pageInfo.reset();
} }
} }
@ -214,15 +217,40 @@ class CommsServer {
if (message.cmd === 'get-config') { if (message.cmd === 'get-config') {
port.postMessage({cmd: "set-config", conf: ExtensionConf}) port.postMessage({cmd: "set-config", conf: ExtensionConf})
} } else if (message.cmd === 'set-stretch') {
if (message.cmd === 'set-stretch') {
this.sendToActive(message); this.sendToActive(message);
} } else if (message.cmd === 'set-ar') {
if (message.cmd === 'set-ar') {
this.sendToActive(message); this.sendToActive(message);
} } else if (message.cmd === 'autoar-start') {
if (message.cmd === 'autoar-enable') {
this.sendToActive(message); this.sendToActive(message);
} else if (message.cmd === "autoar-enable") {
ExtensionConf.arDetect.mode = "blacklist";
Settings.save(ExtensionConf);
this.sendToAll({cmd: "reload-settings", sender: "uwbg"})
if(Debug.debug){
console.log("[uw-bg] autoar set to enabled (blacklist). evidenz:", ExtensionConf);
}
} else if (message.cmd === "autoar-disable") {
ExtensionConf.arDetect.mode = "disabled";
if(message.reason){
ExtensionConf.arDetect.disabledReason = message.reason;
} else {
ExtensionConf.arDetect.disabledReason = 'User disabled';
}
Settings.save(ExtensionConf);
this.sendToAll({cmd: 'reload-settings', newConf: ExtensionConf});
if(Debug.debug){
console.log("[uw-bg] autoar set to disabled. evidenz:", ExtensionConf);
}
} else if (message.cmd === "autoar-set-interval") {
if(Debug.debug)
console.log("[uw-bg] trying to set new interval for autoAr. New interval is",message.timeout,"ms");
// set fairly liberal limit
var timeout = message.timeout < 4 ? 4 : message.timeout;
ExtensionConf.arDetect.timer_playing = timeout;
Settings.save(ExtensionConf);
this.sendToAll({cmd: 'reload-settings', newConf: ExtensionConf});
} }
} }
@ -237,9 +265,34 @@ class CommsServer {
console.log("%c[CommsServer.js::processMessage_nonpersistent_ff] Returning this:", "background-color: #11D; color: #aad", ret); console.log("%c[CommsServer.js::processMessage_nonpersistent_ff] Returning this:", "background-color: #11D; color: #aad", ret);
} }
Promise.resolve(ret); Promise.resolve(ret);
} else if (message.cmd === "autoar-enable") {
ExtensionConf.arDetect.mode = "blacklist";
Settings.save(ExtensionConf);
this.sendToAll({cmd: "reload-settings", sender: "uwbg"})
if(Debug.debug){
console.log("[uw-bg] autoar set to enabled (blacklist). evidenz:", ExtensionConf);
} }
if (message.cmd === "enable-autoar"){ } else if (message.cmd === "autoar-disable") {
this.sendToActive({cmd: "autoar-enable", enabled: true}) ExtensionConf.arDetect.mode = "disabled";
if(message.reason){
ExtensionConf.arDetect.disabledReason = message.reason;
} else {
ExtensionConf.arDetect.disabledReason = 'User disabled';
}
Settings.save(ExtensionConf);
this.sendToAll({cmd: 'reload-settings', newConf: ExtensionConf});
if(Debug.debug){
console.log("[uw-bg] autoar set to disabled. evidenz:", ExtensionConf);
}
} else if (message.cmd === "autoar-set-interval") {
if(Debug.debug)
console.log("[uw-bg] trying to set new interval for autoAr. New interval is",message.timeout,"ms");
// set fairly liberal limit
var timeout = message.timeout < 4 ? 4 : message.timeout;
ExtensionConf.arDetect.timer_playing = timeout;
Settings.save(ExtensionConf);
this.sendToAll({cmd: 'reload-settings', newConf: ExtensionConf});
} }
} }
@ -251,6 +304,34 @@ class CommsServer {
if(message.cmd === 'get-config') { if(message.cmd === 'get-config') {
sendResponse({extensionConf: JSON.stringify(ExtensionConf)}); sendResponse({extensionConf: JSON.stringify(ExtensionConf)});
// return true; // return true;
} else if (message.cmd === "autoar-enable") {
ExtensionConf.arDetect.mode = "blacklist";
Settings.save(ExtensionConf);
this.sendToAll({cmd: "reload-settings", sender: "uwbg"})
if(Debug.debug){
console.log("[uw-bg] autoar set to enabled (blacklist). evidenz:", ExtensionConf);
}
} else if (message.cmd === "autoar-disable") {
ExtensionConf.arDetect.mode = "disabled";
if(message.reason){
ExtensionConf.arDetect.disabledReason = message.reason;
} else {
ExtensionConf.arDetect.disabledReason = 'User disabled';
}
Settings.save(ExtensionConf);
this.sendToAll({cmd: 'reload-settings', newConf: ExtensionConf});
if(Debug.debug){
console.log("[uw-bg] autoar set to disabled. evidenz:", ExtensionConf);
}
} else if (message.cmd === "autoar-set-interval") {
if(Debug.debug)
console.log("[uw-bg] trying to set new interval for autoAr. New interval is",message.timeout,"ms");
// set fairly liberal limit
var timeout = message.timeout < 4 ? 4 : message.timeout;
ExtensionConf.arDetect.timer_playing = timeout;
Settings.save(ExtensionConf);
this.sendToAll({cmd: 'reload-settings', newConf: ExtensionConf});
} }
} }
} }
@ -284,167 +365,167 @@ class Comms {
} }
var _com_queryTabs = async function(tabInfo){ // var _com_queryTabs = async function(tabInfo){
if(BrowserDetect.usebrowser != "firefox"){ // if(BrowserDetect.usebrowser != "firefox"){
return await _com_chrome_tabquery_wrapper(tabInfo); // return await _com_chrome_tabquery_wrapper(tabInfo);
} // }
else{ // else{
return browser.tabs.query(tabInfo); // return browser.tabs.query(tabInfo);
} // }
}
var _com_getActiveTab = async function(tabInfo){
if(BrowserDetect.firefox){
return await browser.tabs.query({currentWindow: true, active: true});
}
return _com_chrome_tabquery_wrapper({currentWindow: true, active: true});
}
var _com_chrome_tabs_sendmsg_wrapper = async function(tab, message, options){
return new Promise(function (resolve, reject){
try{
browser.tabs.sendMessage(tab, message, /*options, */function(response){
console.log("TESTING what is this owo? (response)", response);
// Chrome/js shittiness mitigation — remove this line and an empty array will be returned
var r = response;
resolve(r);
});
}
catch(e){
reject(e);
}
});
}
var _com_sendMessage = async function(tab, message, options){
if(BrowserDetect.usebrowser != "firefox"){
var r = await _com_chrome_tabs_sendmsg_wrapper(tab, message, options);
console.log("TESTING what is this owo? (should be a promise)", r);
return r;
}
else{
return browser.tabs.sendMessage(tab, message, options);
}
}
var _com_chrome_tabs_sendmsgrt_wrapper = async function(message){
return new Promise(function (resolve, reject){
try{
browser.runtime.sendMessage(message, function(response){
// Chrome/js shittiness mitigation — remove this line and an empty array will be returned
var r = response;
resolve(r);
});
}
catch(e){
reject(e);
}
});
}
var _com_sendMessageRuntime = async function(message){
if(BrowserDetect.usebrowser != "firefox"){
return _com_chrome_tabs_sendmsgrt_wrapper(message);
}
else{
return browser.runtime.sendMessage(message);
}
}
// pošlje sporočilce vsem okvirjem v trenutno odprtem zavihku. Vrne tisti odgovor od tistega okvira, ki prispe prvi.
// sends a message to all frames in the currently opened tab. Returns the response of a frame that replied first
var _com_sendToAllFrames = async function(message) {
if(Debug.debug)
console.log("[Comms::_com_sendToAllFrames] sending message to all frames of currenntly active tab");
var tabs = await browser.tabs.query({currentWindow: true, active: true});
if(Debug.debug)
console.log("[Comms::_com_sendToAllFrames] trying to send message", message, " to tab ", tabs[0], ". (all tabs:", tabs,")");
var response = await browser.tabs.sendMessage(tabs[0].id, message);
console.log("[Comms::_com_sendToAllFrames] response is this:",response);
return response;
// if(BrowserDetect.firefox){
// return
// } // }
}
// pošlje sporočilce vsem okvirjem v trenutno odprtem zavihku in vrne _vse_ odgovore // var _com_getActiveTab = async function(tabInfo){
// sends a message to all frames in currently opened tab and returns all responses // if(BrowserDetect.firefox){
var _com_sendToEachFrame = async function(message, tabId) { // return await browser.tabs.query({currentWindow: true, active: true});
if(Debug.debug) // }
console.log("[Comms::_com_sendToEveryFrame] sending message to every frames of currenntly active tab"); // return _com_chrome_tabquery_wrapper({currentWindow: true, active: true});
// }
if(tabId === undefined){
var tabs = await browser.tabs.query({currentWindow: true, active: true});
tabId = tabs[0].id;
}
var frames = await browser.webNavigation.getAllFrames({tabId: tabId});
if(Debug.debug)
console.log("[Comms::_com_sendToEveryFrame] we have this many frames:", frames.length, "||| tabId:", tabId ,"frames:",frames);
// pošlji sporočilce vsakemu okvirju, potisni obljubo v tabelo // var _com_chrome_tabs_sendmsg_wrapper = async function(tab, message, options){
// send message to every frame, push promise to array // return new Promise(function (resolve, reject){
var promises = []; // try{
for(var frame of frames){ // browser.tabs.sendMessage(tab, message, /*options, */function(response){
if(Debug.debug) // console.log("TESTING what is this owo? (response)", response);
console.log("[Comms:_com_sendToEachFrame] we sending message to tab with id", tabId, ", frame with id", frame.frameId);
try{
promises.push(browser.tabs.sendMessage(tabId, message, {frameId: frame.frameId}));
}
catch(e){
if(Debug.debug)
console.log("[Comms:_com_sendToEachFrame] we sending message to tab with id", tabId, ", frame with id", frame.frameId);
}
}
// počakajmo, da so obljube izpolnjene. // // Chrome/js shittiness mitigation — remove this line and an empty array will be returned
// wait for all promises to be kept // var r = response;
var responses = []; // resolve(r);
// });
// }
// catch(e){
// reject(e);
// }
// });
// }
for(var promise of promises){ // var _com_sendMessage = async function(tab, message, options){
var response = await promise; // if(BrowserDetect.usebrowser != "firefox"){
if(response !== undefined) // var r = await _com_chrome_tabs_sendmsg_wrapper(tab, message, options);
responses.push(response); // console.log("TESTING what is this owo? (should be a promise)", r);
} // return r;
// }
// else{
// return browser.tabs.sendMessage(tab, message, options);
// }
// }
if(Debug.debug) // var _com_chrome_tabs_sendmsgrt_wrapper = async function(message){
console.log("[Comms::_com_sendToEveryFrame] we received responses from all frames", responses); // return new Promise(function (resolve, reject){
// try{
// browser.runtime.sendMessage(message, function(response){
return responses; // // Chrome/js shittiness mitigation — remove this line and an empty array will be returned
} // var r = response;
var _com_sendToMainFrame = async function(message, tabId){ // resolve(r);
if(Debug.debug) // });
console.log("[Comms::_com_sendToMainFrame] sending message to every frames of currenntly active tab"); // }
// catch(e){
// reject(e);
// }
// });
// }
if(tabId === undefined){ // var _com_sendMessageRuntime = async function(message){
var tabs = await browser.tabs.query({currentWindow: true, active: true}); // if(BrowserDetect.usebrowser != "firefox"){
tabId = tabs[0].id; // return _com_chrome_tabs_sendmsgrt_wrapper(message);
} // }
// else{
// return browser.runtime.sendMessage(message);
// }
// }
// pošlji sporočilce glavnemu okvirju. Glavni okvir ima id=0 // // pošlje sporočilce vsem okvirjem v trenutno odprtem zavihku. Vrne tisti odgovor od tistega okvira, ki prispe prvi.
// send message to the main frame. Main frame has id=0 // // sends a message to all frames in the currently opened tab. Returns the response of a frame that replied first
try{ // var _com_sendToAllFrames = async function(message) {
var response = await browser.tabs.sendMessage(tabId, message, {frameId: 0}); // if(Debug.debug)
console.log("[Comms::_com_sendToMainFrame] response is this:",response); // console.log("[Comms::_com_sendToAllFrames] sending message to all frames of currenntly active tab");
} // var tabs = await browser.tabs.query({currentWindow: true, active: true});
catch(e){
console.log("[Comms:_com_sendToEachFrame] failed sending message to tab with id", tabId, ", frame with id", 0, "\nerror:",e); // if(Debug.debug)
} // console.log("[Comms::_com_sendToAllFrames] trying to send message", message, " to tab ", tabs[0], ". (all tabs:", tabs,")");
return response;
} // var response = await browser.tabs.sendMessage(tabs[0].id, message);
// console.log("[Comms::_com_sendToAllFrames] response is this:",response);
// return response;
// // if(BrowserDetect.firefox){
// // return
// // }
// }
// // pošlje sporočilce vsem okvirjem v trenutno odprtem zavihku in vrne _vse_ odgovore
// // sends a message to all frames in currently opened tab and returns all responses
// var _com_sendToEachFrame = async function(message, tabId) {
// if(Debug.debug)
// console.log("[Comms::_com_sendToEveryFrame] sending message to every frames of currenntly active tab");
// if(tabId === undefined){
// var tabs = await browser.tabs.query({currentWindow: true, active: true});
// tabId = tabs[0].id;
// }
// var frames = await browser.webNavigation.getAllFrames({tabId: tabId});
// if(Debug.debug)
// console.log("[Comms::_com_sendToEveryFrame] we have this many frames:", frames.length, "||| tabId:", tabId ,"frames:",frames);
// // pošlji sporočilce vsakemu okvirju, potisni obljubo v tabelo
// // send message to every frame, push promise to array
// var promises = [];
// for(var frame of frames){
// if(Debug.debug)
// console.log("[Comms:_com_sendToEachFrame] we sending message to tab with id", tabId, ", frame with id", frame.frameId);
// try{
// promises.push(browser.tabs.sendMessage(tabId, message, {frameId: frame.frameId}));
// }
// catch(e){
// if(Debug.debug)
// console.log("[Comms:_com_sendToEachFrame] we sending message to tab with id", tabId, ", frame with id", frame.frameId);
// }
// }
// // počakajmo, da so obljube izpolnjene.
// // wait for all promises to be kept
// var responses = [];
// for(var promise of promises){
// var response = await promise;
// if(response !== undefined)
// responses.push(response);
// }
// if(Debug.debug)
// console.log("[Comms::_com_sendToEveryFrame] we received responses from all frames", responses);
// return responses;
// }
// var _com_sendToMainFrame = async function(message, tabId){
// if(Debug.debug)
// console.log("[Comms::_com_sendToMainFrame] sending message to every frames of currenntly active tab");
// if(tabId === undefined){
// var tabs = await browser.tabs.query({currentWindow: true, active: true});
// tabId = tabs[0].id;
// }
// // pošlji sporočilce glavnemu okvirju. Glavni okvir ima id=0
// // send message to the main frame. Main frame has id=0
// try{
// var response = await browser.tabs.sendMessage(tabId, message, {frameId: 0});
// console.log("[Comms::_com_sendToMainFrame] response is this:",response);
// }
// catch(e){
// console.log("[Comms:_com_sendToEachFrame] failed sending message to tab with id", tabId, ", frame with id", 0, "\nerror:",e);
// }
// return response;
// }
// var Comms = { // var Comms = {
// getActiveTab: _com_getActiveTab, // getActiveTab: _com_getActiveTab,

View File

@ -11,7 +11,6 @@ class VideoData {
this.resizer = new Resizer(this); this.resizer = new Resizer(this);
this.arDetector = new ArDetector(this); // this starts Ar detection. needs optional parameter that prevets ardetdctor from starting this.arDetector = new ArDetector(this); // this starts Ar detection. needs optional parameter that prevets ardetdctor from starting
// player dimensions need to be in: // player dimensions need to be in:
// this.player.dimensions // this.player.dimensions
} }

View File

@ -22,6 +22,14 @@ class PageInfo {
} }
} }
reset(){
for(video of this.videos) {
video.destroy();
}
this.rescan(RescanReason.MANUAL);
}
rescan(rescanReason){ rescan(rescanReason){
try{ try{
var vids = document.getElementsByTagName('video'); var vids = document.getElementsByTagName('video');

View File

@ -84,6 +84,9 @@ class Resizer {
} }
} else if (this.stretcher.mode === StretchMode.HYBRID) { } else if (this.stretcher.mode === StretchMode.HYBRID) {
var stretchFactors = this.stretcher.calculateStretch(ar); var stretchFactors = this.stretcher.calculateStretch(ar);
} else if (this.stretcher.mode === StretchMode.BASIC) {
console.log("basic stretch mode")
var stretchFactors = this.stretcher.calculateBasicStretch();
} }
this.zoom.applyZoom(stretchFactors); this.zoom.applyZoom(stretchFactors);
@ -92,6 +95,8 @@ class Resizer {
var translate = this.computeOffsets(stretchFactors); var translate = this.computeOffsets(stretchFactors);
this.applyCss(stretchFactors, translate); this.applyCss(stretchFactors, translate);
console.log("applied css")
// if(! this.destroyed) // if(! this.destroyed)
// this.startCssWatcher(); // this.startCssWatcher();
} }
@ -105,6 +110,7 @@ class Resizer {
} }
setStretchMode(stretchMode){ setStretchMode(stretchMode){
console.log("setting stretch mode:", stretchMode)
this.stretcher.mode = stretchMode; this.stretcher.mode = stretchMode;
this.restore(); this.restore();
} }

View File

@ -50,6 +50,18 @@ class Stretcher {
} }
} }
calculateBasicStretch() {
console.log("calculating basic stretch - -- stretcher")
// var videoAr = this.conf.video.videoWidth / this.conf.video.videoHeight;
// var playerAr = this.conf.player.dimensions.width / this.conf.player.dimensions.height;
return {
xFactor: this.conf.player.dimensions.width / this.conf.video.videoWidth,
yFactor: this.conf.player.dimensions.height / this.conf.video.videoHeight
};
// return this.calculateStretch(actualAr);
}
calculateStretch(actualAr) { calculateStretch(actualAr) {
var playerAr = this.conf.player.dimensions.width / this.conf.player.dimensions.height; var playerAr = this.conf.player.dimensions.width / this.conf.player.dimensions.height;
var videoAr = this.conf.video.videoWidth / this.conf.video.videoHeight; var videoAr = this.conf.video.videoWidth / this.conf.video.videoHeight;
@ -93,7 +105,7 @@ class Stretcher {
} else { } else {
// NEEDS CHECKING // NEEDS CHECKING
// player > video > actual — double pillarbox // player > video > actual — double pillarbox
stretchFactors.xFactor = actualAr / playerAr; stretchFactors.xFactor = playerAr / actualAr;
stretchFactors.yFactor = 1; stretchFactors.yFactor = 1;
if(Debug.debug){ if(Debug.debug){

View File

@ -19,258 +19,258 @@ class UWServer {
var server = new UWServer(); var server = new UWServer();
function extractHostname(url){ // function extractHostname(url){
// extract hostname // // extract hostname
if (url.indexOf("://") > -1) { //find & remove protocol (http, ftp, etc.) and get hostname // if (url.indexOf("://") > -1) { //find & remove protocol (http, ftp, etc.) and get hostname
hostname = url.split('/')[2]; // hostname = url.split('/')[2];
} // }
else { // else {
hostname = url.split('/')[0]; // hostname = url.split('/')[0];
} // }
hostname = hostname.split(':')[0]; //find & remove port number // hostname = hostname.split(':')[0]; //find & remove port number
hostname = hostname.split('?')[0]; //find & remove "?" // hostname = hostname.split('?')[0]; //find & remove "?"
return hostname; // return hostname;
} // }
async function main(){ // async function main(){
if(Debug.debug) // if(Debug.debug)
console.log("[uw-bg::main] setting up background script"); // console.log("[uw-bg::main] setting up background script");
Keybinds.keybinds = await Keybinds.fetch(); // Keybinds.keybinds = await Keybinds.fetch();
// Poslušalci za dogodke | event listeners here // // Poslušalci za dogodke | event listeners here
// {===]///[-------------------------------------]\\\[===} // // {===]///[-------------------------------------]\\\[===}
browser.runtime.onMessage.addListener(_uwbg_rcvmsg); // browser.runtime.onMessage.addListener(_uwbg_rcvmsg);
browser.tabs.onActivated.addListener(_uwbg_onTabSwitched); // browser.tabs.onActivated.addListener(_uwbg_onTabSwitched);
if(Debug.debug) // if(Debug.debug)
console.log("[uw-bg::main] listeners registered"); // console.log("[uw-bg::main] listeners registered");
// add currentSite // // add currentSite
var tabs = await Comms.getActiveTab(); // var tabs = await Comms.getActiveTab();
BgVars.currentSite = extractHostname(tabs[0].url); // BgVars.currentSite = extractHostname(tabs[0].url);
// // //
setInterval(_uwbg_check4videos, 5000); // setInterval(_uwbg_check4videos, 5000);
} // }
async function _uwbg_onTabSwitched(activeInfo){ // async function _uwbg_onTabSwitched(activeInfo){
BgVars.hasVideos = false; // BgVars.hasVideos = false;
if(Debug.debug) // if(Debug.debug)
console.log("[uw-bg::onTabSwitched] TAB CHANGED, GETTING INFO FROM MAIN TAB"); // console.log("[uw-bg::onTabSwitched] TAB CHANGED, GETTING INFO FROM MAIN TAB");
var tabId = activeInfo.tabId; // just for readability // var tabId = activeInfo.tabId; // just for readability
var tab = await browser.tabs.get(tabId); // var tab = await browser.tabs.get(tabId);
BgVars.currentSite = extractHostname(tab.url); // BgVars.currentSite = extractHostname(tab.url);
// this can fail. This might also not return a promise? Check that. // // this can fail. This might also not return a promise? Check that.
var videoFrameList = await Comms.sendToEach({"cmd":"has-videos"}, tabId); // var videoFrameList = await Comms.sendToEach({"cmd":"has-videos"}, tabId);
if(Debug.debug) // if(Debug.debug)
console.log("[uw-bg::onTabSwitched] got list of frames and whether they have videos", videoFrameList); // console.log("[uw-bg::onTabSwitched] got list of frames and whether they have videos", videoFrameList);
// Pogledamo, če kateri od okvirjev vsebuje video. Da omogočimo pojavno okno je zadosti že // // Pogledamo, če kateri od okvirjev vsebuje video. Da omogočimo pojavno okno je zadosti že
// en okvir z videom. // // en okvir z videom.
// <===[///]----------------------------[\\\]===> // // <===[///]----------------------------[\\\]===>
// Check if any frame has a video in it. To enable the popup there only needs to be at least one, // // Check if any frame has a video in it. To enable the popup there only needs to be at least one,
// but the popup controls all frames. // // but the popup controls all frames.
var hasVideos = false; // var hasVideos = false;
for(frame of videoFrameList){ // for(frame of videoFrameList){
hasVideos |= frame.response.hasVideos; // hasVideos |= frame.response.hasVideos;
} // }
BgVars.hasVideos = hasVideos; // BgVars.hasVideos = hasVideos;
Settings.reload(); // Settings.reload();
// todo: change extension icon depending on whether there's a video on the page or not // // todo: change extension icon depending on whether there's a video on the page or not
} // }
async function _uwbg_check4videos(){ // async function _uwbg_check4videos(){
if(BgVars.hasVideos) // if(BgVars.hasVideos)
return; // return;
var videoFrameList = Comms.sendToEach({"cmd":"has-videos"}); // var videoFrameList = Comms.sendToEach({"cmd":"has-videos"});
if(Debug.debug) // if(Debug.debug)
console.log("[uw-bg::check4videos] got updated list of frames and whether they have videos", videoFrameList); // console.log("[uw-bg::check4videos] got updated list of frames and whether they have videos", videoFrameList);
var hasVideos = false; // var hasVideos = false;
for(frame of videoFrameList){ // for(frame of videoFrameList){
hasVideos |= frame.response.hasVideos; // hasVideos |= frame.response.hasVideos;
} // }
BgVars.hasVideos = hasVideos; // BgVars.hasVideos = hasVideos;
} // }
async function _uwbg_registerVideo(tabId){ // async function _uwbg_registerVideo(tabId){
var tabs = await Comms.getActiveTab(); // var tabs = await Comms.getActiveTab();
// če ukaz pride iz zavihka, na katerem se trenunto ne nahajamo, potem se za zahtevo ne brigamo // // če ukaz pride iz zavihka, na katerem se trenunto ne nahajamo, potem se za zahtevo ne brigamo
// if command originated from a tab that's _not_ currently active, we ignore the request // // if command originated from a tab that's _not_ currently active, we ignore the request
if(tabId != tabs[0].id){ // if(tabId != tabs[0].id){
if(Debug.debug){ // if(Debug.debug){
console.log("[uw-bg::_uwbg_registerVideo] request didn't come from currently active tab, ignoring"); // console.log("[uw-bg::_uwbg_registerVideo] request didn't come from currently active tab, ignoring");
} // }
return; // return;
} // }
if(Debug.debug){ // if(Debug.debug){
console.log("%c[uw-bg::_uwbg_registerVideo] request came from currently active tab!", "color: #afd, background: #000"); // console.log("%c[uw-bg::_uwbg_registerVideo] request came from currently active tab!", "color: #afd, background: #000");
} // }
BgVars.hasVideos = true; // BgVars.hasVideos = true;
// todo: change extension icon depending on whether there's a video on the page or not // // todo: change extension icon depending on whether there's a video on the page or not
} // }
function _uwbg_rcvmsg(message, sender, sendResponse){ // function _uwbg_rcvmsg(message, sender, sendResponse){
if(Debug.debug){ // if(Debug.debug){
console.log("[uw-bg::_uwbg_rcvmsg] received message", message, "from sender", sender); // console.log("[uw-bg::_uwbg_rcvmsg] received message", message, "from sender", sender);
} // }
message.sender = "uwbg"; // message.sender = "uwbg";
message.receiver = "uw"; // message.receiver = "uw";
if(message.cmd == "has-videos"){ // if(message.cmd == "has-videos"){
if(Debug.debug){ // if(Debug.debug){
console.log("[uw-bg::_uwbg_rcvmsg] does this tab or any of its subframes have videos?", BgVars.hasVideos ); // console.log("[uw-bg::_uwbg_rcvmsg] does this tab or any of its subframes have videos?", BgVars.hasVideos );
} // }
var res = {response: {hasVideos: BgVars.hasVideos}}; // var res = {response: {hasVideos: BgVars.hasVideos}};
if(BrowserDetect.firefox){ // if(BrowserDetect.firefox){
return Promise.resolve(res); // return Promise.resolve(res);
} // }
sendResponse(res); // sendResponse(res);
return true; // return true;
} // }
if(message.cmd == "get-config"){ // if(message.cmd == "get-config"){
var config = {}; // var config = {};
config.videoAlignment = ExtensionConf.miscFullscreenSettings.videoFloat; // config.videoAlignment = ExtensionConf.miscFullscreenSettings.videoFloat;
config.arConf = {}; // config.arConf = {};
config.arConf.enabled_global = ExtensionConf.arDetect.enabled == "blacklist"; // config.arConf.enabled_global = ExtensionConf.arDetect.enabled == "blacklist";
config.site = {}; // config.site = {};
config.site.status = SitesConf.getSiteStatus(BgVars.currentSite); // config.site.status = SitesConf.getSiteStatus(BgVars.currentSite);
config.site.arStatus = SitesConf.getArStatus(BgVars.currentSite); // config.site.arStatus = SitesConf.getArStatus(BgVars.currentSite);
config.mode = ExtensionConf.extensionMode; // config.mode = ExtensionConf.extensionMode;
config.arMode = ExtensionConf.arDetect.mode; // config.arMode = ExtensionConf.arDetect.mode;
config.arDisabledReason = ExtensionConf.arDetect.disabledReason; // config.arDisabledReason = ExtensionConf.arDetect.disabledReason;
config.arTimerPlaying = ExtensionConf.arDetect.timer_playing; // config.arTimerPlaying = ExtensionConf.arDetect.timer_playing;
if(Debug.debug) // if(Debug.debug)
console.log("[uw-bg::_uwbg_rcvmsg] Keybinds.getKeybinds() returned this:", Keybinds.getKeybinds()); // console.log("[uw-bg::_uwbg_rcvmsg] Keybinds.getKeybinds() returned this:", Keybinds.getKeybinds());
config.keyboardShortcuts = Keybinds.getKeybinds(); // config.keyboardShortcuts = Keybinds.getKeybinds();
// predvidevajmo, da je enako. Če je drugače, bomo popravili ko dobimo odgovor // // predvidevajmo, da je enako. Če je drugače, bomo popravili ko dobimo odgovor
// assume current is same as global & change that when you get response from content script // // assume current is same as global & change that when you get response from content script
config.arConf.enabled_current = ExtensionConf.arDetect.enabled == "blacklist"; // config.arConf.enabled_current = ExtensionConf.arDetect.enabled == "blacklist";
var res = {response: config} // var res = {response: config}
if(Debug.debug){ // if(Debug.debug){
console.log("[uw-bg::_uwbg_rcvmsg] get-config: returning this to popup script:", res); // console.log("[uw-bg::_uwbg_rcvmsg] get-config: returning this to popup script:", res);
} // }
if(BrowserDetect.firefox){ // if(BrowserDetect.firefox){
return Promise.resolve(res); // return Promise.resolve(res);
} // }
sendResponse(res); // sendResponse(res);
return true; // return true;
} // }
if(message.cmd == "register-video"){ // if(message.cmd == "register-video"){
// dobili smo sporočilce, ki pravi: "hej jaz imam video, naredi cahen" — ampak preden naredimo cahen, // // dobili smo sporočilce, ki pravi: "hej jaz imam video, naredi cahen" — ampak preden naredimo cahen,
// se je potrebno prepričati, da je sporočilce prišlo iz pravilnega zavihka. Trenutno odprt zavihek // // se je potrebno prepričati, da je sporočilce prišlo iz pravilnega zavihka. Trenutno odprt zavihek
// lahko dobimo to. ID zavihka, iz katerega je prišlo sporočilo, se skriva v sender.tab.id // // lahko dobimo to. ID zavihka, iz katerega je prišlo sporočilo, se skriva v sender.tab.id
// ~<><\\\][=================][///><>~ // // ~<><\\\][=================][///><>~
// we got a message that says: "hey I have a video, make a mark or something" — but before we do the // // we got a message that says: "hey I have a video, make a mark or something" — but before we do the
// mark, we should check if the message has truly arrived from currently active tab. We can get the // // mark, we should check if the message has truly arrived from currently active tab. We can get the
// id of currently active tab here. ID of the sender tab is hidden in sender.tab.id. // // id of currently active tab here. ID of the sender tab is hidden in sender.tab.id.
_uwbg_registerVideo(sender.tab.id); // _uwbg_registerVideo(sender.tab.id);
} // }
else if(message.cmd == "uw-enabled-for-site"){ // else if(message.cmd == "uw-enabled-for-site"){
var mode = SitesConf.getSiteStatus(BgVars.currentSite); // var mode = SitesConf.getSiteStatus(BgVars.currentSite);
if(BrowserDetect.usebrowser == "firefox") // if(BrowserDetect.usebrowser == "firefox")
return Promise.resolve({response: mode}); // return Promise.resolve({response: mode});
try{ // try{
sendResponse({response: mode}); // sendResponse({response: mode});
} // }
catch(chromeIsShitError){}; // catch(chromeIsShitError){};
return true; // return true;
} // }
else if(message.cmd == "enable-for-site"){ // else if(message.cmd == "enable-for-site"){
SitesConf.updateSite(BgVars.currentSite, {status: message.option, statusEmbedded: message.option}); // SitesConf.updateSite(BgVars.currentSite, {status: message.option, statusEmbedded: message.option});
} // }
else if(message.cmd == "enable-autoar"){ // else if(message.cmd == "enable-autoar"){
ExtensionConf.arDetect.mode = "blacklist"; // ExtensionConf.arDetect.mode = "blacklist";
Settings.save(ExtensionConf); // Settings.save(ExtensionConf);
// Comms.sendToAll({cmd: "reload-settings", sender: "uwbg"}) // Comms.sendToAll({cmd: "reload-settings", sender: "uwbg"})
if(Debug.debug){ // if(Debug.debug){
console.log("[uw-bg] autoar set to enabled (blacklist). evidenz:", ExtensionConf); // console.log("[uw-bg] autoar set to enabled (blacklist). evidenz:", ExtensionConf);
} // }
} // }
else if(message.cmd == "disable-autoar"){ // else if(message.cmd == "disable-autoar"){
ExtensionConf.arDetect.mode = "disabled"; // ExtensionConf.arDetect.mode = "disabled";
if(message.reason){ // if(message.reason){
ExtensionConf.arDetect.disabledReason = message.reason; // ExtensionConf.arDetect.disabledReason = message.reason;
} else { // } else {
ExtensionConf.arDetect.disabledReason = ''; // ExtensionConf.arDetect.disabledReason = '';
} // }
Settings.save(ExtensionConf); // Settings.save(ExtensionConf);
// Comms.sendToAll({cmd: "reload-settings", sender: "uwbg"}); // // Comms.sendToAll({cmd: "reload-settings", sender: "uwbg"});
if(Debug.debug){ // if(Debug.debug){
console.log("[uw-bg] autoar set to disabled. evidenz:", ExtensionConf); // console.log("[uw-bg] autoar set to disabled. evidenz:", ExtensionConf);
} // }
} // }
else if(message.cmd == "gib-settings"){ // else if(message.cmd == "gib-settings"){
if(Debug.debug) // if(Debug.debug)
console.log("[uw-bg] we got asked for settings. Returning this:", ExtensionConf); // console.log("[uw-bg] we got asked for settings. Returning this:", ExtensionConf);
if(BrowserDetect.usebrowser == "firefox") // if(BrowserDetect.usebrowser == "firefox")
return Promise.resolve({response: ExtensionConf}); // return Promise.resolve({response: ExtensionConf});
try{ // try{
sendResponse({response: ExtensionConf}); // sendResponse({response: ExtensionConf});
} // }
catch(chromeIsShitError){}; // catch(chromeIsShitError){};
return true; // return true;
} // }
else if(message.cmd = "autoar-set-timer-playing"){ // else if(message.cmd = "autoar-set-timer-playing"){
if(Debug.debug) // if(Debug.debug)
console.log("[uw-bg] trying to set new interval for autoAr. New interval is",message.timeout,"ms"); // console.log("[uw-bg] trying to set new interval for autoAr. New interval is",message.timeout,"ms");
var timeout = message.timeout; // var timeout = message.timeout;
if(timeout < 1) // if(timeout < 1)
timeout = 1; // timeout = 1;
if(timeout > 999) // if(timeout > 999)
timeout = 999; // timeout = 999;
ExtensionConf.arDetect.timer_playing = timeout; // ExtensionConf.arDetect.timer_playing = timeout;
Settings.save(ExtensionConf); // Settings.save(ExtensionConf);
Comms.sendToAll({cmd: "update-settings", sender: "uwbg", newConf: ExtensionConf}); // Comms.sendToAll({cmd: "update-settings", sender: "uwbg", newConf: ExtensionConf});
} // }
} // }
// main(); // main();

View File

@ -273,7 +273,7 @@ document.addEventListener("click", (e) => {
if(e.target.classList.contains("_changeAr")){ if(e.target.classList.contains("_changeAr")){
if(e.target.classList.contains("_ar_auto")){ if(e.target.classList.contains("_ar_auto")){
command.cmd = "autoar-enable"; command.cmd = "autoar-start";
command.enabled = true; command.enabled = true;
return command; return command;
} }
@ -352,18 +352,11 @@ document.addEventListener("click", (e) => {
// this event fires before the checkbox is checked, therefore arStatus is opposite of what it should be // this event fires before the checkbox is checked, therefore arStatus is opposite of what it should be
if(! arStatus){ if(! arStatus){
Comms.sendToBackgroundScript({cmd: "disable-autoar", sender: "popup", receiver: "uwbg"}); return {cmd: "autoar-disable", sender: "popup", receiver: "uwbg"};
Comms.sendToAll({cmd: "disable-autoar", sender: "popup", receiver: "uwbg"}); } else {
Comms.sendToAll({cmd: "stop-autoar", sender: "popup", receiver: "uwbg"}); return {cmd: "autoar-enable", sender: "popup", receiver: "uwbg"};
} }
else{ } else if(e.target.classList.contains("_save_autoAr_frequency")) {
Comms.sendToAll({cmd: "enable-autoar", sender: "popup", receiver: "uwbg"});
Comms.sendToBackgroundScript({cmd: "enable-autoar", sender: "popup", receiver: "uwbg"});
Comms.sendToAll({cmd: "force-ar", newAr: "auto", arType: "legacy", sender: "popup", receiver: "uwbg"});
}
return;
}
else if(e.target.classList.contains("_save_autoAr_frequency")){
var value = parseInt(document.getElementById("_input_autoAr_frequency").value.trim()); var value = parseInt(document.getElementById("_input_autoAr_frequency").value.trim());
if(! isNaN(value)){ if(! isNaN(value)){