web: add locale detection

Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org>
This commit is contained in:
Jens Langhammer 2021-10-01 14:06:32 +02:00
parent 3493d35af9
commit 1252c6b07d
6 changed files with 38 additions and 12 deletions

14
web/package-lock.json generated
View file

@ -18,6 +18,7 @@
"@goauthentik/api": "^2021.9.4-1633083586", "@goauthentik/api": "^2021.9.4-1633083586",
"@lingui/cli": "^3.12.1", "@lingui/cli": "^3.12.1",
"@lingui/core": "^3.12.1", "@lingui/core": "^3.12.1",
"@lingui/detect-locale": "^3.12.1",
"@lingui/macro": "^3.12.1", "@lingui/macro": "^3.12.1",
"@patternfly/patternfly": "^4.135.2", "@patternfly/patternfly": "^4.135.2",
"@polymer/iron-form": "^3.0.1", "@polymer/iron-form": "^3.0.1",
@ -2012,6 +2013,14 @@
"node": ">=10.0.0" "node": ">=10.0.0"
} }
}, },
"node_modules/@lingui/detect-locale": {
"version": "3.12.1",
"resolved": "https://registry.npmjs.org/@lingui/detect-locale/-/detect-locale-3.12.1.tgz",
"integrity": "sha512-/apP+LscyRuh+CIf42+LNuYmEsceNA/rh6N3iqebNcEsOcIzLA8v6dq1llzDOlfd3SxEj7xP9Kfhn6Vnp+78+Q==",
"engines": {
"node": ">=10.0.0"
}
},
"node_modules/@lingui/macro": { "node_modules/@lingui/macro": {
"version": "3.12.1", "version": "3.12.1",
"resolved": "https://registry.npmjs.org/@lingui/macro/-/macro-3.12.1.tgz", "resolved": "https://registry.npmjs.org/@lingui/macro/-/macro-3.12.1.tgz",
@ -10007,6 +10016,11 @@
"messageformat-parser": "^4.1.3" "messageformat-parser": "^4.1.3"
} }
}, },
"@lingui/detect-locale": {
"version": "3.12.1",
"resolved": "https://registry.npmjs.org/@lingui/detect-locale/-/detect-locale-3.12.1.tgz",
"integrity": "sha512-/apP+LscyRuh+CIf42+LNuYmEsceNA/rh6N3iqebNcEsOcIzLA8v6dq1llzDOlfd3SxEj7xP9Kfhn6Vnp+78+Q=="
},
"@lingui/macro": { "@lingui/macro": {
"version": "3.12.1", "version": "3.12.1",
"resolved": "https://registry.npmjs.org/@lingui/macro/-/macro-3.12.1.tgz", "resolved": "https://registry.npmjs.org/@lingui/macro/-/macro-3.12.1.tgz",

View file

@ -17,7 +17,8 @@
"sourceLocale": "en", "sourceLocale": "en",
"locales": [ "locales": [
"en", "en",
"pseudo-LOCALE" "pseudo-LOCALE",
"fr_FR"
], ],
"formatOptions": { "formatOptions": {
"lineNumbers": false "lineNumbers": false
@ -50,6 +51,7 @@
"@goauthentik/api": "^2021.9.4-1633083586", "@goauthentik/api": "^2021.9.4-1633083586",
"@lingui/cli": "^3.12.1", "@lingui/cli": "^3.12.1",
"@lingui/core": "^3.12.1", "@lingui/core": "^3.12.1",
"@lingui/detect-locale": "^3.12.1",
"@lingui/macro": "^3.12.1", "@lingui/macro": "^3.12.1",
"@patternfly/patternfly": "^4.135.2", "@patternfly/patternfly": "^4.135.2",
"@polymer/iron-form": "^3.0.1", "@polymer/iron-form": "^3.0.1",

View file

@ -1,5 +1,7 @@
import { ChartData } from "chart.js"; import { ChartData } from "chart.js";
import { t } from "@lingui/macro";
import { customElement } from "lit/decorators"; import { customElement } from "lit/decorators";
import { AdminApi, LoginMetrics } from "@goauthentik/api"; import { AdminApi, LoginMetrics } from "@goauthentik/api";
@ -17,7 +19,7 @@ export class AdminLoginsChart extends AKChart<LoginMetrics> {
return { return {
datasets: [ datasets: [
{ {
label: "Failed Logins", label: t`Failed Logins`,
backgroundColor: "rgba(201, 25, 11, .5)", backgroundColor: "rgba(201, 25, 11, .5)",
spanGaps: true, spanGaps: true,
data: data:
@ -29,7 +31,7 @@ export class AdminLoginsChart extends AKChart<LoginMetrics> {
}) || [], }) || [],
}, },
{ {
label: "Successful Logins", label: t`Successful Logins`,
backgroundColor: "rgba(189, 229, 184, .5)", backgroundColor: "rgba(189, 229, 184, .5)",
spanGaps: true, spanGaps: true,
data: data:

View file

@ -1,5 +1,7 @@
import { ChartData } from "chart.js"; import { ChartData } from "chart.js";
import { t } from "@lingui/macro";
import { customElement, property } from "lit/decorators"; import { customElement, property } from "lit/decorators";
import { Coordinate, CoreApi } from "@goauthentik/api"; import { Coordinate, CoreApi } from "@goauthentik/api";
@ -22,7 +24,7 @@ export class ApplicationAuthorizeChart extends AKChart<Coordinate[]> {
return { return {
datasets: [ datasets: [
{ {
label: "Authorizations", label: t`Authorizations`,
backgroundColor: "rgba(189, 229, 184, .5)", backgroundColor: "rgba(189, 229, 184, .5)",
spanGaps: true, spanGaps: true,
data: data:

View file

@ -1,5 +1,7 @@
import { ChartData } from "chart.js"; import { ChartData } from "chart.js";
import { t } from "@lingui/macro";
import { customElement, property } from "lit/decorators"; import { customElement, property } from "lit/decorators";
import { CoreApi, UserMetrics } from "@goauthentik/api"; import { CoreApi, UserMetrics } from "@goauthentik/api";
@ -22,7 +24,7 @@ export class UserChart extends AKChart<UserMetrics> {
return { return {
datasets: [ datasets: [
{ {
label: "Failed Logins", label: t`Failed Logins`,
backgroundColor: "rgba(201, 25, 11, .5)", backgroundColor: "rgba(201, 25, 11, .5)",
spanGaps: true, spanGaps: true,
data: data:
@ -34,7 +36,7 @@ export class UserChart extends AKChart<UserMetrics> {
}) || [], }) || [],
}, },
{ {
label: "Successful Logins", label: t`Successful Logins`,
backgroundColor: "rgba(189, 229, 184, .5)", backgroundColor: "rgba(189, 229, 184, .5)",
spanGaps: true, spanGaps: true,
data: data:
@ -46,7 +48,7 @@ export class UserChart extends AKChart<UserMetrics> {
}) || [], }) || [],
}, },
{ {
label: "Application authorizations", label: t`Application authorizations`,
backgroundColor: "rgba(43, 154, 243, .5)", backgroundColor: "rgba(43, 154, 243, .5)",
spanGaps: true, spanGaps: true,
data: data:

View file

@ -1,16 +1,20 @@
import { en } from "make-plural/plurals"; import { en, fr } from "make-plural/plurals";
import { i18n } from "@lingui/core"; import { i18n } from "@lingui/core";
import { detect, fromUrl, fromStorage, fromNavigator } from "@lingui/detect-locale";
import { messages as localeEN } from "../locales/en"; import { messages as localeEN } from "../locales/en";
import { messages as localeFR_FR } from "../locales/fr_FR";
import { messages as localeDEBUG } from "../locales/pseudo-LOCALE"; import { messages as localeDEBUG } from "../locales/pseudo-LOCALE";
i18n.loadLocaleData("en", { plurals: en }); i18n.loadLocaleData("en", { plurals: en });
i18n.loadLocaleData("debug", { plurals: en }); i18n.loadLocaleData("debug", { plurals: en });
i18n.loadLocaleData("fr_FR", { plurals: fr });
i18n.load("en", localeEN); i18n.load("en", localeEN);
i18n.load("fr_FR", localeFR_FR);
i18n.load("debug", localeDEBUG); i18n.load("debug", localeDEBUG);
i18n.activate("en");
if (window.location.search.includes("debugLocale")) { const DEFAULT_FALLBACK = () => "en";
i18n.activate("debug");
} const result = detect(fromUrl("lang"), fromStorage("lang"), fromNavigator(), DEFAULT_FALLBACK);
i18n.activate(result || DEFAULT_FALLBACK());