Fix setBaseClass function

This commit is contained in:
Tamius Han 2020-11-05 23:55:42 +01:00
parent 6b91444f3c
commit f8e3a39620

View File

@ -79,10 +79,20 @@ class PlayerData {
// be better option than doing nothing
return;
}
// note that we should never allow both narrow-screen and wide-screen classes on the video
// element at _any_ time. That may break some sites even more.
// We should also only set/unset css classes when they change, otherwise mutation observer
// will trigger. Triggering mutation observer is problematic because this function may be
// called from said mutation observer, and that is bad.
if (this.video.videoWidth / this.videoHeight <= this.dimensions.width / this.dimensions.height) {
const isNarrowScreen = this.video.videoWidth / this.video.videoHeight > this.dimensions.width / this.dimensions.height;
console.warn('setting base class. Is narrow screen?', isNarrowScreen, 'was narrow screen?', this.isNarrowScreen, "video:", this.video, ":", this.video.videoWidth, "x", this.video.videoHeight, "video file ar:", this.video.videoWidth / this.video.videoHeight, "player ar:", this.dimensions.width / this.dimensions.height)
if (this.isNarrowScreen != isNarrowScreen) {
if (!isNarrowScreen) {
this.video.classList.remove('uw-ultrawidify-base-narrow-screen');
this.video.classList.add('uw-ultrawidify-base-wide-screen');
} else {
@ -91,6 +101,9 @@ class PlayerData {
}
}
this.isNarrowScreen = isNarrowScreen;
}
unsetBaseClass() {
this.video.classList.remove('uw-ultrawidify-base-narrow-screen');
this.video.classList.remove('uw-ultrawidify-base-wide-screen');