el.xwx.moe/components/ViewDropdown.tsx

62 lines
1.8 KiB
TypeScript
Raw Normal View History

2023-12-16 14:06:26 -06:00
import React, { Dispatch, SetStateAction, useEffect, useState } 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";
2023-12-15 21:25:39 -06:00
type Props = {
2023-12-16 14:06:26 -06:00
viewMode: string;
setViewMode: Dispatch<SetStateAction<string>>;
2023-12-15 21:25:39 -06:00
};
2023-12-16 14:06:26 -06:00
export default function ViewDropdown({ viewMode, setViewMode }: Props) {
const { updateSettings } = useLocalSettingsStore();
2023-12-15 22:57:50 -06:00
2023-12-16 14:06:26 -06:00
const onChangeViewMode = (
e: React.MouseEvent<HTMLButtonElement>,
viewMode: ViewMode
) => {
setViewMode(viewMode);
};
2023-12-15 22:57:50 -06:00
2023-12-16 14:06:26 -06:00
useEffect(() => {
updateSettings({ viewMode: viewMode as ViewMode });
}, [viewMode]);
2023-12-15 21:25:39 -06:00
2023-12-16 14:06:26 -06:00
return (
<div className="p-1 flex flex-row gap-1 border border-neutral-content rounded-[0.625rem]">
2023-12-16 14:06:26 -06:00
<button
2023-12-21 09:55:07 -06:00
onClick={(e) => onChangeViewMode(e, ViewMode.Card)}
className={`btn btn-square btn-sm btn-ghost ${
viewMode == ViewMode.Card
? "bg-primary/20 hover:bg-primary/20"
: "hover:bg-neutral/20"
2023-12-16 14:06:26 -06:00
}`}
>
2023-12-21 09:55:07 -06:00
<i className="bi-grid w-4 h-4 text-neutral"></i>
2023-12-16 14:06:26 -06:00
</button>
<button
onClick={(e) => onChangeViewMode(e, ViewMode.List)}
2023-12-21 09:55:07 -06:00
className={`btn btn-square btn-sm btn-ghost ${
viewMode == ViewMode.List
? "bg-primary/20 hover:bg-primary/20"
: "hover:bg-neutral/20"
2023-12-16 14:06:26 -06:00
}`}
>
2023-12-21 09:55:07 -06:00
<i className="bi bi-view-stacked w-4 h-4 text-neutral"></i>
</button>
{/* <button
onClick={(e) => onChangeViewMode(e, ViewMode.Grid)}
2023-12-21 09:55:07 -06:00
className={`btn btn-square btn-sm btn-ghost ${
viewMode == ViewMode.Grid
? "bg-primary/20 hover:bg-primary/20"
: "hover:bg-neutral/20"
2023-12-16 14:06:26 -06:00
}`}
>
2023-12-21 09:55:07 -06:00
<i className="bi-columns-gap w-4 h-4 text-neutral"></i>
</button> */}
2023-12-16 14:06:26 -06:00
</div>
);
2023-12-15 21:25:39 -06:00
}