From fc8dd639ae957505786bd178bc993e41d236990b Mon Sep 17 00:00:00 2001 From: agmmnn Date: Mon, 16 Oct 2023 14:22:51 +0300 Subject: [PATCH] Reload the page when the `preferredLanguage` is changed --- src/options.ts | 5 +---- src/util.ts | 7 +++++++ 2 files changed, 8 insertions(+), 4 deletions(-) diff --git a/src/options.ts b/src/options.ts index 7b956e6..dff70c3 100644 --- a/src/options.ts +++ b/src/options.ts @@ -65,10 +65,7 @@ window.addEventListener('DOMContentLoaded', async function () { languageSelect.addEventListener('change', function () { const selectedLanguage = this.value - chrome.storage.sync.set({ preferredLanguage: selectedLanguage }, function () { - // Reload the current page to apply the language change - location.reload() - }) + chrome.storage.sync.set({ preferredLanguage: selectedLanguage }) }) } diff --git a/src/util.ts b/src/util.ts index ab28f8a..1e1fa27 100644 --- a/src/util.ts +++ b/src/util.ts @@ -150,6 +150,13 @@ export function createTranslationProxy(translationData: LangFile): TranslationPr // Function to localize HTML elements using translation data export function localizeElements(translationData: LangFile) { + chrome.storage.onChanged.addListener((changes, areaName) => { + if (areaName === 'sync' && 'preferredLanguage' in changes) { + // Reload the page when the preferredLanguage is changed + location.reload() + } + }) + document.querySelectorAll('[data-locale]').forEach((elem) => { const element = elem as HTMLElement const localeKey = element.getAttribute('data-locale')