Files
vue3-element-admin/src/store/modules/settings.ts
hxr c797f61691 fix: 🐛 登录页设置的主题进入系统后不一致问题修复
Former-commit-id: 0f6344792e06a2c0b0e669d29d4e4f3797b10d7a
2023-11-05 10:56:08 +08:00

66 lines
1.6 KiB
TypeScript

import { defineStore } from "pinia";
import defaultSettings from "@/settings";
export const useSettingsStore = defineStore("setting", () => {
// state
const tagsView = useStorage<boolean>("tagsView", defaultSettings.tagsView);
const showSettings = ref<boolean>(defaultSettings.showSettings);
const sidebarLogo = ref<boolean>(defaultSettings.sidebarLogo);
const fixedHeader = useStorage<boolean>(
"fixedHeader",
defaultSettings.fixedHeader
);
const layout = useStorage<string>("layout", defaultSettings.layout);
const themeColor = useStorage<string>(
"themeColor",
defaultSettings.themeColor
);
const theme = useStorage<string>("theme", defaultSettings.theme);
// actions
function changeSetting(param: { key: string; value: any }) {
const { key, value } = param;
switch (key) {
case "showSettings":
showSettings.value = value;
break;
case "fixedHeader":
fixedHeader.value = value;
break;
case "tagsView":
tagsView.value = value;
break;
case "sidevarLogo":
sidebarLogo.value = value;
break;
case "layout":
layout.value = value;
break;
case "themeColor":
themeColor.value = value;
break;
case "theme":
theme.value = value;
if (theme.value !== "dark") {
document.documentElement.classList.remove("dark");
}
break;
}
}
return {
showSettings,
tagsView,
fixedHeader,
sidebarLogo,
layout,
themeColor,
changeSetting,
theme,
};
});