LogoBlogistan

Yeni nesil blog.

Hızlı Linkler

  • Anasayfa
  • İletişim

Popüler Kategoriler

  • Genel
  • Teknoloji
  • Haber

Bağlantıda Kalın

admin@admin.com

Tüm hakları saklıdır © 2026

Logo
Blogistan
İletişim
Haber

lorem ipsıum test

21 Kasım 2025

•
14
"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>
  );
}

Paylaş:

Yorumlar (0)

Henüz yorum yapılmamış. İlk yorumu sen yap!

Yorum Yap