wip: support multilingual configuration

This commit is contained in:
vben
2020-11-19 23:01:27 +08:00
parent 3a651767fe
commit 8882d4e7ea
25 changed files with 372 additions and 135 deletions

35
src/setup/i18n/index.ts Normal file
View File

@@ -0,0 +1,35 @@
import type { App } from 'vue';
import type { I18n, Locale, I18nOptions } from 'vue-i18n';
import { createI18n } from 'vue-i18n';
import localeMessages from '/@/locales';
import { useLocale } from '/@/hooks/web/useLocale';
const { getLocale } = useLocale();
const localeData: I18nOptions = {
legacy: false,
locale: getLocale(),
// TODO: setting fallback inside settings
fallbackLocale: 'en',
messages: localeMessages,
// availableLocales: ['ru'],
sync: true, //If you dont want to inherit locale from global scope, you need to set sync of i18n component option to false.
silentTranslationWarn: false, // true - warning off
silentFallbackWarn: true,
};
let i18n: I18n;
// setup i18n instance with glob
export function setupI18n(app: App) {
i18n = createI18n(localeData) as I18n;
setI18nLanguage(getLocale());
app.use(i18n);
}
export function setI18nLanguage(locale: Locale): void {
// @ts-ignore
i18n.global.locale.value = locale;
// i18n.global.setLocaleMessage(locale, messages);
}