2024-05-26 23:06:51 +01:00
|
|
|
|
namespace TaikoWebUI.Pages;
|
2022-09-12 00:28:12 +08:00
|
|
|
|
|
2024-03-26 23:08:12 -04:00
|
|
|
|
public partial class SongList
|
2022-09-12 00:28:12 +08:00
|
|
|
|
{
|
|
|
|
|
[Parameter]
|
|
|
|
|
public int Baid { get; set; }
|
2024-05-16 23:32:46 +01:00
|
|
|
|
|
2024-03-14 00:38:26 -04:00
|
|
|
|
private string Search { get; set; } = string.Empty;
|
|
|
|
|
private string GenreFilter { get; set; } = string.Empty;
|
2024-05-26 23:06:51 +01:00
|
|
|
|
private string? SongNameLanguage { get; set; }
|
2024-03-14 00:38:26 -04:00
|
|
|
|
|
2022-09-12 00:28:12 +08:00
|
|
|
|
private SongBestResponse? response;
|
2024-03-09 01:07:34 -05:00
|
|
|
|
private UserSetting? userSetting;
|
2022-09-12 00:28:12 +08:00
|
|
|
|
|
2024-03-09 11:59:21 -05:00
|
|
|
|
private readonly List<BreadcrumbItem> breadcrumbs = new();
|
2024-05-25 18:12:30 +01:00
|
|
|
|
|
|
|
|
|
private Dictionary<uint, MusicDetail> musicDetailDictionary = new();
|
2024-03-13 22:27:55 -04:00
|
|
|
|
|
2022-09-12 00:28:12 +08:00
|
|
|
|
protected override async Task OnInitializedAsync()
|
|
|
|
|
{
|
|
|
|
|
await base.OnInitializedAsync();
|
2024-05-25 18:12:30 +01:00
|
|
|
|
|
|
|
|
|
if (AuthService.LoginRequired && !AuthService.IsLoggedIn)
|
|
|
|
|
{
|
|
|
|
|
await AuthService.LoginWithAuthToken();
|
|
|
|
|
}
|
|
|
|
|
|
2022-09-12 00:28:12 +08:00
|
|
|
|
response = await Client.GetFromJsonAsync<SongBestResponse>($"api/PlayData/{Baid}");
|
|
|
|
|
response.ThrowIfNull();
|
2024-03-08 15:11:54 -05:00
|
|
|
|
|
2024-03-09 01:07:34 -05:00
|
|
|
|
userSetting = await Client.GetFromJsonAsync<UserSetting>($"api/UserSettings/{Baid}");
|
2024-05-25 18:12:30 +01:00
|
|
|
|
musicDetailDictionary = await GameDataService.GetMusicDetailDictionary();
|
2024-03-13 22:27:55 -04:00
|
|
|
|
|
2024-05-26 23:06:51 +01:00
|
|
|
|
SongNameLanguage = await LocalStorage.GetItemAsync<string>("songNameLanguage");
|
2024-03-08 18:42:56 -05:00
|
|
|
|
|
2024-05-16 23:32:46 +01:00
|
|
|
|
if (AuthService.IsLoggedIn && !AuthService.IsAdmin)
|
2024-03-09 11:59:21 -05:00
|
|
|
|
{
|
2024-05-01 16:13:47 +01:00
|
|
|
|
breadcrumbs.Add(new BreadcrumbItem(Localizer["Dashboard"], href: "/"));
|
2024-03-09 11:59:21 -05:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2024-05-01 16:13:47 +01:00
|
|
|
|
breadcrumbs.Add(new BreadcrumbItem(Localizer["Users"], href: "/Users"));
|
2024-03-09 11:59:21 -05:00
|
|
|
|
};
|
2024-03-09 01:07:34 -05:00
|
|
|
|
breadcrumbs.Add(new BreadcrumbItem($"{userSetting?.MyDonName}", href: null, disabled: true));
|
2024-05-01 16:13:47 +01:00
|
|
|
|
breadcrumbs.Add(new BreadcrumbItem(Localizer["Song List"], href: $"/Users/{Baid}/Songs", disabled: false));
|
2022-09-12 00:28:12 +08:00
|
|
|
|
}
|
|
|
|
|
|
2024-03-14 00:38:26 -04:00
|
|
|
|
private bool FilterSongs(MusicDetail musicDetail)
|
2022-09-22 22:53:35 -04:00
|
|
|
|
{
|
2024-03-14 00:38:26 -04:00
|
|
|
|
var stringsToCheck = new List<string>
|
|
|
|
|
{
|
|
|
|
|
musicDetail.SongName,
|
|
|
|
|
musicDetail.SongNameEN,
|
|
|
|
|
musicDetail.SongNameCN,
|
|
|
|
|
musicDetail.SongNameKO,
|
|
|
|
|
musicDetail.ArtistName,
|
|
|
|
|
musicDetail.ArtistNameEN,
|
|
|
|
|
musicDetail.ArtistNameCN,
|
|
|
|
|
musicDetail.ArtistNameKO
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
if (!string.IsNullOrEmpty(Search) && !stringsToCheck.Any(s => s.Contains(Search, StringComparison.OrdinalIgnoreCase)))
|
|
|
|
|
{
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (!string.IsNullOrEmpty(GenreFilter) && musicDetail.Genre != Enum.Parse<SongGenre>(GenreFilter))
|
|
|
|
|
{
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return true;
|
2022-09-12 00:28:12 +08:00
|
|
|
|
}
|
|
|
|
|
}
|