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