@alauda-fe/common
Version:
Alauda frontend team common codes.
89 lines • 12.4 kB
JavaScript
import { FALLBACK_LANGUAGE } from './constants';
import { getUserLanguage, isBuiltInLanguage, loadAvailableLanguages, } from './i18n-config';
export class I18nAssetsLoader {
constructor(options) {
this.options = options;
this.assetsStore = {};
}
async loadI18n(language) {
const allAssets = await Promise.all([
...(this.options.modules || [])
.reverse()
.map(module => replaceTemplate(`/console-i18n/{{ language }}/${module}.json`, {
language,
}))
.map(filePath => this.fetchI18nFile(filePath)),
...(this.options.files || []).reverse().map(file => {
const filePath = isBuiltInLanguage(language)
? replaceTemplate(file.path, { language, name: file.name })
: replaceTemplate(`/console-i18n/{{ language }}/${file.name}.json`, {
language,
});
return this.fetchI18nFile(filePath).then(i18nObj => file.scope ? { [file.scope]: i18nObj } : i18nObj);
}),
]);
this.assetsStore[language] = Object.values(allAssets).reduce((acc, curr) => Object.assign(acc, curr), {});
return this.assetsStore[language];
}
getLoadedLanguages() {
return Object.keys(this.assetsStore);
}
languageIsLoaded(language) {
return this.getLoadedLanguages().includes(language);
}
getLoadedI18n() {
return this.assetsStore;
}
fetchI18nFile(filePath) {
return fetch(filePath)
.then(res => {
if (!res.ok) {
throw new Error(`HTTP ${res.status}: ${res.statusText}`);
}
return res.json();
})
.catch(err => {
console.error(`Failed to load i18n file: ${filePath}`);
console.error(err);
return {};
});
}
}
export function triggerAllI18nLoader(loaders) {
function run(userLanguage) {
return Promise.all(isBuiltInLanguage(userLanguage)
? loaders.map(loader => loader.loadI18n(userLanguage))
: loaders.flatMap(loader => [
loader.loadI18n(userLanguage),
loader.loadI18n(FALLBACK_LANGUAGE),
]));
}
let userLanguage;
try {
userLanguage = getUserLanguage();
}
catch (err) {
console.error(err);
return loadAvailableLanguages().then(() => run(getUserLanguage()));
}
return run(userLanguage);
}
export function setAuiTranslation(i18nService, loader, locale) {
const allTranslations = loader.getLoadedI18n();
const translation = (isBuiltInLanguage(locale)
? allTranslations[locale]
: {
...allTranslations[FALLBACK_LANGUAGE],
...allTranslations[locale],
});
i18nService.setI18n({
locale,
translation,
});
}
function replaceTemplate(str, data) {
return str.replace(/{{\s*(\w+)\s*}}/g, (_, key) => {
return key in data ? data[key] : '';
});
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"i18n-assets-loader.js","sourceRoot":"","sources":["../../../../../libs/common/src/translate/i18n-assets-loader.ts"],"names":[],"mappings":"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","sourcesContent":["import { I18nService } from '@alauda/ui';\n\nimport { FALLBACK_LANGUAGE } from './constants';\nimport {\n  getUserLanguage,\n  isBuiltInLanguage,\n  loadAvailableLanguages,\n} from './i18n-config';\nimport { Translation } from './types';\n\nexport interface I18nAssetsLoadOptions {\n  modules?: string[];\n  files?: Array<{ name: string; path: string; scope?: string }>;\n}\n\nexport class I18nAssetsLoader {\n  private readonly assetsStore: { [language: string]: Translation } = {};\n\n  constructor(private readonly options: I18nAssetsLoadOptions) {}\n\n  async loadI18n(language: string) {\n    const allAssets: Translation[] = await Promise.all([\n      ...(this.options.modules || [])\n        .reverse()\n        .map(module =>\n          replaceTemplate(`/console-i18n/{{ language }}/${module}.json`, {\n            language,\n          }),\n        )\n        .map(filePath => this.fetchI18nFile(filePath)),\n      ...(this.options.files || []).reverse().map(file => {\n        const filePath = isBuiltInLanguage(language)\n          ? replaceTemplate(file.path, { language, name: file.name })\n          : replaceTemplate(`/console-i18n/{{ language }}/${file.name}.json`, {\n              language,\n            });\n        return this.fetchI18nFile(filePath).then(i18nObj =>\n          file.scope ? { [file.scope]: i18nObj } : i18nObj,\n        );\n      }),\n    ]);\n\n    this.assetsStore[language] = Object.values(allAssets).reduce(\n      (acc, curr) => Object.assign(acc, curr),\n      {},\n    );\n\n    return this.assetsStore[language];\n  }\n\n  getLoadedLanguages() {\n    return Object.keys(this.assetsStore);\n  }\n\n  languageIsLoaded(language: string) {\n    return this.getLoadedLanguages().includes(language);\n  }\n\n  getLoadedI18n() {\n    return this.assetsStore;\n  }\n\n  private fetchI18nFile(filePath: string): Promise<Translation> {\n    return fetch(filePath)\n      .then(res => {\n        if (!res.ok) {\n          throw new Error(`HTTP ${res.status}: ${res.statusText}`);\n        }\n        return res.json();\n      })\n      .catch(err => {\n        console.error(`Failed to load i18n file: ${filePath}`);\n        console.error(err);\n        return {};\n      });\n  }\n}\n\nexport function triggerAllI18nLoader(loaders: I18nAssetsLoader[]) {\n  function run(userLanguage: string) {\n    return Promise.all(\n      isBuiltInLanguage(userLanguage)\n        ? loaders.map(loader => loader.loadI18n(userLanguage))\n        : loaders.flatMap(loader => [\n            loader.loadI18n(userLanguage),\n            loader.loadI18n(FALLBACK_LANGUAGE),\n          ]),\n    );\n  }\n\n  let userLanguage: string;\n  try {\n    userLanguage = getUserLanguage();\n  } catch (err) {\n    console.error(err);\n    return loadAvailableLanguages().then(() => run(getUserLanguage()));\n  }\n\n  return run(userLanguage);\n}\n\nexport function setAuiTranslation(\n  i18nService: I18nService,\n  loader: I18nAssetsLoader,\n  locale: string,\n) {\n  const allTranslations = loader.getLoadedI18n();\n  const translation = (\n    isBuiltInLanguage(locale)\n      ? allTranslations[locale]\n      : {\n          ...allTranslations[FALLBACK_LANGUAGE],\n          ...allTranslations[locale],\n        }\n  ) as Record<string, string>;\n\n  i18nService.setI18n({\n    locale,\n    translation,\n  });\n}\n\nfunction replaceTemplate(str: string, data: Record<string, string>) {\n  return str.replace(/{{\\s*(\\w+)\\s*}}/g, (_, key) => {\n    return key in data ? data[key] : '';\n  });\n}\n"]}