snort3/src/IntlProvider.tsx
2023-02-09 12:30:29 +00:00

39 lines
1.0 KiB
TypeScript

import { type ReactNode } from "react";
import { IntlProvider as ReactIntlProvider } from "react-intl";
import enMessages from "translations/en.json";
import esMessages from "translations/es.json";
import zhMessages from "translations/zh.json";
import jaMessages from "translations/ja.json";
const DEFAULT_LOCALE = "en-US";
const getMessages = (locale: string) => {
const truncatedLocale = locale.toLowerCase().split(/[_-]+/)[0];
switch (truncatedLocale) {
case "en":
return enMessages;
case "es":
return esMessages;
case "zh":
return zhMessages;
case "ja":
return jaMessages;
default:
return enMessages;
}
};
export const IntlProvider = ({ children }: { children: ReactNode }) => {
const getLocale = () => {
return (navigator.languages && navigator.languages[0]) || navigator.language || DEFAULT_LOCALE;
};
const locale = getLocale();
return (
<ReactIntlProvider locale={locale} messages={getMessages(locale)}>
{children}
</ReactIntlProvider>
);
};