get popup to at least mildly work
This commit is contained in:
parent
c7ebd42fe9
commit
167f5173cd
@ -20,29 +20,59 @@
|
|||||||
Build channel: {{BrowserDetect?.processEnvChannel}}
|
Build channel: {{BrowserDetect?.processEnvChannel}}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="">
|
|
||||||
TODO: force open UI button
|
|
||||||
</div>
|
<!-- CONTAINER ROOT -->
|
||||||
<div class="flex flex-row body no-overflow flex-grow">
|
<div class="flex flex-row body no-overflow flex-grow">
|
||||||
<div class="">
|
|
||||||
side menu
|
<!-- TABS -->
|
||||||
|
<div class="flex flex-col">
|
||||||
|
<div
|
||||||
|
v-for="tab of tabs"
|
||||||
|
:key="tab.id"
|
||||||
|
class="tab"
|
||||||
|
:class="{'active': tab.id === selectedTab}"
|
||||||
|
@click="selectTab(tab.id)"
|
||||||
|
>
|
||||||
|
<div class="icon-container">
|
||||||
|
<mdicon
|
||||||
|
:name="tab.icon"
|
||||||
|
:size="32"
|
||||||
|
/>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="label">
|
||||||
|
{{tab.label}}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- CONTENT -->
|
||||||
<div class="scrollable">
|
<div class="scrollable">
|
||||||
site: {{site}}, settings: {{ settings }}
|
|
||||||
<template v-if="settings && siteSettings">
|
<template v-if="settings && siteSettings">
|
||||||
<PopupVideoSettings
|
<PopupVideoSettings
|
||||||
|
v-if="selectedTab === 'videoSettings'"
|
||||||
:settings="settings"
|
:settings="settings"
|
||||||
:eventBus="eventBus"
|
:eventBus="eventBus"
|
||||||
:siteSettings="siteSettings"
|
:siteSettings="siteSettings"
|
||||||
></PopupVideoSettings>
|
></PopupVideoSettings>
|
||||||
|
<PlayerDetectionPanel
|
||||||
|
v-if="selectedTab === 'playerDetection'"
|
||||||
|
:settings="settings"
|
||||||
|
:eventBus="eventBus"
|
||||||
|
:siteSettings="siteSettings"
|
||||||
|
:site="site.host"
|
||||||
|
>
|
||||||
|
</PlayerDetectionPanel>
|
||||||
|
<BaseExtensionSettings
|
||||||
|
v-if="selectedTab === 'extensionSettings'"
|
||||||
|
:settings="settings"
|
||||||
|
:eventBus="eventBus"
|
||||||
|
:siteSettings="siteSettings"
|
||||||
|
:site="site.host"
|
||||||
|
>
|
||||||
|
</BaseExtensionSettings>
|
||||||
</template>
|
</template>
|
||||||
</div>
|
</div>
|
||||||
<!-- <pre>
|
|
||||||
---- site:
|
|
||||||
{{site}}
|
|
||||||
|
|
||||||
----
|
|
||||||
</pre> -->
|
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -50,6 +80,8 @@
|
|||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
|
import BaseExtensionSettings from './src/PlayerUiPanels/BaseExtensionSettings.vue'
|
||||||
|
import PlayerDetectionPanel from './src/PlayerUiPanels/PlayerDetectionPanel.vue'
|
||||||
import PopupVideoSettings from './src/popup/panels/PopupVideoSettings.vue'
|
import PopupVideoSettings from './src/popup/panels/PopupVideoSettings.vue'
|
||||||
import Debug from '../ext/conf/Debug';
|
import Debug from '../ext/conf/Debug';
|
||||||
import BrowserDetect from '../ext/conf/BrowserDetect';
|
import BrowserDetect from '../ext/conf/BrowserDetect';
|
||||||
@ -72,7 +104,14 @@ export default {
|
|||||||
logger: undefined,
|
logger: undefined,
|
||||||
site: undefined,
|
site: undefined,
|
||||||
siteSettings: undefined,
|
siteSettings: undefined,
|
||||||
selectedFrame: '__playing',
|
selectedTab: 'playerUiCtl',
|
||||||
|
tabs: [
|
||||||
|
// see this for icons: https://pictogrammers.com/library/mdi/
|
||||||
|
{id: 'playerUiCtl', label: 'In-player UI', icon: 'artboard'},
|
||||||
|
{id: 'videoSettings', label: 'Video settings', icon: 'crop'},
|
||||||
|
{id: 'playerDetection', label: 'Player detection', icon: 'television-play'},
|
||||||
|
{id: 'extensionSettings', label: 'Site and Extension options', icon: 'cogs' },
|
||||||
|
],
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
async created() {
|
async created() {
|
||||||
@ -101,7 +140,8 @@ export default {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
this.site = config.site;
|
this.site = config.site;
|
||||||
this.selectedSite = this.selectedSite || config.site.host;
|
// this.selectedSite = this.selectedSite || config.site.host;
|
||||||
|
this.siteSettings = this.settings.getSiteSettings(this.site.host);
|
||||||
|
|
||||||
this.eventBus.setupPopupTunnelWorkaround({
|
this.eventBus.setupPopupTunnelWorkaround({
|
||||||
origin: CommsOrigin.Popup,
|
origin: CommsOrigin.Popup,
|
||||||
@ -161,7 +201,7 @@ export default {
|
|||||||
components: {
|
components: {
|
||||||
Debug,
|
Debug,
|
||||||
BrowserDetect,
|
BrowserDetect,
|
||||||
PopupVideoSettings
|
PopupVideoSettings, PlayerDetectionPanel, BaseExtensionSettings
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
async sleep(t) {
|
async sleep(t) {
|
||||||
@ -190,7 +230,9 @@ export default {
|
|||||||
getRandomColor() {
|
getRandomColor() {
|
||||||
return `rgb(${Math.floor(Math.random() * 128)}, ${Math.floor(Math.random() * 128)}, ${Math.floor(Math.random() * 128)})`;
|
return `rgb(${Math.floor(Math.random() * 128)}, ${Math.floor(Math.random() * 128)}, ${Math.floor(Math.random() * 128)})`;
|
||||||
},
|
},
|
||||||
|
selectTab(tab) {
|
||||||
|
this.selectedTab = tab;
|
||||||
|
},
|
||||||
processReceivedMessage(message, port) {
|
processReceivedMessage(message, port) {
|
||||||
this.logger.log('info', 'popup', '[popup::processReceivedMessage] received message:', message)
|
this.logger.log('info', 'popup', '[popup::processReceivedMessage] received message:', message)
|
||||||
console.info('[popup::processReceivedMessage] got message:', message);
|
console.info('[popup::processReceivedMessage] got message:', message);
|
||||||
@ -247,7 +289,7 @@ export default {
|
|||||||
// }
|
// }
|
||||||
|
|
||||||
// update whether video tab can be shown
|
// update whether video tab can be shown
|
||||||
this.updateCanShowVideoTab();
|
// this.updateCanShowVideoTab();
|
||||||
},
|
},
|
||||||
getRandomColor() {
|
getRandomColor() {
|
||||||
return `rgb(${Math.floor(Math.random() * 128)}, ${Math.floor(Math.random() * 128)}, ${Math.floor(Math.random() * 128)})`;
|
return `rgb(${Math.floor(Math.random() * 128)}, ${Math.floor(Math.random() * 128)}, ${Math.floor(Math.random() * 128)})`;
|
||||||
|
@ -361,16 +361,24 @@ export default({
|
|||||||
'siteSettings',
|
'siteSettings',
|
||||||
'frame',
|
'frame',
|
||||||
'eventBus',
|
'eventBus',
|
||||||
'site'
|
'site',
|
||||||
|
'isPopup'
|
||||||
],
|
],
|
||||||
created() {
|
created() {
|
||||||
this.eventBus.subscribe('uw-config-broadcast', {function: (config) => this.handleElementStack(config)});
|
this.eventBus.subscribe('uw-config-broadcast', {function: (config) => this.handleElementStack(config)});
|
||||||
},
|
},
|
||||||
mounted() {
|
mounted() {
|
||||||
this.eventBus.sendToTunnel('get-player-tree');
|
this.getPlayerTree();
|
||||||
},
|
},
|
||||||
computed: {},
|
computed: {},
|
||||||
methods: {
|
methods: {
|
||||||
|
getPlayerTree() {
|
||||||
|
if (this.isPopup) {
|
||||||
|
this.eventBus.send('get-player-tree');
|
||||||
|
} else {
|
||||||
|
this.eventBus.sendToTunnel('get-player-tree');
|
||||||
|
}
|
||||||
|
},
|
||||||
handleElementStack(configBroadcast) {
|
handleElementStack(configBroadcast) {
|
||||||
if (configBroadcast.type === 'player-tree') {
|
if (configBroadcast.type === 'player-tree') {
|
||||||
this.elementStack = configBroadcast.config;
|
this.elementStack = configBroadcast.config;
|
||||||
@ -391,13 +399,13 @@ export default({
|
|||||||
// we just unset our settings for this site
|
// we just unset our settings for this site
|
||||||
if (this.elementStack[index].heuristics?.autoMatch) {
|
if (this.elementStack[index].heuristics?.autoMatch) {
|
||||||
await this.siteSettings.set('DOMConfig.modified.elements.player.manual', false);
|
await this.siteSettings.set('DOMConfig.modified.elements.player.manual', false);
|
||||||
this.eventBus.sendToTunnel('get-player-tree');
|
this.getPlayerTree();
|
||||||
} else {
|
} else {
|
||||||
// ensure settings exist:
|
// ensure settings exist:
|
||||||
await this.siteSettings.set('DOMConfig.modified.elements.player.manual', true, {noSave: true});
|
await this.siteSettings.set('DOMConfig.modified.elements.player.manual', true, {noSave: true});
|
||||||
await this.siteSettings.set('DOMConfig.modified.elements.player.mode', 'index', {noSave: true});
|
await this.siteSettings.set('DOMConfig.modified.elements.player.mode', 'index', {noSave: true});
|
||||||
await this.siteSettings.set('DOMConfig.modified.elements.player.index', index, true);
|
await this.siteSettings.set('DOMConfig.modified.elements.player.index', index, true);
|
||||||
this.eventBus.sendToTunnel('get-player-tree');
|
this.getPlayerTree();
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
/**
|
/**
|
||||||
|
Loading…
Reference in New Issue
Block a user