import { createI18n } from 'vue-i18n' import pinia from '/@/stores/index' import { storeToRefs } from 'pinia' import { useThemeConfig } from '/@/stores/themeConfig' // 定义语言国际化内容 /** * 说明: * 须在 pages 下新建文件夹(建议 `要国际化界面目录` 与 `i18n 目录` 相同,方便查找), * 注意国际化定义的字段,不要与原有的定义字段相同。 * 1、/src/i18n/lang 下的 ts 为框架的国际化内容 * 2、/src/i18n/pages 下的 ts 为各界面的国际化内容 */ // element plus 自带国际化 import enLocale from 'element-plus/lib/locale/lang/en' import zhcnLocale from 'element-plus/lib/locale/lang/zh-cn' import zhtwLocale from 'element-plus/lib/locale/lang/zh-tw' // 定义变量内容 const messages = {} const element = { en: enLocale, 'zh-cn': zhcnLocale, 'zh-tw': zhtwLocale } const itemize = { en: [], 'zh-cn': [], 'zh-tw': [] } const modules: Record = import.meta.glob('./**/*.ts', { eager: true }) // 对自动引入的 modules 进行分类 en、zh-cn、zh-tw // https://vitejs.cn/vite3-cn/guide/features.html#glob-import for (const path in modules) { const key = path.match(/(\S+)\/(\S+).ts/) if (itemize[key![2]]) itemize[key![2]].push(modules[path].default) else itemize[key![2]] = modules[path] } // 合并数组对象(非标准数组对象,数组中对象的每项 key、value 都不同) function mergeArrObj(list: T, key: string) { let obj = {} list[key].forEach((i: EmptyObjectType) => { obj = Object.assign({}, obj, i) }) return obj } // 处理最终格式 for (const key in itemize) { messages[key] = { name: key, el: element[key].el, message: mergeArrObj(itemize, key), } } // 读取 pinia 默认语言 const stores = useThemeConfig(pinia) const { themeConfig } = storeToRefs(stores) // 导出语言国际化 // https://vue-i18n.intlify.dev/guide/essentials/fallback.html#explicit-fallback-with-one-locale export const i18n = createI18n({ legacy: false, silentTranslationWarn: true, missingWarn: false, silentFallbackWarn: true, fallbackWarn: false, locale: themeConfig.value.globalI18n, fallbackLocale: zhcnLocale.name, messages, })