2019-12-07 21:02:00 +02:00
|
|
|
|
import supportedLocales from 'app/i18n';
|
2017-12-30 21:44:32 +02:00
|
|
|
|
|
|
|
|
|
const localeToCountryCode = {
|
2019-11-27 11:03:32 +02:00
|
|
|
|
en: 'gb',
|
|
|
|
|
be: 'by',
|
|
|
|
|
pt: 'br',
|
|
|
|
|
uk: 'ua',
|
|
|
|
|
vi: 'vn',
|
|
|
|
|
sl: 'si',
|
|
|
|
|
sr: 'rs',
|
|
|
|
|
zh: 'cn',
|
2017-12-30 21:44:32 +02:00
|
|
|
|
};
|
2019-12-07 13:28:52 +02:00
|
|
|
|
const SUPPORTED_LANGUAGES: string[] = Object.keys(supportedLocales);
|
2017-12-30 21:44:32 +02:00
|
|
|
|
|
|
|
|
|
export default {
|
2019-12-07 13:28:52 +02:00
|
|
|
|
getCountryList(): string[] {
|
2019-11-27 11:03:32 +02:00
|
|
|
|
return SUPPORTED_LANGUAGES.map(
|
|
|
|
|
locale => localeToCountryCode[locale] || locale,
|
|
|
|
|
);
|
|
|
|
|
},
|
2017-12-30 21:44:32 +02:00
|
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
|
/**
|
|
|
|
|
* Возвращает для указанной локали её флаг с учётом всех нюансов загрузки флага
|
|
|
|
|
* и подбора соответствующего локали флага.
|
|
|
|
|
*
|
|
|
|
|
* @param {string} locale
|
|
|
|
|
*
|
|
|
|
|
* @returns {string}
|
|
|
|
|
*/
|
|
|
|
|
getIconUrl(locale: string): string {
|
|
|
|
|
return require(`flag-icon-css/flags/4x3/${localeToCountryCode[locale] ||
|
|
|
|
|
locale}.svg`);
|
|
|
|
|
},
|
2017-12-30 21:44:32 +02:00
|
|
|
|
};
|