123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 |
- import Cookies from 'js-cookie';
- import zhCN from 'element-plus/es/locale/lang/zh-cn';
- import enUS from 'element-plus/es/locale/lang/en';
- export const useAppStore = defineStore('app', () => {
- const sidebarStatus = Cookies.get('sidebarStatus');
- const sidebar = reactive({
- opened: sidebarStatus ? !!+sidebarStatus : true,
- withoutAnimation: false,
- hide: false
- });
- const device = ref<string>('desktop');
- const size = ref(Cookies.get('size') || 'default');
- // 语言
- const language = ref(Cookies.get('language'));
- const languageObj: any = {
- en_US: enUS,
- zh_CN: zhCN
- };
- const locale = computed(() => {
- if (!language.value) {
- return zhCN;
- }
- return languageObj[language.value];
- });
- const toggleSideBar = (withoutAnimation?: boolean) => {
- if (sidebar.hide) {
- return false;
- }
- sidebar.opened = !sidebar.opened;
- sidebar.withoutAnimation = withoutAnimation as boolean;
- if (sidebar.opened) {
- Cookies.set('sidebarStatus', '1');
- } else {
- Cookies.set('sidebarStatus', '0');
- }
- };
- const closeSideBar = ({ withoutAnimation }: any): void => {
- Cookies.set('sidebarStatus', '0');
- sidebar.opened = false;
- sidebar.withoutAnimation = withoutAnimation;
- };
- const toggleDevice = (d: string): void => {
- device.value = d;
- };
- const setSize = (s: string): void => {
- size.value = s;
- Cookies.set('size', s);
- };
- const toggleSideBarHide = (status: boolean): void => {
- sidebar.hide = status;
- };
- const changeLanguage = (val: string): void => {
- language.value = val;
- Cookies.set('language', val);
- };
- return {
- device,
- sidebar,
- language,
- locale,
- size,
- changeLanguage,
- toggleSideBar,
- closeSideBar,
- toggleDevice,
- setSize,
- toggleSideBarHide
- };
- });
- export default useAppStore;
|