Get basic messaging from popup to CS working. TODO: Forwarding to specific iframes/videos

This commit is contained in:
Tamius Han 2022-11-21 01:01:28 +01:00
parent d558717152
commit 44e3395835
6 changed files with 52 additions and 12 deletions

View File

@ -312,6 +312,7 @@ export default class UWServer {
if (!activeTab || activeTab.length < 1) { if (!activeTab || activeTab.length < 1) {
this.logger.log('warn', 'comms', 'There is no active tab for some reason. activeTab:', activeTab); this.logger.log('warn', 'comms', 'There is no active tab for some reason. activeTab:', activeTab);
return null;
} }
const url = activeTab[0].url; const url = activeTab[0].url;

View File

@ -26,6 +26,14 @@ export default class EventBus {
private upstreamBus?: EventBus; private upstreamBus?: EventBus;
private comms?: CommsClient | CommsServer; private comms?: CommsClient | CommsServer;
private disableTunnel: boolean = false;
private popupContext: any = {};
setupPopupTunnelWorkaround(context: EventBusContext): void {
this.disableTunnel = true;
this.popupContext = context;
}
//#region lifecycle //#region lifecycle
destroy() { destroy() {
this.commands = null; this.commands = null;
@ -107,6 +115,7 @@ export default class EventBus {
* @param config * @param config
*/ */
sendToTunnel(command: string, config: any) { sendToTunnel(command: string, config: any) {
if (!this.disableTunnel) {
window.parent.postMessage( window.parent.postMessage(
{ {
action: 'uw-bus-tunnel', action: 'uw-bus-tunnel',
@ -114,6 +123,14 @@ export default class EventBus {
}, },
'*' '*'
); );
} else {
// because iframe UI components get reused in the popup, we
// also need to set up a detour because the tunnel is closed
// in the popup
if (this.comms) {
this.comms.sendMessage({command, config, context: this.popupContext}, this.popupContext);
}
}
} }

View File

@ -134,7 +134,7 @@ class CommsServer {
return; return;
} }
for (const framePort in this.ports[tab][frame]) { for (const framePort in this.ports[tab][frame]) {
this.ports[tab][frame][framePort].postMessage(message); this.ports[tab][frame][framePort].postMessage(JSON.parse(JSON.stringify(message)));
} }
} }
@ -156,6 +156,7 @@ class CommsServer {
this.logger.log('info', 'comms', `%c[CommsServer::sendToFrame] attempting to send message to tab ${tab}, frame ${frame}`, "background: #dda; color: #11D", message); this.logger.log('info', 'comms', `%c[CommsServer::sendToFrame] attempting to send message to tab ${tab}, frame ${frame}`, "background: #dda; color: #11D", message);
try { try {
this.sendToFrameContentScripts(message, tab, frame, port); this.sendToFrameContentScripts(message, tab, frame, port);
} catch (e) { } catch (e) {
this.logger.log('error', 'comms', `%c[CommsServer::sendToFrame] Sending message failed. Reason:`, "background: #dda; color: #11D", e); this.logger.log('error', 'comms', `%c[CommsServer::sendToFrame] Sending message failed. Reason:`, "background: #dda; color: #11D", e);

View File

@ -32,7 +32,7 @@
:settings="settings" :settings="settings"
:eventBus="eventBus" :eventBus="eventBus"
:site="site" :site="site"
:frame="site.frame[0]" :frame="selectedFrame"
></PopupVideoSettings> ></PopupVideoSettings>
</div> </div>
<pre> <pre>
@ -48,10 +48,11 @@
</template> </template>
<script> <script>
import PopupVideoSettings from './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';
import Comms from '../ext/lib/comms/Comms'; import Comms from '../ext/lib/comms/Comms';
import CommsClient from '../ext/lib/comms/CommsClient'; import CommsClient, {CommsOrigin} from '../ext/lib/comms/CommsClient';
import Settings from '../ext/lib/Settings'; import Settings from '../ext/lib/Settings';
import Logger from '../ext/lib/Logger'; import Logger from '../ext/lib/Logger';
import EventBus from '../ext/lib/EventBus'; import EventBus from '../ext/lib/EventBus';
@ -69,6 +70,8 @@ export default {
sideMenuVisible: null, sideMenuVisible: null,
logger: undefined, logger: undefined,
site: undefined, site: undefined,
selectedFrame: '__playing',
} }
}, },
async created() { async created() {
@ -99,13 +102,25 @@ 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.eventBus.setupPopupTunnelWorkaround({
origin: CommsOrigin.Popup,
comms: {
forwardTo: 'active'
}
});
this.loadFrames(this.site); this.loadFrames(this.site);
} }
} }
); );
this.comms = new CommsClient('popup-port', this.logger, this.eventBus); this.comms = new CommsClient('popup-port', this.logger, this.eventBus);
this.eventBus.setComms(this.comms); this.eventBus.setComms(this.comms);
this.eventBus.setupPopupTunnelWorkaround({
origin: CommsOrigin.Popup,
comms: {forwardTo: 'active'}
});
// ensure we'll clean player markings on popup close // ensure we'll clean player markings on popup close
@ -144,7 +159,7 @@ export default {
}, },
components: { components: {
Debug, Debug,
BrowserDetect, BrowserDetect, PopupVideoSettings
}, },
methods: { methods: {
async sleep(t) { async sleep(t) {

View File

@ -19,6 +19,7 @@
</template> </template>
<script> <script>
import CropOptionsPanel from '../../csui/src/PlayerUiPanels/PanelComponents/VideoSettings/CropOptionsPanel.vue'
import ExecAction from '../../csui/src/ui-libs/ExecAction'; import ExecAction from '../../csui/src/ui-libs/ExecAction';
export default { export default {
@ -36,6 +37,9 @@ export default {
'eventBus', 'eventBus',
'site' 'site'
], ],
components: {
CropOptionsPanel
},
created() { created() {
this.exec = new ExecAction(this.settings, window.location.hostname); this.exec = new ExecAction(this.settings, window.location.hostname);
this.eventBus.subscribe('uw-config-broadcast', {function: (config) => this.handleConfigBroadcast(config)}); this.eventBus.subscribe('uw-config-broadcast', {function: (config) => this.handleConfigBroadcast(config)});

View File

@ -3,4 +3,6 @@ import App from './App';
import mdiVue from 'mdi-vue/v3'; import mdiVue from 'mdi-vue/v3';
import * as mdijs from '@mdi/js'; import * as mdijs from '@mdi/js';
createApp(App).mount('#app') //.use(mdiVue, {icons: mdijs}); createApp(App)
.use(mdiVue, {icons: mdijs})
.mount('#app');