import { Handlers, PageProps } from "$fresh/server.ts"; import { Head } from "$fresh/runtime.ts"; interface FormState { name?: string; email?: string; message?: string; errors?: { name?: string; email?: string; message?: string; }; submitted?: boolean; failed?: boolean; } export const handler: Handlers = { GET(_, ctx) { return ctx.render({}); }, async POST(req, ctx) { const formData = await req.formData(); const state: FormState = { name: formData.get("name")?.toString(), email: formData.get("email")?.toString(), message: formData.get("message")?.toString(), }; // Validation logic const errors: FormState["errors"] = {}; if (!state.name || state.name.trim() === "") { errors.name = "Name is required"; } const emailRegex = /^[^\s@]+@[^\s@]+\.[^\s@]+$/; if (!state.email) { errors.email = "Email is required"; } else if (!emailRegex.test(state.email)) { errors.email = "Invalid email format"; } if (!state.message || state.message.trim() === "") { errors.message = "Message is required"; } // If there are errors, return the form with error messages if (Object.keys(errors).length > 0) { return ctx.render({ ...state, errors, }); } const res = await fetch(`${Deno.env.get("EMAIL_FORM")}`, { method: "POST", body: formData, }); console.log(res); if (!res.ok || res.status !== 200) { return ctx.render({ ...state, failed: true, }); } return ctx.render({ ...state, submitted: true, }); }, }; export default function Contact({ data }: PageProps) { return (
Contact

Contact

{data?.submitted && ( )} {data?.failed && ( )}
{data?.errors?.name && (

{data.errors.name}

)}
{data?.errors?.email && (

{data.errors.email}

)}
{data?.errors?.message && (

{data.errors.message}

)}
); }