From 9a814ea21badc4b8a3e9f12e59d431b64b665c11 Mon Sep 17 00:00:00 2001 From: Lesley Norton Date: Mon, 25 Nov 2024 13:29:33 -0800 Subject: [PATCH 1/3] Allow disconnect from connecting state --- .../extensionController/extensionController.js | 17 +++++++++++++++++ src/components/vpncard.js | 12 ++++++++++++ src/ui/browserAction/popupPage.js | 5 +++++ 3 files changed, 34 insertions(+) diff --git a/src/background/extensionController/extensionController.js b/src/background/extensionController/extensionController.js index 26f6df69..6ae87039 100644 --- a/src/background/extensionController/extensionController.js +++ b/src/background/extensionController/extensionController.js @@ -27,6 +27,7 @@ export class ExtensionController extends Component { static properties = { state: PropertyType.Bindable, toggleConnectivity: PropertyType.Function, + allowDisconnect: PropertyType.Bindable }; /** @@ -51,6 +52,11 @@ export class ExtensionController extends Component { async init() {} toggleConnectivity() { + if (this.#mState.value.state === "Connecting" && this.clientState.state === "Disabled") { + this.#mState.set(new StateFirefoxVPNDisabled(true)); + this.vpnController.postToApp("deactivate"); + return; + } if (this.#mState.value.enabled) { // We are turning off the extension @@ -73,6 +79,12 @@ export class ExtensionController extends Component { } this.#mState.set(new StateFirefoxVPNConnecting()); + + this.#mAllowDisconnect.value = false; + setTimeout(() => { + this.#mAllowDisconnect.value = true; + }, 10000); + // Send activation to client and wait for response this.vpnController.postToApp("activate"); } @@ -81,6 +93,10 @@ export class ExtensionController extends Component { return this.#mState.readOnly; } + get allowDisconnect() { + return this.#mAllowDisconnect.readOnly; + } + /** * * @param {VPNState} newClientState @@ -137,5 +153,6 @@ export class ExtensionController extends Component { } #mState = property(new FirefoxVPNState()); + #mAllowDisconnect = property(false) mKeepAliveConnection = false; } diff --git a/src/components/vpncard.js b/src/components/vpncard.js index c7e68fbb..cf0b2d2a 100644 --- a/src/components/vpncard.js +++ b/src/components/vpncard.js @@ -30,6 +30,7 @@ export class VPNCard extends LitElement { stability: { type: String }, hasContext: { type: Boolean }, connecting: { type: Boolean }, + allowDisconnect: { type: Boolean } }; constructor() { @@ -41,6 +42,7 @@ export class VPNCard extends LitElement { this.connectedSince = 0; this.stability = VPNState.Stable; this.connecting = false; + this.allowDisconnect = false; } #intervalHandle = null; #shieldElement = createRef(); @@ -79,6 +81,7 @@ export class VPNCard extends LitElement { box: true, on: this.enabled, connecting: this.connecting, + allowDisconnect: this.allowDisconnect, unstable: this.enabled && this.stability === VPNState.Unstable, noSignal: this.enabled && this.stability === VPNState.NoSignal, stable: @@ -223,6 +226,15 @@ export class VPNCard extends LitElement { background: var(--main-card-background); box-shadow: var(--box-shadow-on); } + + .box.connecting .pill { + pointer-events: none; + } + + .box.connecting.allowDisconnect .pill { + pointer-events: all; + opacity: 1; + } main, footer { display: flex; diff --git a/src/ui/browserAction/popupPage.js b/src/ui/browserAction/popupPage.js index 18f36bc3..4ce7bd60 100644 --- a/src/ui/browserAction/popupPage.js +++ b/src/ui/browserAction/popupPage.js @@ -58,6 +58,7 @@ export class BrowserActionPopup extends LitElement { _siteContext: { type: Object }, hasSiteContext: { type: Boolean }, _siteContexts: { type: Array }, + allowDisconnect: { type: Boolean } }; constructor() { @@ -79,6 +80,9 @@ export class BrowserActionPopup extends LitElement { this.updatePage(); }); this.updatePage(); + extController.allowDisconnect.subscribe((s) => { + this.allowDisconnect = s; + }); } updatePage() { Utils.getCurrentTab().then(async (tab) => { @@ -182,6 +186,7 @@ export class BrowserActionPopup extends LitElement { .stability=${this.vpnState?.connectionHealth} .hasContext=${this._siteContext} .connecting=${this.extState?.connecting} + .allowDisconnect=${this.allowDisconnect} > ${this.locationSettings()} From f5ee16e0983d4e16eeb9eb08a1bb1bb7a652b68b Mon Sep 17 00:00:00 2001 From: Lesley Norton Date: Thu, 12 Dec 2024 15:16:41 -0600 Subject: [PATCH 2/3] Prettier --- .../extensionController/extensionController.js | 15 +++++++++------ src/components/vpncard.js | 2 +- src/ui/browserAction/popupPage.js | 2 +- 3 files changed, 11 insertions(+), 8 deletions(-) diff --git a/src/background/extensionController/extensionController.js b/src/background/extensionController/extensionController.js index 6ae87039..7bd1e9b4 100644 --- a/src/background/extensionController/extensionController.js +++ b/src/background/extensionController/extensionController.js @@ -27,7 +27,7 @@ export class ExtensionController extends Component { static properties = { state: PropertyType.Bindable, toggleConnectivity: PropertyType.Function, - allowDisconnect: PropertyType.Bindable + allowDisconnect: PropertyType.Bindable, }; /** @@ -52,10 +52,13 @@ export class ExtensionController extends Component { async init() {} toggleConnectivity() { - if (this.#mState.value.state === "Connecting" && this.clientState.state === "Disabled") { - this.#mState.set(new StateFirefoxVPNDisabled(true)); - this.vpnController.postToApp("deactivate"); - return; + if ( + this.#mState.value.state === "Connecting" && + this.clientState.state === "Disabled" + ) { + this.#mState.set(new StateFirefoxVPNDisabled(true)); + this.vpnController.postToApp("deactivate"); + return; } if (this.#mState.value.enabled) { // We are turning off the extension @@ -153,6 +156,6 @@ export class ExtensionController extends Component { } #mState = property(new FirefoxVPNState()); - #mAllowDisconnect = property(false) + #mAllowDisconnect = property(false); mKeepAliveConnection = false; } diff --git a/src/components/vpncard.js b/src/components/vpncard.js index cf0b2d2a..d1cda933 100644 --- a/src/components/vpncard.js +++ b/src/components/vpncard.js @@ -30,7 +30,7 @@ export class VPNCard extends LitElement { stability: { type: String }, hasContext: { type: Boolean }, connecting: { type: Boolean }, - allowDisconnect: { type: Boolean } + allowDisconnect: { type: Boolean }, }; constructor() { diff --git a/src/ui/browserAction/popupPage.js b/src/ui/browserAction/popupPage.js index 4ce7bd60..760ba33f 100644 --- a/src/ui/browserAction/popupPage.js +++ b/src/ui/browserAction/popupPage.js @@ -58,7 +58,7 @@ export class BrowserActionPopup extends LitElement { _siteContext: { type: Object }, hasSiteContext: { type: Boolean }, _siteContexts: { type: Array }, - allowDisconnect: { type: Boolean } + allowDisconnect: { type: Boolean }, }; constructor() { From 14fc0ca3823dbf55543d33dc1feb486d0bb42157 Mon Sep 17 00:00:00 2001 From: Lesley Norton Date: Mon, 16 Dec 2024 17:31:55 -0600 Subject: [PATCH 3/3] Format --- src/components/prefab-screens.js | 21 ++++++++++++--------- 1 file changed, 12 insertions(+), 9 deletions(-) diff --git a/src/components/prefab-screens.js b/src/components/prefab-screens.js index 10866617..f51247a9 100644 --- a/src/components/prefab-screens.js +++ b/src/components/prefab-screens.js @@ -17,11 +17,11 @@ const sumoLink = "https://support.mozilla.org/products/firefox-private-network-vpn"; const closeAfter = (f) => { - if(f){ - f(); - } - window.close(); -} + if (f) { + f(); + } + window.close(); +}; const defineMessageScreen = ( tag, @@ -31,7 +31,7 @@ const defineMessageScreen = ( primaryAction, onPrimaryAction, secondaryAction = tr("getHelp"), - onSecondaryAction = () => closeAfter (()=>open(sumoLink)), + onSecondaryAction = () => closeAfter(() => open(sumoLink)), totalPages = 0, currentPage = 0 ) => { @@ -73,7 +73,8 @@ defineMessageScreen( tr("bodySubscribeNow"), tr("btnSubscribeNow"), () => { - () => closeAfter (()=>open("https://www.mozilla.org/products/vpn#pricing")); + () => + closeAfter(() => open("https://www.mozilla.org/products/vpn#pricing")); } ); @@ -84,7 +85,8 @@ defineMessageScreen( tr("bodyNeedsUpdate2"), tr("btnDownloadNow"), () => { - () => closeAfter (()=>open("https://www.mozilla.org/products/vpn/download/")); + () => + closeAfter(() => open("https://www.mozilla.org/products/vpn/download/")); } ); @@ -105,7 +107,8 @@ defineMessageScreen( `, tr("btnDownloadNow"), () => { - () => closeAfter (()=>open("https://www.mozilla.org/products/vpn/download/")); + () => + closeAfter(() => open("https://www.mozilla.org/products/vpn/download/")); } );