sensible variable naming is important + remove redundant code

This commit is contained in:
Tamius Han 2023-04-12 23:08:19 +02:00
parent e12154601b
commit 0778f07922
2 changed files with 107 additions and 101 deletions

View File

@ -11,6 +11,7 @@ import Logger from '../Logger';
import EventBus from '../EventBus'; import EventBus from '../EventBus';
import UI from '../uwui/UI'; import UI from '../uwui/UI';
import { SiteSettings } from '../settings/SiteSettings'; import { SiteSettings } from '../settings/SiteSettings';
import PageInfo from './PageInfo';
if (process.env.CHANNEL !== 'stable'){ if (process.env.CHANNEL !== 'stable'){
console.info("Loading: PlayerData.js"); console.info("Loading: PlayerData.js");
@ -42,13 +43,14 @@ class PlayerData {
//#region helper objects //#region helper objects
logger: Logger; logger: Logger;
videoData: VideoData; videoData: VideoData;
pageInfo: PageInfo;
siteSettings: SiteSettings; siteSettings: SiteSettings;
notificationService: PlayerNotificationUi; notificationService: PlayerNotificationUi;
eventBus: EventBus; eventBus: EventBus;
//#endregion //#endregion
//#region HTML objects //#region HTML objects
video: any; videoElement: any;
element: any; element: any;
overlayNode: any; overlayNode: any;
//#endregion //#endregion
@ -102,13 +104,18 @@ class PlayerData {
} }
} }
//#region lifecycle
constructor(videoData) { constructor(videoData) {
try { try {
// set all our helper objects
this.logger = videoData.logger; this.logger = videoData.logger;
this.videoData = videoData; this.videoData = videoData;
this.video = videoData.video; this.videoElement = videoData.video;
this.pageInfo = videoData.pageInfo;
this.siteSettings = videoData.siteSettings; this.siteSettings = videoData.siteSettings;
this.eventBus = videoData.eventBus; this.eventBus = videoData.eventBus;
// do the rest
this.invalid = false; this.invalid = false;
this.element = this.getPlayer(); this.element = this.getPlayer();
this.initEventBus(); this.initEventBus();
@ -136,7 +143,6 @@ class PlayerData {
this.trackDimensionChanges(); this.trackDimensionChanges();
this.startChangeDetection(); this.startChangeDetection();
} catch (e) { } catch (e) {
console.error('[Ultrawidify::PlayerData::ctor] There was an error setting up player data. You should be never seeing this message. Error:', e); console.error('[Ultrawidify::PlayerData::ctor] There was an error setting up player data. You should be never seeing this message. Error:', e);
this.invalid = true; this.invalid = true;
@ -151,6 +157,38 @@ class PlayerData {
} }
} }
destroy() {
this.stopChangeDetection();
this.destroyOverlay();
this.notificationService?.destroy();
}
//#endregion
/**
* Enables ultrawidify for this video by adding the relevant classes
* to the video and player element.
*/
enable() {
this.enabled = true;
this.element.classList.add(this.playerCssClass);
this.startChangeDetection();
this.videoData.enable({fromPlayer: true});
}
/**
* Disables ultrawidify for this video by removing the relevant classes
* from the video and player elements.
*
* NOTE: it is very important to keep change detection active while disabled,
* because otherwise ultrawidify will otherwise remain inactive after
* switching (back to) full screen.
*/
disable() {
this.enabled = false;
this.element.classList.remove(this.playerCssClass);
this.videoData.disable({fromPlayer: true});
}
/** /**
* Detects whether player element is in theater mode or not. * Detects whether player element is in theater mode or not.
* If theater mode changed, emits event. * If theater mode changed, emits event.
@ -272,42 +310,12 @@ class PlayerData {
} }
} }
/**
* Enables ultrawidify for this video by adding the relevant classes
* to the video and player element.
*/
enable() {
this.enabled = true;
this.element.classList.add(this.playerCssClass);
this.startChangeDetection();
this.videoData.enable({fromPlayer: true});
}
/**
* Disables ultrawidify for this video by removing the relevant classes
* from the video and player elements.
*
* NOTE: it is very important to keep change detection active while disabled,
* because otherwise ultrawidify will otherwise remain inactive after
* switching (back to) full screen.
*/
disable() {
this.enabled = false;
this.element.classList.remove(this.playerCssClass);
this.videoData.disable({fromPlayer: true});
}
onPlayerDimensionsChanged(mutationList?, observer?) { onPlayerDimensionsChanged(mutationList?, observer?) {
this.trackDimensionChanges(); this.trackDimensionChanges();
} }
destroy() {
this.stopChangeDetection();
this.destroyOverlay();
this.notificationService?.destroy();
}
//#region player element change detection //#region player element change detection
startChangeDetection(){ startChangeDetection(){
if (this.invalid) { if (this.invalid) {
@ -451,17 +459,17 @@ class PlayerData {
*/ */
getPlayer(options?: {verbose?: boolean}) { getPlayer(options?: {verbose?: boolean}) {
const host = window.location.hostname; const host = window.location.hostname;
let element = this.video.parentNode; let element = this.videoElement.parentNode;
const videoWidth = this.video.offsetWidth; const videoWidth = this.videoElement.offsetWidth;
const videoHeight = this.video.offsetHeight; const videoHeight = this.videoElement.offsetHeight;
let playerCandidate; let playerCandidate;
const elementStack: any[] = [{ const elementStack: any[] = [{
element: this.video, element: this.videoElement,
type: 'video', type: 'video',
tagName: 'video', tagName: 'video',
classList: this.video.classList, classList: this.videoElement.classList,
id: this.video.id, id: this.videoElement.id,
}]; }];
// first pass to generate the element stack and translate it into array // first pass to generate the element stack and translate it into array
@ -667,10 +675,6 @@ class PlayerData {
// this.notificationService?.replace(this.element); // this.notificationService?.replace(this.element);
this.trackDimensionChanges(); this.trackDimensionChanges();
} }
showNotification(notificationId) {
// this.notificationService?.showNotification(notificationId);
}
} }
if (process.env.CHANNEL !== 'stable'){ if (process.env.CHANNEL !== 'stable'){

View File

@ -36,7 +36,7 @@ class Resizer {
scaler: Scaler; scaler: Scaler;
stretcher: Stretcher; stretcher: Stretcher;
zoom: Zoom; zoom: Zoom;
conf: VideoData; videoData: VideoData;
eventBus: EventBus; eventBus: EventBus;
//#endregion //#endregion
@ -118,7 +118,7 @@ class Resizer {
constructor(videoData) { constructor(videoData) {
this.resizerId = (Math.random()*100).toFixed(0); this.resizerId = (Math.random()*100).toFixed(0);
this.conf = videoData; this.videoData = videoData;
this.logger = videoData.logger; this.logger = videoData.logger;
this.video = videoData.video; this.video = videoData.video;
this.settings = videoData.settings; this.settings = videoData.settings;
@ -126,9 +126,9 @@ class Resizer {
this.eventBus = videoData.eventBus; this.eventBus = videoData.eventBus;
this.initEventBus(); this.initEventBus();
this.scaler = new Scaler(this.conf); this.scaler = new Scaler(this.videoData);
this.stretcher = new Stretcher(this.conf); this.stretcher = new Stretcher(this.videoData);
this.zoom = new Zoom(this.conf); this.zoom = new Zoom(this.videoData);
this.videoAlignment = this.siteSettings.getDefaultOption('alignment') as {x: VideoAlignmentType, y: VideoAlignmentType} // this is initial video alignment this.videoAlignment = this.siteSettings.getDefaultOption('alignment') as {x: VideoAlignmentType, y: VideoAlignmentType} // this is initial video alignment
@ -186,24 +186,24 @@ class Resizer {
// handles "legacy" options, such as 'fit to widht', 'fit to height' and AspectRatioType.Reset. No zoom tho // handles "legacy" options, such as 'fit to widht', 'fit to height' and AspectRatioType.Reset. No zoom tho
let ratioOut; let ratioOut;
if (!this.conf.video) { if (!this.videoData.video) {
this.logger.log('info', 'debug', "[Scaler.js::modeToAr] No video??",this.conf.video, "killing videoData"); this.logger.log('info', 'debug', "[Scaler.js::modeToAr] No video??",this.videoData.video, "killing videoData");
this.conf.destroy(); this.videoData.destroy();
return null; return null;
} }
if (! this.conf.player.dimensions) { if (! this.videoData.player.dimensions) {
ratioOut = screen.width / screen.height; ratioOut = screen.width / screen.height;
} else { } else {
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) this.logger.log('info', 'debug', `[Resizer::calculateRatioForLegacyOptions] <rid:${this.resizerId}> Player dimensions:`, this.videoData.player.dimensions.width ,'x', this.videoData.player.dimensions.height,'aspect ratio:', this.videoData.player.dimensions.width / this.videoData.player.dimensions.height)
ratioOut = this.conf.player.dimensions.width / this.conf.player.dimensions.height; ratioOut = this.videoData.player.dimensions.width / this.videoData.player.dimensions.height;
} }
// IMPORTANT NOTE: lastAr needs to be set after _res_setAr() is called, as _res_setAr() assumes we're // IMPORTANT NOTE: lastAr needs to be set after _res_setAr() is called, as _res_setAr() assumes we're
// setting a static aspect ratio (even if the function is called from here or ArDetect). // setting a static aspect ratio (even if the function is called from here or ArDetect).
let fileAr = this.conf.video.videoWidth / this.conf.video.videoHeight; let fileAr = this.videoData.video.videoWidth / this.videoData.video.videoHeight;
if (ar.type === AspectRatioType.FitWidth){ if (ar.type === AspectRatioType.FitWidth){
ar.ratio = ratioOut > fileAr ? ratioOut : fileAr; ar.ratio = ratioOut > fileAr ? ratioOut : fileAr;
@ -247,10 +247,10 @@ class Resizer {
// handle autodetection stuff // handle autodetection stuff
if (ar.type === AspectRatioType.Automatic) { if (ar.type === AspectRatioType.Automatic) {
this.conf.arDetector?.start(); this.videoData.arDetector?.start();
return; return;
} else if (ar.type !== AspectRatioType.AutomaticUpdate) { } else if (ar.type !== AspectRatioType.AutomaticUpdate) {
this.conf.arDetector?.stop(); this.videoData.arDetector?.stop();
} }
// unless we're trying to reset aspect ratio, we need to tell VideoData that this would // unless we're trying to reset aspect ratio, we need to tell VideoData that this would
@ -258,7 +258,7 @@ class Resizer {
// //
// CSS, et. al. initialization is deferred in order to avoid breaking wonky sites by default. // CSS, et. al. initialization is deferred in order to avoid breaking wonky sites by default.
if (ar.type !== AspectRatioType.Reset && ar.type !== AspectRatioType.Initial) { if (ar.type !== AspectRatioType.Reset && ar.type !== AspectRatioType.Initial) {
await this.conf.preparePage(); await this.videoData.preparePage();
} }
if (ar.type !== AspectRatioType.AutomaticUpdate) { if (ar.type !== AspectRatioType.AutomaticUpdate) {
@ -267,7 +267,7 @@ class Resizer {
if (!this.video.videoWidth || !this.video.videoHeight) { if (!this.video.videoWidth || !this.video.videoHeight) {
this.logger.log('warning', 'debug', '[Resizer::setAr] <rid:'+this.resizerId+'> Video has no width or no height. This is not allowed. Aspect ratio will not be set, and videoData will be uninitialized.'); this.logger.log('warning', 'debug', '[Resizer::setAr] <rid:'+this.resizerId+'> Video has no width or no height. This is not allowed. Aspect ratio will not be set, and videoData will be uninitialized.');
this.conf.videoUnloaded(); this.videoData.videoUnloaded();
} }
this.logger.log('info', 'debug', '[Resizer::setAr] <rid:'+this.resizerId+'> trying to set ar. New ar:', ar); this.logger.log('info', 'debug', '[Resizer::setAr] <rid:'+this.resizerId+'> trying to set ar. New ar:', ar);
@ -296,11 +296,12 @@ class Resizer {
// is handled in pageInfo.updateCurrentCrop(), which also makes sure to persist aspect ratio if ar // is handled in pageInfo.updateCurrentCrop(), which also makes sure to persist aspect ratio if ar
// is set to persist between videos / through current session / until manual reset. // is set to persist between videos / through current session / until manual reset.
if (ar.type === AspectRatioType.Reset || if (ar.type === AspectRatioType.Reset ||
ar.type === AspectRatioType.Initial ) { ar.type === AspectRatioType.Initial
) {
// reset/undo default // reset/undo default
this.conf.pageInfo.updateCurrentCrop(undefined); this.videoData.pageInfo.updateCurrentCrop(undefined);
} else { } else {
this.conf.pageInfo.updateCurrentCrop(ar); this.videoData.pageInfo.updateCurrentCrop(ar);
} }
if (lastAr) { if (lastAr) {
@ -318,7 +319,7 @@ class Resizer {
} }
if (! this.video) { if (! this.video) {
this.conf.destroy(); this.videoData.destroy();
} }
// pause AR on: // pause AR on:
@ -327,24 +328,25 @@ class Resizer {
// //
// unpause when using other modes // unpause when using other modes
if (ar.type !== AspectRatioType.Automatic || this.stretcher.mode === StretchType.Basic) { if (ar.type !== AspectRatioType.Automatic || this.stretcher.mode === StretchType.Basic) {
this.conf?.arDetector?.pause(); this.videoData?.arDetector?.pause();
} else { } else {
if (this.lastAr.type === AspectRatioType.Automatic) { if (this.lastAr.type === AspectRatioType.Automatic) {
this.conf?.arDetector?.unpause(); this.videoData?.arDetector?.unpause();
} }
} }
// do stretch thingy // do stretch thingy
if (this.stretcher.mode === StretchType.NoStretch if (this.stretcher.mode === StretchType.NoStretch
|| this.stretcher.mode === StretchType.Conditional || this.stretcher.mode === StretchType.Conditional
|| this.stretcher.mode === StretchType.FixedSource){ || this.stretcher.mode === StretchType.FixedSource
){
stretchFactors = this.scaler.calculateCrop(ar); stretchFactors = this.scaler.calculateCrop(ar);
if(! stretchFactors || stretchFactors.error){ if(! stretchFactors || stretchFactors.error){
this.logger.log('error', 'debug', `[Resizer::setAr] <rid:${this.resizerId}> failed to set AR due to problem with calculating crop. Error:`, stretchFactors?.error); this.logger.log('error', 'debug', `[Resizer::setAr] <rid:${this.resizerId}> failed to set AR due to problem with calculating crop. Error:`, stretchFactors?.error);
if (stretchFactors?.error === 'no_video'){ if (stretchFactors?.error === 'no_video'){
this.conf.destroy(); this.videoData.destroy();
return; return;
} }
@ -353,7 +355,7 @@ class Resizer {
// of the two means video is loaded or playing, and that means video has proper dimensions), it will // of the two means video is loaded or playing, and that means video has proper dimensions), it will
// try to reset or re-apply aspect ratio when the video is finally ready. // try to reset or re-apply aspect ratio when the video is finally ready.
if (stretchFactors?.error === 'illegal_video_dimensions') { if (stretchFactors?.error === 'illegal_video_dimensions') {
this.conf.videoDimensionsLoaded = false; this.videoData.videoDimensionsLoaded = false;
return; return;
} }
} }
@ -395,7 +397,7 @@ class Resizer {
// let the UI know // let the UI know
if(!options?.noAnnounce) { if(!options?.noAnnounce) {
this.conf.eventBus.send('announce-zoom', {x: stretchFactors.xFactor, y: stretchFactors.yFactor}); this.videoData.eventBus.send('announce-zoom', {x: stretchFactors.xFactor, y: stretchFactors.yFactor});
} }
let translate = this.computeOffsets(stretchFactors); let translate = this.computeOffsets(stretchFactors);
@ -422,7 +424,7 @@ class Resizer {
panHandler(event, forcePan) { panHandler(event, forcePan) {
if (this.canPan || forcePan) { if (this.canPan || forcePan) {
if(!this.conf.player || !this.conf.player.element) { if(!this.videoData.player || !this.videoData.player.element) {
return; return;
} }
// dont allow weird floats // dont allow weird floats
@ -433,7 +435,7 @@ class Resizer {
this.toFixedAr(); this.toFixedAr();
} }
const player = this.conf.player.element; const player = this.videoData.player.element;
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;
@ -563,11 +565,11 @@ class Resizer {
* We make the assumption of the * We make the assumption of the
*/ */
computeVideoDisplayedDimensions() { computeVideoDisplayedDimensions() {
const offsetWidth = this.conf.video.offsetWidth; const offsetWidth = this.videoData.video.offsetWidth;
const offsetHeight = this.conf.video.offsetHeight; const offsetHeight = this.videoData.video.offsetHeight;
const scaleX = offsetWidth / this.conf.video.videoWidth; const scaleX = offsetWidth / this.videoData.video.videoWidth;
const scaleY = offsetHeight / this.conf.video.videoHeight; const scaleY = offsetHeight / this.videoData.video.videoHeight;
// if differences between the scale factors are minimal, we presume offsetWidth and // if differences between the scale factors are minimal, we presume offsetWidth and
// offsetHeight are the accurate enough for our needs // offsetHeight are the accurate enough for our needs
@ -581,13 +583,13 @@ class Resizer {
} }
// if we're still here, we need to calculate real video dimensions // if we're still here, we need to calculate real video dimensions
const diffX = Math.abs(scaleY * this.conf.video.videoWidth - offsetWidth); const diffX = Math.abs(scaleY * this.videoData.video.videoWidth - offsetWidth);
const diffY = Math.abs(scaleX * this.conf.video.videoHeight - offsetHeight); const diffY = Math.abs(scaleX * this.videoData.video.videoHeight - offsetHeight);
// in this case, we want to base our real dimensions off scaleX // in this case, we want to base our real dimensions off scaleX
// otherwise, we want to base it off scaleY // otherwise, we want to base it off scaleY
if (diffX < diffY) { if (diffX < diffY) {
const realHeight = this.conf.video.videoHeight * scaleX; const realHeight = this.videoData.video.videoHeight * scaleX;
return { return {
realVideoWidth: offsetWidth, realVideoWidth: offsetWidth,
realVideoHeight: realHeight, realVideoHeight: realHeight,
@ -595,7 +597,7 @@ class Resizer {
marginY: (offsetHeight - realHeight) * 0.5 marginY: (offsetHeight - realHeight) * 0.5
} }
} else { } else {
const realWidth = this.conf.video.videoWidth * scaleY; const realWidth = this.videoData.video.videoWidth * scaleY;
return { return {
realVideoWidth: realWidth, realVideoWidth: realWidth,
realVideoHeight: offsetHeight, realVideoHeight: offsetHeight,
@ -608,8 +610,8 @@ class Resizer {
computeCroppedAreas(stretchFactors) { computeCroppedAreas(stretchFactors) {
// PSA: offsetWidth and offsetHeight DO NOT INCLUDE // PSA: offsetWidth and offsetHeight DO NOT INCLUDE
// ZOOM APPLIED THROUGH THE MAGIC OF CSS TRANSFORMS // ZOOM APPLIED THROUGH THE MAGIC OF CSS TRANSFORMS
const sourceWidth = this.conf.video.offsetWidth; const sourceWidth = this.videoData.video.offsetWidth;
const sourceHeight = this.conf.video.offsetHeight; const sourceHeight = this.videoData.video.offsetHeight;
// this is the size of the video AFTER zooming was applied but does // this is the size of the video AFTER zooming was applied but does
// not account for cropping. It may be bigger than the player in // not account for cropping. It may be bigger than the player in
@ -618,8 +620,8 @@ class Resizer {
const postZoomHeight = sourceHeight * stretchFactors.yFactor; const postZoomHeight = sourceHeight * stretchFactors.yFactor;
// this is the size of the video after crop is applied // this is the size of the video after crop is applied
const displayedWidth = Math.min(this.conf.player.dimensions.width, postZoomWidth); const displayedWidth = Math.min(this.videoData.player.dimensions.width, postZoomWidth);
const displayedHeight = Math.min(this.conf.player.dimensions.height, postZoomHeight); const displayedHeight = Math.min(this.videoData.player.dimensions.height, postZoomHeight);
// these two are cropped areas. Negative values mean additional // these two are cropped areas. Negative values mean additional
// letterboxing or pillarboxing. We assume center alignment for // letterboxing or pillarboxing. We assume center alignment for
@ -678,19 +680,19 @@ class Resizer {
stretchFactors.cropStrategy === CropStrategy.CropLetterbox stretchFactors.cropStrategy === CropStrategy.CropLetterbox
&& (!stretchFactors.styleHeightCompensationFactor || stretchFactors.styleHeightCompensationFactor === 1) && (!stretchFactors.styleHeightCompensationFactor || stretchFactors.styleHeightCompensationFactor === 1)
) { ) {
autoHeightCompensationFactor = this.computeAutoHeightCompensationFactor(realVideoWidth, realVideoHeight, this.conf.player.dimensions.width, this.conf.player.dimensions.height, 'height'); autoHeightCompensationFactor = this.computeAutoHeightCompensationFactor(realVideoWidth, realVideoHeight, this.videoData.player.dimensions.width, this.videoData.player.dimensions.height, 'height');
stretchFactors.xFactor *= autoHeightCompensationFactor; stretchFactors.xFactor *= autoHeightCompensationFactor;
stretchFactors.yFactor *= autoHeightCompensationFactor; stretchFactors.yFactor *= autoHeightCompensationFactor;
} }
const offsetWidth = this.conf.video.offsetWidth; const offsetWidth = this.videoData.video.offsetWidth;
const offsetHeight = this.conf.video.offsetHeight; const offsetHeight = this.videoData.video.offsetHeight;
const wdiff = this.conf.player.dimensions.width - realVideoWidth; const wdiff = this.videoData.player.dimensions.width - realVideoWidth;
const hdiff = this.conf.player.dimensions.height - realVideoHeight; const hdiff = this.videoData.player.dimensions.height - realVideoHeight;
const wdiffAfterZoom = realVideoWidth * stretchFactors.xFactor - this.conf.player.dimensions.width; const wdiffAfterZoom = realVideoWidth * stretchFactors.xFactor - this.videoData.player.dimensions.width;
const hdiffAfterZoom = realVideoHeight * stretchFactors.yFactor - this.conf.player.dimensions.height; const hdiffAfterZoom = realVideoHeight * stretchFactors.yFactor - this.videoData.player.dimensions.height;
const translate = { const translate = {
x: wdiff * 0.5, x: wdiff * 0.5,
@ -725,11 +727,11 @@ class Resizer {
this.logger.log( this.logger.log(
'info', ['debug', 'resizer'], "[Resizer::_res_computeOffsets] <rid:"+this.resizerId+"> calculated offsets:", 'info', ['debug', 'resizer'], "[Resizer::_res_computeOffsets] <rid:"+this.resizerId+"> calculated offsets:",
'\n\n---- elements ----', '\n\n---- elements ----',
'\nplayer element: ', this.conf.player.element, '\nplayer element: ', this.videoData.player.element,
'\nvideo element: ', this.conf.video, '\nvideo element: ', this.videoData.video,
'\n\n---- data in ----', '\n\n---- data in ----',
'\nplayer dimensions: ', {w: this.conf.player.dimensions.width, h: this.conf.player.dimensions.height}, '\nplayer dimensions: ', {w: this.videoData.player.dimensions.width, h: this.videoData.player.dimensions.height},
'\nvideo dimensions: ', {w: this.conf.video.offsetWidth, h: this.conf.video.offsetHeight}, '\nvideo dimensions: ', {w: this.videoData.video.offsetWidth, h: this.videoData.video.offsetHeight},
'\nreal video dimensions:', {w: realVideoWidth, h: realVideoHeight}, '\nreal video dimensions:', {w: realVideoWidth, h: realVideoHeight},
'\nauto compensation: ', 'x', autoHeightCompensationFactor, '\nauto compensation: ', 'x', autoHeightCompensationFactor,
'\nstretch factors: ', stretchFactors, '\nstretch factors: ', stretchFactors,
@ -750,8 +752,8 @@ class Resizer {
// conditions are true at the same time, we need to go 'chiny reckon' and recheck our player // conditions are true at the same time, we need to go 'chiny reckon' and recheck our player
// element. Chances are our video is not getting aligned correctly // element. Chances are our video is not getting aligned correctly
if ( if (
(this.conf.video.offsetWidth > this.conf.player.dimensions.width && this.conf.video.offsetHeight > this.conf.player.dimensions.height) || (this.videoData.video.offsetWidth > this.videoData.player.dimensions.width && this.videoData.video.offsetHeight > this.videoData.player.dimensions.height) ||
(this.conf.video.offsetWidth < this.conf.player.dimensions.width && this.conf.video.offsetHeight < this.conf.player.dimensions.height) (this.videoData.video.offsetWidth < this.videoData.player.dimensions.width && this.videoData.video.offsetHeight < this.videoData.player.dimensions.height)
) { ) {
this.logger.log('warn', ['debugger', 'resizer'], `[Resizer::_res_computeOffsets] <rid:${this.resizerId}> We are getting some incredibly funny results here.\n\n`, this.logger.log('warn', ['debugger', 'resizer'], `[Resizer::_res_computeOffsets] <rid:${this.resizerId}> We are getting some incredibly funny results here.\n\n`,
`Video seems to be both wider and taller (or shorter and narrower) than player element at the same time. This is super duper not supposed to happen.\n\n`, `Video seems to be both wider and taller (or shorter and narrower) than player element at the same time. This is super duper not supposed to happen.\n\n`,
@ -762,7 +764,7 @@ class Resizer {
// There seems to be no way to reproduce it. // There seems to be no way to reproduce it.
if (! this._computeOffsetsRecursionGuard) { if (! this._computeOffsetsRecursionGuard) {
this._computeOffsetsRecursionGuard = true; this._computeOffsetsRecursionGuard = true;
this.conf.player.trackDimensionChanges(); this.videoData.player.trackDimensionChanges();
this._computeOffsetsRecursionGuard = false; this._computeOffsetsRecursionGuard = false;
} }
} }
@ -832,7 +834,7 @@ class Resizer {
if (! this.video) { if (! this.video) {
this.logger.log('warn', 'debug', "[Resizer::applyCss] <rid:"+this.resizerId+"> Video went missing, doing nothing."); this.logger.log('warn', 'debug', "[Resizer::applyCss] <rid:"+this.resizerId+"> Video went missing, doing nothing.");
this.conf.destroy(); this.videoData.destroy();
return; return;
} }
@ -840,7 +842,7 @@ class Resizer {
// 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 = {
validFor: this.conf.player.dimensions, validFor: this.videoData.player.dimensions,
// videoWidth: dimensions.width, // videoWidth: dimensions.width,
// videoHeight: dimensions.height // videoHeight: dimensions.height
} }
@ -876,7 +878,7 @@ class Resizer {
} }
setStyleString (styleString) { setStyleString (styleString) {
this.currentCssValidFor = this.conf.player.dimensions; this.currentCssValidFor = this.videoData.player.dimensions;
const newCssString = this.prepareCss(styleString); const newCssString = this.prepareCss(styleString);
// inject new CSS or replace existing one // inject new CSS or replace existing one