UNPKG

@alauda-fe/common

Version:

Alauda frontend team common codes.

76 lines 11.1 kB
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 => res.json()) .catch(err => { console.error(`Failed to load i18n file: ${filePath}`); console.error(err); return {}; }); } } export function triggerAllI18nLoader(loaders) { return loadAvailableLanguages().then(() => { const userLanguage = getUserLanguage(); return Promise.all(isBuiltInLanguage(userLanguage) ? loaders.map(loader => loader.loadI18n(userLanguage)) : loaders.flatMap(loader => [ loader.loadI18n(userLanguage), loader.loadI18n(FALLBACK_LANGUAGE), ])); }); } 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 => res.json())\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  return loadAvailableLanguages().then(() => {\n    const userLanguage = getUserLanguage();\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\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"]}