2023-11-12 17:56:57 +00:00
|
|
|
@page "/Users/{baid:int}/AccessCode"
|
|
|
|
@inject HttpClient Client
|
|
|
|
@inject IDialogService DialogService
|
2024-05-16 23:32:46 +01:00
|
|
|
@inject AuthService AuthService
|
2023-11-12 17:56:57 +00:00
|
|
|
@inject NavigationManager NavigationManager
|
2024-05-16 23:32:46 +01:00
|
|
|
@inject Utilities.StringUtil StringUtil;
|
2023-11-12 17:56:57 +00:00
|
|
|
|
2024-05-16 23:32:46 +01:00
|
|
|
@if (AuthService.LoginRequired && (!AuthService.IsLoggedIn || (AuthService.GetLoggedInBaid() != Baid && !AuthService.IsAdmin))) {
|
|
|
|
NavigationManager.NavigateTo(!AuthService.IsLoggedIn ? "/Login" : "/");
|
|
|
|
} else if (User is null) {
|
|
|
|
// Loading ...
|
|
|
|
<MudContainer Style="display:flex;margin:50px 0;align-items:center;justify-content:center;">
|
|
|
|
<MudProgressCircular Indeterminate="true" Size="Size.Large" Color="Color.Primary" />
|
|
|
|
</MudContainer>
|
|
|
|
} else {
|
|
|
|
<MudBreadcrumbs Items="breadcrumbs" Class="p-0 mb-2"></MudBreadcrumbs>
|
|
|
|
<MudText Typo="Typo.h4">@Localizer["Access Codes"]</MudText>
|
|
|
|
<MudGrid Class="my-4 pb-10">
|
|
|
|
<MudItem xs="12">
|
|
|
|
<MudCard Outlined="true" Class="mb-6">
|
|
|
|
<MudCardContent>
|
|
|
|
<MudGrid Spacing="3">
|
|
|
|
<MudItem xs="12">
|
|
|
|
<MudText Typo="Typo.h6">@Localizer["Add Access Code"]</MudText>
|
|
|
|
<MudForm @ref="bindAccessCodeForm">
|
|
|
|
<MudGrid Spacing="2" Class="mt-4">
|
|
|
|
<MudItem xs="12" md="10">
|
|
|
|
<MudTextField @bind-value="inputAccessCode" InputType="InputType.Text" T="string"
|
|
|
|
FullWidth="true" Required="@true" RequiredError="Access Code is required" Variant="Variant.Outlined" Margin="Margin.Dense"
|
|
|
|
Label=@Localizer["New Access Code"] />
|
|
|
|
</MudItem>
|
|
|
|
<MudItem xs="12" md="2">
|
|
|
|
<MudButton OnClick="OnBind" FullWidth="true" StartIcon="@Icons.Material.Filled.AddCard" Color="Color.Primary" Variant="Variant.Filled" Class="mt-1">@Localizer["Add"]</MudButton>
|
|
|
|
</MudItem>
|
|
|
|
</MudGrid>
|
|
|
|
</MudForm>
|
|
|
|
</MudItem>
|
|
|
|
</MudGrid>
|
|
|
|
</MudCardContent>
|
|
|
|
</MudCard>
|
|
|
|
|
|
|
|
<MudCard Outlined="true">
|
|
|
|
<MudCardContent>
|
|
|
|
<MudGrid Spacing="3" Class="pb-2">
|
|
|
|
<MudItem xs="12">
|
|
|
|
<MudText Typo="Typo.h6">@Localizer["Access Code"]</MudText>
|
|
|
|
</MudItem>
|
|
|
|
@for (var idx = 0; idx < User.AccessCodes.Count; idx++)
|
|
|
|
{
|
|
|
|
var accessCode = User.AccessCodes[idx];
|
|
|
|
var localIdx = idx + 1;
|
|
|
|
<MudItem xs="12" Class="py-0">
|
|
|
|
<div Style="border-bottom:1px solid #eee; padding: 5px 0;">
|
|
|
|
<MudGrid Spacing="2" Class="d-flex align-center">
|
|
|
|
<MudItem xs="12" md="8" Class="d-flex align-center">
|
|
|
|
<pre class="mb-0" style="font-size:16px">
|
2024-08-09 15:46:55 +02:00
|
|
|
@if (accessCode.Length % 4 == 0 && StringUtil.OnlyHexInString(accessCode))
|
2024-05-16 23:32:46 +01:00
|
|
|
{
|
2024-08-09 15:46:55 +02:00
|
|
|
foreach (var digitGroup in StringUtil.SplitIntoGroups(accessCode, 4))
|
|
|
|
{
|
|
|
|
<span class="mr-2">@digitGroup</span>
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
<span class="mr-2">@accessCode</span>
|
2024-05-16 23:32:46 +01:00
|
|
|
}
|
|
|
|
</pre>
|
2024-03-08 11:44:16 -05:00
|
|
|
</MudItem>
|
2024-05-16 23:32:46 +01:00
|
|
|
<MudItem xs="12" md="4" Class="d-flex justify-end">
|
|
|
|
<MudButton OnClick="@(_ => DeleteAccessCode(accessCode))"
|
|
|
|
Size="Size.Small" Variant="Variant.Text" StartIcon="@Icons.Material.Filled.Delete"
|
|
|
|
Color="Color.Error">
|
|
|
|
@Localizer["Delete"]
|
|
|
|
</MudButton>
|
2024-03-08 11:44:16 -05:00
|
|
|
</MudItem>
|
2024-03-09 14:13:56 -05:00
|
|
|
</MudGrid>
|
2024-05-16 23:32:46 +01:00
|
|
|
</div>
|
2024-03-09 14:13:56 -05:00
|
|
|
</MudItem>
|
2024-05-16 23:32:46 +01:00
|
|
|
}
|
|
|
|
</MudGrid>
|
|
|
|
</MudCardContent>
|
|
|
|
</MudCard>
|
|
|
|
</MudItem>
|
|
|
|
</MudGrid>
|
2024-03-09 14:13:56 -05:00
|
|
|
}
|