2022-01-20 08:34:38 +00:00
|
|
|
@using Wabbajack.App.Blazor.Pages
|
|
|
|
@using Wabbajack.App.Blazor.Shared
|
|
|
|
@using Wabbajack.App.Blazor.State
|
|
|
|
|
|
|
|
@namespace Wabbajack.App.Blazor.Components
|
|
|
|
|
|
|
|
@* TODO: [Low] Clean this up a bit. *@
|
2022-01-17 16:45:52 +00:00
|
|
|
<header id="top-bar">
|
2022-01-20 08:34:38 +00:00
|
|
|
<nav class="@(GlobalState.NavigationAllowed ? "" : "disallow")">
|
2022-01-11 03:00:54 +00:00
|
|
|
<ul>
|
|
|
|
<li>
|
2022-01-20 08:34:38 +00:00
|
|
|
<div class='item @CurrentPage("")' @onclick='() => Navigate("")'>Play</div>
|
2022-01-11 03:00:54 +00:00
|
|
|
</li>
|
|
|
|
<li>
|
2022-01-20 08:34:38 +00:00
|
|
|
<div class='item @CurrentPage("Gallery")' @onclick='() => Navigate("Gallery")'>Gallery</div>
|
2022-01-11 03:00:54 +00:00
|
|
|
</li>
|
|
|
|
<li>
|
2022-01-20 08:34:38 +00:00
|
|
|
<div class='item @CurrentPage("Install")' @onclick='() => Navigate("Install")'>Install</div>
|
2022-01-11 03:00:54 +00:00
|
|
|
</li>
|
|
|
|
<li>
|
2022-01-20 08:34:38 +00:00
|
|
|
<div class='item @CurrentPage("Create")' @onclick='() => Navigate("Create")'>Create</div>
|
2022-01-11 03:00:54 +00:00
|
|
|
</li>
|
|
|
|
</ul>
|
|
|
|
</nav>
|
2022-01-20 08:34:38 +00:00
|
|
|
<div class="settings">
|
|
|
|
<InteractionIcon Icon="images/icons/adjust.svg" Label="Settings" Size="100%" OnClick="@(() => Navigate("Settings"))"/>
|
|
|
|
</div>
|
2022-01-17 16:45:52 +00:00
|
|
|
</header>
|
2022-01-20 08:34:38 +00:00
|
|
|
|
|
|
|
@code {
|
|
|
|
|
|
|
|
[Inject]
|
|
|
|
NavigationManager _navigationManager { get; set; }
|
|
|
|
|
|
|
|
[Inject]
|
|
|
|
GlobalState GlobalState { get; set; }
|
|
|
|
|
|
|
|
[CascadingParameter]
|
|
|
|
protected MainLayout _mainLayout { get; set; }
|
|
|
|
|
|
|
|
private void Navigate(string page)
|
|
|
|
{
|
|
|
|
_navigationManager.NavigateTo(page);
|
|
|
|
}
|
|
|
|
|
|
|
|
protected override void OnInitialized()
|
|
|
|
{
|
|
|
|
_navigationManager.LocationChanged += (o, args) => StateHasChanged();
|
|
|
|
GlobalState.OnNavigationStateChange += StateHasChanged;
|
|
|
|
}
|
|
|
|
|
|
|
|
private string CurrentPage(string page)
|
|
|
|
{
|
|
|
|
string relativePath = _navigationManager.ToBaseRelativePath(_navigationManager.Uri).ToLower();
|
|
|
|
return page.ToLower() == relativePath ? "active" : "";
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|