onUpdated doesn't work the way we want (at least not for netflix), so instead of relying on that we just check for changes periodically.
This commit is contained in:
parent
2fd4cb6701
commit
e7b0f80eb2
12
js/uw-bg.js
12
js/uw-bg.js
@ -1,4 +1,4 @@
|
|||||||
debugmsg = false;
|
debugmsg = true;
|
||||||
url_changed = false;
|
url_changed = false;
|
||||||
|
|
||||||
|
|
||||||
@ -10,15 +10,12 @@ function gibActiveTab(){
|
|||||||
return browser.tabs.query({active: true, currentWindow: true});
|
return browser.tabs.query({active: true, currentWindow: true});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var page_change_msg_count = 0;
|
||||||
|
|
||||||
function notifyChange(){
|
function notifyChange(){
|
||||||
|
|
||||||
if(debugmsg)
|
if(debugmsg)
|
||||||
console.log("uw-bg::tab updated. Did we mark for update?", url_changed);
|
console.log("uw-bg::tab updated. seq:", page_change_msg_count++);
|
||||||
|
|
||||||
if(url_changed) //we've already set the proverbial fuse, no need to trigger the function multiple times
|
|
||||||
return;
|
|
||||||
|
|
||||||
// url_changed = true; // We mark that the page was changed. We wait for a while before triggering changes.
|
|
||||||
|
|
||||||
browser.tabs.query({active: true, currentWindow: true}, function(tabs){
|
browser.tabs.query({active: true, currentWindow: true}, function(tabs){
|
||||||
browser.tabs.sendMessage(tabs[0].id, {message: "page-change"});
|
browser.tabs.sendMessage(tabs[0].id, {message: "page-change"});
|
||||||
@ -27,6 +24,7 @@ function notifyChange(){
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
browser.tabs.onUpdated.addListener(notifyChange);
|
browser.tabs.onUpdated.addListener(notifyChange);
|
||||||
|
|
||||||
browser.runtime.onMessage.addListener(function(request, sender, sendResponse) {
|
browser.runtime.onMessage.addListener(function(request, sender, sendResponse) {
|
||||||
|
74
js/uw.js
74
js/uw.js
@ -1,4 +1,5 @@
|
|||||||
var debugmsg = true;
|
var debugmsg = true;
|
||||||
|
var debugmsg_periodic = false;
|
||||||
if(debugmsg){
|
if(debugmsg){
|
||||||
console.log(". . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . ");
|
console.log(". . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . ");
|
||||||
console.log("\nLoading ultrawidify (uw)\nIf you can see this, extension at least tried to load\n\nRandom number: ",Math.floor(Math.random() * 20) + 1,"\n");
|
console.log("\nLoading ultrawidify (uw)\nIf you can see this, extension at least tried to load\n\nRandom number: ",Math.floor(Math.random() * 20) + 1,"\n");
|
||||||
@ -34,6 +35,14 @@ var button_size_base = "x"; // Determines if size of extension buttons is de
|
|||||||
|
|
||||||
var video_wrap;
|
var video_wrap;
|
||||||
|
|
||||||
|
// Here we store the window size, so we know when to trigger css change.
|
||||||
|
var winsize = {w: window.innerWidth, h: window.innerHeight};
|
||||||
|
|
||||||
|
// provider-specific variables
|
||||||
|
|
||||||
|
var netflix_cltbar_visibility = -1; // -1 for invisible, anything non-negative for visible
|
||||||
|
var netflix_periodic_timer;
|
||||||
|
|
||||||
function init(force_reload){
|
function init(force_reload){
|
||||||
|
|
||||||
if(debugmsg)
|
if(debugmsg)
|
||||||
@ -140,6 +149,7 @@ if(page_url.indexOf("netflix.com") != -1){
|
|||||||
|
|
||||||
//END ADDING CSS
|
//END ADDING CSS
|
||||||
|
|
||||||
|
|
||||||
//BEGIN keybind-related stuff
|
//BEGIN keybind-related stuff
|
||||||
// Yeah hi /r/badcode.
|
// Yeah hi /r/badcode.
|
||||||
// Anyway, because nazi localstorage flat out refuses to store arrays:
|
// Anyway, because nazi localstorage flat out refuses to store arrays:
|
||||||
@ -238,9 +248,53 @@ browser.runtime.onMessage.addListener(function (message, sender, stuff ) {
|
|||||||
// console.log(
|
// console.log(
|
||||||
changeCSS(last_whatdo.type, last_whatdo.what_do);
|
changeCSS(last_whatdo.type, last_whatdo.what_do);
|
||||||
updateCtlButtonSize();
|
updateCtlButtonSize();
|
||||||
|
|
||||||
|
if(debugmsg)
|
||||||
|
console.log("uw::onMessage | message number:",num_of_msg," »» everything is done. Buttons: ", document.getElementsByClassName("uw-button"));
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
//Because onUpdated event isn't reliable enough for what we're doing on netflix.
|
||||||
|
function periodic() {
|
||||||
|
if(debugmsg_periodic)
|
||||||
|
console.log("uw::periodic started!");
|
||||||
|
|
||||||
|
if(document.getElementsByClassName("uw_element").length === 0){
|
||||||
|
if(debugmsg)
|
||||||
|
console.log("uw::periodic | no buttons detected. Readding.");
|
||||||
|
|
||||||
|
init();
|
||||||
|
addCtlButtons(0);
|
||||||
|
}
|
||||||
|
var w = window.innerWidth;
|
||||||
|
var h = window.innerHeight;
|
||||||
|
if(winsize.w != w && winsize.h != h){
|
||||||
|
console.log("uw::periodic | detected change in window size. Triggering css change");
|
||||||
|
winsize.w = w;
|
||||||
|
winsize.h = h;
|
||||||
|
changeCSS(last_whatdo.type, last_whatdo.what_do);
|
||||||
|
updateCtlButtonSize();
|
||||||
|
}
|
||||||
|
var controls = document.getElementsByClassName("player-controls-wrapper")[0];
|
||||||
|
if(controls){
|
||||||
|
if(debugmsg_periodic)
|
||||||
|
console.log("uw::periodic | we found controls!");
|
||||||
|
|
||||||
|
var ind = controls.className.indexOf("display-none");
|
||||||
|
if(debugmsg_periodic)
|
||||||
|
console.log("uw::periodic | ind:",ind,"last ind:",netflix_cltbar_visibility);
|
||||||
|
// controls must be visible. We must have not called updateCtlButtonSize before.
|
||||||
|
if( ind != netflix_cltbar_visibility ){
|
||||||
|
if(debugmsg)
|
||||||
|
console.log("uw::periodic | toggled visibility");
|
||||||
|
netflix_cltbar_visibility = ind;
|
||||||
|
if(ind == -1)
|
||||||
|
updateCtlButtonSize();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
// browser.runtime.onMessage.addListener(request => {
|
// browser.runtime.onMessage.addListener(request => {
|
||||||
// console.log("Message from the background script:");
|
// console.log("Message from the background script:");
|
||||||
// console.log(request.greeting);
|
// console.log(request.greeting);
|
||||||
@ -284,6 +338,14 @@ function extSetup(){
|
|||||||
|
|
||||||
keydownSetup();
|
keydownSetup();
|
||||||
addCtlButtons(0);
|
addCtlButtons(0);
|
||||||
|
|
||||||
|
if(page_url.indexOf("netflix.com") != -1){
|
||||||
|
console.log("uw::extSetup | starting netflix-specific setup steps");
|
||||||
|
if(netflix_periodic_timer)
|
||||||
|
clearInterval(netflix_periodic_timer);
|
||||||
|
netflix_periodic_timer = setInterval(function(){ periodic(); }, 100);
|
||||||
|
}
|
||||||
|
|
||||||
if(debugmsg)
|
if(debugmsg)
|
||||||
console.log("======================================[ setup finished ]======================================");
|
console.log("======================================[ setup finished ]======================================");
|
||||||
}
|
}
|
||||||
@ -397,6 +459,9 @@ function addCtlButtons(recursion_depth){
|
|||||||
var button_width = document.getElementsByClassName(sample_button_class)[sample_button_index].scrollHeight;
|
var button_width = document.getElementsByClassName(sample_button_class)[sample_button_index].scrollHeight;
|
||||||
else
|
else
|
||||||
var button_width = document.getElementsByClassName(sample_button_class)[sample_button_index].scrollWidth;
|
var button_width = document.getElementsByClassName(sample_button_class)[sample_button_index].scrollWidth;
|
||||||
|
|
||||||
|
if(debugmsg)
|
||||||
|
console.log("uw::addCtlButtons | width of the element is ", button_width , "and is based on the height of this element:", document.getElementsByClassName(sample_button_class)[sample_button_index], " <extra tags: onMessage>")
|
||||||
}
|
}
|
||||||
catch(e){
|
catch(e){
|
||||||
// Zato, ker predvajalnik ni vselej prisoten. Če predvajalnik ni prisoten,
|
// Zato, ker predvajalnik ni vselej prisoten. Če predvajalnik ni prisoten,
|
||||||
@ -497,6 +562,7 @@ function addCtlButtons(recursion_depth){
|
|||||||
buttons[i].style.backgroundImage = 'url(' + resourceToUrl("/res/img/ytplayer-icons/" + button_def[i] + ".png") + ')';
|
buttons[i].style.backgroundImage = 'url(' + resourceToUrl("/res/img/ytplayer-icons/" + button_def[i] + ".png") + ')';
|
||||||
buttons[i].style.width = (button_width * 0.75) + "px";
|
buttons[i].style.width = (button_width * 0.75) + "px";
|
||||||
buttons[i].style.height = (button_width) + "px";
|
buttons[i].style.height = (button_width) + "px";
|
||||||
|
buttons[i].style.width = 0;
|
||||||
// buttons[i].style.marginLeft = (button_width * 0.3) + "px";
|
// buttons[i].style.marginLeft = (button_width * 0.3) + "px";
|
||||||
buttons[i].style.paddingLeft = (button_width *0.15 ) + "px";
|
buttons[i].style.paddingLeft = (button_width *0.15 ) + "px";
|
||||||
buttons[i].style.paddingRight = (button_width * 0.15) + "px";
|
buttons[i].style.paddingRight = (button_width * 0.15) + "px";
|
||||||
@ -778,9 +844,15 @@ function changeCSS(type, what_do){
|
|||||||
hideMenu("uw-smenu");
|
hideMenu("uw-smenu");
|
||||||
|
|
||||||
|
|
||||||
|
var evideo = $("video")[0];
|
||||||
|
|
||||||
|
if(!evideo){
|
||||||
|
if(debugmsg)
|
||||||
|
console.log("uw::changeCSS | no video element found. Doing nothing.");
|
||||||
|
|
||||||
var video = { "width": $("video")[0].scrollWidth, "height": $("video")[0].scrollHeight };
|
return;
|
||||||
|
}
|
||||||
|
var video = { "width": evideo.scrollWidth, "height": evideo.scrollHeight };
|
||||||
|
|
||||||
var nplayer = { "width": player.clientWidth, "height": player.clientHeight }
|
var nplayer = { "width": player.clientWidth, "height": player.clientHeight }
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user