88 lines
2.1 KiB
TypeScript
Raw Normal View History

2019-12-07 13:28:52 +02:00
import { IntlShape, createIntl, createIntlCache } from 'react-intl';
import captcha from 'app/services/captcha';
import locales from 'app/i18n';
2019-11-11 10:40:05 +02:00
import intlPolyfill from './intlPolyfill';
2020-01-20 09:51:37 +02:00
export const SUPPORTED_LANGUAGES = Object.keys(locales);
export const DEFAULT_LANGUAGE = 'en';
2019-11-11 10:40:05 +02:00
function getBrowserPreferredLanguages(): string[] {
2020-05-24 02:08:24 +03:00
return ([] as string[]).concat(navigator['languages'] || []).concat(navigator['language'] || []);
2019-11-11 10:40:05 +02:00
}
2020-05-24 02:08:24 +03:00
function detectLanguage(userLanguages: string[], availableLanguages: string[], defaultLanguage: string): string {
return (
userLanguages
.map((lang) => (lang.split('-').shift() || '').toLowerCase())
.find((lang) => availableLanguages.indexOf(lang) !== -1) || defaultLanguage
);
2019-11-11 10:40:05 +02:00
}
const cache = createIntlCache();
let intl: IntlShape;
class I18N {
2020-05-24 02:08:24 +03:00
detectLanguage(lang: string = ''): string {
return detectLanguage(
[lang].concat(getBrowserPreferredLanguages()).filter((item) => !!item),
SUPPORTED_LANGUAGES,
DEFAULT_LANGUAGE,
);
2019-11-11 10:40:05 +02:00
}
2020-05-24 02:08:24 +03:00
getIntl(): IntlShape {
if (!intl) {
intl = createIntl(
{
locale: 'en',
messages: {},
},
cache,
);
}
return intl;
}
2020-05-24 02:08:24 +03:00
async changeLocale(locale: string = DEFAULT_LANGUAGE): Promise<IntlShape> {
const { messages } = await this.require(locale);
2020-05-24 02:08:24 +03:00
captcha.setLang(locale);
2020-05-24 02:08:24 +03:00
intl = createIntl(
{
locale,
messages,
},
cache,
);
2020-05-24 02:08:24 +03:00
return intl;
}
async ensureIntl() {
await intlPolyfill('en');
}
async require(
locale: string,
): Promise<{
locale: string;
messages: { [key: string]: string };
}> {
const [{ default: messages }] = await Promise.all([
import(/* webpackChunkName: "locale-[request]" */ `app/i18n/${locale}.json`),
intlPolyfill(locale),
]);
return {
locale,
messages,
};
}
2019-11-11 10:40:05 +02:00
}
export default new I18N();