import { useState } from "react"; import { useRouter } from "next/router"; import Link from "next/link"; import { observer } from "mobx-react-lite"; import { Pencil, Trash2 } from "lucide-react"; // components import { CreateUpdateWorkspaceViewModal, DeleteGlobalViewModal } from "components/workspace"; // ui import { CustomMenu, PhotoFilterIcon } from "@plane/ui"; // helpers import { truncateText } from "helpers/string.helper"; import { calculateTotalFilters } from "helpers/filter.helper"; // types import { IWorkspaceView } from "types/workspace-views"; type Props = { view: IWorkspaceView }; export const GlobalViewListItem: React.FC<Props> = observer((props) => { const { view } = props; const [updateViewModal, setUpdateViewModal] = useState(false); const [deleteViewModal, setDeleteViewModal] = useState(false); const router = useRouter(); const { workspaceSlug } = router.query; const totalFilters = calculateTotalFilters(view.query_data.filters ?? {}); return ( <> <CreateUpdateWorkspaceViewModal data={view} isOpen={updateViewModal} onClose={() => setUpdateViewModal(false)} /> <DeleteGlobalViewModal data={view} isOpen={deleteViewModal} onClose={() => setDeleteViewModal(false)} /> <div className="group hover:bg-custom-background-90 border-b border-custom-border-200"> <Link href={`/${workspaceSlug}/workspace-views/${view.id}`}> <a className="flex items-center justify-between relative rounded p-4 w-full"> <div className="flex items-center justify-between w-full"> <div className="flex items-center gap-4"> <div className="grid place-items-center h-10 w-10 rounded bg-custom-background-90 group-hover:bg-custom-background-100"> <PhotoFilterIcon className="h-3.5 w-3.5" /> </div> <div className="flex flex-col"> <p className="truncate text-sm leading-4 font-medium">{truncateText(view.name, 75)}</p> {view?.description && <p className="text-xs text-custom-text-200">{view.description}</p>} </div> </div> <div className="ml-2 flex flex-shrink-0"> <div className="flex items-center gap-4"> <p className="rounded bg-custom-background-80 py-1 px-2 text-xs text-custom-text-200 hidden group-hover:block"> {totalFilters} {totalFilters === 1 ? "filter" : "filters"} </p> <CustomMenu width="auto" ellipsis> <CustomMenu.MenuItem onClick={(e) => { e.preventDefault(); e.stopPropagation(); setUpdateViewModal(true); }} > <span className="flex items-center justify-start gap-2"> <Pencil size={14} strokeWidth={2} /> <span>Edit View</span> </span> </CustomMenu.MenuItem> <CustomMenu.MenuItem onClick={(e) => { e.preventDefault(); e.stopPropagation(); setDeleteViewModal(true); }} > <span className="flex items-center justify-start gap-2"> <Trash2 size={14} strokeWidth={2} /> <span>Delete View</span> </span> </CustomMenu.MenuItem> </CustomMenu> </div> </div> </div> </a> </Link> </div> </> ); });