keycloak-scim/js/apps/account-ui/src/i18n.ts
Erik Jan de Wit 0e0fee40c4
convert the account ui to properties (#24788)
Signed-off-by: Erik Jan de Wit <erikjan.dewit@gmail.com>
2023-11-16 10:25:14 +01:00

38 lines
1.1 KiB
TypeScript

import { createInstance } from "i18next";
import HttpBackend from "i18next-http-backend";
import { initReactI18next } from "react-i18next";
import { environment } from "./environment";
import { joinPath } from "./utils/joinPath";
const DEFAULT_LOCALE = "en";
type KeyValue = { key: string; value: string };
// This type is aliased to any, so that we can find all the places where we use it.
// In the future all casts to this type should be removed from the code, so
// that we can have a proper type-safe translation function.
export type TFuncKey = any;
export const i18n = createInstance({
fallbackLng: DEFAULT_LOCALE,
interpolation: {
escapeValue: false,
},
backend: {
loadPath: joinPath(
environment.authUrl,
`resources/${environment.realm}/account/{{lng}}`,
),
parse: (data: string) => {
const messages = JSON.parse(data);
const result: Record<string, string> = {};
messages.forEach((v: KeyValue) => (result[v.key] = v.value));
return result;
},
},
});
i18n.use(HttpBackend);
i18n.use(initReactI18next);