expose videoData objects via window.ultrawidify

This commit is contained in:
Tamius Han 2021-01-27 00:41:42 +01:00
parent 13b89eb2a9
commit 84da78e2e8
7 changed files with 59 additions and 5 deletions

View File

@ -9,7 +9,7 @@
Video options Video options
</div> </div>
</div> </div>
<div> <div>sudpo
<!-- Panel section --> <!-- Panel section -->
<template v-if="settingsInitialized"> <template v-if="settingsInitialized">
<VideoSettings <VideoSettings
@ -92,10 +92,16 @@ export default {
await this.settings.init(); await this.settings.init();
this.settingsInitialized = true; this.settingsInitialized = true;
console.log("settings inited")
this.execAction.setSettings(this.settings); this.execAction.setSettings(this.settings);
console.log("created!"); console.log("created!");
console.log("store:", this.$store, this); console.log("store:", this.$store, this);
console.log("settings:", this.settings)
console.log("windowPD", window.ultrawidify);
console.log("this:", this);
} catch (e) { } catch (e) {
console.error('Failed to initiate ultrawidify player ui.', e); console.error('Failed to initiate ultrawidify player ui.', e);
} }

View File

@ -19,6 +19,7 @@
<div> <div>
<h1>Streth video:</h1> <h1>Streth video:</h1>
<div class="flex flex-row flex-wrap"> <div class="flex flex-row flex-wrap">
<div @click="testAction()">TEST CLICK ME</div>
</div> </div>
</div> </div>
<div> <div>
@ -96,6 +97,9 @@ export default {
// 'page', // 'page',
// this.frame // this.frame
// ); // );
},
testAction() {
window.ultrawidify.videos[0].setAr({type: AspectRatio.FitWidth});
} }
} }
} }

33
src/ext/lib/UWGlobals.js Normal file
View File

@ -0,0 +1,33 @@
export default class UWGlobals {
constructor() {
this.videos = [];
}
getNewVideoID() {
let random;
while (true) {
// 4-digit [a-z0-9] string. Should be unique per page on first try
random = (Math.random() * 1679616).toFixed().toString(36);
if (this.videos.findIndex(x => x.vdid === random) === -1) {
return random;
}
}
}
addVideo(video) {
// get video ID
const id = this.getNewVideoID();
video.vdid = id;
this.videos.push(video);
}
getVideo(id) {
return this.videos.find(x => x.vdid === id);
}
destroy() {
// todo: implement
}
}

View File

@ -30,7 +30,6 @@ class PlayerUi extends UI {
this.settings = settings; this.settings = settings;
} }
//#region constructor helpers //#region constructor helpers
// we will move some things out of the constructor in order to keep things clean // we will move some things out of the constructor in order to keep things clean
static getStoreConfig() { static getStoreConfig() {

View File

@ -47,6 +47,7 @@ class PlayerData {
this.element = this.getPlayer(); this.element = this.getPlayer();
this.notificationService = new PlayerNotificationUi(this.element, this.settings); this.notificationService = new PlayerNotificationUi(this.element, this.settings);
this.ui = new PlayerUi(this.element, this.settings); this.ui = new PlayerUi(this.element, this.settings);
this.dimensions = undefined; this.dimensions = undefined;
this.overlayNode = undefined; this.overlayNode = undefined;

View File

@ -8,7 +8,8 @@ class VideoData {
constructor(video, settings, pageInfo){ constructor(video, settings, pageInfo){
this.vdid = (Math.random()*100).toFixed(); window.ultrawidify.addVideo(this);
this.logger = pageInfo.logger; this.logger = pageInfo.logger;
this.arSetupComplete = false; this.arSetupComplete = false;
this.video = video; this.video = video;
@ -91,6 +92,7 @@ class VideoData {
} }
//#endregion //#endregion
//#region lifecycle-ish //#region lifecycle-ish
/** /**
* Injects base CSS and sets up handlers for <video> tag events * Injects base CSS and sets up handlers for <video> tag events

View File

@ -7,6 +7,7 @@ import Comms from './lib/comms/Comms';
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'; import Logger from './lib/Logger';
import UWGlobals from './lib/UWGlobals';
if(process.env.CHANNEL !== 'stable'){ if(process.env.CHANNEL !== 'stable'){
@ -65,6 +66,14 @@ class UW {
} }
} }
createUWGlobals() {
if (window.ultrawidify) {
window.ultrawidify.destroy();
}
window.ultrawidify = new UWGlobals();
}
reloadSettings() { reloadSettings() {
this.logger.log('info', 'debug', 'Things happened in the popup. Will reload extension settings.'); this.logger.log('info', 'debug', 'Things happened in the popup. Will reload extension settings.');
this.init(); this.init();
@ -75,6 +84,8 @@ class UW {
console.log("[uw::main] loading configuration ..."); console.log("[uw::main] loading configuration ...");
} }
this.createUWGlobals();
// logger init is the first thing that needs to run // logger init is the first thing that needs to run
try { try {
if (!this.logger) { if (!this.logger) {
@ -179,8 +190,6 @@ class UW {
this.logger.log('error', 'debug', "[uw::init] FAILED TO START EXTENSION. Error:", e); this.logger.log('error', 'debug', "[uw::init] FAILED TO START EXTENSION. Error:", e);
} }
} }
} }
var main = new UW(); var main = new UW();