get popup to at least mildly work

This commit is contained in:
Tamius Han 2023-09-11 00:43:26 +02:00
parent c7ebd42fe9
commit 167f5173cd
2 changed files with 71 additions and 21 deletions

View File

@ -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)})`;

View File

@ -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();
} }
}, },
/** /**