import React from "react"; import { useRouter } from "next/router"; import { mutate } from "swr"; // headless ui import { Disclosure, Transition } from "@headlessui/react"; // services import issuesService from "services/issue.service"; // ui import { CustomMenu } from "components/ui"; // icons import { ChevronDownIcon, XMarkIcon, PlusIcon, PencilIcon, TrashIcon } from "@heroicons/react/24/outline"; import { Component, X } from "lucide-react"; // types import { ICurrentUserResponse, IIssueLabels } from "types"; // fetch-keys import { PROJECT_ISSUE_LABELS } from "constants/fetch-keys"; type Props = { label: IIssueLabels; labelChildren: IIssueLabels[]; addLabelToGroup: (parentLabel: IIssueLabels) => void; editLabel: (label: IIssueLabels) => void; handleLabelDelete: () => void; user: ICurrentUserResponse | undefined; }; export const SingleLabelGroup: React.FC = ({ label, labelChildren, addLabelToGroup, editLabel, handleLabelDelete, user, }) => { const router = useRouter(); const { workspaceSlug, projectId } = router.query; const removeFromGroup = (label: IIssueLabels) => { if (!workspaceSlug || !projectId) return; mutate( PROJECT_ISSUE_LABELS(projectId as string), (prevData) => prevData?.map((l) => { if (l.id === label.id) return { ...l, parent: null }; return l; }), false ); issuesService .patchIssueLabel( workspaceSlug as string, projectId as string, label.id, { parent: null, }, user ) .then(() => { mutate(PROJECT_ISSUE_LABELS(projectId as string)); }); }; return ( {({ open }) => ( <>
{label.name}
addLabelToGroup(label)}> Add more labels editLabel(label)}> Edit label Delete label
{labelChildren.map((child) => (
{child.name}
} > removeFromGroup(child)}> Remove from group editLabel(child)}> Edit label
))}
)}
); };