mirror of
https://github.com/sysadminsmedia/homebox.git
synced 2025-12-21 13:23:14 +01:00
* fix: #321 use date-fns for localized datetime formatting * chore: lint fixes for use-formatters * chore: more lint fixes for use-formatters * date and currency localization fixes --------- Co-authored-by: Ádám Kleizer <adkl@boyum-it.com>
81 lines
2.2 KiB
TypeScript
81 lines
2.2 KiB
TypeScript
import type { CompileError, MessageContext } from "vue-i18n";
|
|
import { createI18n } from "vue-i18n";
|
|
import { IntlMessageFormat } from "intl-messageformat";
|
|
|
|
export default defineNuxtPlugin(({ vueApp }) => {
|
|
function checkDefaultLanguage() {
|
|
let matched = null;
|
|
const languages = Object.getOwnPropertyNames(messages());
|
|
const matching = navigator.languages.filter(lang => languages.some(l => l.toLowerCase() === lang.toLowerCase()));
|
|
if (matching.length > 0) {
|
|
matched = matching[0];
|
|
}
|
|
if (!matched) {
|
|
languages.forEach(lang => {
|
|
const languagePartials = navigator.language.split("-")[0];
|
|
if (lang.toLowerCase() === languagePartials) {
|
|
matched = lang;
|
|
}
|
|
});
|
|
}
|
|
return matched;
|
|
}
|
|
const preferences = useViewPreferences();
|
|
const i18n = createI18n({
|
|
fallbackLocale: "en",
|
|
globalInjection: true,
|
|
legacy: false,
|
|
locale: preferences.value.language || checkDefaultLanguage() || "en",
|
|
messageCompiler,
|
|
messages: messages(),
|
|
});
|
|
vueApp.use(i18n);
|
|
|
|
return {
|
|
provide: {
|
|
i18nGlobal: i18n.global,
|
|
},
|
|
};
|
|
});
|
|
|
|
export const messages = () => {
|
|
const messages: Record<string, any> = {};
|
|
const modules = import.meta.glob("~//locales/**.json", { eager: true });
|
|
for (const path in modules) {
|
|
const key = path.slice(9, -5);
|
|
messages[key] = modules[path];
|
|
}
|
|
return messages;
|
|
};
|
|
|
|
export const messageCompiler: (
|
|
message: String | any,
|
|
{
|
|
locale,
|
|
key,
|
|
onError,
|
|
}: {
|
|
locale: any;
|
|
key: any;
|
|
onError: any;
|
|
}
|
|
) => (ctx: MessageContext) => unknown = (message, { locale, key, onError }) => {
|
|
if (typeof message === "string") {
|
|
/**
|
|
* You can tune your message compiler performance more with your cache strategy or also memoization at here
|
|
*/
|
|
const formatter = new IntlMessageFormat(message, locale);
|
|
return (ctx: MessageContext) => {
|
|
return formatter.format(ctx.values);
|
|
};
|
|
} else {
|
|
/**
|
|
* for AST.
|
|
* If you would like to support it,
|
|
* You need to transform locale messages such as `json`, `yaml`, etc. with the bundle plugin.
|
|
*/
|
|
onError && onError(new Error("not support for AST") as CompileError);
|
|
return () => key;
|
|
}
|
|
};
|