Charity donation
Accept monetary donations for a cause.
Fields
Full nametextrequiredEmailemailrequiredDonation amountnumberrequiredFrequencyselectMake this donation anonymouscheckboxMessage (optional)textarea
Code
import { useState } from "react";
export function CharityDonationForm() {
const [sent, setSent] = useState(false);
async function onSubmit(e: React.FormEvent<HTMLFormElement>) {
e.preventDefault();
const form = e.currentTarget;
const res = await fetch("https://formward.eu/f/your-form-id", {
method: "POST",
headers: { Accept: "application/json" },
body: new FormData(form),
});
if (res.ok) {
setSent(true);
form.reset();
}
}
if (sent) return <p>Thanks! Your message has been sent.</p>;
return (
<form onSubmit={onSubmit}>
<label htmlFor="name">Full name</label>
<input type="text" name="name" id="name" required />
<label htmlFor="email">Email</label>
<input type="email" name="email" id="email" required />
<label htmlFor="amount">Donation amount</label>
<input type="number" name="amount" id="amount" required />
<label htmlFor="frequency">Frequency</label>
<select name="frequency" id="frequency">
<option value="One-time">One-time</option>
<option value="Monthly">Monthly</option>
<option value="Annually">Annually</option>
</select>
<label>
<input type="checkbox" name="anonymous" id="anonymous" /> Make this donation anonymous
</label>
<label htmlFor="message">Message (optional)</label>
<textarea name="message" id="message" />
<input
type="text"
name="_gotcha"
tabIndex={-1}
autoComplete="off"
style={{ position: "absolute", left: "-9999px" }}
aria-hidden="true"
/>
<button type="submit">Send</button>
</form>
);
}
Use this with Formward
Create a form, copy your endpoint, and replace https://formward.eu/f/your-form-id in the code above.