2024-09-09 18:16:28 -05:00
|
|
|
import React, { Dispatch, SetStateAction, useEffect } from "react";
|
2023-12-15 22:57:50 -06:00
|
|
|
import useLocalSettingsStore from "@/store/localSettings";
|
2023-12-16 14:06:26 -06:00
|
|
|
import { ViewMode } from "@/types/global";
|
2024-08-26 17:47:10 -05:00
|
|
|
import { dropdownTriggerer } from "@/lib/client/utils";
|
|
|
|
import { useTranslation } from "next-i18next";
|
2023-12-15 21:25:39 -06:00
|
|
|
|
|
|
|
type Props = {
|
2024-08-12 23:08:57 -05:00
|
|
|
viewMode: ViewMode;
|
|
|
|
setViewMode: Dispatch<SetStateAction<ViewMode>>;
|
2023-12-15 21:25:39 -06:00
|
|
|
};
|
|
|
|
|
2023-12-16 14:06:26 -06:00
|
|
|
export default function ViewDropdown({ viewMode, setViewMode }: Props) {
|
2024-08-26 17:47:10 -05:00
|
|
|
const { settings, updateSettings } = useLocalSettingsStore((state) => state);
|
|
|
|
const { t } = useTranslation();
|
2023-12-15 22:57:50 -06:00
|
|
|
|
2024-09-09 18:16:28 -05:00
|
|
|
useEffect(() => {
|
|
|
|
updateSettings({ viewMode });
|
|
|
|
}, [viewMode, updateSettings]);
|
|
|
|
|
2024-09-09 18:05:30 -05:00
|
|
|
const onChangeViewMode = (mode: ViewMode) => {
|
2024-08-26 17:47:10 -05:00
|
|
|
setViewMode(mode);
|
2024-09-09 18:05:30 -05:00
|
|
|
updateSettings({ viewMode });
|
2024-08-26 17:47:10 -05:00
|
|
|
};
|
|
|
|
|
|
|
|
const toggleShowSetting = (setting: keyof typeof settings.show) => {
|
|
|
|
const newShowSettings = {
|
|
|
|
...settings.show,
|
|
|
|
[setting]: !settings.show[setting],
|
|
|
|
};
|
|
|
|
updateSettings({ show: newShowSettings });
|
2023-12-16 14:06:26 -06:00
|
|
|
};
|
2023-12-15 22:57:50 -06:00
|
|
|
|
2024-09-09 18:05:30 -05:00
|
|
|
const onColumnsChange = (e: React.ChangeEvent<HTMLInputElement>) => {
|
|
|
|
updateSettings({ columns: Number(e.target.value) });
|
|
|
|
};
|
2023-12-15 21:25:39 -06:00
|
|
|
|
2023-12-16 14:06:26 -06:00
|
|
|
return (
|
2024-08-26 17:47:10 -05:00
|
|
|
<div className="dropdown dropdown-bottom dropdown-end">
|
|
|
|
<div
|
|
|
|
tabIndex={0}
|
|
|
|
role="button"
|
|
|
|
onMouseDown={dropdownTriggerer}
|
|
|
|
className="btn btn-sm btn-square btn-ghost border-none"
|
2023-12-16 14:06:26 -06:00
|
|
|
>
|
2024-08-26 17:47:10 -05:00
|
|
|
{viewMode === ViewMode.Card ? (
|
|
|
|
<i className="bi-grid w-4 h-4 text-neutral"></i>
|
|
|
|
) : viewMode === ViewMode.Masonry ? (
|
|
|
|
<i className="bi-columns-gap w-4 h-4 text-neutral"></i>
|
|
|
|
) : (
|
|
|
|
<i className="bi-view-stacked w-4 h-4 text-neutral"></i>
|
|
|
|
)}
|
|
|
|
</div>
|
2024-09-09 18:05:30 -05:00
|
|
|
<ul
|
|
|
|
tabIndex={0}
|
|
|
|
className="dropdown-content z-[30] menu shadow bg-base-200 min-w-52 border border-neutral-content rounded-xl mt-1"
|
|
|
|
>
|
2024-08-26 17:47:10 -05:00
|
|
|
<p className="mb-1 text-sm text-neutral">{t("view")}</p>
|
2024-09-09 18:05:30 -05:00
|
|
|
<div className="p-1 flex w-full justify-between gap-1 border border-neutral-content rounded-[0.625rem]">
|
2024-08-26 17:47:10 -05:00
|
|
|
<button
|
2024-09-09 18:05:30 -05:00
|
|
|
onClick={(e) => onChangeViewMode(ViewMode.Card)}
|
2024-09-04 21:19:40 -05:00
|
|
|
className={`btn w-[31%] btn-sm btn-ghost ${
|
2024-08-26 17:47:10 -05:00
|
|
|
viewMode === ViewMode.Card
|
|
|
|
? "bg-primary/20 hover:bg-primary/20"
|
|
|
|
: "hover:bg-neutral/20"
|
|
|
|
}`}
|
|
|
|
>
|
|
|
|
<i className="bi-grid text-lg text-neutral"></i>
|
|
|
|
</button>
|
|
|
|
<button
|
2024-09-09 18:05:30 -05:00
|
|
|
onClick={(e) => onChangeViewMode(ViewMode.Masonry)}
|
2024-09-04 21:19:40 -05:00
|
|
|
className={`btn w-[31%] btn-sm btn-ghost ${
|
2024-08-26 17:47:10 -05:00
|
|
|
viewMode === ViewMode.Masonry
|
|
|
|
? "bg-primary/20 hover:bg-primary/20"
|
|
|
|
: "hover:bg-neutral/20"
|
|
|
|
}`}
|
|
|
|
>
|
|
|
|
<i className="bi-columns-gap text-lg text-neutral"></i>
|
|
|
|
</button>
|
|
|
|
<button
|
2024-09-09 18:05:30 -05:00
|
|
|
onClick={(e) => onChangeViewMode(ViewMode.List)}
|
2024-09-04 21:19:40 -05:00
|
|
|
className={`btn w-[31%] btn-sm btn-ghost ${
|
2024-08-26 17:47:10 -05:00
|
|
|
viewMode === ViewMode.List
|
|
|
|
? "bg-primary/20 hover:bg-primary/20"
|
|
|
|
: "hover:bg-neutral/20"
|
|
|
|
}`}
|
|
|
|
>
|
|
|
|
<i className="bi-view-stacked text-lg text-neutral"></i>
|
|
|
|
</button>
|
|
|
|
</div>
|
2024-09-09 18:05:30 -05:00
|
|
|
<p className="mb-1 mt-2 text-sm text-neutral">{t("show")}</p>
|
2024-08-26 17:47:10 -05:00
|
|
|
{Object.entries(settings.show)
|
|
|
|
.filter((e) =>
|
2024-08-26 18:56:04 -05:00
|
|
|
settings.viewMode === ViewMode.List // Hide tags, image, icon, and description checkboxes in list view
|
|
|
|
? e[0] !== "tags" &&
|
|
|
|
e[0] !== "image" &&
|
|
|
|
e[0] !== "icon" &&
|
|
|
|
e[0] !== "description"
|
|
|
|
: settings.viewMode === ViewMode.Card // Hide tags and description checkboxes in card view
|
|
|
|
? e[0] !== "tags" && e[0] !== "description"
|
2024-08-26 17:47:10 -05:00
|
|
|
: true
|
|
|
|
)
|
|
|
|
.map(([key, value]) => (
|
|
|
|
<li key={key}>
|
2024-09-09 18:05:30 -05:00
|
|
|
<label className="label cursor-pointer flex justify-start">
|
2024-08-26 17:47:10 -05:00
|
|
|
<input
|
|
|
|
type="checkbox"
|
|
|
|
className="checkbox checkbox-primary"
|
|
|
|
checked={value}
|
|
|
|
onChange={() =>
|
|
|
|
toggleShowSetting(key as keyof typeof settings.show)
|
|
|
|
}
|
|
|
|
/>
|
|
|
|
<span className="label-text whitespace-nowrap">{t(key)}</span>
|
|
|
|
</label>
|
|
|
|
</li>
|
|
|
|
))}
|
2024-09-09 23:09:33 -05:00
|
|
|
{settings.viewMode !== ViewMode.List && (
|
|
|
|
<>
|
|
|
|
<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 range-primary"
|
|
|
|
step="1"
|
|
|
|
/>
|
2024-09-11 00:38:38 -05:00
|
|
|
<div className="flex w-full justify-between px-2 text-xs text-neutral select-none">
|
2024-09-09 23:09:33 -05:00
|
|
|
<span>|</span>
|
|
|
|
<span>|</span>
|
|
|
|
<span>|</span>
|
|
|
|
<span>|</span>
|
|
|
|
<span>|</span>
|
|
|
|
<span>|</span>
|
|
|
|
<span>|</span>
|
|
|
|
<span>|</span>
|
|
|
|
<span>|</span>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</>
|
|
|
|
)}
|
2024-08-26 17:47:10 -05:00
|
|
|
</ul>
|
2023-12-16 14:06:26 -06:00
|
|
|
</div>
|
|
|
|
);
|
2023-12-15 21:25:39 -06:00
|
|
|
}
|