import { observer } from "mobx-react"; // types import { IIssueDisplayProperties } from "@plane/types"; // helpers import { cn } from "@/helpers/common.helper"; // hooks import { useIssueDetail, useProject } from "@/hooks/store"; type TIssueIdentifierBaseProps = { projectId: string; size?: "xs" | "sm" | "md" | "lg"; textContainerClassName?: string; displayProperties?: IIssueDisplayProperties | undefined; }; type TIssueIdentifierFromStore = TIssueIdentifierBaseProps & { issueId: string; }; type TIssueIdentifierWithDetails = TIssueIdentifierBaseProps & { issueTypeId?: string | null; projectIdentifier: string; issueSequenceId: string | number; }; type TIssueIdentifierProps = TIssueIdentifierFromStore | TIssueIdentifierWithDetails; export const IssueIdentifier: React.FC = observer((props) => { const { projectId, textContainerClassName, displayProperties } = props; // store hooks const { getProjectIdentifierById } = useProject(); const { issue: { getIssueById }, } = useIssueDetail(); // Determine if the component is using store data or not const isUsingStoreData = "issueId" in props; // derived values const issue = isUsingStoreData ? getIssueById(props.issueId) : null; const projectIdentifier = isUsingStoreData ? getProjectIdentifierById(projectId) : props.projectIdentifier; const issueSequenceId = isUsingStoreData ? issue?.sequence_id : props.issueSequenceId; const shouldRenderIssueID = displayProperties ? displayProperties.key : true; if (!shouldRenderIssueID) return null; return (
{projectIdentifier}-{issueSequenceId}
); });