el.xwx.moe/store/localSettings.ts

59 lines
1.4 KiB
TypeScript
Raw Normal View History

import { create } from "zustand";
2023-12-15 22:57:50 -06:00
import {ViewMode} from "@/types/global";
type LocalSettings = {
2023-12-15 22:57:50 -06:00
theme?: string;
viewMode?: string
};
type LocalSettingsStore = {
settings: LocalSettings;
updateSettings: (settings: LocalSettings) => void;
2023-11-24 06:50:16 -06:00
setSettings: () => void;
};
const useLocalSettingsStore = create<LocalSettingsStore>((set) => ({
settings: {
2023-11-24 06:50:16 -06:00
theme: "",
2023-12-15 22:57:50 -06:00
viewMode: "",
},
updateSettings: async (newSettings) => {
2023-11-24 06:50:16 -06:00
if (
newSettings.theme &&
newSettings.theme !== localStorage.getItem("theme")
) {
localStorage.setItem("theme", newSettings.theme);
2023-11-26 04:17:08 -06:00
const localTheme = localStorage.getItem("theme") || "";
2023-11-24 06:50:16 -06:00
2023-11-26 04:17:08 -06:00
document.querySelector("html")?.setAttribute("data-theme", localTheme);
2023-11-24 06:50:16 -06:00
}
2023-12-15 22:57:50 -06:00
if (
newSettings.viewMode &&
newSettings.viewMode !== localStorage.getItem("viewMode")
) {
localStorage.setItem("viewMode", newSettings.viewMode);
// const localTheme = localStorage.getItem("viewMode") || "";
}
set((state) => ({ settings: { ...state.settings, ...newSettings } }));
},
2023-11-24 06:50:16 -06:00
setSettings: async () => {
if (!localStorage.getItem("theme")) {
localStorage.setItem("theme", "dark");
}
2023-11-26 04:17:08 -06:00
const localTheme = localStorage.getItem("theme") || "";
set((state) => ({
settings: { ...state.settings, theme: localTheme },
}));
document.querySelector("html")?.setAttribute("data-theme", localTheme);
2023-11-24 06:50:16 -06:00
},
}));
export default useLocalSettingsStore;