"use client"; // mobx react lite import { observer } from "mobx-react-lite"; import { useMobxStore } from "lib/mobx/store-provider"; // components import { IssueBlockPriority } from "components/issues/board-views/block-priority"; import { IssueBlockState } from "components/issues/board-views/block-state"; import { IssueBlockLabels } from "components/issues/board-views/block-labels"; import { IssueBlockDueDate } from "components/issues/board-views/block-due-date"; // interfaces import { IIssue } from "types/issue"; import { RootStore } from "store/root"; export const IssueListBlock = observer(({ issue }: { issue: IIssue }) => { const store: RootStore = useMobxStore(); const { issue: issueStore } = store; return (
{/* id */}
{store?.project?.project?.identifier}-{issue?.sequence_id}
{/* name */}
issueStore?.setActivePeekOverviewIssueId(issue?.id)} className="text-custom-text-100 text-sm font-medium h-full break-words line-clamp-2 cursor-pointer" > {issue.name}
{/* priority */}
{issue?.priority && (
)} {/* state */} {issue?.state_detail && (
)} {/* labels */} {issue?.label_details && issue?.label_details.length > 0 && (
)} {/* due date */} {issue?.target_date && (
)}
); });