add number of columns slider

This commit is contained in:
daniel31x13 2024-09-09 19:05:30 -04:00
parent 9ae6a22236
commit 4602269dd8
3 changed files with 44 additions and 24 deletions

View File

@ -13,11 +13,9 @@ export default function ViewDropdown({ viewMode, setViewMode }: Props) {
const { settings, updateSettings } = useLocalSettingsStore((state) => state); const { settings, updateSettings } = useLocalSettingsStore((state) => state);
const { t } = useTranslation(); const { t } = useTranslation();
const onChangeViewMode = ( const onChangeViewMode = (mode: ViewMode) => {
e: React.MouseEvent<HTMLButtonElement>,
mode: ViewMode
) => {
setViewMode(mode); setViewMode(mode);
updateSettings({ viewMode });
}; };
const toggleShowSetting = (setting: keyof typeof settings.show) => { const toggleShowSetting = (setting: keyof typeof settings.show) => {
@ -28,9 +26,9 @@ export default function ViewDropdown({ viewMode, setViewMode }: Props) {
updateSettings({ show: newShowSettings }); updateSettings({ show: newShowSettings });
}; };
useEffect(() => { const onColumnsChange = (e: React.ChangeEvent<HTMLInputElement>) => {
updateSettings({ viewMode }); updateSettings({ columns: Number(e.target.value) });
}, [viewMode, updateSettings]); };
return ( return (
<div className="dropdown dropdown-bottom dropdown-end"> <div className="dropdown dropdown-bottom dropdown-end">
@ -48,15 +46,14 @@ export default function ViewDropdown({ viewMode, setViewMode }: Props) {
<i className="bi-view-stacked w-4 h-4 text-neutral"></i> <i className="bi-view-stacked w-4 h-4 text-neutral"></i>
)} )}
</div> </div>
<ul className="dropdown-content z-[30] menu shadow bg-base-200 min-w-52 border border-neutral-content rounded-xl mt-1"> <ul
<p className="mb-1 text-sm text-neutral">{t("view")}</p>
<div
className="p-1 flex w-full justify-between gap-1 border border-neutral-content rounded-[0.625rem]"
tabIndex={0} tabIndex={0}
role="button" className="dropdown-content z-[30] menu shadow bg-base-200 min-w-52 border border-neutral-content rounded-xl mt-1"
> >
<p className="mb-1 text-sm text-neutral">{t("view")}</p>
<div className="p-1 flex w-full justify-between gap-1 border border-neutral-content rounded-[0.625rem]">
<button <button
onClick={(e) => onChangeViewMode(e, ViewMode.Card)} onClick={(e) => onChangeViewMode(ViewMode.Card)}
className={`btn w-[31%] btn-sm btn-ghost ${ className={`btn w-[31%] btn-sm btn-ghost ${
viewMode === ViewMode.Card viewMode === ViewMode.Card
? "bg-primary/20 hover:bg-primary/20" ? "bg-primary/20 hover:bg-primary/20"
@ -66,7 +63,7 @@ export default function ViewDropdown({ viewMode, setViewMode }: Props) {
<i className="bi-grid text-lg text-neutral"></i> <i className="bi-grid text-lg text-neutral"></i>
</button> </button>
<button <button
onClick={(e) => onChangeViewMode(e, ViewMode.Masonry)} onClick={(e) => onChangeViewMode(ViewMode.Masonry)}
className={`btn w-[31%] btn-sm btn-ghost ${ className={`btn w-[31%] btn-sm btn-ghost ${
viewMode === ViewMode.Masonry viewMode === ViewMode.Masonry
? "bg-primary/20 hover:bg-primary/20" ? "bg-primary/20 hover:bg-primary/20"
@ -76,7 +73,7 @@ export default function ViewDropdown({ viewMode, setViewMode }: Props) {
<i className="bi-columns-gap text-lg text-neutral"></i> <i className="bi-columns-gap text-lg text-neutral"></i>
</button> </button>
<button <button
onClick={(e) => onChangeViewMode(e, ViewMode.List)} onClick={(e) => onChangeViewMode(ViewMode.List)}
className={`btn w-[31%] btn-sm btn-ghost ${ className={`btn w-[31%] btn-sm btn-ghost ${
viewMode === ViewMode.List viewMode === ViewMode.List
? "bg-primary/20 hover:bg-primary/20" ? "bg-primary/20 hover:bg-primary/20"
@ -86,7 +83,7 @@ export default function ViewDropdown({ viewMode, setViewMode }: Props) {
<i className="bi-view-stacked text-lg text-neutral"></i> <i className="bi-view-stacked text-lg text-neutral"></i>
</button> </button>
</div> </div>
<p className="my-1 text-sm text-neutral">{t("show")}</p> <p className="mb-1 mt-2 text-sm text-neutral">{t("show")}</p>
{Object.entries(settings.show) {Object.entries(settings.show)
.filter((e) => .filter((e) =>
settings.viewMode === ViewMode.List // Hide tags, image, icon, and description checkboxes in list view settings.viewMode === ViewMode.List // Hide tags, image, icon, and description checkboxes in list view
@ -100,11 +97,7 @@ export default function ViewDropdown({ viewMode, setViewMode }: Props) {
) )
.map(([key, value]) => ( .map(([key, value]) => (
<li key={key}> <li key={key}>
<label <label className="label cursor-pointer flex justify-start">
className="label cursor-pointer flex justify-start"
tabIndex={0}
role="button"
>
<input <input
type="checkbox" type="checkbox"
className="checkbox checkbox-primary" className="checkbox checkbox-primary"
@ -117,6 +110,21 @@ export default function ViewDropdown({ viewMode, setViewMode }: Props) {
</label> </label>
</li> </li>
))} ))}
<p className="mb-1 mt-2 text-sm text-neutral">
{t("columns")}:{" "}
{settings.columns === 0 ? t("default") : settings.columns}
</p>
<div>
<input
type="range"
min={0}
max="8"
value={settings.columns}
onChange={(e) => onColumnsChange(e)}
className="range range-xs"
step="1"
/>
</div>
</ul> </ul>
</div> </div>
); );

View File

@ -391,5 +391,7 @@
"no_tags": "No tags.", "no_tags": "No tags.",
"no_description_provided": "No description provided.", "no_description_provided": "No description provided.",
"change_icon": "Change Icon", "change_icon": "Change Icon",
"upload_preview_image": "Upload Preview Image" "upload_preview_image": "Upload Preview Image",
"columns": "Columns",
"default": "Default"
} }

View File

@ -14,6 +14,7 @@ type LocalSettings = {
collection: boolean; collection: boolean;
date: boolean; date: boolean;
}; };
columns: number;
sortBy?: Sort; sortBy?: Sort;
}; };
@ -37,10 +38,11 @@ const useLocalSettingsStore = create<LocalSettingsStore>((set) => ({
collection: true, collection: true,
date: true, date: true,
}, },
columns: 0,
sortBy: Sort.DateNewestFirst, sortBy: Sort.DateNewestFirst,
}, },
updateSettings: (newSettings) => { updateSettings: (newSettings) => {
const { theme, viewMode, sortBy, show } = newSettings; const { theme, viewMode, sortBy, show, columns } = newSettings;
if (theme !== undefined && theme !== localStorage.getItem("theme")) { if (theme !== undefined && theme !== localStorage.getItem("theme")) {
localStorage.setItem("theme", theme); localStorage.setItem("theme", theme);
@ -58,6 +60,10 @@ const useLocalSettingsStore = create<LocalSettingsStore>((set) => ({
localStorage.setItem("sortBy", sortBy.toString()); localStorage.setItem("sortBy", sortBy.toString());
} }
if (columns !== undefined) {
localStorage.setItem("columns", columns.toString());
}
const currentShowString = localStorage.getItem("show"); const currentShowString = localStorage.getItem("show");
const newShowString = show ? JSON.stringify(show) : currentShowString; const newShowString = show ? JSON.stringify(show) : currentShowString;
@ -80,6 +86,9 @@ const useLocalSettingsStore = create<LocalSettingsStore>((set) => ({
const viewMode = localStorage.getItem("viewMode") || "card"; const viewMode = localStorage.getItem("viewMode") || "card";
localStorage.setItem("viewMode", viewMode); localStorage.setItem("viewMode", viewMode);
const columns = parseInt(localStorage.getItem("columns") || "0");
localStorage.setItem("columns", columns.toString());
const storedShow = localStorage.getItem("show"); const storedShow = localStorage.getItem("show");
const show = storedShow const show = storedShow
? JSON.parse(storedShow) ? JSON.parse(storedShow)
@ -100,6 +109,7 @@ const useLocalSettingsStore = create<LocalSettingsStore>((set) => ({
theme, theme,
viewMode, viewMode,
show, show,
columns,
sortBy: useLocalSettingsStore.getState().settings.sortBy, sortBy: useLocalSettingsStore.getState().settings.sortBy,
}, },
}); });