import defaultSettings from "@/settings";
|
|
// 导入 Element Plus 中英文语言包
|
import zhCn from "element-plus/es/locale/lang/zh-cn";
|
import en from "element-plus/es/locale/lang/en";
|
import { store } from "@/store";
|
import { DeviceEnum } from "@/enums/settings/device.enum";
|
import { SidebarStatus } from "@/enums/settings/layout.enum";
|
|
export const useAppStore = defineStore("app", () => {
|
// 设备类型
|
const device = useStorage("device", DeviceEnum.DESKTOP);
|
// 布局大小
|
const size = useStorage("size", defaultSettings.size);
|
// 语言
|
const language = useStorage("language", defaultSettings.language);
|
// 侧边栏状态
|
const sidebarStatus = useStorage("sidebarStatus", SidebarStatus.CLOSED);
|
const sidebar = reactive({
|
opened: sidebarStatus.value === SidebarStatus.OPENED,
|
withoutAnimation: false,
|
});
|
|
// 顶部菜单激活路径
|
const activeTopMenuPath = useStorage("activeTopMenuPath", "");
|
|
/**
|
* 根据语言标识读取对应的语言包
|
*/
|
const locale = computed(() => {
|
if (language?.value == "en") {
|
return en;
|
} else {
|
return zhCn;
|
}
|
});
|
|
// 切换侧边栏
|
function toggleSidebar() {
|
sidebar.opened = !sidebar.opened;
|
sidebarStatus.value = sidebar.opened ? SidebarStatus.OPENED : SidebarStatus.CLOSED;
|
}
|
|
// 关闭侧边栏
|
function closeSideBar() {
|
sidebar.opened = false;
|
sidebarStatus.value = SidebarStatus.CLOSED;
|
}
|
|
// 打开侧边栏
|
function openSideBar() {
|
sidebar.opened = true;
|
sidebarStatus.value = SidebarStatus.OPENED;
|
}
|
|
// 切换设备
|
function toggleDevice(val: string) {
|
device.value = val;
|
}
|
|
/**
|
* 改变布局大小
|
*
|
* @param val 布局大小 default | small | large
|
*/
|
function changeSize(val: string) {
|
size.value = val;
|
}
|
/**
|
* 切换语言
|
*
|
* @param val
|
*/
|
function changeLanguage(val: string) {
|
language.value = val;
|
}
|
/**
|
* 混合模式顶部切换
|
*/
|
function activeTopMenu(val: string) {
|
activeTopMenuPath.value = val;
|
}
|
return {
|
device,
|
sidebar,
|
language,
|
locale,
|
size,
|
activeTopMenu,
|
toggleDevice,
|
changeSize,
|
changeLanguage,
|
toggleSidebar,
|
closeSideBar,
|
openSideBar,
|
activeTopMenuPath,
|
};
|
});
|
|
/**
|
* 用于在组件外部(如在Pinia Store 中)使用 Pinia 提供的 store 实例。
|
* 官方文档解释了如何在组件外部使用 Pinia Store:
|
* https://pinia.vuejs.org/core-concepts/outside-component-usage.html#using-a-store-outside-of-a-component
|
*/
|
export function useAppStoreHook() {
|
return useAppStore(store);
|
}
|