el.xwx.moe/store/localSettings.ts

122 lines
2.9 KiB
TypeScript
Raw Normal View History

import { Sort } from "@/types/global";
import { create } from "zustand";
type LocalSettings = {
2024-08-26 17:47:10 -05:00
theme: string;
viewMode: string;
show: {
link: boolean;
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;
sortBy?: Sort;
};
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;
};
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,
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,
sortBy: Sort.DateNewestFirst,
},
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-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: () => {
const theme = localStorage.getItem("theme") || "dark";
localStorage.setItem("theme", theme);
const viewMode = localStorage.getItem("viewMode") || "card";
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
},
}));
export default useLocalSettingsStore;