Files
AnnasRechnungsManager/app/routes/companies.new.tsx
T
hwinkel 38c8304336
Build and Push Docker Image / build (push) Successful in 1m23s
feat: update AUTH_SECRET handling and improve session management
fix: add credentials to POST request in NewCompanyPage
fix: update Docker image pull policy for app service
2026-05-03 09:24:41 +02:00

59 lines
1.5 KiB
TypeScript

import { Link, useNavigate } from "react-router";
export const handle = {
breadcrumbs: () => [
{ label: "Mandanten", href: "/companies" },
{ label: "Neuer Mandant" },
],
};
import { CompanyForm } from "@/components/company/company-form";
import { Card, CardContent, CardHeader, CardTitle } from "@/components/ui/card";
import { ChevronLeft } from "lucide-react";
export default function NewCompanyPage() {
const navigate = useNavigate();
async function handleSubmit(data: Record<string, unknown>) {
const res = await fetch("/api/companies", {
method: "POST",
headers: { "Content-Type": "application/json" },
body: JSON.stringify(data),
credentials: "include",
});
if (res.ok) {
const company = await res.json();
navigate(`/companies/${company.id}`);
}
}
return (
<div>
<Link
to="/companies"
className="inline-flex items-center gap-1 text-sm text-gray-500 hover:text-gray-700 mb-6"
>
<ChevronLeft className="h-4 w-4" /> Zurück zu Mandanten
</Link>
<div className="mb-8">
<h1 className="text-2xl font-bold text-gray-900">Neuer Mandant</h1>
<p className="text-gray-500 mt-1">Legen Sie einen neuen Mandanten an</p>
</div>
<Card>
<CardHeader>
<CardTitle>Mandantendaten</CardTitle>
</CardHeader>
<CardContent>
<CompanyForm
onSubmit={handleSubmit}
submitLabel="Mandant anlegen"
/>
</CardContent>
</Card>
</div>
);
}