1
0
mirror of synced 2025-01-19 08:07:24 +01:00
TaikoLocalServer/TaikoWebUI/Pages/Dialogs/ChooseTitleDialog.razor

111 lines
3.5 KiB
Plaintext
Raw Normal View History

@using System.Collections.Immutable
2022-09-15 17:47:46 +08:00
@inject IGameDataService GameDataService
@inject IJSRuntime Js
2022-09-15 17:47:46 +08:00
<MudDialog>
<DialogContent>
<MudTable Items="@Titles" Filter="@Filter" @bind-SelectedItem="@selectedTitle" Height="40vh" Hover="true">
2022-09-15 20:05:36 +09:00
<ColGroup>
2022-09-15 11:57:39 -04:00
<col style="width: 50px;" />
2022-09-15 20:05:36 +09:00
<col />
</ColGroup>
2022-09-15 17:47:46 +08:00
<ToolBarContent>
<MudTextField @bind-Value="searchString" Placeholder="Search" Adornment="Adornment.Start" Immediate="true"
2024-03-08 18:42:56 -05:00
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))">
@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))">
@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>
<MudTablePager RowsPerPageString=@Localizer["Rows Per Page"] />
2022-09-15 17:47:46 +08:00
</PagerContent>
</MudTable>
2024-06-05 02:07:33 +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>
<MudButton Color="Color.Primary" OnClick="Submit">
2024-06-05 02:07:33 +01:00
@Localizer["Dialog OK"]
</MudButton>
2022-09-15 17:47:46 +08:00
</DialogActions>
</MudDialog>
@code {
[CascadingParameter]
MudDialogInstance MudDialog { get; set; } = null!;
[Parameter]
public UserSetting UserSetting { get; set; } = new();
[Parameter]
public bool AllowFreeProfileEditing { get; set; }
2024-05-16 23:32:46 +01:00
[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();
var currentTitle = new Title
{
TitleName = UserSetting.Title
2024-03-08 18:42:56 -05:00
};
if (Titles.Contains(currentTitle))
2024-03-08 18:42:56 -05:00
{
selectedTitle = currentTitle;
}
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;
}
2022-09-15 17:47:46 +08:00
return string.IsNullOrEmpty(searchString) ||
2024-03-08 18:42:56 -05:00
title.TitleName.Contains(searchString, StringComparison.InvariantCultureIgnoreCase);
2022-09-15 17:47:46 +08:00
}
private async Task Submit()
2022-09-15 17:47:46 +08:00
{
if (selectedTitle is not null)
{
UserSetting.Title = selectedTitle.TitleName;
UserSetting.TitlePlateId = selectedTitle.TitleRarity;
2022-09-15 17:47:46 +08:00
}
await Js.InvokeVoidAsync("updateTitleText", UserSetting.Title);
2022-09-15 17:47:46 +08:00
MudDialog.Close(DialogResult.Ok(true));
}
private void Cancel() => MudDialog.Cancel();
}