Jay
7 天以前 47ee647ad4b08891d1cba06449577b3b3aaae5ef
提交 | 用户 | 时间
820397 1 import type { App } from 'vue'
H 2 import { createI18n } from 'vue-i18n'
3 import { useLocaleStoreWithOut } from '@/store/modules/locale'
4 import type { I18n, I18nOptions } from 'vue-i18n'
5 import { setHtmlPageLang } from './helper'
6
7 export let i18n: ReturnType<typeof createI18n>
8
9 const createI18nOptions = async (): Promise<I18nOptions> => {
10   const localeStore = useLocaleStoreWithOut()
11   const locale = localeStore.getCurrentLocale
12   const localeMap = localeStore.getLocaleMap
13   const defaultLocal = await import(`../../locales/${locale.lang}.ts`)
14   const message = defaultLocal.default ?? {}
15
16   setHtmlPageLang(locale.lang)
17
18   localeStore.setCurrentLocale({
19     lang: locale.lang
20     // elLocale: elLocal
21   })
22
23   return {
24     legacy: false,
25     locale: locale.lang,
26     fallbackLocale: locale.lang,
27     messages: {
28       [locale.lang]: message
29     },
30     availableLocales: localeMap.map((v) => v.lang),
31     sync: true,
32     silentTranslationWarn: true,
33     missingWarn: false,
34     silentFallbackWarn: true
35   }
36 }
37
38 export const setupI18n = async (app: App<Element>) => {
39   const options = await createI18nOptions()
40   i18n = createI18n(options) as I18n
41   app.use(i18n)
42 }