1
0
mirror of https://github.com/bitwarden/browser synced 2025-12-21 18:53:29 +00:00

delay i18n loads

This commit is contained in:
Kyle Spearrin
2018-01-12 21:51:07 -05:00
parent 76752f81c6
commit c0262306f8
2 changed files with 29 additions and 27 deletions

View File

@@ -1,28 +1,16 @@
import { PlatformUtilsService } from 'jslib/abstractions';
// First locale is the default (English)
const SupportedLocales = [
'en', 'cs', 'da', 'de', 'es', 'et', 'fi', 'fr', 'hr', 'hu', 'id', 'it', 'ja',
'nb', 'nl', 'pl', 'pt-BR', 'pt-PT', 'ro', 'ru', 'sk', 'sv', 'tr', 'uk', 'vi',
'zh-CN', 'zh-TW',
];
export default function i18nService(platformUtilsService: PlatformUtilsService) {
const defaultMessages: any = {};
const localeMessages: any = {};
// First locale is the default (English)
const supportedLocales = [
'en', 'cs', 'da', 'de', 'es', 'et', 'fi', 'fr', 'hr', 'hu', 'id', 'it', 'ja',
'nb', 'nl', 'pl', 'pt-BR', 'pt-PT', 'ro', 'ru', 'sk', 'sv', 'tr', 'uk', 'vi',
'zh-CN', 'zh-TW',
];
async function loadMessages(localesDir: string, locale: string, messagesObj: any,
messageCallback: (prop: string, message: string) => string): Promise<any> {
const formattedLocale = locale.replace('-', '_');
const file = await fetch(localesDir + formattedLocale + '/messages.json');
const locales = await file.json();
for (const prop in locales) {
if (locales.hasOwnProperty(prop)) {
messagesObj[prop] = messageCallback(prop, locales[prop].message);
}
}
}
if (platformUtilsService.isEdge()) {
loadMessages('../_locales/', 'en', localeMessages,
(prop: string, message: string) => chrome.i18n.getMessage(prop));
@@ -31,18 +19,19 @@ export default function i18nService(platformUtilsService: PlatformUtilsService)
if (platformUtilsService.isSafari()) {
let lang = navigator.language;
if (supportedLocales.indexOf(lang) === -1) {
if (SupportedLocales.indexOf(lang) === -1) {
lang = lang.slice(0, 2);
if (supportedLocales.indexOf(lang) === -1) {
lang = supportedLocales[0];
if (SupportedLocales.indexOf(lang) === -1) {
lang = SupportedLocales[0];
}
}
const dir = './_locales/';
loadMessages(dir, lang, localeMessages, (prop: string, message: string) => message);
if (lang !== supportedLocales[0]) {
loadMessages(dir, supportedLocales[0], defaultMessages, (prop: string, message: string) => message);
if (lang !== SupportedLocales[0]) {
loadMessages(dir, SupportedLocales[0], defaultMessages,
(prop: string, message: string) => message);
}
}
@@ -66,3 +55,15 @@ export default function i18nService(platformUtilsService: PlatformUtilsService)
},
});
}
async function loadMessages(localesDir: string, locale: string, messagesObj: any,
messageCallback: (prop: string, message: string) => string): Promise<any> {
const formattedLocale = locale.replace('-', '_');
const file = await fetch(localesDir + formattedLocale + '/messages.json');
const locales = await file.json();
for (const prop in locales) {
if (locales.hasOwnProperty(prop)) {
messagesObj[prop] = messageCallback(prop, locales[prop].message);
}
}
}