feat: add financial transactions management for companies

- Implemented a new route for managing financial transactions (money) for companies, including creating, editing, and deleting transactions.
- Added a new model `Buchung` to represent transactions with fields for date, account type, transaction type, amount, and description.
- Updated the `companies` model to include a relation to the new `Buchung` model.
- Enhanced the company overview page to link to the new financial transactions page.
- Added migration scripts to create the necessary database tables and fields for the new functionality.
- Created utility scripts for resetting the admin password and setting up the initial admin user.
This commit is contained in:
hwinkel
2026-03-24 19:25:48 +01:00
parent 6d8c4b615f
commit d582c748a2
29 changed files with 2464 additions and 815 deletions
+11 -1
View File
@@ -7,6 +7,8 @@ const createSchema = z.object({
companyId: z.string().min(1),
kategorie: z.nativeEnum(EinnahmeKategorie),
betrag: z.number().positive(),
steuersatz: z.number().min(0).default(0),
zahlungsart: z.enum(["KASSE", "BANK"]).default("BANK"),
datum: z.string().min(1),
beschreibung: z.string().optional(),
});
@@ -52,6 +54,7 @@ export async function loader({ request }: { request: Request }) {
einnahmen.map((e) => ({
...e,
betrag: Number(e.betrag),
steuersatz: Number(e.steuersatz),
datum: e.datum.toISOString(),
}))
);
@@ -93,13 +96,20 @@ export async function action({ request }: { request: Request }) {
companyId: parsed.data.companyId,
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,
},
});
return Response.json(
{ ...einnahme, betrag: Number(einnahme.betrag), datum: einnahme.datum.toISOString() },
{
...einnahme,
betrag: Number(einnahme.betrag),
steuersatz: Number(einnahme.steuersatz),
datum: einnahme.datum.toISOString(),
},
{ status: 201 }
);
}