vue-vben-admin/src/locales/setupI18n.ts

30 lines
825 B
TypeScript
Raw Normal View History

2021-01-09 23:28:52 +08:00
import type { App } from 'vue';
2020-11-23 00:35:15 +08:00
import type { I18n, I18nOptions } from 'vue-i18n';
import { createI18n } from 'vue-i18n';
2021-01-09 23:28:52 +08:00
2020-11-26 21:10:21 +08:00
import projectSetting from '/@/settings/projectSetting';
2021-01-09 23:28:52 +08:00
import messages from './getMessage';
2020-11-26 21:10:21 +08:00
const { lang, availableLocales, fallback } = projectSetting?.locale;
2021-01-09 23:28:52 +08:00
const localeData: I18nOptions = {
legacy: false,
2020-11-26 21:10:21 +08:00
locale: lang,
fallbackLocale: fallback,
2021-01-09 23:28:52 +08:00
messages,
2020-11-26 21:10:21 +08:00
availableLocales: availableLocales,
sync: true, //If you dont want to inherit locale from global scope, you need to set sync of i18n component option to false.
silentTranslationWarn: true, // true - warning off
missingWarn: false,
silentFallbackWarn: true,
};
2021-01-09 23:28:52 +08:00
export let i18n: I18n;
// setup i18n instance with glob
export function setupI18n(app: App) {
i18n = createI18n(localeData) as I18n;
app.use(i18n);
}