useLocale.ts 1.8 KB
Newer Older
V
vben 已提交
1 2 3
/**
 * Multi-language related operations
 */
4
import type { LocaleType } from '/#/config';
V
vben 已提交
5

6
import moment from 'moment';
V
vben 已提交
7

V
vben 已提交
8
import { i18n } from './setupI18n';
9
import { localeStore } from '/@/store/modules/locale';
V
Vben 已提交
10
import { unref, computed } from 'vue';
V
vben 已提交
11

12 13 14 15 16 17 18
interface LangModule {
  message: Recordable;
  momentLocale: Recordable;
  momentLocaleName: string;
}

const loadLocalePool: LocaleType[] = [];
V
vben 已提交
19

20 21 22 23 24 25 26 27 28
function setI18nLanguage(locale: LocaleType) {
  if (i18n.mode === 'legacy') {
    i18n.global.locale = locale;
  } else {
    (i18n.global.locale as any).value = locale;
  }
  localeStore.setLocaleInfo({ locale });
  document.querySelector('html')?.setAttribute('lang', locale);
}
V
vben 已提交
29 30

export function useLocale() {
31 32 33 34 35 36
  const getLocale = computed(() => localeStore.getLocale);
  const getShowLocalePicker = computed(() => localeStore.getShowPicker);

  const getAntdLocale = computed(() => {
    return i18n.global.getLocaleMessage(unref(getLocale))?.antdLocale;
  });
V
vben 已提交
37 38 39

  // Switching the language will change the locale of useI18n
  // And submit to configuration modification
40 41 42 43
  async function changeLocale(locale: LocaleType) {
    const globalI18n = i18n.global;
    const currentLocale = unref(globalI18n.locale);
    if (currentLocale === locale) return locale;
V
vben 已提交
44

45 46 47 48 49 50
    if (loadLocalePool.includes(locale)) {
      setI18nLanguage(locale);
      return locale;
    }
    const langModule = ((await import(`./lang/${locale}.ts`)) as any).default as LangModule;
    if (!langModule) return;
V
vben 已提交
51

52
    const { message, momentLocale, momentLocaleName } = langModule;
V
vben 已提交
53

54 55 56
    globalI18n.setLocaleMessage(locale, message);
    moment.updateLocale(momentLocaleName, momentLocale);
    loadLocalePool.push(locale);
V
vben 已提交
57

58 59
    setI18nLanguage(locale);
    return locale;
V
vben 已提交
60 61
  }

V
vben 已提交
62 63
  return {
    getLocale,
64
    getShowLocalePicker,
V
vben 已提交
65
    changeLocale,
66
    getAntdLocale,
V
vben 已提交
67 68
  };
}