Revert "split popup into ts"

This reverts commit 73eb5ffe93.
This commit is contained in:
Tamius Han 2021-03-11 21:58:12 +01:00
parent e7613aa691
commit d64b41a363
3 changed files with 56 additions and 43 deletions

View File

@ -195,8 +195,8 @@
:settings="settings" :settings="settings"
:site="selectedSite" :site="selectedSite"
/> />
<!-- <PerformancePanel v-if="selectedTab === 'performance-metrics'" <PerformancePanel v-if="selectedTab === 'performance-metrics'"
:performance="performance" /> --> :performance="performance" />
<WhatsNewPanel v-if="selectedTab === 'whats-new'" /> <WhatsNewPanel v-if="selectedTab === 'whats-new'" />
<AboutPanel v-if="selectedTab === 'about'" /> <AboutPanel v-if="selectedTab === 'about'" />
<Donate v-if="selectedTab === 'donate'" /> <Donate v-if="selectedTab === 'donate'" />
@ -205,23 +205,39 @@
</div> </div>
</template> </template>
<script lang="ts"> <script>
import Icon from '../common/components/Icon.vue'
import WhatsNewPanel from './panels/WhatsNewPanel.vue';
import SiteDetailsPanel from './panels/SiteDetailsPanel.vue';
import Donate from '../common/misc/Donate.vue';
import Debug from '../ext/conf/Debug';
import BrowserDetect from '../ext/conf/BrowserDetect';
import Comms from '../ext/lib/comms/Comms';
import VideoPanel from './panels/VideoPanel';
import PerformancePanel from './panels/PerformancePanel';
import Settings from '../ext/lib/Settings';
import ExecAction from './js/ExecAction.js';
import DefaultSettingsPanel from './panels/DefaultSettingsPanel';
import AboutPanel from './panels/AboutPanel';
import ExtensionMode from '../common/enums/ExtensionMode.enum';
import Logger from '../ext/lib/Logger';
import {ChromeShittinessMitigations as CSM} from '../common/js/ChromeShittinessMitigations';
export default {
export default Vue.extend({ data () {
data () {
return { return {
selectedTab: 'video', selectedTab: 'video',
selectedFrame: '__all', selectedFrame: '__all',
selectedSite: '', selectedSite: '',
activeFrames: [], activeFrames: [],
activeSites: [], activeSites: [],
comms: new Comms(),
frameStore: {}, frameStore: {},
frameStoreCount: 0, frameStoreCount: 0,
performance: {}, performance: {},
site: null, site: null,
currentZoom: 1, currentZoom: 1,
execAction: new ExecAction(null, null), execAction: new ExecAction(),
settings: {}, settings: {},
settingsInitialized: false, settingsInitialized: false,
logger: {}, logger: {},
@ -244,10 +260,9 @@ export default Vue.extend({
await this.settings.init(); await this.settings.init();
this.settingsInitialized = true; this.settingsInitialized = true;
const port = browser.runtime.connect(null, {name: 'popup-port'}); const port = BrowserDetect.firefox ? browser.runtime.connect({name: 'popup-port'}) : chrome.runtime.connect({name: 'popup-port'});
// port.onMessage.addListener( (m,p) => this.processReceivedMessage(m,p)); port.onMessage.addListener( (m,p) => this.processReceivedMessage(m,p));
CSM.setProperty('port', port);
// CSM.setProperty('port', port);
this.execAction.setSettings(this.settings); this.execAction.setSettings(this.settings);
@ -257,12 +272,12 @@ export default Vue.extend({
cmd: 'unmark-player', cmd: 'unmark-player',
forwardToAll: true, forwardToAll: true,
}); });
// if (BrowserDetect.anyChromium) { if (BrowserDetect.anyChromium) {
// chrome.extension.getBackgroundPage().sendUnmarkPlayer({ chrome.extension.getBackgroundPage().sendUnmarkPlayer({
// cmd: 'unmark-player', cmd: 'unmark-player',
// forwardToAll: true, forwardToAll: true,
// }); });
// } }
}); });
// get info about current site from background script // get info about current site from background script
@ -292,6 +307,7 @@ export default Vue.extend({
components: { components: {
VideoPanel, VideoPanel,
DefaultSettingsPanel, DefaultSettingsPanel,
PerformancePanel,
Debug, Debug,
BrowserDetect, BrowserDetect,
AboutPanel, AboutPanel,
@ -302,7 +318,7 @@ export default Vue.extend({
}, },
methods: { methods: {
async sleep(t) { async sleep(t) {
return new Promise<void>( (resolve,reject) => { return new Promise( (resolve,reject) => {
setTimeout(() => resolve(), t); setTimeout(() => resolve(), t);
}); });
}, },
@ -317,6 +333,20 @@ export default Vue.extend({
this.logger.log('error','popup','[popup::getSite] sending get-current-site failed for some reason. Reason:', e); this.logger.log('error','popup','[popup::getSite] sending get-current-site failed for some reason. Reason:', e);
} }
}, },
getRandomColor() {
return `rgb(${Math.floor(Math.random() * 128)}, ${Math.floor(Math.random() * 128)}, ${Math.floor(Math.random() * 128)})`;
},
selectTab(tab) {
this.selectedTab = tab;
if (tab === 'whats-new') {
this.settings.active.whatsNewChecked = true;
this.settings.save();
}
this.toggleSideMenu(false);
},
selectFrame(frame) {
this.selectedFrame = frame;
},
async updateConfig() { async updateConfig() {
// when this runs, a site could have been enabled or disabled // when this runs, a site could have been enabled or disabled
// this means we must update canShowVideoTab // this means we must update canShowVideoTab
@ -357,7 +387,7 @@ export default Vue.extend({
if (this.site) { if (this.site) {
if (!this.site.host) { if (!this.site.host) {
// dunno why this fix is needed, but sometimes it is // dunno why this fix is needed, but sometimes it is
this.site.host = message.site.tabHostname; this.site.host = site.tabHostname;
} }
} }
if (!this.site || this.site.host !== message.site.host) { if (!this.site || this.site.host !== message.site.host) {
@ -499,7 +529,7 @@ export default Vue.extend({
// update whether video tab can be shown // update whether video tab can be shown
this.updateCanShowVideoTab(); this.updateCanShowVideoTab();
}, },
getRandomColor(): string { 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)})`;
}, },
setCurrentZoom(nz) { setCurrentZoom(nz) {
@ -508,16 +538,8 @@ export default Vue.extend({
updateZoom(nz){ updateZoom(nz){
this.currentZoom = nz; this.currentZoom = nz;
}, },
selectTab(tab) { selectFrame(id){
this.selectedTab = tab; this.selectedFrame = id;
if (tab === 'whats-new') {
this.settings.active.whatsNewChecked = true;
this.settings.save();
}
this.toggleSideMenu(false);
},
selectFrame(frame) {
this.selectedFrame = frame;
}, },
selectSite(host) { selectSite(host) {
this.selectedSite = host; this.selectedSite = host;
@ -526,7 +548,7 @@ export default Vue.extend({
this.sideMenuVisible = visible ?? !this.sideMenuVisible; this.sideMenuVisible = visible ?? !this.sideMenuVisible;
} }
} }
}) }
</script> </script>
<style src="../res/css/font/overpass.css"></style> <style src="../res/css/font/overpass.css"></style>

View File

@ -1,10 +0,0 @@
import { createApp } from 'vue'
import App from './ExtensionActionButtonApp.vue';
class Popup {
static createApp() {
createApp(App).mount('#app');
}
}
export default Popup;

View File

@ -1,3 +1,4 @@
import Popup from './Popup'; import { createApp } from 'vue'
import App from './App';
Popup.createApp(); createApp(App).mount('#app');