WorkTracker/Components/Layout/NavMenu.razor

89 lines
3.8 KiB
Text
Raw Normal View History

2026-04-20 14:11:18 +02:00
@using Microsoft.Extensions.Options
@using WorkTracker.Configuration
@inject IOptions<AppAuthOptions> AppAuthOptions
@code {
[Parameter] public bool IsCollapsed { get; set; }
}
<div class="nav-menu-shell @(IsCollapsed ? "nav-menu-shell-collapsed" : string.Empty)" data-testid="sidebar-shell" data-collapsed="@(IsCollapsed ? "true" : "false")">
2026-04-20 14:11:18 +02:00
<div class="top-row ps-3 navbar navbar-dark">
2026-02-18 17:11:13 +01:00
<div class="container-fluid">
<a class="navbar-brand" href="" aria-label="WorkTracker home">
<span class="sidebar-brand-full">WorkTracker</span>
<span class="sidebar-brand-compact" aria-hidden="true">WT</span>
</a>
2026-02-18 17:11:13 +01:00
</div>
</div>
<div class="nav-scrollable">
<nav id="sidebar-navigation" class="nav flex-column" aria-label="Sidebar navigation">
2026-02-18 17:11:13 +01:00
<div class="nav-item px-3">
<NavLink class="nav-link" href="" Match="NavLinkMatch.All" aria-label="Dashboard" title="Dashboard">
<span class="bi bi-house-door-fill-nav-menu" aria-hidden="true"></span>
<span class="nav-label">Dashboard</span>
2026-02-18 17:11:13 +01:00
</NavLink>
</div>
<div class="nav-item px-3">
<NavLink class="nav-link" href="grid" aria-label="Grid View" title="Grid View">
<span class="bi bi-list-nested-nav-menu" aria-hidden="true"></span>
<span class="nav-label">Grid View</span>
</NavLink>
</div>
<div class="nav-item px-3">
<NavLink class="nav-link" href="calendar" aria-label="Calendar" title="Calendar">
<span class="bi bi-calendar3-nav-menu" aria-hidden="true"></span>
<span class="nav-label">Calendar</span>
</NavLink>
</div>
<div class="nav-item px-3">
<NavLink class="nav-link" href="summary" aria-label="Summary" title="Summary">
<span class="bi bi-bar-chart-fill-nav-menu" aria-hidden="true"></span>
<span class="nav-label">Summary</span>
</NavLink>
</div>
2026-02-18 17:11:13 +01:00
<div class="nav-item px-3">
<NavLink class="nav-link" href="settings" aria-label="Settings" title="Settings">
<span class="bi bi-gear-fill-nav-menu" aria-hidden="true"></span>
<span class="nav-label">Settings</span>
2026-02-18 17:11:13 +01:00
</NavLink>
</div>
<AuthorizeView>
<Authorized>
<div class="nav-item px-3">
<NavLink class="nav-link" href="auth" aria-label="@context.User.Identity?.Name" title="@context.User.Identity?.Name">
<span class="bi bi-person-fill-nav-menu" aria-hidden="true"></span>
<span class="nav-label">@context.User.Identity?.Name</span>
2026-02-18 17:11:13 +01:00
</NavLink>
</div>
2026-04-20 14:11:18 +02:00
@if (AppAuthOptions.Value.Enabled)
{
<div class="nav-item px-3">
<form action="/api/logout" method="post">
<button type="submit" class="nav-link" aria-label="Logout" title="Logout">
<span class="bi bi-arrow-bar-left-nav-menu" aria-hidden="true"></span>
<span class="nav-label">Logout</span>
2026-04-20 14:11:18 +02:00
</button>
</form>
</div>
}
2026-02-18 17:11:13 +01:00
</Authorized>
<NotAuthorized>
<div class="nav-item px-3">
<NavLink class="nav-link" href="login" aria-label="Login" title="Login">
<span class="bi bi-person-badge-nav-menu" aria-hidden="true"></span>
<span class="nav-label">Login</span>
2026-02-18 17:11:13 +01:00
</NavLink>
</div>
</NotAuthorized>
</AuthorizeView>
</nav>
</div>
</div>
2026-02-18 17:11:13 +01:00