web: prioritise ?locale parameter over saved locale

Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org>
This commit is contained in:
Jens Langhammer
2022-02-26 16:17:04 +01:00
parent 2f8dbe9b97
commit 2c54be85be
2 changed files with 12 additions and 4 deletions

View File

@ -1,7 +1,7 @@
import { de, en, es, fr, pl, tr, zh } from "make-plural/plurals";
import { Messages, i18n } from "@lingui/core";
import { detect, fromNavigator, fromStorage, fromUrl } from "@lingui/detect-locale";
import { detect, fromNavigator, fromUrl } from "@lingui/detect-locale";
import { t } from "@lingui/macro";
import { messages as localeDE } from "../locales/de";
@ -93,7 +93,7 @@ const DEFAULT_FALLBACK = () => "en";
export function autoDetectLanguage() {
let detected =
detect(fromUrl("lang"), fromStorage("lang"), fromNavigator(), DEFAULT_FALLBACK) ||
detect(fromUrl("locale"), fromNavigator(), DEFAULT_FALLBACK) ||
DEFAULT_FALLBACK();
// For now we only care about the first locale part
if (detected.includes("_")) {
@ -107,4 +107,12 @@ export function autoDetectLanguage() {
i18n.activate(DEFAULT_FALLBACK());
}
}
export function activateLocale(code: string) {
const urlLocale = fromUrl("locale");
if (urlLocale !== null && urlLocale !== "") {
i18n.activate(urlLocale);
return;
}
i18n.activate(code);
}
autoDetectLanguage();