import React, { FC, useState } from "react"; import { useRouter } from "next/router"; import { AlertTriangle } from "lucide-react"; import { Dialog, Transition } from "@headlessui/react"; // ui import { Button, TOAST_TYPE, setToast } from "@plane/ui"; // constants import { WEBHOOK_DELETED } from "@/constants/event-tracker"; // hooks import { useWebhook, useEventTracker } from "@/hooks/store"; interface IDeleteWebhook { isOpen: boolean; onClose: () => void; } export const DeleteWebhookModal: FC = (props) => { const { isOpen, onClose } = props; // states const [isDeleting, setIsDeleting] = useState(false); // router const router = useRouter(); // store hooks const { removeWebhook } = useWebhook(); const { captureEvent } = useEventTracker(); const { workspaceSlug, webhookId } = router.query; const handleClose = () => { onClose(); }; const handleDelete = async () => { if (!workspaceSlug || !webhookId) return; setIsDeleting(true); removeWebhook(workspaceSlug.toString(), webhookId.toString()) .then(() => { captureEvent(WEBHOOK_DELETED, { webhook_id: webhookId.toString(), }); setToast({ type: TOAST_TYPE.SUCCESS, title: "Success!", message: "Webhook deleted successfully.", }); router.replace(`/${workspaceSlug}/settings/webhooks/`); }) .catch((error) => setToast({ type: TOAST_TYPE.ERROR, title: "Error!", message: error?.error ?? "Something went wrong. Please try again.", }) ) .finally(() => setIsDeleting(false)); }; return (

Delete webhook

Are you sure you want to delete this webhook? Future events will not be delivered to this webhook. This action cannot be undone.

); };