Files
Sveltey/src/lib/components/Header.svelte
2025-06-02 21:22:35 -05:00

105 lines
3.6 KiB
Svelte

<script lang="ts">
import { page } from '$app/state';
import SvelteyLogoLetter from '$lib/assets/Sveltey-logo-letter.svelte';
import ThemeSwitch from '$lib/components/ThemeSwitch.svelte';
import { BookOpen, DollarSign, Home, LayoutDashboard, LogOut, User } from '@lucide/svelte';
import { Avatar } from '@skeletonlabs/skeleton-svelte';
let { data } = $props();
let { session } = $derived(data);
// Helper function to check if a path is active
function isActivePath(path: string): boolean {
return page.url.pathname === path;
}
// Helper function to get navigation link classes
function getNavClasses(path: string): string {
return `btn btn-sm flex items-center gap-2 ${page.url.pathname === path ? 'cursor-default disabled' : ''}`;
}
</script>
<header
class="bg-surface-50-950-token border-surface-200-700-token sticky top-0 z-50 border-b backdrop-blur-2xl"
>
<nav class="container mx-auto px-6 py-4">
<div class="flex items-center justify-between">
<!-- Left side - Brand and Main navigation -->
<div class="flex items-center gap-8">
<!-- Brand -->
<a href="/" class="flex items-center gap-2" aria-label="Sveltey - Go to homepage">
<SvelteyLogoLetter size="size-8" />
<span class="hidden font-bold sm:block">Sveltey</span>
</a>
<!-- Main Navigation -->
<div class="hidden items-center gap-2 md:flex">
<a href="/" class={getNavClasses('/')} aria-label="Go to homepage">
<Home class="size-4" aria-hidden="true" />
<span>Home</span>
</a>
<a href="/pricing" class={getNavClasses('/pricing')} aria-label="View pricing plans">
<DollarSign class="size-4" aria-hidden="true" />
<span>Pricing</span>
</a>
<a href="/blog" class={getNavClasses('/blog')} aria-label="Read our blog">
<BookOpen class="size-4" aria-hidden="true" />
<span>Blog</span>
</a>
{#if session}
<a href="/app/dashboard" class={getNavClasses('/app/dashboard')} aria-label="Go to dashboard">
<LayoutDashboard class="size-4" aria-hidden="true" />
<span>Dashboard</span>
</a>
{/if}
</div>
</div>
<!-- Right side - User actions and theme switcher -->
<div class="flex gap-1 sm:gap-3">
<ThemeSwitch />
{#if session}
<!-- User Profile Section -->
<div class="border-surface-300-600 flex items-center gap-3 border-l pl-3">
<Avatar
size="size-8"
src={session.user.user_metadata.avatar_url}
name={session.user.user_metadata.full_name || session.user.email}
/>
<div class="hidden md:block">
<p class="text-sm font-medium">
{session.user.user_metadata.full_name || session.user.email?.split('@')[0]}
</p>
<p class="text-xs opacity-75">{session.user.email}</p>
</div>
<form action="/auth/logout" method="POST" style="display: inline;">
<button
type="submit"
class="btn flex items-center gap-2"
title="Sign Out"
aria-label="Sign out of your account"
>
<LogOut class="size-4" aria-hidden="true" />
<span class="hidden sm:inline">Sign Out</span>
</button>
</form>
</div>
{:else}
<!-- Authentication Buttons -->
<div class="flex items-center gap-1 sm:gap-3">
<a href="/auth" class={getNavClasses('/auth')} aria-label="Sign in or register">
<User class="size-4" aria-hidden="true" />
<span class="hidden sm:inline">Sign In / Register</span>
</a>
</div>
{/if}
</div>
</div>
</nav>
</header>