import { createSignal, createEffect, onCleanup, Show } from "solid-js"; import CountdownCircleTimer from "~/components/CountdownCircleTimer"; import LoadingSpinner from "~/components/LoadingSpinner"; import { getClientCookie } from "~/lib/cookies.client"; export default function DeletionForm() { const [countDown, setCountDown] = createSignal(0); const [emailSent, setEmailSent] = createSignal(false); const [error, setError] = createSignal(""); const [loading, setLoading] = createSignal(false); // Form ref let emailRef: HTMLInputElement | undefined; let timerInterval: number | undefined; // Calculate remaining time from cookie const calcRemainder = (timer: string) => { const expires = new Date(timer); const remaining = expires.getTime() - Date.now(); const remainingInSeconds = remaining / 1000; if (remainingInSeconds <= 0) { setCountDown(0); if (timerInterval) { clearInterval(timerInterval); } } else { setCountDown(remainingInSeconds); } }; createEffect(() => { const timer = getClientCookie("deletionRequestSent"); if (timer) { timerInterval = setInterval( () => calcRemainder(timer), 1000 ) as unknown as number; onCleanup(() => { if (timerInterval) { clearInterval(timerInterval); } }); } }); const sendEmailTrigger = async (e: Event) => { e.preventDefault(); setLoading(true); setError(""); setEmailSent(false); if (!emailRef) { setError("Please enter your email"); setLoading(false); return; } const email = emailRef.value; try { const response = await fetch("/api/trpc/misc.sendDeletionRequestEmail", { method: "POST", headers: { "Content-Type": "application/json" }, body: JSON.stringify({ email }) }); const result = await response.json(); if (response.ok && result.result?.data?.message === "request sent") { setEmailSent(true); const timer = getClientCookie("deletionRequestSent"); if (timer) { if (timerInterval) { clearInterval(timerInterval); } timerInterval = setInterval( () => calcRemainder(timer), 1000 ) as unknown as number; } } else { const errorMsg = result.error?.message || "Failed to send deletion request"; setError(errorMsg); } } catch (err: any) { console.error("Deletion request error:", err); setError(err.message || "An error occurred"); } finally { setLoading(false); } }; // Countdown timer render function const renderTime = ({ remainingTime }: { remainingTime: number }) => { return (