Refactor financial transaction handling: Consolidate Einnahmen and Ausgaben into Buchung model, update routes and UI components, and add new migration scripts for database schema changes.

This commit is contained in:
hwinkel
2026-03-24 21:06:07 +01:00
parent d582c748a2
commit 1ec15600b5
18 changed files with 928 additions and 358 deletions
+17 -15
View File
@@ -1,11 +1,10 @@
import { getApiUser } from "@/session.server";
import prisma from "@/lib/prisma.server";
import { z } from "zod";
import { AusgabeKategorie } from "@prisma/client";
const createSchema = z.object({
companyId: z.string().min(1),
kategorie: z.nativeEnum(AusgabeKategorie),
kategorie: z.string().min(1),
betrag: z.number().positive(),
steuersatz: z.number().min(0).default(0),
zahlungsart: z.enum(["KASSE", "BANK"]).default("BANK"),
@@ -26,25 +25,26 @@ export async function loader({ request }: { request: Request }) {
const company = await prisma.company.findFirst({ where: { id: companyId, userId: user.id } });
if (!company) return Response.json({ error: "Not found" }, { status: 404 });
const ausgaben = await prisma.betriebsausgabe.findMany({
const ausgaben = await prisma.buchung.findMany({
where: {
companyId,
type: "ENTNAHME",
isBusinessRecord: true,
...(year ? {
datum: {
date: {
gte: new Date(`${year}-01-01`),
lt: new Date(`${year + 1}-01-01`),
},
} : {}),
},
orderBy: { datum: "desc" },
orderBy: { date: "desc" },
});
return Response.json(
ausgaben.map((a) => ({
...a,
betrag: Number(a.betrag),
steuersatz: Number(a.steuersatz),
datum: a.datum.toISOString(),
amount: Number(a.amount),
date: a.date.toISOString(),
}))
);
}
@@ -62,22 +62,24 @@ export async function action({ request }: { request: Request }) {
});
if (!company) return Response.json({ error: "Company not found" }, { status: 404 });
const ausgabe = await prisma.betriebsausgabe.create({
const ausgabe = await prisma.buchung.create({
data: {
companyId: parsed.data.companyId,
account: parsed.data.zahlungsart === "KASSE" ? "KASSE" : "BANK",
type: "ENTNAHME",
amount: parsed.data.betrag,
date: new Date(parsed.data.datum),
description: parsed.data.beschreibung,
kategorie: parsed.data.kategorie,
betrag: parsed.data.betrag,
steuersatz: parsed.data.steuersatz,
zahlungsart: parsed.data.zahlungsart,
datum: new Date(parsed.data.datum),
beschreibung: parsed.data.beschreibung,
isBusinessRecord: true,
},
});
return Response.json({
...ausgabe,
betrag: Number(ausgabe.betrag),
steuersatz: Number(ausgabe.steuersatz),
datum: ausgabe.datum.toISOString(),
amount: Number(ausgabe.amount),
date: ausgabe.date.toISOString(),
}, { status: 201 });
}