summaryrefslogtreecommitdiffhomepage
path: root/packages/frontend/src/lib/components/Header.svelte
blob: 72a6ebf8f2fb63cfd20a5f82b37fae415a6edc3f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
<script lang="ts">
import ListIcon from "phosphor-svelte/lib/ListIcon";
import { router } from "../router.svelte.js";
import { wsClient } from "../ws.svelte.js";

const { onToggleSidebar }: { onToggleSidebar: () => void } = $props();
</script>

<header class="navbar bg-base-200 px-4 min-h-14 flex-shrink-0">
	<div class="navbar-start">
		<button class="text-xl font-bold tracking-tight btn btn-ghost px-0" onclick={() => router.navigate("dashboard")}>Dispatch</button>
	</div>
	<div class="navbar-end flex items-center gap-3">
		<span class="flex items-center gap-1.5 text-xs text-base-content/60">
			<span class="status status-sm {wsClient.connectionStatus === 'connected' ? 'status-success' : wsClient.connectionStatus === 'connecting' ? 'status-warning' : 'status-error'}"></span>
			<span class="capitalize">{wsClient.connectionStatus}</span>
		</span>
		<button
			type="button"
			class="btn btn-square btn-sm btn-neutral"
			onclick={onToggleSidebar}
			aria-label="Toggle sidebar"
		>
			<ListIcon size={20} weight="bold" aria-hidden="true" />
		</button>
	</div>
</header>