freekake_webapp/app-setting.ts
2025-06-29 22:23:57 +07:00

88 lines
2.9 KiB
TypeScript

import { $themeConfig } from './theme.config';
import { useAppStore } from '@/stores/index';
export default {
init(setLocale: any) {
const store = useAppStore();
// set default styles
let val: any = localStorage.getItem('theme'); // light, dark, system
val = val || $themeConfig.theme;
store.toggleTheme(val);
val = localStorage.getItem('menu'); // vertical, collapsible-vertical, horizontal
val = val || $themeConfig.menu;
store.toggleMenu(val);
val = localStorage.getItem('layout'); // full, boxed-layout
val = val || $themeConfig.layout;
store.toggleLayout(val);
val = localStorage.getItem('i18n_locale'); // en, da, de, el, es, fr, hu, it, ja, pl, pt, ru, sv, tr, zh
val = val || $themeConfig.locale;
const list = store.languageList;
const item = list.find((item: any) => item.code === val);
if (item) {
this.toggleLanguage(item, setLocale);
}
val = localStorage.getItem('rtlClass'); // rtl, ltr
val = val || $themeConfig.rtlClass;
store.toggleRTL(val);
val = localStorage.getItem('animation'); // animate__fadeIn, animate__fadeInDown, animate__fadeInUp, animate__fadeInLeft, animate__fadeInRight, animate__slideInDown, animate__slideInLeft, animate__slideInRight, animate__zoomIn
val = val || $themeConfig.animation;
store.toggleAnimation(val);
val = localStorage.getItem('navbar'); // navbar-sticky, navbar-floating, navbar-static
val = val || $themeConfig.navbar;
store.toggleNavbar(val);
val = localStorage.getItem('semidark');
val = val === 'true' ? true : $themeConfig.semidark;
store.toggleSemidark(val);
},
toggleLanguage(item: any, setLocale: any) {
const store = useAppStore();
let lang: any = null;
if (item) {
lang = item;
} else {
let code = store.locale || null;
if (!code) {
code = localStorage.getItem('i18n_locale');
}
item = store.languageList.find((d: any) => d.code === code);
if (item) {
lang = item;
}
}
if (!lang) {
lang = store.languageList.find((d: any) => d.code === 'en');
}
store.toggleLocale(lang.code, setLocale);
return lang;
},
changeAnimation(type = 'add') {
const store = useAppStore();
if (store.animation) {
const eleanimation: any = document.querySelector('.animation');
if (type === 'add') {
eleanimation?.classList.add('animate__animated');
eleanimation?.classList.add(store.animation);
} else {
eleanimation?.classList.remove('animate__animated');
eleanimation?.classList.remove(store.animation);
}
}
},
};