import { nextTick } from 'vue'; import { createI18n } from 'vue-i18n'; import { getUserLanguage } from '~/utils/locale'; import { loadTimeAgoLocale } from './useTimeAgo'; const userLanguage = getUserLanguage(); const fallbackLocale = 'en'; export const i18n = createI18n({ locale: userLanguage, legacy: false, globalInjection: true, fallbackLocale, }); export const loadLocaleMessages = async (locale: string) => { const { default: messages } = await import(`~/assets/locales/${locale}.json`); i18n.global.setLocaleMessage(locale, messages); loadTimeAgoLocale(locale); return nextTick(); }; export const setI18nLanguage = async (lang: string): Promise => { if (!i18n.global.availableLocales.includes(lang)) { await loadLocaleMessages(lang); } i18n.global.locale.value = lang; }; loadLocaleMessages(fallbackLocale); loadLocaleMessages(userLanguage);