Further migrations to runlevel
This commit is contained in:
parent
a466f77b6e
commit
abeded1d03
@ -73,7 +73,7 @@ class PlayerData {
|
|||||||
//#endregion
|
//#endregion
|
||||||
|
|
||||||
//#region flags
|
//#region flags
|
||||||
runLevel: RunLevel;
|
runLevel: RunLevel = RunLevel.Off;
|
||||||
enabled: boolean;
|
enabled: boolean;
|
||||||
invalid: boolean = false;
|
invalid: boolean = false;
|
||||||
private periodicallyRefreshPlayerElement: boolean = false;
|
private periodicallyRefreshPlayerElement: boolean = false;
|
||||||
@ -221,20 +221,7 @@ class PlayerData {
|
|||||||
//#endregion
|
//#endregion
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Enables ultrawidify for this video by adding the relevant classes
|
* Sets extension runLevel and sets or unsets appropriate css classes as necessary
|
||||||
* to the video and player element.
|
|
||||||
*/
|
|
||||||
enable() {
|
|
||||||
console.log('enabling UI')
|
|
||||||
this.enabled = true;
|
|
||||||
this.element.classList.add(this.playerCssClass);
|
|
||||||
this.startChangeDetection();
|
|
||||||
this.videoData.enable({fromPlayer: true});
|
|
||||||
this.ui.enable();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Sets extension runLevel
|
|
||||||
* @param runLevel
|
* @param runLevel
|
||||||
* @returns
|
* @returns
|
||||||
*/
|
*/
|
||||||
@ -264,22 +251,6 @@ class PlayerData {
|
|||||||
this.runLevel = runLevel;
|
this.runLevel = runLevel;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* 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() {
|
|
||||||
console.log('disabling UI')
|
|
||||||
this.enabled = false;
|
|
||||||
this.element.classList.remove(this.playerCssClass);
|
|
||||||
this.videoData.disable({fromPlayer: true});
|
|
||||||
this.ui.disable();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 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.
|
||||||
@ -354,26 +325,14 @@ class PlayerData {
|
|||||||
// Check if extension is allowed to run in current combination of theater + full screen
|
// Check if extension is allowed to run in current combination of theater + full screen
|
||||||
const canEnable = this.siteSettings.isEnabledForEnvironment(this.isFullscreen, this.isTheaterMode) === ExtensionMode.Enabled;
|
const canEnable = this.siteSettings.isEnabledForEnvironment(this.isFullscreen, this.isTheaterMode) === ExtensionMode.Enabled;
|
||||||
|
|
||||||
// TODO: if canEnable is 'true' and runLevel is OFF, we should
|
if (this.runLevel === RunLevel.Off && canEnable) {
|
||||||
// call restoreAr function of resizer and let it figure out the necessary run level.
|
this.eventBus.send('restore-ar', null);
|
||||||
// Function that restores the last user-set AR may also need to be written.
|
// must be called after
|
||||||
|
|
||||||
// Enable/disable
|
|
||||||
if (canEnable) {
|
|
||||||
if (!this.enabled) {
|
|
||||||
// we should really check other constraints first before enabling
|
|
||||||
this.enable();
|
|
||||||
this.handleDimensionChanges(currentPlayerDimensions, this.dimensions);
|
this.handleDimensionChanges(currentPlayerDimensions, this.dimensions);
|
||||||
return;
|
} else if (!canEnable && this.runLevel !== RunLevel.Off) {
|
||||||
}
|
// must be called before
|
||||||
} else {
|
|
||||||
// if canEnable comes out negative, there's no amount of constraints that will
|
|
||||||
// cause PlayerData to be enabled.
|
|
||||||
if (this.enabled) {
|
|
||||||
this.handleDimensionChanges(currentPlayerDimensions, this.dimensions);
|
this.handleDimensionChanges(currentPlayerDimensions, this.dimensions);
|
||||||
this.disable();
|
this.setRunLevel(RunLevel.Off);
|
||||||
}
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -38,7 +38,7 @@ class VideoData {
|
|||||||
//#region flags
|
//#region flags
|
||||||
arSetupComplete: boolean = false;
|
arSetupComplete: boolean = false;
|
||||||
enabled: boolean;
|
enabled: boolean;
|
||||||
runLevel: RunLevel;
|
runLevel: RunLevel = RunLevel.Off;
|
||||||
destroyed: boolean = false;
|
destroyed: boolean = false;
|
||||||
invalid: boolean = false;
|
invalid: boolean = false;
|
||||||
videoStatusOk: boolean = false;
|
videoStatusOk: boolean = false;
|
||||||
@ -85,6 +85,18 @@ class VideoData {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private eventBusCommands = {
|
||||||
|
'get-drm-status': [{
|
||||||
|
function: () => {
|
||||||
|
this.hasDrm = hasDrm(this.video);
|
||||||
|
this.eventBus.send('uw-config-broadcast', {type: 'drm-status', hasDrm: this.hasDrm});
|
||||||
|
}
|
||||||
|
}],
|
||||||
|
'set-run-level': [{
|
||||||
|
function: (runLevel: RunLevel) => this.setRunLevel(runLevel)
|
||||||
|
}]
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates new VideoData object
|
* Creates new VideoData object
|
||||||
* @param video
|
* @param video
|
||||||
@ -120,11 +132,12 @@ class VideoData {
|
|||||||
|
|
||||||
if (pageInfo.eventBus) {
|
if (pageInfo.eventBus) {
|
||||||
this.eventBus.setUpstreamBus(pageInfo.eventBus);
|
this.eventBus.setUpstreamBus(pageInfo.eventBus);
|
||||||
this.eventBus.subscribe('get-drm-status', {function: () => {
|
|
||||||
this.hasDrm = hasDrm(this.video);
|
for (const action in this.eventBusCommands) {
|
||||||
this.eventBus.send('uw-config-broadcast', {type: 'drm-status', hasDrm: this.hasDrm});
|
for (const command of this.eventBusCommands[action]) {
|
||||||
}});
|
this.eventBus.subscribe(action, command);
|
||||||
// this.eventBus.subscribe('')
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
this.setupEventListeners();
|
this.setupEventListeners();
|
||||||
@ -251,10 +264,6 @@ class VideoData {
|
|||||||
this.injectBaseCss();
|
this.injectBaseCss();
|
||||||
this.pageInfo.initMouseActionHandler(this);
|
this.pageInfo.initMouseActionHandler(this);
|
||||||
|
|
||||||
// aspect ratio autodetection cannot be properly initialized at this time,
|
|
||||||
// so we'll avoid doing that
|
|
||||||
this.enable();
|
|
||||||
|
|
||||||
// start fallback video/player size detection
|
// start fallback video/player size detection
|
||||||
this.fallbackChangeDetection();
|
this.fallbackChangeDetection();
|
||||||
}
|
}
|
||||||
@ -344,9 +353,10 @@ class VideoData {
|
|||||||
this.video.removeEventListener('ontimeupdate', this.onTimeUpdate);
|
this.video.removeEventListener('ontimeupdate', this.onTimeUpdate);
|
||||||
}
|
}
|
||||||
|
|
||||||
this.disable();
|
this.eventBus.send('set-run-level', RunLevel.Off);
|
||||||
this.destroyed = true;
|
this.destroyed = true;
|
||||||
this.eventBus?.unsetUpstreamBus();
|
this.eventBus?.unsetUpstreamBus();
|
||||||
|
|
||||||
try {
|
try {
|
||||||
this.arDetector.stop();
|
this.arDetector.stop();
|
||||||
this.arDetector.destroy();
|
this.arDetector.destroy();
|
||||||
@ -367,32 +377,18 @@ class VideoData {
|
|||||||
}
|
}
|
||||||
//#endregion
|
//#endregion
|
||||||
|
|
||||||
/**
|
|
||||||
* Enables ultrawidify in general.
|
|
||||||
* @param options
|
|
||||||
*/
|
|
||||||
enable(options?: {fromPlayer?: boolean}) {
|
|
||||||
this.enabled = true;
|
|
||||||
|
|
||||||
// NOTE — since base class for our <video> element depends on player aspect ratio,
|
|
||||||
// we handle it in PlayerData class.
|
|
||||||
this.video.classList.add(this.baseCssName);
|
|
||||||
this.video.classList.add(this.userCssClassName); // this also needs to be applied BEFORE we initialize resizer! — O RLY? NEEDS TO BE CHECKED
|
|
||||||
|
|
||||||
if (!options?.fromPlayer) {
|
|
||||||
this.player?.enable();
|
|
||||||
}
|
|
||||||
// this.restoreCrop();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
setRunLevel(runLevel: RunLevel, options?: {fromPlayer?: boolean}) {
|
setRunLevel(runLevel: RunLevel, options?: {fromPlayer?: boolean}) {
|
||||||
|
console.log('setting new runlevel for videodata. current:', this.runLevel, 'new', runLevel)
|
||||||
if (this.runLevel === runLevel) {
|
if (this.runLevel === runLevel) {
|
||||||
return; // also no need to propagate to the player
|
return; // also no need to propagate to the player
|
||||||
}
|
}
|
||||||
|
|
||||||
|
console.log('setting run level ...')
|
||||||
|
|
||||||
// Run level decreases towards 'off'
|
// Run level decreases towards 'off'
|
||||||
if (this.runLevel > runLevel) {
|
if (this.runLevel > runLevel) {
|
||||||
|
console.log('decreasing css.')
|
||||||
if (runLevel < RunLevel.CustomCSSActive) {
|
if (runLevel < RunLevel.CustomCSSActive) {
|
||||||
this.video.classList.remove(this.baseCssName);
|
this.video.classList.remove(this.baseCssName);
|
||||||
this.video.classList.remove(this.userCssClassName);
|
this.video.classList.remove(this.userCssClassName);
|
||||||
@ -428,9 +424,6 @@ class VideoData {
|
|||||||
this.video.classList.remove(this.baseCssName);
|
this.video.classList.remove(this.baseCssName);
|
||||||
this.video.classList.remove(this.userCssClassName);
|
this.video.classList.remove(this.userCssClassName);
|
||||||
|
|
||||||
if (!options?.fromPlayer) {
|
|
||||||
this.player?.disable();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//#region video status
|
//#region video status
|
||||||
|
@ -911,8 +911,6 @@ class Resizer {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
this.videoData.disable();
|
|
||||||
}
|
}
|
||||||
//#endregion
|
//#endregion
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user