saleor-dashboard/src/components/Locale/Locale.tsx

240 lines
6.2 KiB
TypeScript
Raw Normal View History

2019-08-09 10:26:22 +00:00
import React from "react";
2019-08-13 11:26:34 +00:00
import { IntlProvider } from "react-intl";
2019-06-19 14:40:52 +00:00
2019-08-29 13:59:29 +00:00
import locale_AR from "@locale/ar.json";
import locale_AZ from "@locale/az.json";
import locale_BG from "@locale/bg.json";
import locale_BN from "@locale/bn.json";
import locale_CA from "@locale/ca.json";
import locale_CS from "@locale/cs.json";
import locale_DA from "@locale/da.json";
import locale_DE from "@locale/de.json";
import locale_EL from "@locale/el.json";
import locale_ES from "@locale/es.json";
import locale_ES_CO from "@locale/es_CO.json";
import locale_ET from "@locale/et.json";
import locale_FA from "@locale/fa.json";
import locale_FR from "@locale/fr.json";
import locale_HI from "@locale/hi.json";
import locale_HU from "@locale/hu.json";
import locale_HY from "@locale/hy.json";
import locale_ID from "@locale/id.json";
import locale_IS from "@locale/is.json";
import locale_IT from "@locale/it.json";
import locale_JA from "@locale/ja.json";
import locale_KO from "@locale/ko.json";
import locale_MN from "@locale/mn.json";
import locale_NB from "@locale/nb.json";
import locale_NL from "@locale/nl.json";
import locale_PL from "@locale/pl.json";
import locale_PT from "@locale/pt.json";
import locale_PT_BR from "@locale/pt_BR.json";
import locale_RO from "@locale/ro.json";
import locale_RU from "@locale/ru.json";
import locale_SK from "@locale/sk.json";
import locale_SL from "@locale/sl.json";
import locale_SQ from "@locale/sq.json";
import locale_SR from "@locale/sr.json";
import locale_SV from "@locale/sv.json";
import locale_TH from "@locale/th.json";
import locale_TR from "@locale/tr.json";
import locale_UK from "@locale/uk.json";
import locale_VI from "@locale/vi.json";
import locale_ZH_HANS from "@locale/zh-Hans.json";
import locale_ZH_HANT from "@locale/zh-Hant.json";
2019-09-10 16:02:31 +00:00
export enum Locale {
2019-08-29 13:59:29 +00:00
AR = "ar",
AZ = "az",
BG = "bg",
BN = "bn",
CA = "ca",
CS = "cs",
DA = "da",
DE = "de",
EL = "el",
2019-09-10 16:02:31 +00:00
EN = "en",
2019-08-29 13:59:29 +00:00
ES = "es",
ES_CO = "es-co",
ET = "et",
FA = "fa",
FR = "fr",
HI = "hi",
HU = "hu",
HY = "hy",
ID = "id",
IS = "is",
IT = "it",
JA = "ja",
KO = "ko",
MN = "mn",
NB = "nb",
NL = "nl",
PL = "pl",
PT = "pt",
PT_BR = "pt-br",
RO = "ro",
RU = "ru",
SK = "sk",
SL = "sl",
SQ = "sq",
SR = "sr",
SV = "sv",
TH = "th",
TR = "tr",
UK = "uk",
VI = "vi",
ZH_HANS = "zh-hans",
ZH_HANT = "zh-hant"
2019-08-27 12:05:53 +00:00
}
type LocaleMessages = Record<string, string>;
const localeData: Record<Locale, LocaleMessages> = {
2019-08-29 13:59:29 +00:00
[Locale.AR]: locale_AR,
[Locale.AZ]: locale_AZ,
[Locale.BG]: locale_BG,
[Locale.BN]: locale_BN,
[Locale.CA]: locale_CA,
[Locale.CS]: locale_CS,
[Locale.DA]: locale_DA,
[Locale.DE]: locale_DE,
[Locale.EL]: locale_EL,
2019-09-10 16:02:31 +00:00
// Default language
[Locale.EN]: undefined,
2019-08-29 13:59:29 +00:00
[Locale.ES]: locale_ES,
[Locale.ES_CO]: locale_ES_CO,
[Locale.ET]: locale_ET,
[Locale.FA]: locale_FA,
[Locale.FR]: locale_FR,
[Locale.HI]: locale_HI,
[Locale.HU]: locale_HU,
[Locale.HY]: locale_HY,
[Locale.ID]: locale_ID,
[Locale.IS]: locale_IS,
[Locale.IT]: locale_IT,
[Locale.JA]: locale_JA,
[Locale.KO]: locale_KO,
[Locale.MN]: locale_MN,
[Locale.NB]: locale_NB,
[Locale.NL]: locale_NL,
[Locale.PL]: locale_PL,
[Locale.PT]: locale_PT,
[Locale.PT_BR]: locale_PT_BR,
[Locale.RO]: locale_RO,
[Locale.RU]: locale_RU,
[Locale.SK]: locale_SK,
[Locale.SL]: locale_SL,
[Locale.SQ]: locale_SQ,
[Locale.SR]: locale_SR,
[Locale.SV]: locale_SV,
[Locale.TH]: locale_TH,
[Locale.TR]: locale_TR,
[Locale.UK]: locale_UK,
[Locale.VI]: locale_VI,
[Locale.ZH_HANS]: locale_ZH_HANS,
[Locale.ZH_HANT]: locale_ZH_HANT
2019-08-27 12:05:53 +00:00
};
2019-10-16 15:18:29 +00:00
export const localeNames: Record<Locale, string> = {
[Locale.AR]: "العربيّة",
[Locale.AZ]: "Azərbaycanca",
[Locale.BG]: "български",
[Locale.BN]: "বাংলা",
[Locale.CA]: "català",
[Locale.CS]: "česky",
[Locale.DA]: "dansk",
[Locale.DE]: "Deutsch",
[Locale.EL]: "Ελληνικά",
[Locale.EN]: "English",
[Locale.ES]: "español",
[Locale.ES_CO]: "español de Colombia",
[Locale.ET]: "eesti",
[Locale.FA]: "فارسی",
[Locale.FR]: "français",
[Locale.HI]: "Hindi",
[Locale.HU]: "Magyar",
[Locale.HY]: "հայերեն",
[Locale.ID]: "Bahasa Indonesia",
[Locale.IS]: "Íslenska",
[Locale.IT]: "italiano",
[Locale.JA]: "日本語",
[Locale.KO]: "한국어",
[Locale.MN]: "Mongolian",
[Locale.NB]: "norsk (bokmål)",
[Locale.NL]: "Nederlands",
[Locale.PL]: "polski",
[Locale.PT]: "Português",
[Locale.PT_BR]: "Português Brasileiro",
[Locale.RO]: "Română",
[Locale.RU]: "Русский",
[Locale.SK]: "Slovensky",
[Locale.SL]: "Slovenščina",
[Locale.SQ]: "shqip",
[Locale.SR]: "српски",
[Locale.SV]: "svenska",
[Locale.TH]: "ภาษาไทย",
[Locale.TR]: "Türkçe",
[Locale.UK]: "Українська",
[Locale.VI]: "Tiếng Việt",
[Locale.ZH_HANS]: "简体中文",
[Locale.ZH_HANT]: "繁體中文"
};
2019-09-10 16:02:31 +00:00
export function getMatchingLocale(languages: readonly string[]): Locale {
2019-08-27 12:05:53 +00:00
const localeEntries = Object.entries(Locale);
2019-09-10 16:02:31 +00:00
for (const preferredLocale of languages) {
2019-08-27 12:05:53 +00:00
for (const localeEntry of localeEntries) {
if (localeEntry[1].toLowerCase() === preferredLocale.toLowerCase()) {
return Locale[localeEntry[0]];
2019-08-14 16:21:41 +00:00
}
}
2019-08-27 12:05:53 +00:00
}
2019-09-04 14:01:26 +00:00
return undefined;
2019-08-27 12:05:53 +00:00
}
2019-10-16 15:18:29 +00:00
const defaultLocale = Locale.EN;
export interface LocaleContextType {
locale: Locale;
setLocale: (locale: Locale) => void;
}
export const LocaleContext = React.createContext<LocaleContextType>({
locale: defaultLocale,
setLocale: () => undefined
});
const { Consumer: LocaleConsumer, Provider: RawLocaleProvider } = LocaleContext;
2019-08-27 12:05:53 +00:00
const LocaleProvider: React.FC = ({ children }) => {
2019-10-16 15:18:29 +00:00
const [locale, setLocale] = React.useState(
2019-09-10 16:02:31 +00:00
getMatchingLocale(navigator.languages) || defaultLocale
);
2019-08-13 11:26:34 +00:00
return (
2019-08-29 13:59:29 +00:00
<IntlProvider
defaultLocale={defaultLocale}
locale={locale}
messages={localeData[locale]}
onError={err => {
if (!err.includes("[React Intl] Missing message: ")) {
console.error(err);
}
}}
key={locale}
>
2019-10-16 15:18:29 +00:00
<RawLocaleProvider
value={{
locale,
setLocale
}}
>
{children}
</RawLocaleProvider>
2019-08-13 11:26:34 +00:00
</IntlProvider>
);
2019-06-19 14:40:52 +00:00
};
2019-08-16 13:55:04 +00:00
export { LocaleConsumer, LocaleProvider, RawLocaleProvider };