-
-
-
Bezeichnung
-
Startdatum
-
Enddatum
-
Aktionen
-
+
+ Praktikumszeiträume verwalten - Admin
+
-
- {#each zeitraeume as d}
-
-
{d.bezeichnung}
-
{new Date(d.startDatum).toLocaleDateString('de-DE', { day: '2-digit', month: '2-digit', year: 'numeric' })}
-
{new Date(d.endDatum).toLocaleDateString('de-DE', { day: '2-digit', month: '2-digit', year: 'numeric' })}
-
-
{
- neuerBezeichnung = d.bezeichnung;
- //neuerstartDatum = d.startDatum;
- neuerstartDatum = d.startDatum ? d.startDatum.slice(0, 10) : '';
- neuerendDatum = d.endDatum ? d.endDatum.slice(0, 10) : '';
- bearbeiteId = d.id;
- }}
- class="text-blue-600 hover:underline"
- >
- Bearbeiten
-
-
loeschen(d.id)}
- class="text-red-600 hover:underline"
- >
- Löschen
-
+
+
+
+
+ {#if fehlermeldung}
+
+
+
+
+
Fehler
+
{fehlermeldung}
- {/each}
+
+ {/if}
+
+
+
+
+ {bearbeiteId !== null ? 'Praktikumszeitraum bearbeiten' : 'Neuen Praktikumszeitraum hinzufügen'}
+
+
+
+
+
+ Bezeichnung
+
+
+
+
+
+
+ Startdatum
+
+
+
+
+
+
+ Enddatum
+
+
+
+
+
+
+ Zurücksetzen
+
+
+ {bearbeiteId !== null ? 'Ändern' : 'Hinzufügen'}
+
+
+
-
-
-
- {
- await fetch('/api/admin/logout', { method: 'POST' });
- location.reload();
- }}
- class="bg-red-600 hover:bg-red-700 text-white px-6 py-2 rounded"
- >
- Logout
-
-
-
-
-
\ No newline at end of file
+ {#if isLoading}
+
+
+
Lade Praktikumszeiträume...
+
+ {:else if zeitraeume.length === 0}
+
+
+
+
+
Keine Praktikumszeiträume
+
Erstellen Sie Ihren ersten Praktikumszeitraum über das Formular oben.
+
+ {:else}
+
+
+
Alle Praktikumszeiträume
+
+
+
+
+
+
+
+ Bezeichnung
+
+
+ Startdatum
+
+
+ Enddatum
+
+
+ Aktionen
+
+
+
+
+ {#each zeitraeume as d}
+
+
+ {d.bezeichnung}
+
+
+ {new Date(d.startDatum).toLocaleDateString('de-DE', {
+ day: '2-digit',
+ month: '2-digit',
+ year: 'numeric'
+ })}
+
+
+ {new Date(d.endDatum).toLocaleDateString('de-DE', {
+ day: '2-digit',
+ month: '2-digit',
+ year: 'numeric'
+ })}
+
+
+ bearbeiten(d)}
+ class="text-blue-600 hover:text-blue-900 mr-4"
+ >
+ Bearbeiten
+
+ loeschen(d.id)}
+ class="text-red-600 hover:text-red-900"
+ >
+ Löschen
+
+
+
+ {/each}
+
+
+
+
+ {/if}
+
+
\ No newline at end of file
diff --git a/src/routes/api/admin/zeitraeume/+server.ts b/src/routes/api/admin/zeitraeume/+server.ts
index a0560db..145f75c 100644
--- a/src/routes/api/admin/zeitraeume/+server.ts
+++ b/src/routes/api/admin/zeitraeume/+server.ts
@@ -6,8 +6,9 @@ const prisma = new PrismaClient();
import type { Cookies } from '@sveltejs/kit';
+// Korrigierte Auth-Funktion mit neuem Cookie-Namen
function checkAuth(cookies: Cookies) {
- return cookies.get('admin_session') === 'true';
+ return cookies.get('admin-auth') === 'authenticated';
}
function isValidDate(date: string | Date) {
@@ -16,73 +17,144 @@ function isValidDate(date: string | Date) {
}
export const GET: RequestHandler = async ({ cookies }) => {
- if (!checkAuth(cookies)) return new Response('Nicht erlaubt', { status: 401 });
- const zeitraeume = await prisma.praktikumszeitraum.findMany();
- return json(zeitraeume);
+ if (!checkAuth(cookies)) {
+ return new Response(
+ JSON.stringify({ error: 'Nicht autorisiert' }),
+ {
+ status: 401,
+ headers: { 'Content-Type': 'application/json' }
+ }
+ );
+ }
+
+ try {
+ const zeitraeume = await prisma.praktikumszeitraum.findMany();
+ return json(zeitraeume);
+ } catch (error) {
+ console.error('Fehler beim Laden der Praktikumszeiträume:', error);
+ return json({ error: 'Fehler beim Laden der Praktikumszeiträume' }, { status: 500 });
+ }
};
export const POST: RequestHandler = async ({ cookies, request }) => {
- if (!checkAuth(cookies)) return new Response('Nicht erlaubt', { status: 401 });
- const { bezeichnung, startDatum, endDatum } = await request.json();
- if (!isValidDate(startDatum) || !isValidDate(endDatum)) {
- return json({ error: 'Ungültige Datum' }, { status: 400 });
+ if (!checkAuth(cookies)) {
+ return json({ error: 'Nicht autorisiert' }, { status: 401 });
}
+
try {
- const created = await prisma.praktikumszeitraum.create({ data: {
- bezeichnung,
- startDatum: new Date(startDatum),
- endDatum: new Date(endDatum)
- } });
- return json(created);
- } catch (e) {
- console.error('Fehler beim Hinzufuegen:', e);
- return json({ error: 'Zeitraum existiert bereits' }, { status: 400 });
+ const { bezeichnung, startDatum, endDatum } = await request.json();
+
+ // Validierung
+ if (!bezeichnung || typeof bezeichnung !== 'string' || bezeichnung.trim().length === 0) {
+ return json({ error: 'Bezeichnung ist erforderlich' }, { status: 400 });
+ }
+
+ if (!isValidDate(startDatum) || !isValidDate(endDatum)) {
+ return json({ error: 'Ungültiges Datum' }, { status: 400 });
+ }
+
+ const created = await prisma.praktikumszeitraum.create({
+ data: {
+ bezeichnung: bezeichnung.trim(),
+ startDatum: new Date(startDatum),
+ endDatum: new Date(endDatum)
+ }
+ });
+ return json(created, { status: 201 });
+ } catch (error) {
+ console.error('Fehler beim Erstellen des Praktikumszeitraums:', error);
+ return json({ error: 'Fehler beim Erstellen des Praktikumszeitraums' }, { status: 500 });
}
};
export const PATCH: RequestHandler = async ({ cookies, request }) => {
- if (!checkAuth(cookies)) return new Response('Nicht erlaubt', { status: 401 });
-
- const { id, bezeichnung, startDatum, endDatum } = await request.json();
-
- if (typeof id !== 'number' || isNaN(id) || !bezeichnung || !isValidDate(startDatum) || !isValidDate(endDatum)) {
- return json({ error: 'Ungültige Eingabedaten' }, { status: 400 });
- }
-
- const existing = await prisma.praktikumszeitraum.findUnique({ where: { id } });
- if (!existing) {
- return json({ error: 'Zeitraum nicht gefunden' }, { status: 404 });
- }
-
- const konflikt = await prisma.praktikumszeitraum.findFirst({
- where: {
- bezeichnung,
- NOT: { id },
- },
- });
- if (konflikt) {
- return json({ error: 'Eine andere Praktikumszeitraum mit diesem Namen existiert bereits' }, { status: 400 });
+ if (!checkAuth(cookies)) {
+ return json({ error: 'Nicht autorisiert' }, { status: 401 });
}
try {
+ const { id, bezeichnung, startDatum, endDatum } = await request.json();
+
+ // Validierung
+ if (typeof id !== 'number' || isNaN(id)) {
+ return json({ error: 'Ungültige ID' }, { status: 400 });
+ }
+
+ if (!bezeichnung || typeof bezeichnung !== 'string' || bezeichnung.trim().length === 0) {
+ return json({ error: 'Bezeichnung ist erforderlich' }, { status: 400 });
+ }
+
+ if (!isValidDate(startDatum) || !isValidDate(endDatum)) {
+ return json({ error: 'Ungültiges Datum' }, { status: 400 });
+ }
+
+ // Prüfe ob Praktikumszeitraum existiert
+ const existing = await prisma.praktikumszeitraum.findUnique({ where: { id } });
+ if (!existing) {
+ return json({ error: 'Praktikumszeitraum nicht gefunden' }, { status: 404 });
+ }
+
+ // Prüfe ob neue Bezeichnung bereits bei anderem Zeitraum existiert
+ const konflikt = await prisma.praktikumszeitraum.findFirst({
+ where: {
+ bezeichnung: bezeichnung.trim(),
+ NOT: { id },
+ },
+ });
+
+ if (konflikt) {
+ return json({ error: 'Ein anderer Praktikumszeitraum mit dieser Bezeichnung existiert bereits' }, { status: 400 });
+ }
+
const updated = await prisma.praktikumszeitraum.update({
where: { id },
data: {
- bezeichnung,
+ bezeichnung: bezeichnung.trim(),
startDatum: new Date(startDatum),
endDatum: new Date(endDatum)
},
});
+
return json(updated);
- } catch (e) {
- console.error('Fehler beim Update:', e);
- return json({ error: 'Update fehlgeschlagen' }, { status: 400 });
+ } catch (error) {
+ console.error('Fehler beim Aktualisieren des Praktikumszeitraums:', error);
+ return json({ error: 'Fehler beim Aktualisieren des Praktikumszeitraums' }, { status: 500 });
}
};
export const DELETE: RequestHandler = async ({ cookies, url }) => {
- if (!checkAuth(cookies)) return new Response('Nicht erlaubt', { status: 401 });
+ if (!checkAuth(cookies)) {
+ return json({ error: 'Nicht autorisiert' }, { status: 401 });
+ }
+
const id = Number(url.searchParams.get('id'));
- await prisma.praktikumszeitraum.delete({ where: { id } });
- return json({ success: true });
+
+ if (isNaN(id)) {
+ return json({ error: 'Ungültige ID' }, { status: 400 });
+ }
+
+ try {
+ // Prüfe ob Praktikumszeitraum existiert
+ const existing = await prisma.praktikumszeitraum.findUnique({ where: { id } });
+ if (!existing) {
+ return json({ error: 'Praktikumszeitraum nicht gefunden' }, { status: 404 });
+ }
+
+ // Hier könntest du prüfen, ob noch Anmeldungen mit diesem Zeitraum verknüpft sind
+ // const assignedCount = await prisma.anmeldung.count({
+ // where: { praktikumszeitraumId: id }
+ // });
+ //
+ // if (assignedCount > 0) {
+ // return json({
+ // error: 'Praktikumszeitraum kann nicht gelöscht werden. Es sind noch Anmeldungen damit verknüpft.'
+ // }, { status: 400 });
+ // }
+
+ await prisma.praktikumszeitraum.delete({ where: { id } });
+ return json({ success: true, message: 'Praktikumszeitraum erfolgreich gelöscht' });
+ } catch (error) {
+ console.error('Fehler beim Löschen des Praktikumszeitraums:', error);
+ return json({ error: 'Fehler beim Löschen des Praktikumszeitraums' }, { status: 500 });
+ }
};
\ No newline at end of file