2024-05-26 23:06:51 +01:00
|
|
|
@using Blazored.LocalStorage
|
|
|
|
@using TaikoWebUI.Utilities;
|
|
|
|
|
|
|
|
@inject IGameDataService GameDataService
|
2022-09-09 20:31:45 +08:00
|
|
|
@inject HttpClient Client
|
2024-05-16 23:32:46 +01:00
|
|
|
@inject AuthService AuthService
|
2024-05-26 23:06:51 +01:00
|
|
|
@inject ILocalStorageService LocalStorage
|
2024-03-09 14:13:56 -05:00
|
|
|
@inject NavigationManager NavigationManager
|
2022-09-09 20:31:45 +08:00
|
|
|
|
2024-03-09 22:48:26 -05:00
|
|
|
@page "/Users/{baid:int}/Songs"
|
2022-09-09 20:31:45 +08:00
|
|
|
|
2024-03-09 14:13:56 -05:00
|
|
|
<MudBreadcrumbs Items="breadcrumbs" Class="p-0 mb-2"></MudBreadcrumbs>
|
2024-05-01 16:13:47 +01:00
|
|
|
<MudText Typo="Typo.h4">@Localizer["Song List"]</MudText>
|
2023-11-11 23:12:26 +00:00
|
|
|
|
2022-09-10 00:56:53 -04:00
|
|
|
<MudGrid Class="my-8">
|
2022-09-10 23:45:18 +08:00
|
|
|
@if (response is null)
|
|
|
|
{
|
2024-03-13 22:27:55 -04:00
|
|
|
<MudContainer Style="display:flex;margin:50px 0;align-items:center;justify-content:center;">
|
|
|
|
<MudProgressCircular Indeterminate="true" Size="Size.Large" Color="Color.Primary" />
|
|
|
|
</MudContainer>
|
2022-09-10 23:45:18 +08:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2024-05-16 23:32:46 +01:00
|
|
|
@if (AuthService.LoginRequired && (!AuthService.IsLoggedIn || (AuthService.GetLoggedInBaid() != Baid && !AuthService.IsAdmin)))
|
2023-10-16 10:38:27 +01:00
|
|
|
{
|
2024-05-16 23:32:46 +01:00
|
|
|
NavigationManager.NavigateTo(AuthService.IsLoggedIn ? "/" : "/Login");
|
2023-10-16 10:38:27 +01:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
<MudItem xs="12">
|
2024-06-05 15:07:24 +02:00
|
|
|
<MudTable Items="musicDetailDictionary.Values" Elevation="0" Outlined="true" Filter="@FilterSongs" Breakpoint=Breakpoint.None>
|
2024-03-14 00:38:26 -04:00
|
|
|
<ToolBarContent>
|
|
|
|
<MudGrid Spacing="2">
|
|
|
|
<MudItem xs="12" md="8">
|
|
|
|
<MudTextField @bind-Value="Search"
|
|
|
|
Placeholder="@Localizer["Search by Title or Artist"]"
|
|
|
|
Variant="Variant.Outlined"
|
2024-03-26 23:51:32 -04:00
|
|
|
Clearable="true"
|
|
|
|
Immediate="true"
|
2024-03-14 00:38:26 -04:00
|
|
|
Margin="Margin.Dense"
|
|
|
|
Adornment="Adornment.Start"
|
|
|
|
AdornmentIcon="@Icons.Material.Filled.Search"
|
|
|
|
IconSize="Size.Medium" />
|
|
|
|
</MudItem>
|
|
|
|
<MudItem xs="12" md="4">
|
|
|
|
<MudSelect @bind-Value="GenreFilter" T="string" Label="@Localizer["Filter by Genre"]" Variant="Variant.Outlined" Margin="Margin.Dense" Clearable="true">
|
|
|
|
@foreach (var genre in Enum.GetValues(typeof(SongGenre)))
|
|
|
|
{
|
|
|
|
var genreValue = (SongGenre)genre;
|
|
|
|
<MudSelectItem Value="@genreValue.ToString()" Label="@Localizer[$"Key_{genreValue}"]">
|
|
|
|
@ScoreUtils.GetGenreTitle(genreValue)
|
2024-03-17 15:46:47 -04:00
|
|
|
</MudSelectItem>
|
2024-03-14 00:38:26 -04:00
|
|
|
}
|
|
|
|
</MudSelect>
|
|
|
|
</MudItem>
|
|
|
|
</MudGrid>
|
|
|
|
</ToolBarContent>
|
2024-03-13 22:27:55 -04:00
|
|
|
<HeaderContent>
|
2024-03-14 00:38:26 -04:00
|
|
|
<MudTh>
|
2024-05-26 23:06:51 +01:00
|
|
|
<MudTableSortLabel T="MusicDetail" SortBy="context => GameDataService.GetMusicNameBySongId(musicDetailDictionary, context.SongId, SongNameLanguage)">
|
2024-05-01 16:13:47 +01:00
|
|
|
@Localizer["Song Title / Artist"]
|
2024-03-14 00:38:26 -04:00
|
|
|
</MudTableSortLabel>
|
|
|
|
</MudTh>
|
2024-03-26 23:08:12 -04:00
|
|
|
<MudTh>
|
|
|
|
<MudTableSortLabel T="MusicDetail" SortBy="context => context.Genre">
|
2024-05-01 16:13:47 +01:00
|
|
|
@Localizer["Genre"]
|
2024-03-26 23:08:12 -04:00
|
|
|
</MudTableSortLabel>
|
|
|
|
</MudTh>
|
2024-03-26 23:48:41 -04:00
|
|
|
@foreach (var difficulty in Enum.GetValues<Difficulty>())
|
|
|
|
{
|
|
|
|
@if (difficulty is not Difficulty.None)
|
|
|
|
{
|
|
|
|
<MudTh>
|
2024-05-25 18:12:30 +01:00
|
|
|
<MudTableSortLabel T="MusicDetail" SortBy="context => GameDataService.GetMusicStarLevel(musicDetailDictionary, context.SongId, difficulty)">
|
2024-03-26 23:48:41 -04:00
|
|
|
<img src="@ScoreUtils.GetDifficultyIcon(difficulty)" alt="@ScoreUtils.GetDifficultyTitle(difficulty)" style="@Constants.ICON_STYLE" />
|
|
|
|
</MudTableSortLabel>
|
|
|
|
</MudTh>
|
|
|
|
}
|
|
|
|
}
|
2024-03-13 22:27:55 -04:00
|
|
|
</HeaderContent>
|
|
|
|
<RowTemplate>
|
2024-03-26 23:08:12 -04:00
|
|
|
<MudTd Style="width:400px">
|
2024-03-17 15:46:47 -04:00
|
|
|
<MudStack Row="true" Justify="Justify.SpaceBetween" AlignItems="AlignItems.Center">
|
|
|
|
<div>
|
|
|
|
<a href="@($"/Users/{Baid}/Songs/{context.SongId}")">
|
2024-03-26 23:48:41 -04:00
|
|
|
<MudText Typo="Typo.body2" Style="font-weight:bold">
|
2024-05-26 23:06:51 +01:00
|
|
|
@GameDataService.GetMusicNameBySongId(musicDetailDictionary, context.SongId, SongNameLanguage)
|
2024-03-17 15:46:47 -04:00
|
|
|
</MudText>
|
|
|
|
<MudText Typo="Typo.caption">
|
2024-05-26 23:06:51 +01:00
|
|
|
@GameDataService.GetMusicArtistBySongId(musicDetailDictionary, context.SongId, SongNameLanguage)
|
2024-03-17 15:46:47 -04:00
|
|
|
</MudText>
|
|
|
|
</a>
|
|
|
|
</div>
|
|
|
|
<div>
|
2024-07-01 15:51:49 +01:00
|
|
|
<MudToggleIconButton Toggled="@context.IsFavorite"
|
|
|
|
ToggledChanged="@(async () => await OnFavoriteToggled(context))"
|
|
|
|
Icon="@Icons.Material.Filled.FavoriteBorder" Color="@Color.Secondary"
|
|
|
|
ToggledIcon="@Icons.Material.Filled.Favorite" ToggledColor="@Color.Secondary"
|
|
|
|
Size="Size.Small"
|
|
|
|
ToggledSize="Size.Small"
|
|
|
|
Title="Add to favorites" ToggledTitle="Remove from favorites" />
|
2024-03-17 15:46:47 -04:00
|
|
|
</div>
|
|
|
|
</MudStack>
|
2024-03-14 00:38:26 -04:00
|
|
|
</MudTd>
|
2024-03-26 23:08:12 -04:00
|
|
|
<MudTd>
|
|
|
|
<MudChip Style="@ScoreUtils.GetGenreStyle(context.Genre)" Size="Size.Small">
|
|
|
|
@ScoreUtils.GetGenreTitle(context.Genre)
|
|
|
|
</MudChip>
|
|
|
|
</MudTd>
|
2024-03-26 23:48:41 -04:00
|
|
|
@foreach (var difficulty in Enum.GetValues<Difficulty>())
|
|
|
|
{
|
|
|
|
@if (difficulty is not Difficulty.None)
|
|
|
|
{
|
2024-05-25 18:12:30 +01:00
|
|
|
var starLevel = GameDataService.GetMusicStarLevel(musicDetailDictionary, context.SongId, difficulty);
|
2024-03-26 23:48:41 -04:00
|
|
|
<MudTd>
|
|
|
|
@if (starLevel > 0)
|
|
|
|
{
|
|
|
|
<MudStack Row="true" Spacing="1" AlignItems="AlignItems.Center">
|
|
|
|
<MudIcon Icon="@Icons.Material.Filled.Star" Size="Size.Small" />
|
|
|
|
<MudText Typo="Typo.caption" Style="line-height:1;margin-top:2px;margin-right:2px;">@starLevel</MudText>
|
|
|
|
</MudStack>
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
<MudText Typo="Typo.body2" Style="font-weight:bold">
|
|
|
|
-
|
|
|
|
</MudText>
|
|
|
|
}
|
|
|
|
</MudTd>
|
|
|
|
}
|
|
|
|
}
|
2024-03-13 22:27:55 -04:00
|
|
|
</RowTemplate>
|
2024-03-14 00:38:26 -04:00
|
|
|
<PagerContent>
|
2024-05-03 22:46:27 +01:00
|
|
|
<MudTablePager RowsPerPageString=@Localizer["Rows Per Page"] />
|
2024-03-14 00:38:26 -04:00
|
|
|
</PagerContent>
|
2024-03-13 22:27:55 -04:00
|
|
|
</MudTable>
|
2023-10-16 10:38:27 +01:00
|
|
|
</MudItem>
|
|
|
|
}
|
2022-09-10 23:45:18 +08:00
|
|
|
}
|
2022-09-12 00:28:12 +08:00
|
|
|
</MudGrid>
|