Files
engel/app/[locale]/contact/page.js
2026-04-21 07:37:18 +03:30

50 lines
2.0 KiB
JavaScript

import Link from "next/link";
import { notFound } from "next/navigation";
import { getLandingContent, isSupportedLocale, locales } from "@/lib/site-data";
export function generateStaticParams() {
return locales.map((locale) => ({ locale }));
}
export default async function ContactPage({ params }) {
const { locale } = await params;
if (!isSupportedLocale(locale)) {
notFound();
}
const { contact, shared } = getLandingContent(locale);
return (
<main className="min-h-screen bg-brand-light text-gray-800">
<section className="mx-auto max-w-5xl px-6 py-16">
<Link href={`/${locale}`} className="text-sm font-semibold text-brand-purple">
{locale === "de" ? "Startseite" : "Home"}
</Link>
<div className="mt-6 grid gap-10 md:grid-cols-2">
<div>
<h1 className="text-4xl font-bold text-brand-dark">{shared.contactTitle}</h1>
<p className="mt-4 text-gray-600">{shared.contactIntro}</p>
<div className="mt-8 space-y-4 text-gray-700">
<p>{contact.location}</p>
<p>{contact.phone}</p>
<p>{contact.email}</p>
</div>
</div>
<form className="rounded-3xl bg-white p-8 shadow-sm ring-1 ring-gray-100">
<div className="grid gap-4">
<input className="rounded-xl border border-gray-200 px-4 py-3" placeholder={shared.nameLabel} />
<input className="rounded-xl border border-gray-200 px-4 py-3" placeholder={shared.emailLabel} />
<input className="rounded-xl border border-gray-200 px-4 py-3" placeholder={shared.phoneLabel} />
<textarea className="min-h-36 rounded-xl border border-gray-200 px-4 py-3" placeholder={shared.messageLabel} />
<button className="rounded-xl bg-brand-purple px-5 py-3 font-bold text-white transition hover:bg-purple-700">
{shared.sendMessage}
</button>
</div>
</form>
</div>
</section>
</main>
);
}