import { useState, FC } from "react"; import { observer } from "mobx-react-lite"; import { useRouter } from "next/router"; // icons import { Copy, Eye, EyeOff, RefreshCw } from "lucide-react"; import { IWebhook } from "@plane/types"; // ui import { Button, Tooltip, TOAST_TYPE, setToast } from "@plane/ui"; // constants import { WEBHOOK_KEY_REGEN } from "@/constants/event-tracker"; // helpers import { csvDownload } from "@/helpers/download.helper"; import { copyTextToClipboard } from "@/helpers/string.helper"; // hooks import { useWebhook, useWorkspace, useEventTracker } from "@/hooks/store"; // types import { usePlatformOS } from "@/hooks/use-platform-os"; // utils import { getCurrentHookAsCSV } from "../utils"; type Props = { data: Partial; }; export const WebhookSecretKey: FC = observer((props) => { const { data } = props; // states const [isRegenerating, setIsRegenerating] = useState(false); const [shouldShowKey, setShouldShowKey] = useState(false); // router const router = useRouter(); const { workspaceSlug, webhookId } = router.query; // store hooks const { currentWorkspace } = useWorkspace(); const { currentWebhook, regenerateSecretKey, webhookSecretKey } = useWebhook(); const { captureEvent } = useEventTracker(); const { isMobile } = usePlatformOS(); const handleCopySecretKey = () => { if (!webhookSecretKey) return; copyTextToClipboard(webhookSecretKey) .then(() => setToast({ type: TOAST_TYPE.SUCCESS, title: "Success!", message: "Secret key copied to clipboard.", }) ) .catch(() => setToast({ type: TOAST_TYPE.ERROR, title: "Error!", message: "Error occurred while copying secret key.", }) ); }; const handleRegenerateSecretKey = () => { if (!workspaceSlug || !data.id) return; setIsRegenerating(true); regenerateSecretKey(workspaceSlug.toString(), data.id) .then(() => { setToast({ type: TOAST_TYPE.SUCCESS, title: "Success!", message: "New key regenerated successfully.", }); captureEvent(WEBHOOK_KEY_REGEN, { webhook_id: data.id, }); if (currentWebhook && webhookSecretKey) { const csvData = getCurrentHookAsCSV(currentWorkspace, currentWebhook, webhookSecretKey); csvDownload(csvData, `webhook-secret-key-${Date.now()}`); } }) .catch((err) => setToast({ type: TOAST_TYPE.ERROR, title: "Error!", message: err?.error ?? "Something went wrong. Please try again.", }) ) .finally(() => setIsRegenerating(false)); }; const toggleShowKey = () => setShouldShowKey((prevState) => !prevState); const SECRET_KEY_OPTIONS = [ { label: "View secret key", Icon: shouldShowKey ? EyeOff : Eye, onClick: toggleShowKey, key: "eye" }, { label: "Copy secret key", Icon: Copy, onClick: handleCopySecretKey, key: "copy" }, ]; return ( <> {(data || webhookSecretKey) && (
{webhookId &&
Secret key
}
Generate a token to sign-in to the webhook payload
{shouldShowKey ? (

{webhookSecretKey}

) : (
{[...Array(30)].map((_, index) => (
))}
)}
{webhookSecretKey && (
{SECRET_KEY_OPTIONS.map((option) => ( ))}
)}
{data && (
)}
)} ); });