ultrawidify/js/uw.js

303 lines
9.2 KiB
JavaScript
Raw Normal View History

if(Debug.debug){
console.log("\n\n\n\n\n\n ——— Sᴛλʀᴛɪɴɢ Uʟᴛʀᴀɪɪʏ ———\n << ʟᴏᴀᴅɪɴɢ ᴍᴀɪɴ ꜰɪʟᴇ >>\n\n\n\n");
try {
if(window.self !== window.top){
console.log("%cWe aren't in an iframe.", "color: #afc, background: #174");
}
else{
console.log("%cWe are in an iframe!", "color: #fea, background: #d31", window.self, window.top);
}
} catch (e) {
console.log("%cWe are in an iframe!", "color: #fea, background: #d31");
}
}
2017-12-02 21:09:08 +01:00
// load all settings from localStorage:
2017-12-17 22:56:07 +01:00
async function main(){
if(Debug.debug)
console.log("[uw::main] loading configuration ...");
2017-12-17 22:56:07 +01:00
// load settings
var isSlave = true;
await Settings.init(isSlave);
2017-12-17 22:56:07 +01:00
var scpromise = SitesConf.init();
var kbpromise = Keybinds.init();
// reset current css stuff in GlobalVars
GlobalVars.correctedVideoDimensions.top = null;
GlobalVars.correctedVideoDimensions.left = null;
GlobalVars.correctedVideoDimensions.width = null;
GlobalVars.correctedVideoDimensions.height = null;
GlobalVars.currentCss = {top: null, left: null};
2017-12-17 22:56:07 +01:00
// počakamo, da so nastavitve naložene
// wait for settings to load
await scpromise;
await kbpromise;
// globalVars: lastAr type = original
GlobalVars.lastAr = {type: "original"};
2017-12-17 22:56:07 +01:00
if(Debug.debug)
console.log("[uw::main] configuration should be loaded now");
2017-12-17 22:56:07 +01:00
// start autoar and setup everything
2017-12-02 21:09:08 +01:00
if(Debug.debug)
console.log("[uw::main] | document is ready. Starting ar script ...");
2017-12-17 22:56:07 +01:00
if(! SitesConf.isEnabled(window.location.hostname)){
2017-12-02 21:09:08 +01:00
if(Debug.debug)
console.log("[uw:main] | site", window.location.hostname, "is blacklisted.");
2017-12-02 21:09:08 +01:00
return;
2018-02-04 17:39:26 +01:00
}
// if(SitesConf.isArEnabled(window.location.hostname)){
// if(Debug.debug)
// console.log("[uw::main] Aspect ratio detection is enabled. Starting ArDetect");
// ArDetect.arSetup();
// }
// console.log("[uw::main] ExtensionConf:", ExtensionConf);
if(ExtensionConf.arDetect.mode == "blacklist"){
2017-12-31 18:26:59 +01:00
if(Debug.debug)
console.log("[uw::main] Aspect ratio detection is enabled (mode=",ExtensionConf.arDetect.mode,"). Starting ArDetect");
2018-02-04 17:39:26 +01:00
ArDetect.arSetup();
2017-12-31 18:26:59 +01:00
}
else{
if(Debug.debug)
console.log("[uw::main] Aspect ratio detection is disabled. Mode:", ExtensionConf.arDetect.mode);
2017-12-31 18:26:59 +01:00
}
2017-01-02 17:45:51 +01:00
2018-01-11 22:43:25 +01:00
browser.runtime.onMessage.addListener(receiveMessage);
setInterval( ghettoOnChange, 100);
2018-02-05 22:46:38 +01:00
setInterval( ghettoUrlWatcher, 500);
// ko se na ticevki zamenja video, console.log pravi da ultrawidify spremeni razmerje stranic. preglej element
// in pogled na predvajalnik pravita, da se to ni zgodilo. Iz tega sledi, da nam ticevka povozi css, ki smo ga
// vsilili. To super duper ni kul, zato uvedemo nekaj protiukrepov.
//
// when you change a video on youtube, console.log says that ultrawidify changes aspect ratio. inspect element
// and a look at youtube player, on the other hand, say this didn't happen. It seems that youtube overrides our
// css, and this is super duper uncool. Therefore, extra checks and measures.
setInterval( Resizer.antiCssOverride, 200);
2017-12-17 22:56:07 +01:00
}
// tukaj gledamo, ali se je velikost predvajalnika spremenila. Če se je, ponovno prožimo resizer
// here we check (in the most ghetto way) whether player size has changed. If it has, we retrigger resizer.
var _video_recheck_counter = 5;
var _video_recheck_period = 1; // on this many retries
2018-01-20 22:59:31 +01:00
function ghettoOnChange(){
2018-01-20 22:59:31 +01:00
if(_video_recheck_counter++ > _video_recheck_period){
_video_recheck_counter = 0;
2018-02-04 17:39:26 +01:00
if ( GlobalVars.video == null ||
GlobalVars.video == undefined ||
GlobalVars.video.videoWidth == 0 ||
GlobalVars.video.videoHeight == 0 ){
2018-01-20 22:59:31 +01:00
var video = document.getElementsByTagName("video")[0];
2018-02-04 17:39:26 +01:00
if ( video !== undefined &&
video !== null &&
video.videoWidth > 0 &&
video.videoHeight > 0 ){
if(Debug.debug){
console.log("%c[uw::ghettoOnChange] detected video. registering!", "color: #99f, background: #000");
console.log("[uw::ghettoOnChange] just for shits and giggles, let's see what's happened with GlobalVars.playerDimensions:", GlobalVars.playerDimensions)
}
// zaznali smo novo <video> značko. Zaradi tega bomo resetirali GlobalVars.playerDimensions
// a new <video> has been detected. We'll be resetting GlobalVars.playerDimensions
GlobalVars.playerDimensions = PlayerDetect.getPlayerDimensions(video);
2018-01-20 22:59:31 +01:00
GlobalVars.video = video;
Comms.sendToBackgroundScript({"cmd":"register-video"});
}
2018-01-20 22:59:31 +01:00
}
}
2018-04-22 15:11:48 +02:00
if(! GlobalVars.video)
2018-01-20 22:59:31 +01:00
return;
if(GlobalVars.playerDimensions == null){
GlobalVars.playerDimensions = PlayerDetect.getPlayerDimensions( GlobalVars.video );
if(GlobalVars.playerDimensions == undefined){
GlobalVars.playerDimensions = null;
return;
}
}
if(PlayerDetect.checkPlayerSizeChange()){
if(Debug.debug){
console.log("[uw::ghettoOnChange] change detected");
}
GlobalVars.playerDimensions = PlayerDetect.getPlayerDimensions( GlobalVars.video );
if(GlobalVars.playerDimensions == undefined){
GlobalVars.playerDimensions = null;
return;
}
2018-04-22 15:11:48 +02:00
Resizer.restore(); // note: this returns true if change goes through, false otherwise.
}
// sometimes, checkPlayerSizeChange might not detect a change to fullscreen. This means we need to
// trick it into doing that
if(GlobalVars.playerDimensions.fullscreen != PlayerDetect.isFullScreen()){
if(Debug.debug){
console.log("[uw::ghettoOnChange] fullscreen switch detected");
}
GlobalVars.playerDimensions = PlayerDetect.getPlayerDimensions(GlobalVars.video);
if(GlobalVars.playerDimensions == undefined){
GlobalVars.playerDimensions = null;
return;
}
Resizer.restore();
}
}
2018-02-05 22:46:38 +01:00
function ghettoUrlWatcher(){
if (GlobalVars.lastUrl != window.location.href){
if(Debug.debug){
console.log("[uw::ghettoUrlWatcher] URL has changed. Trying to retrigger autoAr");
}
GlobalVars.video = null;
GlobalVars.lastUrl = window.location.href;
2018-04-22 15:11:48 +02:00
// Resizer.reset();
2018-02-05 22:46:38 +01:00
main();
}
}
// comms
2018-01-11 22:43:25 +01:00
function receiveMessage(message, sender, sendResponse) {
if(Debug.debug)
console.log("[uw::receiveMessage] we received a message.", message);
2017-12-30 18:36:08 +01:00
if(message.cmd == "has-videos"){
var anyVideos = GlobalVars.video != null;
2018-01-20 22:59:31 +01:00
if(Debug.debug)
console.log("[uw::receiveMessage] are there any videos on this page?", anyVideos, GlobalVars.video, this);
2018-01-20 22:59:31 +01:00
2018-01-11 22:43:25 +01:00
if(BrowserDetect.usebrowser == "firefox")
return Promise.resolve({response: {"hasVideos": anyVideos }});
try{
sendResponse({response: {"hasVideos":anyVideos}});
return true;
}
catch(chromeIsShitError){}
return;
2017-12-30 18:36:08 +01:00
}
else if(message.cmd == "get-config"){
var config = {};
config.videoAlignment = ExtensionConf.miscFullscreenSettings.videoFloat;
config.arConf = {};
config.arConf.enabled_global = ExtensionConf.arDetect.enabled == "global";
var keybinds = Keybinds.getKeybinds();
if(Debug.debug)
console.log("[uw-bg::_uwbg_rcvmsg] Keybinds.fetch returned this:", keybinds);
config.keyboardShortcuts = keybinds;
// 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
config.arConf.enabled_current = ArDetect.isRunning();
2018-01-11 22:43:25 +01:00
if(BrowserDetect.usebrowser == "firefox")
return Promise.resolve({response: config});
try{
sendResponse({response: config});
}
catch(chromeIsShitError){};
2018-01-11 22:43:25 +01:00
return true;
2017-12-30 18:36:08 +01:00
}
2017-12-30 18:36:08 +01:00
else if(message.cmd == "force-ar"){
if(Debug.debug)
console.log("[uw::receiveMessage] we're being commanded to change aspect ratio to", message.newAr);
if(message.arType == "legacy"){
ArDetect.stop();
Resizer.legacyAr(message.newAr);
}
else{
ArDetect.stop();
Resizer.setAr(message.newAr);
}
2017-12-30 18:36:08 +01:00
}
else if(message.cmd == "force-video-float"){
if(Debug.debug)
console.log("[uw::receiveMessage] we're aligning video to", message.newFloat);
ExtensionConf.miscFullscreenSettings.videoFloat = message.newFloat;
Settings.save(ExtensionConf);
}
2017-12-30 18:36:08 +01:00
else if(message.cmd == "stop-autoar"){
ArDetect.stop();
}
else if(message.cmd == "update-settings"){
if(Debug.debug){
console.log("[uw] we got sent new ExtensionConf to abide by:", cmd.newConf);
}
ExtensionConf = cmd.newConf;
}
// else if(message.cmd == "enable-autoar"){
// if(Debug.debug){
// console.log("[uw] enabling autoar.");
// }
// ExtensionConf.autoAr.mode == "blacklist";
// Settings.save(ExtensionConf);
// }
// else if(message.cmd == "disable-autoar"){
// if(Debug.debug){
// console.log("[uw] disabling autoar.");
// }
// ExtensionConf.autoAr.mode == "disabled";
// Settings.save(ExtensionConf);
// }
if(message.cmd == "testing"){
2018-01-11 22:43:25 +01:00
if(Browserdetect.usebrowser = "firefox")
return Promise.resolve({response: "test response hier"});
sendResponse({response: "test response hier"});
return true;
}
}
2017-12-30 02:58:24 +01:00
// $(document).ready(function() {
2018-01-20 22:59:31 +01:00
main();
// });