import { FC, MouseEvent } from "react"; import { observer } from "mobx-react"; import Link from "next/link"; import { useRouter } from "next/router"; import { Tooltip, PriorityIcon } from "@plane/ui"; // components import { InboxIssueStatus } from "@/components/inbox"; // constants import { INBOX_ISSUE_OPENED } from "@/constants/event-tracker"; // helpers import { cn } from "@/helpers/common.helper"; import { renderFormattedDate } from "@/helpers/date-time.helper"; // hooks import { useEventTracker, useLabel, useProjectInbox } from "@/hooks/store"; import { usePlatformOS } from "@/hooks/use-platform-os"; // store import { IInboxIssueStore } from "@/store/inbox/inbox-issue.store"; type InboxIssueListItemProps = { workspaceSlug: string; projectId: string; projectIdentifier?: string; inboxIssue: IInboxIssueStore; setToggleMobileSidebar: (value: boolean) => void; }; export const InboxIssueListItem: FC = observer((props) => { const { workspaceSlug, projectId, inboxIssue, projectIdentifier, setToggleMobileSidebar } = props; // router const router = useRouter(); const { inboxIssueId } = router.query; // store const { currentTab } = useProjectInbox(); const { projectLabels } = useLabel(); const { isMobile } = usePlatformOS(); const { captureEvent } = useEventTracker(); const issue = inboxIssue.issue; const handleIssueRedirection = (event: MouseEvent, currentIssueId: string | undefined) => { if (inboxIssueId === currentIssueId) event.preventDefault(); setToggleMobileSidebar(false); }; if (!issue) return <>; return ( <> { handleIssueRedirection(e, issue.id); captureEvent(INBOX_ISSUE_OPENED, { issueId: issue.id, }); }} >
{projectIdentifier}-{issue.sequence_id}
{inboxIssue.status !== -2 && }

{issue.name}

{renderFormattedDate(issue.created_at ?? "")}
{issue.priority && ( )} {issue.label_ids && issue.label_ids.length > 3 ? (
{`${issue.label_ids.length} labels`}
) : ( <> {(issue.label_ids ?? []).map((labelId) => { const labelDetails = projectLabels?.find((l) => l.id === labelId); if (!labelDetails) return null; return (
{labelDetails.name}
); })} )}
); });