2024-02-07 06:00:06 +00:00
|
|
|
import { FC, Fragment } from "react";
|
2024-02-05 14:39:17 +00:00
|
|
|
import Link from "next/link";
|
|
|
|
import { observer } from "mobx-react-lite";
|
|
|
|
// hooks
|
2024-02-08 18:11:30 +00:00
|
|
|
import { useViewDetail } from "hooks/store";
|
2024-02-05 14:39:17 +00:00
|
|
|
// ui
|
2024-02-07 06:00:06 +00:00
|
|
|
import { PhotoFilterIcon, Tooltip } from "@plane/ui";
|
2024-02-05 14:39:17 +00:00
|
|
|
// types
|
|
|
|
import { TViewTypes } from "@plane/types";
|
|
|
|
|
|
|
|
type TViewItem = {
|
|
|
|
workspaceSlug: string;
|
|
|
|
projectId: string | undefined;
|
2024-02-08 18:11:30 +00:00
|
|
|
viewId: string;
|
2024-02-05 14:39:17 +00:00
|
|
|
viewType: TViewTypes;
|
|
|
|
viewItemId: string;
|
2024-02-08 18:11:30 +00:00
|
|
|
baseRoute: string;
|
2024-02-05 14:39:17 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
export const ViewItem: FC<TViewItem> = observer((props) => {
|
2024-02-08 18:11:30 +00:00
|
|
|
const { workspaceSlug, projectId, viewId, viewType, viewItemId, baseRoute } = props;
|
2024-02-05 14:39:17 +00:00
|
|
|
// hooks
|
2024-02-07 06:00:06 +00:00
|
|
|
const viewDetailStore = useViewDetail(workspaceSlug, projectId, viewItemId, viewType);
|
2024-02-05 14:39:17 +00:00
|
|
|
|
2024-02-07 06:00:06 +00:00
|
|
|
if (!viewDetailStore) return <></>;
|
2024-02-05 14:39:17 +00:00
|
|
|
return (
|
2024-02-07 06:00:06 +00:00
|
|
|
<div className="space-y-0.5 relative h-full flex flex-col justify-between">
|
|
|
|
<Tooltip tooltipContent={viewDetailStore?.name} position="top">
|
|
|
|
<Link
|
2024-02-08 18:11:30 +00:00
|
|
|
href={`${baseRoute}/${viewItemId}`}
|
2024-02-07 06:00:06 +00:00
|
|
|
className={`cursor-pointer relative p-2 px-2.5 flex justify-center items-center gap-1 rounded transition-all hover:bg-custom-background-80
|
2024-02-05 14:39:17 +00:00
|
|
|
${viewItemId === viewId ? `text-custom-primary-100 bg-custom-primary-100/10` : `border-transparent`}
|
|
|
|
`}
|
2024-02-07 06:00:06 +00:00
|
|
|
onClick={(e) => viewItemId === viewId && e.preventDefault()}
|
|
|
|
>
|
|
|
|
<div
|
|
|
|
className={`flex-shrink-0 rounded-sm relative w-5 h-5 flex justify-center items-center overflow-hidden
|
|
|
|
${viewItemId === viewId ? `bg-transparent` : `bg-custom-background-80`}
|
|
|
|
`}
|
|
|
|
>
|
|
|
|
<PhotoFilterIcon className="w-3 h-3" />
|
|
|
|
</div>
|
|
|
|
<div className="w-full max-w-[80px] inline-block text-sm line-clamp-1 truncate overflow-hidden font-medium">
|
|
|
|
{viewDetailStore?.name}
|
|
|
|
</div>
|
|
|
|
</Link>
|
|
|
|
</Tooltip>
|
2024-02-08 18:11:30 +00:00
|
|
|
<div
|
|
|
|
className={`border-b-2 rounded-t-sm ${
|
|
|
|
viewItemId === viewId ? `border-custom-primary-100` : `border-transparent`
|
|
|
|
}`}
|
|
|
|
/>
|
2024-02-05 14:39:17 +00:00
|
|
|
</div>
|
|
|
|
);
|
|
|
|
});
|