"use client"; import { Command } from "cmdk"; import { observer } from "mobx-react"; import { useParams } from "next/navigation"; import { LinkIcon, Signal, Trash2, UserMinus2, UserPlus2, Users } from "lucide-react"; import { TIssue } from "@plane/types"; // hooks import { DoubleCircleIcon, TOAST_TYPE, setToast } from "@plane/ui"; // constants import { EIssuesStoreType } from "@/constants/issue"; // helpers import { copyTextToClipboard } from "@/helpers/string.helper"; // hooks import { useCommandPalette, useIssues, useUser } from "@/hooks/store"; type Props = { closePalette: () => void; issueDetails: TIssue | undefined; pages: string[]; setPages: (pages: string[]) => void; setPlaceholder: (placeholder: string) => void; setSearchTerm: (searchTerm: string) => void; }; export const CommandPaletteIssueActions: React.FC = observer((props) => { const { closePalette, issueDetails, pages, setPages, setPlaceholder, setSearchTerm } = props; // router const { workspaceSlug, projectId, issueId } = useParams(); // hooks const { issues: { updateIssue }, } = useIssues(EIssuesStoreType.PROJECT); const { toggleCommandPaletteModal, toggleDeleteIssueModal } = useCommandPalette(); const { data: currentUser } = useUser(); const handleUpdateIssue = async (formData: Partial) => { if (!workspaceSlug || !projectId || !issueDetails) return; const payload = { ...formData }; await updateIssue(workspaceSlug.toString(), projectId.toString(), issueDetails.id, payload).catch((e) => { console.error(e); }); }; const handleIssueAssignees = (assignee: string) => { if (!issueDetails || !assignee) return; closePalette(); const updatedAssignees = issueDetails.assignee_ids ?? []; if (updatedAssignees.includes(assignee)) updatedAssignees.splice(updatedAssignees.indexOf(assignee), 1); else updatedAssignees.push(assignee); handleUpdateIssue({ assignee_ids: updatedAssignees }); }; const deleteIssue = () => { toggleCommandPaletteModal(false); toggleDeleteIssueModal(true); }; const copyIssueUrlToClipboard = () => { if (!issueId) return; const url = new URL(window.location.href); copyTextToClipboard(url.href) .then(() => { setToast({ type: TOAST_TYPE.SUCCESS, title: "Copied to clipboard", }); }) .catch(() => { setToast({ type: TOAST_TYPE.ERROR, title: "Some error occurred", }); }); }; return ( { setPlaceholder("Change state..."); setSearchTerm(""); setPages([...pages, "change-issue-state"]); }} className="focus:outline-none" >
Change state...
{ setPlaceholder("Change priority..."); setSearchTerm(""); setPages([...pages, "change-issue-priority"]); }} className="focus:outline-none" >
Change priority...
{ setPlaceholder("Assign to..."); setSearchTerm(""); setPages([...pages, "change-issue-assignee"]); }} className="focus:outline-none" >
Assign to...
{ handleIssueAssignees(currentUser?.id ?? ""); setSearchTerm(""); }} className="focus:outline-none" >
{issueDetails?.assignee_ids.includes(currentUser?.id ?? "") ? ( <> Un-assign from me ) : ( <> Assign to me )}
Delete issue
{ closePalette(); copyIssueUrlToClipboard(); }} className="focus:outline-none" >
Copy issue URL
); });