Replace consoles in ext with custom logger

This commit is contained in:
Tamius Han 2019-07-18 21:25:58 +02:00
parent f0fa6aa9a8
commit 338afad417
13 changed files with 229 additions and 330 deletions

View File

@ -2,6 +2,46 @@
// version: {ExtensionConf object, but only properties that get overwritten} // version: {ExtensionConf object, but only properties that get overwritten}
const ExtensionConfPatch = { const ExtensionConfPatch = {
'4.3.0': {
sites: {
"old.reddit.com" : {
type: 'testing',
DOM: {
player: {
manual: true,
useRelativeAncestor: false,
querySelectors: '.media-preview-content'
}
},
css: '',
},
"www.reddit.com" : {
type: 'testing',
DOM: {
player: {
manual: true,
useRelativeAncestor: false,
querySelectors: '.media-preview-content'
}
},
css: '',
},
"www.youtube.com" : {
DOM: {
player: {
manual: true,
querySelectors: "#movie_player, #player",
additionalCss: "",
useRelativeAncestor: false,
playerNodeCss: "",
}
}
},
"www.netflix.com" : {
arPersistance: true
}
}
},
'4.2.1': { '4.2.1': {
sites: { sites: {
"old.reddit.com" : { "old.reddit.com" : {

View File

@ -915,6 +915,7 @@ whatsNewChecked: true,
stretch: Stretch.Default, stretch: Stretch.Default,
videoAlignment: VideoAlignment.Default, videoAlignment: VideoAlignment.Default,
keyboardShortcutsEnabled: ExtensionMode.Default, keyboardShortcutsEnabled: ExtensionMode.Default,
arPersistence: true, // persist aspect ratio between different videos
autoarPreventConditions: { // prevents autoar on following conditions autoarPreventConditions: { // prevents autoar on following conditions
videoStyleString: { // if video style string thing does anything of what follows videoStyleString: { // if video style string thing does anything of what follows
containsProperty: { // if video style string has any of these properties (listed as keys) containsProperty: { // if video style string has any of these properties (listed as keys)

View File

@ -4,18 +4,17 @@ import ExtensionMode from '../../common/enums/extension-mode.enum';
class ActionHandler { class ActionHandler {
constructor(pageInfo) { constructor(pageInfo, logger) {
this.pageInfo = pageInfo; this.pageInfo = pageInfo;
this.settings = pageInfo.settings; this.settings = pageInfo.settings;
this.inputs = ['input', 'select', 'button', 'textarea']; this.inputs = ['input', 'select', 'button', 'textarea'];
this.keyboardLocalDisabled = false; this.keyboardLocalDisabled = false;
this.logger = logger;
} }
init() { init() {
if (Debug.debug) { this.logger.log('info', 'debug', "[ActionHandler::init] starting init");
console.log("[ActionHandler::init] starting init");
}
this.keyUpActions = []; this.keyUpActions = [];
this.keyDownActions = []; this.keyDownActions = [];
@ -105,15 +104,13 @@ class ActionHandler {
document.addEventListener('keyup', (event) => ths.handleKeyup(event) ); document.addEventListener('keyup', (event) => ths.handleKeyup(event) );
this.pageInfo.setActionHandler(this); this.pageInfo.setActionHandler(this);
if (Debug.debug) {
console.log("[ActionHandler::init] initialization complete"); this.logger.log('info', 'debug', "[ActionHandler::init] initialization complete");
}
} }
registerHandleMouse(videoData) { registerHandleMouse(videoData) {
if (Debug.debug && Debug.mousemove) { this.logger.log('info', ['actionHandler', 'mousemove'], "[ActionHandler::registerHandleMouse] registering handle mouse for videodata:", videoData)
console.log("[ActionHandler::registerHandleMouse] registering handle mouse for videodata:", videoData)
}
var ths = this; var ths = this;
if (videoData.player && videoData.player.element) { if (videoData.player && videoData.player.element) {
videoData.player.element.addEventListener('mousemove', (event) => ths.handleMouseMove(event, videoData)); videoData.player.element.addEventListener('mousemove', (event) => ths.handleMouseMove(event, videoData));
@ -133,10 +130,10 @@ class ActionHandler {
preventAction() { preventAction() {
var activeElement = document.activeElement; var activeElement = document.activeElement;
if(Debug.debug && Debug.keyboard) { if(this.logger.canLog('keyboard')) {
Debug.debug = false; // temp disable to avoid recursing; this.logger.pause(); // temp disable to avoid recursing;
console.log("[ActionHandler::preventAction] Testing whether we're in a textbox or something. Detailed rundown of conditions:\n" + this.logger.log('info', 'keyboard', "[ActionHandler::preventAction] Testing whether we're in a textbox or something. Detailed rundown of conditions:\n" +
"is full screen? (yes->allow):", PlayerData.isFullScreen(), "is full screen? (yes->allow):", PlayerData.isFullScreen(),
"\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",
@ -151,7 +148,7 @@ class ActionHandler {
"insta-fail inputs:", this.inputs "insta-fail inputs:", this.inputs
); );
Debug.debug = true; // undisable this.logger.resume(); // undisable
} }
// lately youtube has allowed you to read and write comments while watching video in // lately youtube has allowed you to read and write comments while watching video in
@ -187,15 +184,11 @@ class ActionHandler {
} }
execAction(actions, event, videoData) { execAction(actions, event, videoData) {
if(Debug.debug && Debug.keyboard ){ this.logger.log('info', 'keyboard', "%c[ActionHandler::execAction] Trying to find and execute action for event. Actions/event: ", "color: #ff0", actions, event);
console.log("%c[ActionHandler::execAction] Trying to find and execute action for event. Actions/event: ", "color: #ff0", actions, event);
}
for (var action of actions) { for (var action of actions) {
if (this.isActionMatch(action.shortcut, event)) { if (this.isActionMatch(action.shortcut, event)) {
if(Debug.debug && Debug.keyboard ){ this.logger.log('info', 'keyboard', "%c[ActionHandler::execAction] found an action associated with keypress/event: ", "color: #ff0", action);
console.log("%c[ActionHandler::execAction] found an action associated with keypress/event: ", "color: #ff0", action);
}
for (var cmd of action.cmd) { for (var cmd of action.cmd) {
if (action.scope === 'page') { if (action.scope === 'page') {
@ -243,14 +236,10 @@ class ActionHandler {
handleKeyup(event) { handleKeyup(event) {
if(Debug.debug && Debug.keyboard ){ this.logger.log('info', 'keyboard', "%c[ActionHandler::handleKeyup] we pressed a key: ", "color: #ff0", event.key , " | keyup: ", event.keyup, "event:", event);
console.log("%c[ActionHandler::handleKeyup] we pressed a key: ", "color: #ff0", event.key , " | keyup: ", event.keyup, "event:", event);
}
if (this.preventAction()) { if (this.preventAction()) {
if (Debug.debug && Debug.keyboard) { this.logger.log('info', 'keyboard', "[ActionHandler::handleKeyup] we are in a text box or something. Doing nothing.");
console.log("[ActionHandler::handleKeyup] we are in a text box or something. Doing nothing.");
}
return; return;
} }
@ -263,9 +252,7 @@ class ActionHandler {
} }
if (this.preventAction()) { if (this.preventAction()) {
if (Debug.debug && Debug.keyboard) { this.logger.log('info', 'keyboard', "[ActionHandler::handleKeydown] we are in a text box or something. Doing nothing.");
console.log("[ActionHandler::handleKeydown] we are in a text box or something. Doing nothing.");
}
return; return;
} }
@ -273,9 +260,7 @@ class ActionHandler {
} }
handleMouseMove(event, videoData) { handleMouseMove(event, videoData) {
if (Debug.debug && Debug.mousemove) { this.logger.log('info', 'keyboard', "[ActionHandler::handleMouseMove] mouse move is being handled.\nevent:", event, "\nvideo data:", videoData);
console.log("[ActionHandler::handleMouseMove] mouse move is being handled.\nevent:", event, "\nvideo data:", videoData);
}
videoData.panHandler(event); videoData.panHandler(event);
this.execAction(this.mouseMoveActions, event, videoData) this.execAction(this.mouseMoveActions, event, videoData)
} }

View File

@ -3,6 +3,7 @@ class Logger {
this.conf = conf; this.conf = conf;
this.history = []; this.history = [];
this.startTime = performance.now(); this.startTime = performance.now();
this.temp_disable = false;
} }
clear() { clear() {
@ -39,7 +40,34 @@ class Logger {
return logfileStr; return logfileStr;
} }
pause() {
this.temp_disable = true;
}
resume() {
this.temp_disable = false;
}
canLog(component) { canLog(component) {
return this.canLogFile(component) || this.canLogConsole(component);
}
canLogFile(component) {
if (!this.conf.fileOptions.enabled || this.temp_disable) {
return false;
}
if (component.length ) {
for (const c in component) {
if (this.conf.fileOptions[component]) {
return this.conf.fileOptions[component];
}
}
}
return this.conf.fileOptions[component];
}
canLogConsole(component) {
if (!this.conf.consoleOptions.enabled || this.temp_disable) {
return false;
}
if (component.length) { if (component.length) {
for (const c in component) { for (const c in component) {
if (this.conf.fileOptions[component]) { if (this.conf.fileOptions[component]) {
@ -58,7 +86,7 @@ class Logger {
return; return;
} }
if (this.conf.logToFile) { if (this.conf.logToFile) {
if (this.canLog(component)) { if (this.canLogFile(component)) {
let ts = performance.now(); let ts = performance.now();
if (ts <= this.history[this.history.length - 1]) { if (ts <= this.history[this.history.length - 1]) {
ts = this.history[this.history.length - 1] + 0.00001; ts = this.history[this.history.length - 1] + 0.00001;
@ -71,7 +99,7 @@ class Logger {
} }
} }
if (this.conf.logToConsole) { if (this.conf.logToConsole) {
if (this.canLog(component)) { if (this.canLogConsole(component)) {
console.log(...message); console.log(...message);
} }
} }

View File

@ -2,7 +2,7 @@ import Debug from '../../conf/Debug';
import BrowserDetect from '../../conf/BrowserDetect'; import BrowserDetect from '../../conf/BrowserDetect';
class CommsClient { class CommsClient {
constructor(name, settings) { constructor(name, settings, logger) {
if (BrowserDetect.firefox) { if (BrowserDetect.firefox) {
this.port = browser.runtime.connect({name: name}); this.port = browser.runtime.connect({name: name});
} else if (BrowserDetect.chrome) { } else if (BrowserDetect.chrome) {
@ -18,6 +18,7 @@ class CommsClient {
this.settings = settings; this.settings = settings;
this.pageInfo = undefined; this.pageInfo = undefined;
this.commsId = (Math.random() * 20).toFixed(0); this.commsId = (Math.random() * 20).toFixed(0);
this.logger = logger;
} }
destroy() { destroy() {
@ -32,9 +33,7 @@ class CommsClient {
this.pageInfo = pageInfo; this.pageInfo = pageInfo;
if(Debug.debug) { this.logger.log('info', 'debug', `[CommsClient::setPageInfo] <${this.commsId}>`, "SETTING PAGEINFO —", this.pageInfo, this)
console.log(`[CommsClient::setPageInfo] <${this.commsId}>`, "SETTING PAGEINFO —", this.pageInfo, this)
}
var ths = this; var ths = this;
this._listener = m => ths.processReceivedMessage(m); this._listener = m => ths.processReceivedMessage(m);
@ -46,17 +45,13 @@ class CommsClient {
} }
processReceivedMessage(message){ processReceivedMessage(message){
if(Debug.debug && Debug.comms){ this.logger.log('info', 'comms', `[CommsClient.js::processMessage] <${this.commsId}> Received message from background script!`, message);
console.log(`[CommsClient.js::processMessage] <${this.commsId}> Received message from background script!`, message);
}
if (!this.pageInfo || !this.settings.active) { if (!this.pageInfo || !this.settings.active) {
if(Debug.debug && Debug.comms){ this.logger.log('info', 'comms', `[CommsClient.js::processMessage] <${this.commsId}> this.pageInfo (or settings) not defined. Extension is probably disabled for this site.\npageInfo:`, this.pageInfo,
console.log(`[CommsClient.js::processMessage] <${this.commsId}> this.pageInfo (or settings) not defined. Extension is probably disabled for this site.\npageInfo:`, this.pageInfo,
"\nsettings.active:", this.settings.active, "\nsettings.active:", this.settings.active,
"\nnobj:", this "\nnobj:", this
); );
}
return; return;
} }
@ -135,13 +130,11 @@ class CommsClient {
} }
async requestSettings(){ async requestSettings(){
if(Debug.debug){ this.logger.log('info', 'comms', "%c[CommsClient::requestSettings] sending request for congif!", "background: #11D; color: #aad");
console.log("%c[CommsClient::requestSettings] sending request for congif!", "background: #11D; color: #aad");
}
var response = await this.sendMessage_nonpersistent({cmd: 'get-config'}); var response = await this.sendMessage_nonpersistent({cmd: 'get-config'});
if(Debug.debug){
console.log("%c[CommsClient::requestSettings] received settings response!", "background: #11D; color: #aad", response); this.logger.log('info', 'comms', "%c[CommsClient::requestSettings] received settings response!", "background: #11D; color: #aad", response);
}
if(! response || response.extensionConf){ if(! response || response.extensionConf){
return Promise.resolve(false); return Promise.resolve(false);
@ -156,9 +149,7 @@ class CommsClient {
} }
registerVideo(){ registerVideo(){
if (Debug.debug && Debug.comms) { this.logger.log('info', 'comms', `[CommsClient::registerVideo] <${this.commsId}>`, "Registering video for current page.");
console.log(`[CommsClient::registerVideo] <${this.commsId}>`, "Registering video for current page.");
}
if (this.pageInfo) { if (this.pageInfo) {
if (this.pageInfo.hasVideo()) { if (this.pageInfo.hasVideo()) {
this.port.postMessage({cmd: "has-video"}); this.port.postMessage({cmd: "has-video"});
@ -173,9 +164,7 @@ class CommsClient {
} }
unregisterVideo(){ unregisterVideo(){
if (Debug.debug && Debug.comms) { this.logger.log('info', 'comms', `[CommsClient::unregisterVideo] <${this.commsId}>`, "Unregistering video for current page.");
console.log(`[CommsClient::unregisterVideo] <${this.commsId}>`, "Unregistering video for current page.");
}
this.port.postMessage({cmd: "noVideo"}); // ayymd this.port.postMessage({cmd: "noVideo"}); // ayymd
} }

View File

@ -9,7 +9,7 @@ if(Debug.debug)
class PageInfo { class PageInfo {
constructor(comms, settings, extensionMode, readOnly = false){ constructor(comms, settings, logger, extensionMode, readOnly = false){
this.hasVideos = false; this.hasVideos = false;
this.siteDisabled = false; this.siteDisabled = false;
this.videos = []; this.videos = [];
@ -20,6 +20,8 @@ class PageInfo {
this.extensionMode = extensionMode; this.extensionMode = extensionMode;
this.readOnly = readOnly; this.readOnly = readOnly;
this.logger = logger;
if (comms){ if (comms){
this.comms = comms; this.comms = comms;
} }
@ -42,9 +44,7 @@ class PageInfo {
} }
destroy() { destroy() {
if(Debug.debug || Debug.init){ this.logger.log('info', ['debug', 'init'], "[PageInfo::destroy] destroying all videos!")
console.log("[PageInfo::destroy] destroying all videos!")
}
if(this.rescanTimer){ if(this.rescanTimer){
clearTimeout(this.rescanTimer); clearTimeout(this.rescanTimer);
} }
@ -118,9 +118,7 @@ class PageInfo {
this.hasVideos = false; this.hasVideos = false;
if(rescanReason == RescanReason.PERIODIC){ if(rescanReason == RescanReason.PERIODIC){
if (Debug.debug && Debug.videoRescan && Debug.periodic) { this.logger.log('info', 'videoRescan', "[PageInfo::rescan] Scheduling normal rescan.")
console.log("[PageInfo::rescan] Scheduling normal rescan:")
}
this.scheduleRescan(RescanReason.PERIODIC); this.scheduleRescan(RescanReason.PERIODIC);
} }
return; return;
@ -169,18 +167,14 @@ class PageInfo {
if (videoExists) { if (videoExists) {
continue; continue;
} else { } else {
if (Debug.debug && Debug.periodic && Debug.videoRescan) { this.logger.log('info', 'videoRescan', "[PageInfo::rescan] found new video candidate:", video, "NOTE:: Video initialization starts here:\n--------------------------------\n")
console.log("[PageInfo::rescan] found new video candidate:", video, "NOTE:: Video initialization starts here:\n--------------------------------\n")
}
v = new VideoData(video, this.settings, this); v = new VideoData(video, this.settings, this, logger);
// console.log("[PageInfo::rescan] v is:", v) // console.log("[PageInfo::rescan] v is:", v)
v.initArDetection(); v.initArDetection();
this.videos.push(v); this.videos.push(v);
if(Debug.debug && Debug.periodic && Debug.videoRescan){ this.logger.log('info', 'videoRescan', "END VIDEO INITIALIZATION\n\n\n-------------------------------------\nvideos[] is now this:", this.videos,"\n\n\n\n\n\n\n\n")
console.log("[PageInfo::rescan] END VIDEO INITIALIZATION\n\n\n-------------------------------------\nvideos[] is now this:", this.videos,"\n\n\n\n\n\n\n\n")
}
} }
} }
@ -212,9 +206,7 @@ class PageInfo {
// if we encounter a fuckup, we can assume that no videos were found on the page. We destroy all videoData // if we encounter a fuckup, we can assume that no videos were found on the page. We destroy all videoData
// objects to prevent multiple initalization (which happened, but I don't know why). No biggie if we destroyed // objects to prevent multiple initalization (which happened, but I don't know why). No biggie if we destroyed
// videoData objects in error — they'll be back in the next rescan // videoData objects in error — they'll be back in the next rescan
if (Debug.debug) { this.logger.log('error', 'debug', "rescan error: — destroying all videoData objects",e);
console.log("rescan error: — destroying all videoData objects",e);
}
for (const v of this.videos) { for (const v of this.videos) {
v.destroy(); v.destroy();
} }
@ -249,9 +241,7 @@ class PageInfo {
ths = null; ths = null;
}, this.settings.active.pageInfo.timeouts.rescan, RescanReason.PERIODIC) }, this.settings.active.pageInfo.timeouts.rescan, RescanReason.PERIODIC)
} catch(e) { } catch(e) {
if(Debug.debug){ this.logger.log('error', 'debug', "[PageInfo::scheduleRescan] scheduling rescan failed. Here's why:",e)
console.log("[PageInfo::scheduleRescan] scheduling rescan failed. Here's why:",e)
}
} }
} }
@ -269,17 +259,13 @@ class PageInfo {
ths = null; ths = null;
}, this.settings.active.pageInfo.timeouts.urlCheck) }, this.settings.active.pageInfo.timeouts.urlCheck)
} catch(e){ } catch(e){
if(Debug.debug){ this.logger.log('error', 'debug', "[PageInfo::scheduleUrlCheck] scheduling URL check failed. Here's why:",e)
console.error("[PageInfo::scheduleUrlCheck] scheduling URL check failed. Here's why:",e)
}
} }
} }
ghettoUrlCheck() { ghettoUrlCheck() {
if (this.lastUrl != window.location.href){ if (this.lastUrl != window.location.href){
if(Debug.debug && Debug.periodic){ this.logger.log('error', 'videoRescan', "[PageInfo::ghettoUrlCheck] URL has changed. Triggering a rescan!");
console.log("[PageInfo::ghettoUrlCheck] URL has changed. Triggering a rescan!");
}
this.rescan(RescanReason.URL_CHANGE); this.rescan(RescanReason.URL_CHANGE);
this.lastUrl = window.location.href; this.lastUrl = window.location.href;
@ -343,7 +329,7 @@ class PageInfo {
startArDetection(playingOnly){ startArDetection(playingOnly){
if (Debug.debug) { if (Debug.debug) {
console.log('[PageInfo::startArDetection()] starting automatic ar detection!') this.logger.log('info', 'debug', '[PageInfo::startArDetection()] starting automatic ar detection!')
} }
if (playingOnly) { if (playingOnly) {
for(var vd of this.videos){ for(var vd of this.videos){
@ -373,16 +359,12 @@ class PageInfo {
} }
setAr(ar, playingOnly){ setAr(ar, playingOnly){
if (Debug.debug) { this.logger.log('info', 'debug', '[PageInfo::setAr] aspect ratio:', ar, "playing only?", playingOnly)
console.log('[PageInfo::setAr] aspect ratio:', ar, "playing only?", playingOnly)
}
if (ar.type !== AspectRatio.Automatic) { if (ar.type !== AspectRatio.Automatic) {
this.stopArDetection(playingOnly); this.stopArDetection(playingOnly);
} else { } else {
if (Debug.debug) { this.logger.log('info', 'debug', '[PageInfo::setAr] aspect ratio is auto');
console.log('[PageInfo::setAr] aspect ratio is auto');
}
try { try {
for (var vd of this.videos) { for (var vd of this.videos) {
@ -391,7 +373,7 @@ class PageInfo {
} }
} }
} catch (e) { } catch (e) {
console.log("???", e); this.logger.log('error', 'debug', "???", e);
} }
this.initArDetection(playingOnly); this.initArDetection(playingOnly);
this.startArDetection(playingOnly); this.startArDetection(playingOnly);

View File

@ -33,7 +33,7 @@ if(Debug.debug)
*/ */
class PlayerData { class PlayerData {
constructor(videoData) { constructor(videoData, logger) {
this.videoData = videoData; this.videoData = videoData;
this.video = videoData.video; this.video = videoData.video;
this.settings = videoData.settings; this.settings = videoData.settings;
@ -41,6 +41,7 @@ class PlayerData {
this.element = undefined; this.element = undefined;
this.dimensions = undefined; this.dimensions = undefined;
this.overlayNode = undefined; this.overlayNode = undefined;
this.logger = logger;
if (this.extensionMode === ExtensionMode.Enabled) { if (this.extensionMode === ExtensionMode.Enabled) {
this.getPlayerDimensions(); this.getPlayerDimensions();
@ -117,9 +118,7 @@ class PlayerData {
} }
unmarkPlayer() { unmarkPlayer() {
if (Debug.debug) { this.logger.log('info', 'debug', "[PlayerData::unmarkPlayer] unmarking player!")
console.log("[PlayerData::unmarkPlayer] unmarking player!")
}
if (this.playerIdElement) { if (this.playerIdElement) {
this.playerIdElement.remove(); this.playerIdElement.remove();
} }
@ -146,9 +145,7 @@ class PlayerData {
try{ try{
ths.ghettoWatcher(); ths.ghettoWatcher();
} catch(e) { } catch(e) {
if (Debug.debug) { this.logger.log('info', 'debug', "[PlayerData::scheduleGhettoWatcher] Scheduling failed. Error:",e)
console.log("[PlayerData::scheduleGhettoWatcher] Scheduling failed. Error:",e)
}
ths.scheduleGhettoWatcher(1000); ths.scheduleGhettoWatcher(1000);
} }
@ -160,9 +157,7 @@ class PlayerData {
ghettoWatcherFull() { ghettoWatcherFull() {
if(this.checkPlayerSizeChange()){ if(this.checkPlayerSizeChange()){
if(Debug.debug){ this.logger.log('info', 'debug', "[uw::ghettoOnChange] change detected");
console.log("[uw::ghettoOnChange] change detected");
}
this.getPlayerDimensions(); this.getPlayerDimensions();
if(! this.element ){ if(! this.element ){
@ -179,9 +174,7 @@ class PlayerData {
// trick it into doing that // trick it into doing that
if(this.dimensions.fullscreen != PlayerData.isFullScreen()) { if(this.dimensions.fullscreen != PlayerData.isFullScreen()) {
if(Debug.debug){ this.logger.log('info', 'debug', "[PlayerData::ghettoWatcher] fullscreen switch detected (basic change detection failed)");
console.log("[PlayerData::ghettoWatcher] fullscreen switch detected (basic change detection failed)");
}
this.getPlayerDimensions(); this.getPlayerDimensions();
@ -238,9 +231,7 @@ class PlayerData {
let element = this.video.parentNode; let element = this.video.parentNode;
if(! element ){ if(! element ){
if(Debug.debug) { this.logger.log('info', 'debug', "[PlayerDetect::_pd_getPlayer] element is not valid, doing nothing.", element)
console.log("[PlayerDetect::_pd_getPlayer] element is not valid, doing nothing.", element)
}
if(this.element) { if(this.element) {
const ths = this; const ths = this;
} }
@ -306,16 +297,11 @@ class PlayerData {
grows = trustCandidateAfterGrows; grows = trustCandidateAfterGrows;
if(Debug.debug){ this.logger.log('info', 'debug', "Found new candidate for player. Dimensions: w:", candidate_width, "h:",candidate_height, "node:", playerCandidateNode);
console.log("Found new candidate for player. Dimensions: w:", candidate_width, "h:",candidate_height, "node:", playerCandidateNode);
}
} }
} }
else if(grows --<= 0){ else if(grows --<= 0){
this.logger.log('info', 'playerDetect', "Current element grew in comparrison to the child. We probably found the player. breaking loop, returning current result");
if(Debug.debug && Debug.playerDetect){
console.log("Current element grew in comparrison to the child. We probably found the player. breaking loop, returning current result");
}
break; break;
} }
@ -334,9 +320,7 @@ class PlayerData {
const element = this.getPlayer(isFullScreen); const element = this.getPlayer(isFullScreen);
if(! element ){ if(! element ){
if(Debug.debug) { this.logger.log('error', 'debug', "[PlayerDetect::getPlayerDimensions] element is not valid, doing nothing.", element)
console.log("[PlayerDetect::getPlayerDimensions] element is not valid, doing nothing.", element)
}
this.element = undefined; this.element = undefined;
this.dimensions = undefined; this.dimensions = undefined;
return; return;
@ -367,7 +351,7 @@ class PlayerData {
} }
checkPlayerSizeChange(){ checkPlayerSizeChange(){
if(Debug.debug){ if (this.logger.canLog('debug')){
if(this.element == undefined){ if(this.element == undefined){
// return true; // return true;
} }
@ -378,18 +362,18 @@ class PlayerData {
if (this.dimensions && this.dimensions.fullscreen){ if (this.dimensions && this.dimensions.fullscreen){
if(! PlayerData.isFullScreen()){ if(! PlayerData.isFullScreen()){
console.log("[PlayerDetect] player size changed. reason: exited fullscreen"); this.logger.log('info', 'debug', "[PlayerDetect] player size changed. reason: exited fullscreen");
} }
} }
if(! this.element && Debug.debug && Debug.playerDetect) { if(! this.element) {
console.log("[PlayerDetect] player element isnt defined"); this.logger.log('info', 'playerDetect', "[PlayerDetect] player element isnt defined");
} }
if ( this.element && if ( this.element &&
( this.dimensions.width != this.element.offsetWidth || ( this.dimensions.width != this.element.offsetWidth ||
this.dimensions.height != this.element.offsetHeight ) this.dimensions.height != this.element.offsetHeight )
) { ) {
console.log("[PlayerDetect] player size changed. reason: dimension change. Old dimensions?", this.dimensions.width, this.dimensions.height, "new dimensions:", this.element.offsetWidth, this.element.offsetHeight); this.logger.log('info', 'debug', "[PlayerDetect] player size changed. reason: dimension change. Old dimensions?", this.dimensions.width, this.dimensions.height, "new dimensions:", this.element.offsetWidth, this.element.offsetHeight);
} }
} }
@ -417,9 +401,7 @@ class PlayerData {
return false; return false;
} }
if(Debug.debug) { this.logger.log('info', 'debug', "[PlayerData::checkFullscreenChange] this.dimensions is not defined. Assuming fs change happened and setting default values.")
console.log("[PlayerData::checkFullscreenChange] this.dimensions is not defined. Assuming fs change happened and setting default values.")
}
this.dimensions = { this.dimensions = {
fullscreen: isFs, fullscreen: isFs,

View File

@ -5,35 +5,31 @@ import ArDetector from '../ar-detect/ArDetector';
class VideoData { class VideoData {
constructor(video, settings, pageInfo){ constructor(video, settings, pageInfo, logger){
this.arSetupComplete = false; this.arSetupComplete = false;
this.video = video; this.video = video;
this.destroyed = false; this.destroyed = false;
this.settings = settings; this.settings = settings;
this.pageInfo = pageInfo; this.pageInfo = pageInfo;
this.extensionMode = pageInfo.extensionMode; this.extensionMode = pageInfo.extensionMode;
this.logger = logger;
// POZOR: VRSTNI RED JE POMEMBEN (arDetect mora bit zadnji) // POZOR: VRSTNI RED JE POMEMBEN (arDetect mora bit zadnji)
// NOTE: ORDERING OF OBJ INITIALIZATIONS IS IMPORTANT (arDetect needs to go last) // NOTE: ORDERING OF OBJ INITIALIZATIONS IS IMPORTANT (arDetect needs to go last)
this.player = new PlayerData(this); this.player = new PlayerData(this, logger);
this.resizer = new Resizer(this); this.resizer = new Resizer(this, logger);
this.arDetector = new ArDetector(this); // this starts Ar detection. needs optional parameter that prevets ardetdctor from starting this.arDetector = new ArDetector(this, logger); // 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
// apply default align and stretch // apply default align and stretch
if (Debug.init) { this.logger.log('info', 'debug', "%c[VideoData::ctor] Initial resizer reset!", {background: '#afd', color: '#132'});
console.log("%c[VideoData::ctor] Initial resizer reset!", {background: '#afd', color: '#132'});
}
this.resizer.reset(); this.resizer.reset();
this.vdid = (Math.random()*100).toFixed(); this.vdid = (Math.random()*100).toFixed();
if (Debug.init) { this.logger.log('info', 'init', "[VideoData::ctor] Created videoData with vdid", this.vdid,"\nextension mode:", this.extensionMode);
console.log("[VideoData::ctor] Created videoData with vdid", this.vdid,"\nextension mode:", this.extensionMode);
}
this.pageInfo.initMouseActionHandler(this); this.pageInfo.initMouseActionHandler(this);
} }
@ -61,9 +57,7 @@ class VideoData {
} }
startArDetection() { startArDetection() {
if (Debug.debug) { this.logger.log('info', 'debug', "[VideoData::startArDetection] starting AR detection")
console.log("[VideoData::startArDetection] starting AR detection")
}
if(this.destroyed) { if(this.destroyed) {
throw {error: 'VIDEO_DATA_DESTROYED', data: {videoData: this}}; throw {error: 'VIDEO_DATA_DESTROYED', data: {videoData: this}};
} }
@ -87,9 +81,7 @@ class VideoData {
} }
destroy() { destroy() {
if(Debug.debug || Debug.init){ this.logger.log('info', ['debug', 'init'], `[VideoData::destroy] <vdid:${this.vdid}> received destroy command`);
console.log(`[VideoData::destroy] <vdid:${this.vdid}> received destroy command`);
}
this.pause(); this.pause();
this.destroyed = true; this.destroyed = true;
@ -133,9 +125,7 @@ class VideoData {
this.player.start(); this.player.start();
} }
} catch (e) { } catch (e) {
if(Debug.debug){ this.logger.log('error', 'debug', "[VideoData.js::resume] cannot resume for reasons. Will destroy videoData. Error here:", e);
console.log("[VideoData.js::resume] cannot resume for reasons. Will destroy videoData. Error here:", e);
}
this.destroy(); this.destroy();
} }
} }

View File

@ -14,15 +14,17 @@ if(Debug.debug) {
class Resizer { class Resizer {
constructor(videoData) { constructor(videoData, logger) {
this.conf = videoData; this.conf = videoData;
this.video = videoData.video; this.video = videoData.video;
this.settings = videoData.settings; this.settings = videoData.settings;
this.extensionMode = videoData.extensionMode; this.extensionMode = videoData.extensionMode;
this.scaler = new Scaler(this.conf); this.logger = logger;
this.stretcher = new Stretcher(this.conf);
this.zoom = new Zoom(this.conf); this.scaler = new Scaler(this.conf, logger);
this.stretcher = new Stretcher(this.conf, logger);
this.zoom = new Zoom(this.conf, logger);
this.cssCheckDisabled = false; this.cssCheckDisabled = false;
@ -50,7 +52,7 @@ class Resizer {
this.resizerId = (Math.random(99)*100).toFixed(0); this.resizerId = (Math.random(99)*100).toFixed(0);
if (this.settings.active.pan) { if (this.settings.active.pan) {
console.log("can pan:", this.settings.active.miscSettings.mousePan.enabled, "(default:", this.settings.active.miscSettings.mousePan.enabled, ")") this.logger.log('info', 'debug', "can pan:", this.settings.active.miscSettings.mousePan.enabled, "(default:", this.settings.active.miscSettings.mousePan.enabled, ")")
this.canPan = this.settings.active.miscSettings.mousePan.enabled; this.canPan = this.settings.active.miscSettings.mousePan.enabled;
} else { } else {
this.canPan = false; this.canPan = false;
@ -68,9 +70,7 @@ class Resizer {
} }
destroy(){ destroy(){
if(Debug.debug || Debug.init){ this.logger.log('info', ['debug', 'init'], `[Resizer::destroy] <rid:${this.resizerId}> received destroy command.`);
console.log(`[Resizer::destroy] <rid:${this.resizerId}> received destroy command.`);
}
this.destroyed = true; this.destroyed = true;
this.stopCssWatcher(); this.stopCssWatcher();
} }
@ -86,9 +86,7 @@ class Resizer {
var ratioOut; var ratioOut;
if (!this.conf.video) { if (!this.conf.video) {
if (Debug.debug) { this.logger.log('info', 'debug', "[Scaler.js::modeToAr] No video??",this.conf.video, "killing videoData");
console.log("[Scaler.js::modeToAr] No video??",this.conf.video, "killing videoData");
}
this.conf.destroy(); this.conf.destroy();
return null; return null;
} }
@ -97,9 +95,7 @@ class Resizer {
if (! this.conf.player.dimensions) { if (! this.conf.player.dimensions) {
ratioOut = screen.width / screen.height; ratioOut = screen.width / screen.height;
} else { } else {
if (Debug.debug && Debug.resizer) { this.logger.log('info', 'debug', `[Resizer::calculateRatioForLegacyOptions] <rid:${this.resizerId}> Player dimensions:`, this.conf.player.dimensions.width ,'x', this.conf.player.dimensions.height,'aspect ratio:', this.conf.player.dimensions.width / this.conf.player.dimensions.height)
console.log(`[Resizer::calculateRatioForLegacyOptions] <rid:${this.resizerId}> Player dimensions:`, this.conf.player.dimensions.width ,'x', this.conf.player.dimensions.height,'aspect ratio:', this.conf.player.dimensions.width / this.conf.player.dimensions.height)
}
ratioOut = this.conf.player.dimensions.width / this.conf.player.dimensions.height; ratioOut = this.conf.player.dimensions.width / this.conf.player.dimensions.height;
} }
@ -118,9 +114,7 @@ class Resizer {
ar.ratio = ratioOut < fileAr ? ratioOut : fileAr; ar.ratio = ratioOut < fileAr ? ratioOut : fileAr;
} }
else if(ar.type === AspectRatio.Reset){ else if(ar.type === AspectRatio.Reset){
if(Debug.debug){ this.logger.log('info', 'debug', "[Scaler.js::modeToAr] Using original aspect ratio -", fileAr);
console.log("[Scaler.js::modeToAr] Using original aspect ratio -", fileAr);
}
ar.ratio = fileAr; ar.ratio = fileAr;
} else { } else {
return null; return null;
@ -135,9 +129,7 @@ class Resizer {
return; return;
} }
if(Debug.debug){ this.logger.log('info', 'debug', '[Resizer::setAr] <rid:'+this.resizerId+'> trying to set ar. New ar:', ar)
console.log('[Resizer::setAr] <rid:'+this.resizerId+'> trying to set ar. New ar:', ar)
}
if (ar == null) { if (ar == null) {
return; return;
@ -166,17 +158,13 @@ class Resizer {
// check if property value is on the list of allowed values // check if property value is on the list of allowed values
// if it's not, we aren't allowed to start aard // if it's not, we aren't allowed to start aard
if (bannedProperties[prop].allowedValues.indexOf(styleValue) === -1) { if (bannedProperties[prop].allowedValues.indexOf(styleValue) === -1) {
if (Debug.debug) { this.logger.log('error', 'debug', "%c[Resizer::setAr] video style contains forbidden css property/value combo: ", "color: #900, background: #100", prop, " — we aren't allowed to start autoar.")
console.log("%c[Resizer::setAr] video style contains forbidden css property/value combo: ", "color: #900, background: #100", prop, " — we aren't allowed to start autoar.")
}
return; return;
} }
} else { } else {
// no allowed values, no problem. We have forbidden property // no allowed values, no problem. We have forbidden property
// and this means aard can't start. // and this means aard can't start.
if (Debug.debug) { this.logger.log('info', 'debug', "%c[Resizer::setAr] video style contains forbidden css property: ", "color: #900, background: #100", prop, " — we aren't allowed to start autoar.")
console.log("%c[Resizer::setAr] video style contains forbidden css property: ", "color: #900, background: #100", prop, " — we aren't allowed to start autoar.")
}
return; return;
} }
} }
@ -195,9 +183,7 @@ class Resizer {
// I'm not sure whether they do. Check that. // I'm not sure whether they do. Check that.
ar = this.calculateRatioForLegacyOptions(ar); ar = this.calculateRatioForLegacyOptions(ar);
if (! ar) { if (! ar) {
if (Debug.debug && Debug.resizer) { this.logger.log('info', 'resizer', `[Resizer::setAr] <${this.resizerId}> Something wrong with ar or the player. Doing nothing.`);
console.log(`[Resizer::setAr] <${this.resizerId}> Something wrong with ar or the player. Doing nothing.`);
}
return; return;
} }
this.lastAr = {type: ar.type, ratio: ar.ratio} this.lastAr = {type: ar.type, ratio: ar.ratio}
@ -238,16 +224,12 @@ class Resizer {
var stretchFactors = this.scaler.calculateCrop(ar); var stretchFactors = this.scaler.calculateCrop(ar);
if(! stretchFactors || stretchFactors.error){ if(! stretchFactors || stretchFactors.error){
if(Debug.debug){ this.logger.log('error', 'debug', "[Resizer::setAr] <rid:"+this.resizerId+"> failed to set AR due to problem with calculating crop. Error:", (stretchFactors ? stretchFactors.error : stretchFactors));
console.log("[Resizer::setAr] <rid:"+this.resizerId+"> failed to set AR due to problem with calculating crop. Error:", (stretchFactors ? stretchFactors.error : stretchFactors));
}
if (stretchFactors.error === 'no_video'){ if (stretchFactors.error === 'no_video'){
this.conf.destroy(); this.conf.destroy();
} }
if (stretchFactors.error === 'illegal_video_dimensions') { if (stretchFactors.error === 'illegal_video_dimensions') {
if(Debug.debug){ this.logger.log('error', 'debug', "[Resizer::setAr] <rid:"+this.resizerId+"> Illegal video dimensions found. We will pause everything.");
console.log("[Resizer::setAr] <rid:"+this.resizerId+"> Illegal video dimensions found. We will pause everything.");
}
// if we get illegal video dimensions, cssWatcher goes nuts. This is harmful, // if we get illegal video dimensions, cssWatcher goes nuts. This is harmful,
// so we stop it until that sorts itself out // so we stop it until that sorts itself out
this.stopCssWatcher(); this.stopCssWatcher();
@ -260,25 +242,17 @@ class Resizer {
this.stretcher.applyConditionalStretch(stretchFactors, ar.ratio); this.stretcher.applyConditionalStretch(stretchFactors, ar.ratio);
} }
if (Debug.debug) { this.logger.log('info', 'debug', "[Resizer::setAr] Processed stretch factors for ", this.stretcher.mode === Stretch.NoStretch ? 'stretch-free crop.' : 'crop with conditional stretch.', 'Stretch factors are:', stretchFactors);
console.log("[Resizer::setAr] Processed stretch factors for ", this.stretcher.mode === Stretch.NoStretch ? 'stretch-free crop.' : 'crop with conditional stretch.', 'Stretch factors are:', stretchFactors);
}
} else if (this.stretcher.mode === Stretch.Hybrid) { } else if (this.stretcher.mode === Stretch.Hybrid) {
var stretchFactors = this.stretcher.calculateStretch(ar.ratio); var stretchFactors = this.stretcher.calculateStretch(ar.ratio);
if (Debug.debug) { this.logger.log('info', 'debug', '[Resizer::setAr] Processed stretch factors for hybrid stretch/crop. Stretch factors are:', stretchFactors);
console.log('[Resizer::setAr] Processed stretch factors for hybrid stretch/crop. Stretch factors are:', stretchFactors);
}
} else if (this.stretcher.mode === Stretch.Basic) { } else if (this.stretcher.mode === Stretch.Basic) {
var stretchFactors = this.stretcher.calculateBasicStretch(); var stretchFactors = this.stretcher.calculateBasicStretch();
if (Debug.debug) { this.logger.log('info', 'debug', '[Resizer::setAr] Processed stretch factors for basic stretch. Stretch factors are:', stretchFactors);
console.log('[Resizer::setAr] Processed stretch factors for basic stretch. Stretch factors are:', stretchFactors);
}
} else { } else {
var stretchFactors = {xFactor: 1, yFactor: 1} var stretchFactors = {xFactor: 1, yFactor: 1}
if (Debug.debug) { this.logger.log('error', 'debug', '[Resizer::setAr] Okay wtf happened? If you see this, something has gone wrong', stretchFactors,"\n------[ i n f o d u m p ]------\nstretcher:", this.stretcher);
console.log('[Resizer::setAr] Okay wtf happened? If you see this, something has gone wrong', stretchFactors,"\n------[ i n f o d u m p ]------\nstretcher:", this.stretcher);
}
} }
this.zoom.applyZoom(stretchFactors); this.zoom.applyZoom(stretchFactors);
@ -320,10 +294,7 @@ class Resizer {
const relativeX = (event.pageX - player.offsetLeft) / player.offsetWidth; const relativeX = (event.pageX - player.offsetLeft) / player.offsetWidth;
const relativeY = (event.pageY - player.offsetTop) / player.offsetHeight; const relativeY = (event.pageY - player.offsetTop) / player.offsetHeight;
if (Debug.debug && Debug.mousemove) { this.logger.log('info', 'mousemove', "[Resizer::panHandler] mousemove.pageX, pageY:", event.pageX, event.pageY, "\nrelativeX/Y:", relativeX, relativeY)
console.log("[Resizer::panHandler] mousemove.pageX, pageY:", event.pageX, event.pageY,
"\nrelativeX/Y:", relativeX, relativeY)
}
this.setPan(relativeX, relativeY); this.setPan(relativeX, relativeY);
} }
@ -343,9 +314,6 @@ class Resizer {
this.pan.relativeOffsetX = -(relativeMousePosX * 1.1) + 0.55; this.pan.relativeOffsetX = -(relativeMousePosX * 1.1) + 0.55;
this.pan.relativeOffsetY = -(relativeMousePosY * 1.1) + 0.55; this.pan.relativeOffsetY = -(relativeMousePosY * 1.1) + 0.55;
} }
// if(Debug.debug){
// console.log("[Resizer::setPan] relative cursor pos:", relativeMousePosX, ",",relativeMousePosY, " | new pan obj:", this.pan)
// }
this.restore(); this.restore();
} }
@ -355,9 +323,7 @@ class Resizer {
} }
startCssWatcher(){ startCssWatcher(){
if(Debug.debug) { this.logger.log('info', 'cssWatcher', "[Resizer.js::startCssWatcher] starting css watcher. Is resizer destroyed?", this.destroyed);
console.log("[Resizer.js::startCssWatcher] starting css watcher. Is resizer destroyed?", this.destroyed);
}
if (this.destroyed) { if (this.destroyed) {
return; return;
} }
@ -399,25 +365,19 @@ class Resizer {
ths.cssCheck(); ths.cssCheck();
} }
} catch (e) { } catch (e) {
if(Debug.debug) { this.logger.log('error', 'debug', "[Resizer.js::scheduleCssWatcher] Css check failed. Error:", e);
console.log("[Resizer.js::scheduleCssWatcher] Css check failed. Error:", e);
}
} }
}, timeout); }, timeout);
} }
stopCssWatcher() { stopCssWatcher() {
if (Debug.debug) { this.logger.log('info', 'cssWatcher', `[Resizer.js] <${this.resizerId}> STOPPING CSS WATCHER!`)
console.log(`[Resizer.js] <${this.resizerId}> STOPPING CSS WATCHER!`)
}
this.cssCheckDisabled = true; this.cssCheckDisabled = true;
clearInterval(this.cssWatcherTimeout); clearInterval(this.cssWatcherTimeout);
} }
restore() { restore() {
if(Debug.debug){ this.logger.log('info', 'debug', "[Resizer::restore] <rid:"+this.resizerId+"> attempting to restore aspect ratio. this & settings:", {'a_lastAr': this.lastAr, 'this': this, "settings": this.settings} );
console.log("[Resizer::restore] <rid:"+this.resizerId+"> attempting to restore aspect ratio. this & settings:", {'a_lastAr': this.lastAr, 'this': this, "settings": this.settings} );
}
// this is true until we verify that css has actually been applied // this is true until we verify that css has actually been applied
this.restore_wd = true; this.restore_wd = true;
@ -481,9 +441,7 @@ class Resizer {
computeOffsets(stretchFactors){ computeOffsets(stretchFactors){
if (Debug.debug) { this.logger.log('info', 'debug', "[Resizer::computeOffsets] <rid:"+this.resizerId+"> video will be aligned to ", this.settings.active.sites['@global'].videoAlignment);
console.log("[Resizer::computeOffsets] <rid:"+this.resizerId+"> video will be aligned to ", this.settings.active.sites['@global'].videoAlignment);
}
const wdiff = this.conf.player.dimensions.width - this.conf.video.offsetWidth; const wdiff = this.conf.player.dimensions.width - this.conf.video.offsetWidth;
const hdiff = this.conf.player.dimensions.height - this.conf.video.offsetHeight; const hdiff = this.conf.player.dimensions.height - this.conf.video.offsetHeight;
@ -512,8 +470,7 @@ class Resizer {
} }
} }
if(Debug.debug) { this.logger.log('info', 'debug', "[Resizer::_res_computeOffsets] <rid:"+this.resizerId+"> calculated offsets:\n\n",
console.log("[Resizer::_res_computeOffsets] <rid:"+this.resizerId+"> calculated offsets:\n\n",
'---- data in ----\n', '---- data in ----\n',
'player dimensions:', {w: this.conf.player.dimensions.width, h: this.conf.player.dimensions.height}, 'player dimensions:', {w: this.conf.player.dimensions.width, h: this.conf.player.dimensions.height},
'video dimensions: ', {w: this.conf.video.offsetWidth, h: this.conf.video.offsetHeight}, 'video dimensions: ', {w: this.conf.video.offsetWidth, h: this.conf.video.offsetHeight},
@ -521,7 +478,6 @@ class Resizer {
'pan & zoom: ', this.pan, this.zoom, 'pan & zoom: ', this.pan, this.zoom,
'\n\n---- data out ----\n', '\n\n---- data out ----\n',
'translate:', translate); 'translate:', translate);
}
return translate; return translate;
} }
@ -583,18 +539,13 @@ class Resizer {
// apply extra CSS here. In case of duplicated properties, extraCss overrides // apply extra CSS here. In case of duplicated properties, extraCss overrides
// default styleString // default styleString
if (! this.video) { if (! this.video) {
if(Debug.debug) { this.logger.log('warn', 'debug', "[Resizer::applyCss] <rid:"+this.resizerId+"> Video went missing, doing nothing.");
console.log("[Resizer::applyCss] <rid:"+this.resizerId+"> Video went missing, doing nothing.");
}
this.conf.destroy(); this.conf.destroy();
return; return;
} }
if (Debug.debug && Debug.resizer) { this.logger.log('info', 'resizer', "[Resizer::applyCss] <rid:"+this.resizerId+"> will apply css.", {stretchFactors, translate});
console.log("[Resizer::applyCss] <rid:"+this.resizerId+"> will apply css.", {stretchFactors, translate});
}
// save stuff for quick tests (before we turn numbers into css values): // save stuff for quick tests (before we turn numbers into css values):
this.currentVideoSettings = { this.currentVideoSettings = {
@ -633,8 +584,7 @@ class Resizer {
if (this.restore_wd) { if (this.restore_wd) {
if (!this.video){ if (!this.video){
if(Debug.debug) this.logger.log('warn', 'debug', "[Resizer::_res_setStyleString] <rid:"+this.resizerId+"> Video element went missing, nothing to do here.")
console.log("[Resizer::_res_setStyleString] <rid:"+this.resizerId+"> Video element went missing, nothing to do here.")
return; return;
} }
@ -658,14 +608,13 @@ class Resizer {
// } // }
} }
else{ else{
if(Debug.debug) this.logger.log('info', 'resizer', "[Resizer::_res_setStyleString] <rid:"+this.resizerId+"> css applied. Style string:", styleString);
console.log("[Resizer::_res_setStyleString] <rid:"+this.resizerId+"> css applied. Style string:", styleString);
} }
} }
cssCheck(){ cssCheck(){
if (this.cssCheckDisabled) { if (this.cssCheckDisabled) {
throw "fucking dont" // throw "fucking dont"
return; return;
} }
// this means we haven't set our CSS yet, or that we changed video. // this means we haven't set our CSS yet, or that we changed video.
@ -676,17 +625,13 @@ class Resizer {
// this means video went missing. videoData will be re-initialized when the next video is found // this means video went missing. videoData will be re-initialized when the next video is found
if (!this.video){ if (!this.video){
if(Debug.debug && Debug.resizer) { this.logger.log('info', 'cssWatcher', "[Resizer::cssCheck] <rid:"+this.resizerId+"> no video detecting, issuing destroy command");
console.log("[Resizer::cssCheck] <rid:"+this.resizerId+"> no video detecting, issuing destroy command");
}
this.conf.destroy(); this.conf.destroy();
return; return;
} }
if(this.destroyed) { if(this.destroyed) {
if(Debug.debug && Debug.resizer) { this.logger.log('info', 'cssWatcher', "[Resizer::cssCheck] <rid:"+this.resizerId+"> destroyed flag is set, we shouldnt be running");
console.log("[Resizer::cssCheck] <rid:"+this.resizerId+"> destroyed flag is set, we shouldnt be running");
}
this.stopCssWatcher(); this.stopCssWatcher();
return; return;
} }
@ -705,9 +650,7 @@ class Resizer {
cssValid &= this.currentPlayerStyleString === playerStyleString; cssValid &= this.currentPlayerStyleString === playerStyleString;
} }
if (!cssValid){ if (!cssValid){
if(Debug.debug && Debug.resizer) { this.logger.log('info', 'cssWatcher', `%c[Resizer::cssCheck] <rid:${this.resizerId}> something touched our style string. We need to re-apply the style.`, {background: '#ddf', color: '#007'});
console.log(`%c[Resizer::cssCheck] <rid:${this.resizerId}> something touched our style string. We need to re-apply the style.`, {background: '#ddf', color: '#007'});
}
this.restore(); this.restore();
this.scheduleCssWatcher(10); this.scheduleCssWatcher(10);

View File

@ -9,8 +9,9 @@ class Scaler {
// internal variables // internal variables
// functions // functions
constructor(videoData) { constructor(videoData, logger) {
this.conf = videoData; this.conf = videoData;
this.logger = logger;
} }
@ -25,9 +26,7 @@ class Scaler {
var ratioOut; var ratioOut;
if (!this.conf.video) { if (!this.conf.video) {
if(Debug.debug){ this.logger.log('error', 'debug', "[Scaler.js::modeToAr] No video??",this.conf.video, "killing videoData");
console.log("[Scaler.js::modeToAr] No video??",this.conf.video, "killing videoData");
}
this.conf.destroy(); this.conf.destroy();
return null; return null;
} }
@ -59,9 +58,7 @@ class Scaler {
return ratioOut; return ratioOut;
} }
else if(ar.type === AspectRatio.Reset){ else if(ar.type === AspectRatio.Reset){
if(Debug.debug){ this.logger.log('info', 'debug', "[Scaler.js::modeToAr] Using original aspect ratio -", fileAr)
console.log("[Scaler.js::modeToAr] Using original aspect ratio -", fileAr)
}
ar.ar = fileAr; ar.ar = fileAr;
return fileAr; return fileAr;
} }
@ -71,9 +68,7 @@ class Scaler {
calculateCrop(ar) { calculateCrop(ar) {
if(!this.conf.video){ if(!this.conf.video){
if (Debug.debug) { this.logger.log('info', 'debug', "[Scaler::calculateCrop] ERROR — no video detected. Conf:", this.conf, "video:", this.conf.video, "video dimensions:", this.conf.video && this.conf.video.videoWidth, '×', this.conf.video && this.conf.video.videoHeight);
console.log("[Scaler::calculateCrop] ERROR — no video detected. Conf:", this.conf, "video:", this.conf.video, "video dimensions:", this.conf.video && this.conf.video.videoWidth, '×', this.conf.video && this.conf.video.videoHeight);
}
this.conf.destroy(); this.conf.destroy();
return {error: "no_video"}; return {error: "no_video"};
@ -81,9 +76,7 @@ class Scaler {
if (this.conf.video.videoWidth == 0 || this.conf.video.videoHeight == 0) { if (this.conf.video.videoWidth == 0 || this.conf.video.videoHeight == 0) {
// that's illegal, but not illegal enough to just blast our shit to high hell // that's illegal, but not illegal enough to just blast our shit to high hell
// mr officer will let you go with a warning this time around // mr officer will let you go with a warning this time around
if (Debug.debug) { this.logger.log('error', 'debug', "[Scaler::calculateCrop] Video has illegal dimensions. Video dimensions:", this.conf.video && this.conf.video.videoWidth, '×', this.conf.video && this.conf.video.videoHeight);
console.log("[Scaler::calculateCrop] Video has illegal dimensions. Video dimensions:", this.conf.video && this.conf.video.videoWidth, '×', this.conf.video && this.conf.video.videoHeight);
}
return {error: "illegal_video_dimensions"}; return {error: "illegal_video_dimensions"};
} }
@ -94,20 +87,14 @@ class Scaler {
// handle fuckie-wuckies // handle fuckie-wuckies
if (!ar.ratio){ if (!ar.ratio){
if (Debug.debug && Debug.scaler) { this.logger.log('error', 'scaler', "[Scaler::calculateCrop] no ar?", ar.ratio, " -- we were given this mode:", ar);
console.log("[Scaler::calculateCrop] no ar?", ar.ratio, " -- we were given this mode:", ar);
}
return {error: "no_ar", ratio: ar.ratio}; return {error: "no_ar", ratio: ar.ratio};
} }
if (Debug.debug && Debug.scaler) { this.logger.log('info', 'scaler', "[Scaler::calculateCrop] trying to set ar. args are: ar->",ar.ratio,"; this.conf.player.dimensions->",this.conf.player.dimensions.width, "×", this.conf.player.dimensions.height, "| obj:", this.conf.player.dimensions);
console.log("[Scaler::calculateCrop] trying to set ar. args are: ar->",ar.ratio,"; this.conf.player.dimensions->",this.conf.player.dimensions.width, "×", this.conf.player.dimensions.height, "| obj:", this.conf.player.dimensions);
}
if( (! this.conf.player.dimensions) || this.conf.player.dimensions.width === 0 || this.conf.player.dimensions.height === 0 ){ if( (! this.conf.player.dimensions) || this.conf.player.dimensions.width === 0 || this.conf.player.dimensions.height === 0 ){
if (Debug.debug && Debug.scaler) { this.logger.log('error', 'scaler', "[Scaler::calculateCrop] ERROR — no (or invalid) this.conf.player.dimensions:",this.conf.player.dimensions);
console.log("[Scaler::calculateCrop] ERROR — no (or invalid) this.conf.player.dimensions:",this.conf.player.dimensions);
}
return {error: "this.conf.player.dimensions_error"}; return {error: "this.conf.player.dimensions_error"};
} }
@ -124,9 +111,7 @@ class Scaler {
} }
if (Debug.debug && Debug.scaler) { this.logger.log('info', 'scaler', "[Scaler::calculateCrop] ar is " ,ar.ratio, ", file ar is", fileAr, ", this.conf.player.dimensions are ", this.conf.player.dimensions.width, "×", this.conf.player.dimensions.height, "| obj:", this.conf.player.dimensions);
console.log("[Scaler::calculateCrop] ar is " ,ar.ratio, ", file ar is", fileAr, ", this.conf.player.dimensions are ", this.conf.player.dimensions.width, "×", this.conf.player.dimensions.height, "| obj:", this.conf.player.dimensions);
}
var videoDimensions = { var videoDimensions = {
xFactor: 1, xFactor: 1,
@ -152,9 +137,7 @@ class Scaler {
videoDimensions.yFactor = videoDimensions.xFactor; videoDimensions.yFactor = videoDimensions.xFactor;
} }
if (Debug.debug && Debug.scaler) { this.logger.log('info', 'scaler', "[Scaler::calculateCrop] Crop factor calculated — ", videoDimensions.xFactor);
console.log("[Scaler::calculateCrop] Crop factor calculated — ", videoDimensions.xFactor);
}
return videoDimensions; return videoDimensions;
} }

View File

@ -1,4 +1,3 @@
import Debug from '../../conf/Debug';
import Stretch from '../../../common/enums/stretch.enum'; import Stretch from '../../../common/enums/stretch.enum';
// računa vrednosti za transform-scale (x, y) // računa vrednosti za transform-scale (x, y)
@ -11,10 +10,11 @@ class Stretcher {
// functions // functions
constructor(videoData) { constructor(videoData, logger) {
this.conf = videoData; this.conf = videoData;
this.settings = videoData.settings; this.settings = videoData.settings;
this.mode = this.settings.getDefaultStretchMode(window.location.hostname); this.mode = this.settings.getDefaultStretchMode(window.location.hostname);
this.logger = logger;
} }
setStretchMode(stretchMode) { setStretchMode(stretchMode) {
@ -120,9 +120,7 @@ class Stretcher {
stretchFactors.xFactor = playerAr / videoAr; stretchFactors.xFactor = playerAr / videoAr;
stretchFactors.yFactor = actualAr / videoAr; stretchFactors.yFactor = actualAr / videoAr;
if(Debug.debug){ this.logger.log('info', 'stretcher', "[Stretcher.js::calculateStretch] stretching strategy 1")
console.log("[Stretcher.js::calculateStretch] stretching strategy 1")
}
} else if ( actualAr >= videoAr) { } else if ( actualAr >= videoAr) {
// VERIFIED WORKS // VERIFIED WORKS
@ -132,18 +130,14 @@ class Stretcher {
stretchFactors.xFactor = playerAr / videoAr; stretchFactors.xFactor = playerAr / videoAr;
stretchFactors.yFactor = actualAr / videoAr; stretchFactors.yFactor = actualAr / videoAr;
if(Debug.debug){ this.logger.log('info', 'stretcher', "[Stretcher.js::calculateStretch] stretching strategy 2")
console.log("[Stretcher.js::calculateStretch] stretching strategy 2")
}
} else { } else {
// NEEDS CHECKING // NEEDS CHECKING
// player > video > actual — double pillarbox // player > video > actual — double pillarbox
stretchFactors.xFactor = actualAr / playerAr; stretchFactors.xFactor = actualAr / playerAr;
stretchFactors.yFactor = 1; stretchFactors.yFactor = 1;
if(Debug.debug){ this.logger.log('info', 'stretcher', "[Stretcher.js::calculateStretch] stretching strategy 3")
console.log("[Stretcher.js::calculateStretch] stretching strategy 3")
}
} }
} else { } else {
// player adds LETTERBOX // player adds LETTERBOX
@ -156,9 +150,7 @@ class Stretcher {
stretchFactors.xFactor = actualAr / playerAr; stretchFactors.xFactor = actualAr / playerAr;
stretchFactors.yFactor = videoAr / playerAr; stretchFactors.yFactor = videoAr / playerAr;
if(Debug.debug){ this.logger.log('info', 'stretcher', "[Stretcher.js::calculateStretch] stretching strategy 4")
console.log("[Stretcher.js::calculateStretch] stretching strategy 4")
}
} else if ( actualAr < videoAr ) { } else if ( actualAr < videoAr ) {
// NEEDS CHECKING // NEEDS CHECKING
@ -168,9 +160,7 @@ class Stretcher {
stretchFactors.xFactor = actualAr / playerAr; stretchFactors.xFactor = actualAr / playerAr;
stretchFActors.yFactor = actualAr / playerAr; stretchFActors.yFactor = actualAr / playerAr;
if(Debug.debug){ this.logger.log('info', 'stretcher', "[Stretcher.js::calculateStretch] stretching strategy 5")
console.log("[Stretcher.js::calculateStretch] stretching strategy 5")
}
} else { } else {
// VERIFIED CORRECT // VERIFIED CORRECT
@ -179,9 +169,7 @@ class Stretcher {
stretchFactors.xFactor = 1; stretchFactors.xFactor = 1;
stretchFactors.yFactor = actualAr / playerAr; stretchFactors.yFactor = actualAr / playerAr;
if(Debug.debug){ this.logger.log('info', 'stretcher', "[Stretcher.js::calculateStretch] stretching strategy 6")
console.log("[Stretcher.js::calculateStretch] stretching strategy 6")
}
} }
} }

View File

@ -5,13 +5,14 @@ import Debug from '../../conf/Debug';
class Zoom { class Zoom {
// functions // functions
constructor(videoData) { constructor(videoData, logger) {
this.scale = 1; this.scale = 1;
this.logScale = 0; this.logScale = 0;
this.scaleStep = 0.1; this.scaleStep = 0.1;
this.minScale = -1; // 50% (log2(0.5) = -1) this.minScale = -1; // 50% (log2(0.5) = -1)
this.maxScale = 3; // 800% (log2(8) = 3) this.maxScale = 3; // 800% (log2(8) = 3)
this.conf = videoData; this.conf = videoData;
this.logger = logger;
} }
reset(){ reset(){
@ -30,18 +31,14 @@ class Zoom {
this.scale = Math.pow(2, this.logScale); this.scale = Math.pow(2, this.logScale);
if (Debug.debug) { this.logger.log('info', 'debug', "[Zoom::zoomStep] changing zoom by", amount, ". New zoom level:", this.scale);
console.log("[Zoom::zoomStep] changing zoom by", amount, ". New zoom level:", this.scale);
}
this.conf.restoreAr(); this.conf.restoreAr();
this.conf.announceZoom(this.scale); this.conf.announceZoom(this.scale);
} }
setZoom(scale, no_announce){ setZoom(scale, no_announce){
if (Debug.debug) { this.logger.log('info', 'debug', "[Zoom::setZoom] Setting zoom to", scale, "!");
console.log("[Zoom::setZoom] Setting zoom to", scale, "!");
}
// NOTE: SCALE IS NOT LOGARITHMIC // NOTE: SCALE IS NOT LOGARITHMIC
if(scale < Math.pow(2, this.minScale)) { if(scale < Math.pow(2, this.minScale)) {
@ -62,16 +59,12 @@ class Zoom {
if (!stretchFactors) { if (!stretchFactors) {
return; return;
} }
if (Debug.debug) { this.logger.log('info', 'debug', "[Zoom::setZoom] Applying zoom. Stretch factors pre:", stretchFactors, " —> scale:", this.scale);
console.log("[Zoom::setZoom] Applying zoom. Stretch factors pre:", stretchFactors, " —> scale:", this.scale);
}
stretchFactors.xFactor *= this.scale; stretchFactors.xFactor *= this.scale;
stretchFactors.yFactor *= this.scale; stretchFactors.yFactor *= this.scale;
if (Debug.debug) { this.logger.log('info', 'debug', "[Zoom::setZoom] Applying zoom. Stretch factors post:", stretchFactors);
console.log("[Zoom::setZoom] Applying zoom. Stretch factors post:", stretchFactors);
}
} }
} }

View File

@ -5,6 +5,7 @@ import Settings from './lib/Settings';
import ActionHandler from './lib/ActionHandler'; import ActionHandler from './lib/ActionHandler';
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';
import Logger from './lib/Logger';
if(Debug.debug){ if(Debug.debug){
console.log("\n\n\n\n\n\n ——— Sᴛλʀᴛɪɴɢ Uʟᴛʀᴀɪɪʏ ———\n << ʟᴏᴀᴅɪɴɢ ᴍᴀɪɴ ꜰɪʟᴇ >>\n\n\n\n"); console.log("\n\n\n\n\n\n ——— Sᴛλʀᴛɪɴɢ Uʟᴛʀᴀɪɪʏ ———\n << ʟᴏᴀᴅɪɴɢ ᴍᴀɪɴ ꜰɪʟᴇ >>\n\n\n\n");
@ -30,6 +31,7 @@ class UW {
this.comms = undefined; this.comms = undefined;
this.settings = undefined; this.settings = undefined;
this.actionHandler = undefined; this.actionHandler = undefined;
this.logger = undefined;
} }
async init(){ async init(){
@ -39,9 +41,8 @@ class UW {
// init() is re-run any time settings change // init() is re-run any time settings change
if (this.pageInfo) { if (this.pageInfo) {
if(Debug.debug){ // if this executes, logger must have been initiated at some point before this point
console.log("[uw::init] Destroying existing pageInfo", this.pageInfo); this.logger.log('info', 'debug', "[uw::init] Destroying existing pageInfo", this.pageInfo);
}
this.pageInfo.destroy(); this.pageInfo.destroy();
} }
if (this.comms) { if (this.comms) {
@ -54,51 +55,45 @@ class UW {
await this.settings.init(); await this.settings.init();
} }
this.comms = new CommsClient('content-client-port', this.settings); if (!this.logger) {
this.logger = new Logger(this.settings.getLoggingOptions);
}
this.comms = new CommsClient('content-client-port', this.settings, this.logger);
// če smo razširitev onemogočili v nastavitvah, ne naredimo ničesar // če smo razširitev onemogočili v nastavitvah, ne naredimo ničesar
// If extension is soft-disabled, don't do shit // If extension is soft-disabled, don't do shit
var extensionMode = this.settings.getExtensionMode(); var extensionMode = this.settings.getExtensionMode();
if(Debug.debug) { this.logger.log('info', 'debug', "[uw::init] Extension mode:" + (extensionMode < 0 ? "disabled" : extensionMode == '1' ? 'basic' : 'full'));
console.log("[uw::init] Extension mode:" + (extensionMode < 0 ? "disabled" : extensionMode == '1' ? 'basic' : 'full'));
}
const isSiteDisabled = extensionMode === ExtensionMode.Disabled const isSiteDisabled = extensionMode === ExtensionMode.Disabled
if (isSiteDisabled) { if (isSiteDisabled) {
if (this.settings.getExtensionMode('@global') === ExtensionMode.Disabled) { if (this.settings.getExtensionMode('@global') === ExtensionMode.Disabled) {
if (Debug.debug) { this.logger.log('info', 'debug', "[uw::init] EXTENSION DISABLED, THEREFORE WONT BE STARTED")
console.log("[uw::init] EXTENSION DISABLED, THEREFORE WONT BE STARTED")
}
return; return;
} }
} }
try { try {
this.pageInfo = new PageInfo(this.comms, this.settings, extensionMode, isSiteDisabled); this.pageInfo = new PageInfo(this.comms, this.settings, this.logger, extensionMode, isSiteDisabled);
if(Debug.debug){ this.logger.log('info', 'debug', "[uw.js::setup] pageInfo initialized. Here's the object:", this.pageInfo);
console.log("[uw.js::setup] pageInfo initialized. Here's the object:", this.pageInfo);
}
this.comms.setPageInfo(this.pageInfo); this.comms.setPageInfo(this.pageInfo);
if(Debug.debug) { this.logger.log('info', 'debug', "[uw.js::setup] will try to initate ActionHandler. Settings are:", this.settings, this.settings.active)
console.log("[uw.js::setup] will try to initate ActionHandler. Settings are:", this.settings, this.settings.active)
}
// 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) {
this.actionHandler = new ActionHandler(this.pageInfo); this.actionHandler = new ActionHandler(this.pageInfo, this.logger);
this.actionHandler.init(); this.actionHandler.init();
if(Debug.debug) { this.logger.log('info', 'debug', "[uw.js::setup] ActionHandler initiated:", this.actionHandler);
console.log("[uw.js::setup] ActionHandler initiated:", this.actionHandler);
}
} }
} catch (e) { } catch (e) {
console.log("[uw::init] FAILED TO START EXTENSION. Error:", e); this.logger.log('error', 'debug', "[uw::init] FAILED TO START EXTENSION. Error:", e);
} }