2023-05-23 18:07:26 -05:00
|
|
|
import { create } from "zustand";
|
2023-12-15 22:57:50 -06:00
|
|
|
import {ViewMode} from "@/types/global";
|
2023-05-23 18:07:26 -05:00
|
|
|
|
|
|
|
type LocalSettings = {
|
2023-12-15 22:57:50 -06:00
|
|
|
theme?: string;
|
|
|
|
viewMode?: string
|
2023-05-23 18:07:26 -05:00
|
|
|
};
|
|
|
|
|
|
|
|
type LocalSettingsStore = {
|
|
|
|
settings: LocalSettings;
|
|
|
|
updateSettings: (settings: LocalSettings) => void;
|
2023-11-24 06:50:16 -06:00
|
|
|
setSettings: () => void;
|
2023-05-23 18:07:26 -05:00
|
|
|
};
|
|
|
|
|
|
|
|
const useLocalSettingsStore = create<LocalSettingsStore>((set) => ({
|
|
|
|
settings: {
|
2023-11-24 06:50:16 -06:00
|
|
|
theme: "",
|
2023-12-15 22:57:50 -06:00
|
|
|
viewMode: "",
|
2023-05-23 18:07:26 -05:00
|
|
|
},
|
|
|
|
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") || "";
|
|
|
|
}
|
|
|
|
|
2023-05-23 18:07:26 -05:00
|
|
|
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
|
|
|
},
|
2023-05-23 18:07:26 -05:00
|
|
|
}));
|
|
|
|
|
|
|
|
export default useLocalSettingsStore;
|