get DRM status in player ui

This commit is contained in:
Tamius Han 2022-07-28 00:45:27 +02:00
parent f30de3f4a0
commit 88dec55116
2 changed files with 23 additions and 22 deletions

View File

@ -78,22 +78,13 @@
<!-- autodetection warning --> <!-- autodetection warning -->
<div class="warning-area"> <div class="warning-area">
<div class="warning-box"> <div
v-if="statusFlags.hasDrm"
class="warning-box"
>
<div class="icon-container"> <div class="icon-container">
<mdicon name="alert" :size="32" /> <mdicon name="alert" :size="32" />
</div> </div>
<div>
DRM warnings will appear in this box<br/>
<a>Learn more ...</a>
</div>
</div>
</div>
<div v-if="ultrawidify?.videoData?.hasDrm" class="warning-area">
<div class="warning-box">
<div>
<mdicon name="alert" :size="42" />
</div>
<div> <div>
This site is blocking automatic aspect ratio detection. You will have to adjust aspect ratio manually.<br/> This site is blocking automatic aspect ratio detection. You will have to adjust aspect ratio manually.<br/>
<a>Learn more ...</a> <a>Learn more ...</a>
@ -201,6 +192,10 @@ export default {
}, },
debugDataPrettified: '', debugDataPrettified: '',
statusFlags: {
hasDrm: undefined,
},
tabs: [ tabs: [
{id: 'videoSettings', label: 'Video settings', icon: 'crop'}, {id: 'videoSettings', label: 'Video settings', icon: 'crop'},
{id: 'playerDetection', label: 'Player detection', icon: 'television-play'}, {id: 'playerDetection', label: 'Player detection', icon: 'television-play'},
@ -212,12 +207,6 @@ export default {
}; };
}, },
computed: { computed: {
// we don't have vuex here at the moment, so no mapState yet!
// ...mapState([
// 'showUi',
// 'resizerDebugData',
// 'playerDebugData'
// ]),
// LPT: NO ARROW FUNCTIONS IN COMPUTED, // LPT: NO ARROW FUNCTIONS IN COMPUTED,
// IS SUPER HARAM // IS SUPER HARAM
// THINGS WILL NOT WORK IF YOU USE ARROWS // THINGS WILL NOT WORK IF YOU USE ARROWS
@ -249,8 +238,6 @@ export default {
}, },
async created() { async created() {
console.log('player-tree: player UI base created')
this.logger = new Logger(); this.logger = new Logger();
await this.logger.init({ await this.logger.init({
allowLogging: true, allowLogging: true,
@ -278,6 +265,12 @@ export default {
} }
}, this.origin); }, this.origin);
}); });
this.eventBus.subscribe('uw-config-broadcast', (data) => {
if (data.type === 'drm-status') {
this.statusFlags.hasDrm = data.hasDrm;
}
});
}, },
methods: { methods: {
@ -324,7 +317,7 @@ export default {
this.uwTriggerZoneTimeout = setTimeout( this.uwTriggerZoneTimeout = setTimeout(
() => this.uwTriggerZoneVisible = false, () => this.uwTriggerZoneVisible = false,
250 250
) );
} }
/* we check if our mouse is hovering over an element. /* we check if our mouse is hovering over an element.
@ -363,6 +356,9 @@ export default {
this.uwWindowFadeOut = false; this.uwWindowFadeOut = false;
this.uwWindowVisible = true; this.uwWindowVisible = true;
this.uwTriggerZoneVisible = false; this.uwTriggerZoneVisible = false;
// refresh DRM status
this.eventBus.send('get-drm-status');
}, },
hideUwWindow() { hideUwWindow() {

View File

@ -92,6 +92,10 @@ 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);
this.eventBus.send('uw-config-broadcast', {type: 'drm-status', hasDrm: this.hasDrm});
}});
} }
@ -634,6 +638,7 @@ class VideoData {
} }
} }
startArDetection() { startArDetection() {
this.logger.log('info', 'debug', "[VideoData::startArDetection] starting AR detection") this.logger.log('info', 'debug', "[VideoData::startArDetection] starting AR detection")
if(this.destroyed || this.invalid) { if(this.destroyed || this.invalid) {