import React from "react"; import { useRouter } from "next/router"; import { mutate } from "swr"; // headless ui import { Dialog, Transition } from "@headlessui/react"; // services import { IssueAttachmentService } from "services/issue"; // hooks import useToast from "hooks/use-toast"; // ui import { Button } from "@plane/ui"; // icons import { ExclamationTriangleIcon } from "@heroicons/react/24/outline"; // helper import { getFileName } from "helpers/attachment.helper"; // types import type { IIssueAttachment } from "types"; // fetch-keys import { ISSUE_ATTACHMENTS, PROJECT_ISSUES_ACTIVITY } from "constants/fetch-keys"; type Props = { isOpen: boolean; setIsOpen: React.Dispatch>; data: IIssueAttachment | null; }; // services const issueAttachmentService = new IssueAttachmentService(); export const DeleteAttachmentModal: React.FC = ({ isOpen, setIsOpen, data }) => { const router = useRouter(); const { workspaceSlug, projectId, issueId } = router.query; const { setToastAlert } = useToast(); const handleClose = () => { setIsOpen(false); }; const handleDeletion = async (assetId: string) => { if (!workspaceSlug || !projectId || !data) return; mutate( ISSUE_ATTACHMENTS(issueId as string), (prevData) => (prevData ?? [])?.filter((p) => p.id !== assetId), false ); await issueAttachmentService .deleteIssueAttachment(workspaceSlug as string, projectId as string, issueId as string, assetId as string) .then(() => mutate(PROJECT_ISSUES_ACTIVITY(issueId as string))) .catch(() => { setToastAlert({ type: "error", title: "error!", message: "Something went wrong please try again.", }); }); }; return ( data && (
Delete Attachment

Are you sure you want to delete attachment-{" "} {getFileName(data.attributes.name)}? This attachment will be permanently removed. This action cannot be undone.

) ); };