"use client";
import { useState } from "react";
import { SiteHeader } from "@/components/site-header";
import { Button } from "@/components/ui/button";
import { Input } from "@/components/ui/input";
import { Textarea } from "@/components/ui/textarea";
import { Label } from "@/components/ui/label";
import { Card, CardContent, CardDescription, CardHeader, CardTitle } from "@/components/ui/card";
import { toast } from "sonner";
import { Send, Loader2, Mail } from "lucide-react";
export default function ContactPage() {
const [loading, setLoading] = useState(false);
const handleSubmit = async (e: React.FormEvent<HTMLFormElement>) => {
e.preventDefault();
setLoading(true);
const formData = new FormData(e.currentTarget);
const data = Object.fromEntries(formData.entries());
try {
const res = await fetch("/api/contact", {
method: "POST",
body: JSON.stringify(data),
});
if (!res.ok) throw new Error();
toast.success("Mesajınız gönderildi! En kısa sürede dönüş yapacağız.");
(e.target as HTMLFormElement).reset();
} catch {
toast.error("Bir hata oluştu, lütfen tekrar deneyin.");
} finally {
setLoading(false);
}
};
return (
<div className="min-h-screen flex flex-col">
<SiteHeader />
<main className="flex-1 container max-w-screen-md mx-auto px-4 py-12">
<Card>
<CardHeader>
<CardTitle className="flex items-center gap-2 text-2xl">
<Mail className="h-6 w-6" /> İletişime Geç
</CardTitle>
<CardDescription>
Bir sorunuz mu var veya işbirliği mi yapmak istiyorsunuz? Aşağıdaki formu doldurun.
</CardDescription>
</CardHeader>
<CardContent>
<form onSubmit={handleSubmit} className="space-y-4">
<div className="grid md:grid-cols-2 gap-4">
<div className="space-y-2">
<Label htmlFor="name">Adınız</Label>
<Input id="name" name="name" required placeholder="Ad Soyad" />
</div>
<div className="space-y-2">
<Label htmlFor="email">E-Posta</Label>
<Input id="email" name="email" type="email" required placeholder="mail@ornek.com" />
</div>
</div>
<div className="space-y-2">
<Label htmlFor="subject">Konu</Label>
<Input id="subject" name="subject" placeholder="Mesajınız ne hakkında?" />
</div>
<div className="space-y-2">
<Label htmlFor="content">Mesajınız</Label>
<Textarea id="content" name="content" required placeholder="Bize ne söylemek istersiniz?" rows={5} />
</div>
<Button type="submit" className="w-full" disabled={loading}>
{loading ? <Loader2 className="mr-2 h-4 w-4 animate-spin" /> : <Send className="mr-2 h-4 w-4" />}
Mesajı Gönder
</Button>
</form>
</CardContent>
</Card>
</main>
</div>
);
}
Yorumlar (0)
Henüz yorum yapılmamış. İlk yorumu sen yap!