From 685cfc94665b15470713fbf501680242c3737d41 Mon Sep 17 00:00:00 2001 From: Tamius Han Date: Sat, 21 Sep 2019 19:55:47 +0200 Subject: [PATCH] Popup: Fix issue where 'sites' tab would be disabled if extension mode was set to whitelist only --- src/popup/App.vue | 18 +++++++++++++----- 1 file changed, 13 insertions(+), 5 deletions(-) diff --git a/src/popup/App.vue b/src/popup/App.vue index 6265dd9..bc4d6d9 100644 --- a/src/popup/App.vue +++ b/src/popup/App.vue @@ -347,13 +347,21 @@ export default { // Extension site disabled, embedded videos from non-blacklisted hosts — show video settings // Extension site enabled — show vido settings + // note: this if statement is ever so slightly unnecessary if (! this.settings.canStartExtension('@global')) { - if (this.selectedTab === 'video' || this.selectedTab === 'site') { - this.selectTab('global'); + // canStartExtension and getExtensionMode return disabled/false for non-whitelisted + // sites, even if extension mode is set to "whitelist only." This is problematic + // because in order to whitelist a given site, we need to set extension to global- + // enabled, whitelist the site, and then set extension to whitelist only. This makes + // for a bad user experience, so let's fix this. + if (this.settings.active.sites['@global'].mode === ExtensionMode.Disabled) { + if (this.selectedTab === 'video' || this.selectedTab === 'site') { + this.selectTab('global'); + } + this.siteTabDisabled = true; + this.videoTabDisabled = true; + return; } - this.siteTabDisabled = true; - this.videoTabDisabled = true; - return; } this.siteTabDisabled = false;;