2024-08-14 15:48:32 +01:00
|
|
|
@inject IJSRuntime Js
|
2022-09-15 17:47:46 +08:00
|
|
|
|
|
|
|
<MudDialog>
|
|
|
|
<DialogContent>
|
2024-05-25 18:12:30 +01:00
|
|
|
<MudTable Items="@Titles" Filter="@Filter" @bind-SelectedItem="@selectedTitle" Height="40vh" Hover="true">
|
2022-09-15 20:05:36 +09:00
|
|
|
<ColGroup>
|
2024-08-14 15:48:32 +01:00
|
|
|
<col style="width: 50px;"/>
|
|
|
|
<col/>
|
2022-09-15 20:05:36 +09:00
|
|
|
</ColGroup>
|
2022-09-15 17:47:46 +08:00
|
|
|
<ToolBarContent>
|
2024-08-14 15:48:32 +01:00
|
|
|
<MudTextField @bind-Value="searchString" Placeholder=@Localizer["Search"] Adornment="Adornment.Start" Immediate="true"
|
|
|
|
AdornmentIcon="@Icons.Material.Filled.Search" IconSize="Size.Medium" Class="mt-0">
|
2022-09-15 17:47:46 +08:00
|
|
|
</MudTextField>
|
|
|
|
</ToolBarContent>
|
|
|
|
<HeaderContent>
|
|
|
|
<MudTh>
|
|
|
|
<MudTableSortLabel SortBy="@(new Func<Title, object>(x => x.TitleId))">
|
2024-03-08 11:13:56 -05:00
|
|
|
@Localizer["ID"]
|
2024-03-08 18:42:56 -05:00
|
|
|
</MudTableSortLabel>
|
2022-09-15 17:47:46 +08:00
|
|
|
</MudTh>
|
|
|
|
<MudTh>
|
|
|
|
<MudTableSortLabel SortBy="@(new Func<Title, object>(x => x.TitleName))">
|
2024-03-08 11:13:56 -05:00
|
|
|
@Localizer["Title"]
|
2022-09-15 17:47:46 +08:00
|
|
|
</MudTableSortLabel>
|
|
|
|
</MudTh>
|
|
|
|
</HeaderContent>
|
|
|
|
<RowTemplate>
|
2022-09-16 21:48:16 +08:00
|
|
|
@{
|
|
|
|
// Disable nullable warnings, which seems to be a false positive
|
2024-03-08 18:42:56 -05:00
|
|
|
#pragma warning disable CS8602
|
2022-09-16 21:48:16 +08:00
|
|
|
}
|
2022-09-15 20:05:36 +09:00
|
|
|
<MudTd DataLabel="Id" Class="cursor-pointer">@context.TitleId</MudTd>
|
2022-09-15 11:59:40 -04:00
|
|
|
<MudTd DataLabel="Title" Class="cursor-pointer">@context.TitleName</MudTd>
|
2022-09-16 21:48:16 +08:00
|
|
|
@{
|
2024-03-08 18:42:56 -05:00
|
|
|
#pragma warning restore CS8602
|
2022-09-16 21:48:16 +08:00
|
|
|
}
|
2022-09-15 17:47:46 +08:00
|
|
|
</RowTemplate>
|
|
|
|
<PagerContent>
|
2024-08-14 15:48:32 +01:00
|
|
|
<MudTablePager RowsPerPageString=@Localizer["Rows Per Page:"]/>
|
2022-09-15 17:47:46 +08:00
|
|
|
</PagerContent>
|
|
|
|
</MudTable>
|
2024-08-14 15:48:32 +01:00
|
|
|
<MudText Class="mt-4 d-block" Typo="Typo.caption">
|
|
|
|
<b>@Localizer["Currently Selected:"]</b> @selectedTitle?.TitleName
|
|
|
|
</MudText>
|
2022-09-15 17:47:46 +08:00
|
|
|
</DialogContent>
|
|
|
|
<DialogActions>
|
2024-03-08 18:42:56 -05:00
|
|
|
<MudButton OnClick="Cancel">
|
|
|
|
@Localizer["Cancel"]
|
|
|
|
</MudButton>
|
2024-03-08 11:13:56 -05:00
|
|
|
<MudButton Color="Color.Primary" OnClick="Submit">
|
2024-06-05 02:07:33 +01:00
|
|
|
@Localizer["Dialog OK"]
|
2024-03-08 11:13:56 -05:00
|
|
|
</MudButton>
|
2022-09-15 17:47:46 +08:00
|
|
|
</DialogActions>
|
|
|
|
</MudDialog>
|
|
|
|
|
|
|
|
@code {
|
|
|
|
|
2024-08-14 15:48:32 +01:00
|
|
|
[CascadingParameter] MudDialogInstance MudDialog { get; set; } = null!;
|
2022-09-15 17:47:46 +08:00
|
|
|
|
2024-08-14 15:48:32 +01:00
|
|
|
[Parameter] public UserSetting UserSetting { get; set; } = new();
|
2022-09-15 17:47:46 +08:00
|
|
|
|
2024-08-14 15:48:32 +01:00
|
|
|
[Parameter] public bool AllowFreeProfileEditing { get; set; }
|
|
|
|
|
|
|
|
[Parameter] public List<Title> Titles { get; set; } = new();
|
2022-09-15 17:47:46 +08:00
|
|
|
|
|
|
|
private Title? selectedTitle;
|
|
|
|
|
|
|
|
private string searchString = string.Empty;
|
|
|
|
|
|
|
|
protected override void OnInitialized()
|
|
|
|
{
|
|
|
|
base.OnInitialized();
|
2022-09-16 00:06:26 +08:00
|
|
|
var currentTitle = new Title
|
2024-08-14 15:48:32 +01:00
|
|
|
{
|
|
|
|
TitleName = UserSetting.Title
|
|
|
|
};
|
2024-05-25 18:12:30 +01:00
|
|
|
if (Titles.Contains(currentTitle))
|
2024-03-08 18:42:56 -05:00
|
|
|
{
|
2024-05-25 18:12:30 +01:00
|
|
|
selectedTitle = currentTitle;
|
2022-09-16 00:06:26 +08:00
|
|
|
}
|
2022-09-15 17:47:46 +08:00
|
|
|
}
|
|
|
|
|
2022-09-16 21:48:16 +08:00
|
|
|
private bool Filter(Title? title)
|
2022-09-15 17:47:46 +08:00
|
|
|
{
|
2022-09-16 21:48:16 +08:00
|
|
|
if (title is null)
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
2024-08-14 15:48:32 +01:00
|
|
|
|
2022-09-15 17:47:46 +08:00
|
|
|
return string.IsNullOrEmpty(searchString) ||
|
2024-08-14 15:48:32 +01:00
|
|
|
title.TitleName.Contains(searchString, StringComparison.InvariantCultureIgnoreCase);
|
2022-09-15 17:47:46 +08:00
|
|
|
}
|
|
|
|
|
2024-05-03 22:46:27 +01:00
|
|
|
private async Task Submit()
|
2022-09-15 17:47:46 +08:00
|
|
|
{
|
|
|
|
if (selectedTitle is not null)
|
|
|
|
{
|
|
|
|
UserSetting.Title = selectedTitle.TitleName;
|
2023-11-12 23:12:54 +00:00
|
|
|
UserSetting.TitlePlateId = selectedTitle.TitleRarity;
|
2022-09-15 17:47:46 +08:00
|
|
|
}
|
2024-08-14 15:48:32 +01:00
|
|
|
|
2024-05-03 22:46:27 +01:00
|
|
|
await Js.InvokeVoidAsync("updateTitleText", UserSetting.Title);
|
2022-09-15 17:47:46 +08:00
|
|
|
MudDialog.Close(DialogResult.Ok(true));
|
|
|
|
}
|
|
|
|
|
2024-08-14 15:48:32 +01:00
|
|
|
private void Cancel()
|
|
|
|
{
|
|
|
|
MudDialog.Cancel();
|
|
|
|
}
|
2022-09-15 17:47:46 +08:00
|
|
|
|
|
|
|
}
|