import React from "react"; import Link from "next/link"; import { observer } from "mobx-react-lite"; import { CircleDot, CopyPlus, Pencil, X, XCircle } from "lucide-react"; // hooks import { useIssueDetail, useIssues, useProject } from "hooks/store"; import useToast from "hooks/use-toast"; // components import { ExistingIssuesListModal } from "components/core"; // ui import { RelatedIcon, Tooltip } from "@plane/ui"; // helpers import { cn } from "helpers/common.helper"; // types import { TIssueRelationTypes, ISearchIssueResponse } from "@plane/types"; export type TRelationObject = { className: string; icon: (size: number) => React.ReactElement; placeholder: string }; export const issueRelationObject: Record = { relates_to: { className: "bg-neutral-component-surface-dark text-custom-text-200", icon: (size) => , placeholder: "Add related issues", }, blocking: { className: "bg-orange-30 text-orange-110", icon: (size) => , placeholder: "None", }, blocked_by: { className: "bg-danger-component-surface-light text-danger-text-medium", icon: (size) => , placeholder: "None", }, duplicate: { className: "bg-neutral-component-surface-dark text-custom-text-200", icon: (size) => , placeholder: "None", }, }; type TIssueRelationSelect = { className?: string; workspaceSlug: string; projectId: string; issueId: string; relationKey: TIssueRelationTypes; disabled?: boolean; }; export const IssueRelationSelect: React.FC = observer((props) => { const { className = "", workspaceSlug, projectId, issueId, relationKey, disabled = false } = props; // hooks const { getProjectById } = useProject(); const { createRelation, removeRelation, relation: { getRelationByIssueIdRelationType }, isRelationModalOpen, toggleRelationModal, } = useIssueDetail(); const { issueMap } = useIssues(); // toast alert const { setToastAlert } = useToast(); const relationIssueIds = getRelationByIssueIdRelationType(issueId, relationKey); const onSubmit = async (data: ISearchIssueResponse[]) => { if (data.length === 0) { setToastAlert({ type: "error", title: "Error!", message: "Please select at least one issue.", }); return; } await createRelation( workspaceSlug, projectId, issueId, relationKey, data.map((i) => i.id) ); toggleRelationModal(null); }; if (!relationIssueIds) return null; return ( <> toggleRelationModal(null)} searchParams={{ issue_relation: true, issue_id: issueId }} handleOnSubmit={onSubmit} workspaceLevelToggle /> ); });