2024-08-12 23:08:57 -05:00
|
|
|
import { Sort } from "@/types/global";
|
2023-05-23 18:07:26 -05:00
|
|
|
import { create } from "zustand";
|
|
|
|
|
|
|
|
type LocalSettings = {
|
2024-08-26 17:47:10 -05:00
|
|
|
theme: string;
|
|
|
|
viewMode: string;
|
|
|
|
show: {
|
|
|
|
link: boolean;
|
2024-08-26 18:56:04 -05:00
|
|
|
name: boolean;
|
2024-08-26 17:47:10 -05:00
|
|
|
description: boolean;
|
|
|
|
image: boolean;
|
|
|
|
tags: boolean;
|
|
|
|
icon: boolean;
|
|
|
|
collection: boolean;
|
|
|
|
date: boolean;
|
|
|
|
};
|
2024-09-09 18:05:30 -05:00
|
|
|
columns: number;
|
2024-08-12 23:08:57 -05:00
|
|
|
sortBy?: Sort;
|
2023-05-23 18:07:26 -05:00
|
|
|
};
|
|
|
|
|
|
|
|
type LocalSettingsStore = {
|
|
|
|
settings: LocalSettings;
|
2024-08-26 17:47:10 -05:00
|
|
|
updateSettings: (settings: Partial<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: "",
|
2024-08-26 17:47:10 -05:00
|
|
|
show: {
|
|
|
|
link: true,
|
2024-08-26 18:56:04 -05:00
|
|
|
name: true,
|
2024-08-26 17:47:10 -05:00
|
|
|
description: true,
|
|
|
|
image: true,
|
|
|
|
tags: true,
|
|
|
|
icon: true,
|
|
|
|
collection: true,
|
|
|
|
date: true,
|
|
|
|
},
|
2024-09-09 18:05:30 -05:00
|
|
|
columns: 0,
|
2024-08-12 23:08:57 -05:00
|
|
|
sortBy: Sort.DateNewestFirst,
|
2023-05-23 18:07:26 -05:00
|
|
|
},
|
2024-08-26 17:47:10 -05:00
|
|
|
updateSettings: (newSettings) => {
|
2024-09-09 18:05:30 -05:00
|
|
|
const { theme, viewMode, sortBy, show, columns } = newSettings;
|
2023-11-24 06:50:16 -06:00
|
|
|
|
2024-08-26 17:47:10 -05:00
|
|
|
if (theme !== undefined && theme !== localStorage.getItem("theme")) {
|
|
|
|
localStorage.setItem("theme", theme);
|
|
|
|
document.querySelector("html")?.setAttribute("data-theme", theme);
|
2023-11-24 06:50:16 -06:00
|
|
|
}
|
|
|
|
|
2023-12-15 22:57:50 -06:00
|
|
|
if (
|
2024-08-26 17:47:10 -05:00
|
|
|
viewMode !== undefined &&
|
|
|
|
viewMode !== localStorage.getItem("viewMode")
|
2023-12-15 22:57:50 -06:00
|
|
|
) {
|
2024-08-26 17:47:10 -05:00
|
|
|
localStorage.setItem("viewMode", viewMode);
|
2023-12-15 22:57:50 -06:00
|
|
|
}
|
|
|
|
|
2024-08-26 17:47:10 -05:00
|
|
|
if (sortBy !== undefined) {
|
|
|
|
localStorage.setItem("sortBy", sortBy.toString());
|
2024-08-12 23:08:57 -05:00
|
|
|
}
|
|
|
|
|
2024-09-09 18:05:30 -05:00
|
|
|
if (columns !== undefined) {
|
|
|
|
localStorage.setItem("columns", columns.toString());
|
|
|
|
}
|
|
|
|
|
2024-08-26 17:47:10 -05:00
|
|
|
const currentShowString = localStorage.getItem("show");
|
|
|
|
const newShowString = show ? JSON.stringify(show) : currentShowString;
|
2023-11-24 06:50:16 -06:00
|
|
|
|
2024-08-26 17:47:10 -05:00
|
|
|
if (newShowString !== currentShowString) {
|
|
|
|
localStorage.setItem("show", newShowString || "");
|
|
|
|
}
|
2023-11-26 04:17:08 -06:00
|
|
|
|
|
|
|
set((state) => ({
|
2024-08-26 17:47:10 -05:00
|
|
|
settings: {
|
|
|
|
...state.settings,
|
|
|
|
...newSettings,
|
|
|
|
show: show ? { ...state.settings.show, ...show } : state.settings.show,
|
|
|
|
},
|
2023-11-26 04:17:08 -06:00
|
|
|
}));
|
2024-08-26 17:47:10 -05:00
|
|
|
},
|
|
|
|
setSettings: () => {
|
2025-01-05 17:41:52 -06:00
|
|
|
const theme = localStorage.getItem("theme") || "light";
|
2024-08-26 17:47:10 -05:00
|
|
|
localStorage.setItem("theme", theme);
|
|
|
|
|
2025-01-10 21:36:16 -06:00
|
|
|
const viewMode = localStorage.getItem("viewMode") || "masonry";
|
2024-08-26 17:47:10 -05:00
|
|
|
localStorage.setItem("viewMode", viewMode);
|
|
|
|
|
2024-09-09 18:05:30 -05:00
|
|
|
const columns = parseInt(localStorage.getItem("columns") || "0");
|
|
|
|
localStorage.setItem("columns", columns.toString());
|
|
|
|
|
2024-08-26 17:47:10 -05:00
|
|
|
const storedShow = localStorage.getItem("show");
|
|
|
|
const show = storedShow
|
|
|
|
? JSON.parse(storedShow)
|
|
|
|
: {
|
|
|
|
link: true,
|
|
|
|
name: true,
|
|
|
|
description: true,
|
|
|
|
image: true,
|
|
|
|
tags: true,
|
|
|
|
icon: true,
|
|
|
|
collection: true,
|
|
|
|
date: true,
|
|
|
|
};
|
|
|
|
localStorage.setItem("show", JSON.stringify(show));
|
|
|
|
|
|
|
|
set({
|
|
|
|
settings: {
|
|
|
|
theme,
|
|
|
|
viewMode,
|
|
|
|
show,
|
2024-09-09 18:05:30 -05:00
|
|
|
columns,
|
2024-08-26 17:47:10 -05:00
|
|
|
sortBy: useLocalSettingsStore.getState().settings.sortBy,
|
|
|
|
},
|
|
|
|
});
|
2023-11-26 04:17:08 -06:00
|
|
|
|
2024-08-26 17:47:10 -05:00
|
|
|
document.querySelector("html")?.setAttribute("data-theme", theme);
|
2023-11-24 06:50:16 -06:00
|
|
|
},
|
2023-05-23 18:07:26 -05:00
|
|
|
}));
|
|
|
|
|
|
|
|
export default useLocalSettingsStore;
|