"use client"; import { FC } from "react"; import { observer } from "mobx-react-lite"; import { useRouter, useSearchParams } from "next/navigation"; // components import { IssueBlockDueDate } from "@/components/issues/board-views/block-due-date"; import { IssueBlockLabels } from "@/components/issues/board-views/block-labels"; import { IssueBlockPriority } from "@/components/issues/board-views/block-priority"; import { IssueBlockState } from "@/components/issues/board-views/block-state"; // mobx hook import { useIssueDetails, useProject } from "@/hooks/store"; // interfaces import { IIssue } from "@/types/issue"; // store type IssueListBlockProps = { issue: IIssue; workspaceSlug: string; projectId: string; }; export const IssueListBlock: FC = observer((props) => { const { workspaceSlug, projectId, issue } = props; const searchParams = useSearchParams(); // query params const board = searchParams.get("board") || undefined; const state = searchParams.get("state") || undefined; const priority = searchParams.get("priority") || undefined; const labels = searchParams.get("labels") || undefined; // store const { project } = useProject(); const { setPeekId } = useIssueDetails(); // router const router = useRouter(); const handleBlockClick = () => { setPeekId(issue.id); let queryParams: any = { board: board, peekId: issue.id }; if (priority && priority.length > 0) queryParams = { ...queryParams, priority: priority }; if (state && state.length > 0) queryParams = { ...queryParams, state: state }; if (labels && labels.length > 0) queryParams = { ...queryParams, labels: labels }; queryParams = new URLSearchParams(queryParams).toString(); router.push(`/${workspaceSlug}/${projectId}?${queryParams}`); }; return (
{/* id */}
{project?.identifier}-{issue?.sequence_id}
{/* name */}
{issue.name}
{/* priority */} {issue?.priority && (
)} {/* state */} {issue?.state_detail && (
)} {/* labels */} {issue?.label_details && issue?.label_details.length > 0 && (
)} {/* due date */} {issue?.target_date && (
)}
); });