import React, { FC, useEffect, useState } from "react"; import { observer } from "mobx-react"; import { Controller, useForm } from "react-hook-form"; import { IWebhook, TWebhookEventTypes } from "@plane/types"; // hooks import { Button } from "@plane/ui"; import { WebhookIndividualEventOptions, WebhookInput, WebhookOptions, WebhookSecretKey, WebhookToggle, } from "@/components/web-hooks"; // constants import { WEBHOOK_UPDATED } from "@/constants/event-tracker"; import { useWebhook, useEventTracker } from "@/hooks/store"; // components // ui // types type Props = { data?: Partial; onSubmit: (data: IWebhook, webhookEventType: TWebhookEventTypes) => Promise; handleClose?: () => void; }; const initialWebhookPayload: Partial = { cycle: true, issue: true, issue_comment: true, module: true, project: true, url: "", }; export const WebhookForm: FC = observer((props) => { const { data, onSubmit, handleClose } = props; // states const [webhookEventType, setWebhookEventType] = useState("all"); // store hooks const { webhookSecretKey } = useWebhook(); const { captureEvent } = useEventTracker(); // use form const { handleSubmit, control, formState: { isSubmitting, errors, dirtyFields }, } = useForm({ defaultValues: { ...initialWebhookPayload, ...data }, }); const handleFormSubmit = async (formData: IWebhook) => { await onSubmit(formData, webhookEventType).then(() => { if (!data) return; captureEvent(WEBHOOK_UPDATED, { webhook_id: data.id, change_details: Object.keys(dirtyFields), enabled: formData.is_active, }); }); }; useEffect(() => { if (!data) return; if (data.project && data.cycle && data.module && data.issue && data.issue_comment) setWebhookEventType("all"); else setWebhookEventType("individual"); }, [data]); return (
{data ? "Webhook details" : "Create webhook"}
( )} /> {errors.url &&
{errors.url.message}
}
{data && }
setWebhookEventType(val)} />
{webhookEventType === "individual" && }
{data ? (
) : (
{!webhookSecretKey && ( )}
)}
); });