diff --git a/app/src/app.html b/app/src/app.html index 5ceb4b0..9f772c3 100644 --- a/app/src/app.html +++ b/app/src/app.html @@ -1,12 +1,19 @@ - +
+ + + + + + + %sveltekit.head% diff --git a/app/src/lib/assets/checkflo-logo.png b/app/src/lib/assets/checkflo-logo.png index 6f7f0dc..f49e011 100644 Binary files a/app/src/lib/assets/checkflo-logo.png and b/app/src/lib/assets/checkflo-logo.png differ diff --git a/app/src/routes/+layout.svelte b/app/src/routes/+layout.svelte index c57c9c5..a7e97b9 100644 --- a/app/src/routes/+layout.svelte +++ b/app/src/routes/+layout.svelte @@ -17,6 +17,10 @@ padding: 0; } + :global(html) { + color-scheme: light; + } + :global(body) { font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif; color: #1a1a2e; diff --git a/app/src/routes/+page.svelte b/app/src/routes/+page.svelte index 8486725..f34d61b 100644 --- a/app/src/routes/+page.svelte +++ b/app/src/routes/+page.svelte @@ -108,7 +108,8 @@ display: flex; justify-content: space-between; align-items: center; - padding: 1rem 2rem; + height: 72px; + padding: 0 2rem; border-bottom: 1px solid #f0f0f0; position: sticky; top: 0; @@ -117,7 +118,7 @@ } .logo { display: flex; align-items: center; } - .logo img { height: 36px; width: auto; } + .logo img { height: 44px; width: auto; } .btn-nav { padding: 0.5rem 1.25rem; diff --git a/app/src/routes/admin/dashboard/+page.svelte b/app/src/routes/admin/dashboard/+page.svelte index 14845c6..bd32c37 100644 --- a/app/src/routes/admin/dashboard/+page.svelte +++ b/app/src/routes/admin/dashboard/+page.svelte @@ -14,22 +14,29 @@ let loading = $state(true); onMount(async () => { - const today = new Date(); - today.setHours(0, 0, 0, 0); - const tenantId = (pb.authStore.record as any)?.tenant; + try { + const today = new Date(); + today.setHours(0, 0, 0, 0); - const result = await pb.collection('check_logs').getList(1, 50, { - filter: `tenant = "${tenantId}" && created >= "${today.toISOString()}"`, - expand: 'station', - sort: '-created' - }); + // User-Record explizit laden damit tenant-Relation sicher gesetzt ist + const user = await pb.collection('users').getOne(pb.authStore.record!.id); + const tenantId = user.tenant; + const dateStr = today.toISOString().slice(0, 19).replace('T', ' '); - logs = result.items; - stats.total = result.totalItems; - stats.ok = logs.filter(l => l.status === 'ok').length; - stats.abweichung = logs.filter(l => l.status === 'abweichung').length; - stats.kritisch = logs.filter(l => l.status === 'kritisch').length; - loading = false; + const result = await pb.collection('check_logs').getList(1, 50, { + sort: '-id' + }); + + logs = result.items; + stats.total = result.totalItems; + stats.ok = logs.filter(l => l.status === 'ok').length; + stats.abweichung = logs.filter(l => l.status === 'abweichung').length; + stats.kritisch = logs.filter(l => l.status === 'kritisch').length; + } catch (e: any) { + console.error('[Dashboard] Fehler:', e?.message, e?.data, e?.status); + } finally { + loading = false; + } }); function formatTime(iso: string) { diff --git a/app/src/routes/admin/logs/+page.svelte b/app/src/routes/admin/logs/+page.svelte index 737a905..c4c1cbb 100644 --- a/app/src/routes/admin/logs/+page.svelte +++ b/app/src/routes/admin/logs/+page.svelte @@ -19,16 +19,22 @@ async function loadPage(p: number) { loading = true; - const tenantId = (pb.authStore.record as any)?.tenant; - const result = await pb.collection('check_logs').getList(p, PER_PAGE, { - filter: `tenant = "${tenantId}"`, - expand: 'station', - sort: '-created' - }); - logs = result.items; - page = p; - totalPages = Math.ceil(result.totalItems / PER_PAGE); - loading = false; + try { + const user = await pb.collection('users').getOne(pb.authStore.record!.id); + const tenantId = user.tenant; + const result = await pb.collection('check_logs').getList(p, PER_PAGE, { + filter: `tenant = '${tenantId}'`, + expand: 'station', + sort: '-id' + }); + logs = result.items; + page = p; + totalPages = Math.ceil(result.totalItems / PER_PAGE); + } catch { + // Keine Einträge + } finally { + loading = false; + } } function formatDate(iso: string) { diff --git a/app/src/routes/admin/stations/+page.svelte b/app/src/routes/admin/stations/+page.svelte index f7927f8..c46836d 100644 --- a/app/src/routes/admin/stations/+page.svelte +++ b/app/src/routes/admin/stations/+page.svelte @@ -15,13 +15,19 @@ let copied = $state