mirror of
https://github.com/LukeHagar/Sveltey.git
synced 2025-12-07 20:57:46 +00:00
Theming, A11y, added resend, formatting
This commit is contained in:
104
src/lib/components/Header.svelte
Normal file
104
src/lib/components/Header.svelte
Normal file
@@ -0,0 +1,104 @@
|
||||
<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-12" />
|
||||
<span class="hidden text-xl 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-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-3">
|
||||
<a href="/auth" class={getNavClasses('/auth')} aria-label="Sign in or register">
|
||||
<User class="size-4" aria-hidden="true" />
|
||||
<span>Sign In / Register</span>
|
||||
</a>
|
||||
</div>
|
||||
{/if}
|
||||
</div>
|
||||
</div>
|
||||
</nav>
|
||||
</header>
|
||||
Reference in New Issue
Block a user