From 290dfbac14c973e8efe007012419d7c583510d14 Mon Sep 17 00:00:00 2001 From: dessant Date: Mon, 3 Jun 2024 23:09:11 +0300 Subject: [PATCH] feat: reload options page when client app is installed --- src/background/main.js | 10 ++++++++++ src/options/App.vue | 8 ++++++++ src/setup/App.vue | 4 ++-- 3 files changed, 20 insertions(+), 2 deletions(-) diff --git a/src/background/main.js b/src/background/main.js index be247b5..c30e4c0 100644 --- a/src/background/main.js +++ b/src/background/main.js @@ -899,6 +899,8 @@ async function processMessage(request, sender) { return getBrowser(); } else if (request.id === 'optionChange') { await onOptionChange(); + } else if (request.id === 'clientAppInstall') { + await onClientAppInstall(); } } @@ -908,6 +910,14 @@ function onMessage(request, sender, sendResponse) { return processMessageResponse(response, sendResponse); } +async function onClientAppInstall() { + await storage.set({simulateUserInput: true}); + + await browser.runtime + .sendMessage({id: 'reloadOptionsPage'}) + .catch(() => null); +} + async function onOptionChange() { await setChallengeLocale(); } diff --git a/src/options/App.vue b/src/options/App.vue index 644dcf5..5b68e1d 100644 --- a/src/options/App.vue +++ b/src/options/App.vue @@ -360,6 +360,8 @@ export default { getText, setup: async function () { + browser.runtime.onMessage.addListener(this.onMessage); + const options = await storage.get(optionKeys); for (const option of Object.keys(this.options)) { @@ -388,6 +390,12 @@ export default { this.dataLoaded = true; }, + onMessage: function (request, sender) { + if (request.id === 'reloadOptionsPage') { + self.location.reload(); + } + }, + verifyClientApp: async function () { try { await pingClientApp(); diff --git a/src/setup/App.vue b/src/setup/App.vue index ceaa780..a7ff128 100644 --- a/src/setup/App.vue +++ b/src/setup/App.vue @@ -65,7 +65,6 @@