woodpecker/web/src/compositions/useI18n.ts

36 lines
890 B
TypeScript
Raw Normal View History

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<void> => {
if (!i18n.global.availableLocales.includes(lang)) {
await loadLocaleMessages(lang);
}
i18n.global.locale.value = lang;
};
loadLocaleMessages(fallbackLocale);
loadLocaleMessages(userLanguage);