2021-11-26 00:31:19 -08:00
|
|
|
import { currentLocale } from "../i18n";
|
|
|
|
import { setPageLocale } from "../util-frontend";
|
|
|
|
const langModules = import.meta.glob("../languages/*.js");
|
|
|
|
|
|
|
|
export default {
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
language: currentLocale(),
|
|
|
|
};
|
|
|
|
},
|
|
|
|
|
2021-11-29 00:45:52 -08:00
|
|
|
async created() {
|
|
|
|
if (this.language !== "en") {
|
|
|
|
await this.changeLang(this.language);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2021-11-26 00:31:19 -08:00
|
|
|
watch: {
|
|
|
|
async language(lang) {
|
|
|
|
await this.changeLang(lang);
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
methods: {
|
2022-06-02 02:38:17 -07:00
|
|
|
/** Change the application language */
|
2021-11-26 00:31:19 -08:00
|
|
|
async changeLang(lang) {
|
|
|
|
let message = (await langModules["../languages/" + lang + ".js"]()).default;
|
|
|
|
this.$i18n.setLocaleMessage(lang, message);
|
|
|
|
this.$i18n.locale = lang;
|
|
|
|
localStorage.locale = lang;
|
|
|
|
setPageLocale();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|