Добален поиск по трекам
This commit is contained in:
@@ -1,4 +1,5 @@
|
||||
@page "/shared/{token}"
|
||||
@using PlaylistShared.Pwa.Components.SharedPlaylist
|
||||
@using PlaylistShared.Shared.DTO
|
||||
@using PlaylistShared.Shared.Enums
|
||||
@using PlaylistShared.Pwa.Services
|
||||
@@ -60,36 +61,13 @@
|
||||
</MudCardHeader>
|
||||
|
||||
<MudCardContent>
|
||||
<!-- Блок добавления трека (только для авторизованных с правом добавления) -->
|
||||
@if (_canAdd)
|
||||
{
|
||||
<MudPaper Class="pa-4 mb-4" Elevation="0" Style="background-color: rgba(0,0,0,0.05); border-radius: 8px;">
|
||||
<MudText Typo="Typo.h6" GutterBottom>Добавить трек</MudText>
|
||||
<MudGrid>
|
||||
<MudItem xs="12" sm="10">
|
||||
<MudTextField @bind-Value="_trackLink" Label="Ссылка на трек Яндекс.Музыки"
|
||||
Variant="Variant.Outlined" FullWidth="true"
|
||||
Placeholder="https://music.yandex.ru/album/2488464/track/21696942" />
|
||||
</MudItem>
|
||||
<MudItem xs="12" sm="2">
|
||||
<MudButton Variant="Variant.Filled" Color="Color.Primary" OnClick="AddTrack"
|
||||
Disabled="_addingTrack" FullWidth="true" Style="height: 100%;">
|
||||
@if (_addingTrack)
|
||||
{
|
||||
<MudProgressCircular Size="Size.Small" Indeterminate />
|
||||
}
|
||||
else
|
||||
{
|
||||
|
||||
<span>Добавить</span>
|
||||
}
|
||||
</MudButton>
|
||||
</MudItem>
|
||||
</MudGrid>
|
||||
<MudText Typo="Typo.body2" Class="mt-2" Color="Color.Secondary">
|
||||
Поддерживаются ссылки вида: https://music.yandex.ru/album/12345/track/67890
|
||||
</MudText>
|
||||
</MudPaper>
|
||||
<AddTrackSection ShareToken="@Token"
|
||||
OnTrackAdded="LoadTracks"
|
||||
OnPlayTrack="PlayTrack"
|
||||
CurrentPlayingTrackId="_currentTrackId"
|
||||
IsPlaying="_isPlaying" />
|
||||
}
|
||||
|
||||
<!-- Список треков -->
|
||||
@@ -171,6 +149,8 @@
|
||||
@code {
|
||||
[Parameter] public string Token { get; set; }
|
||||
|
||||
private int _addTrackTabIndex = 0; // 0 - ссылка, 1 - поиск
|
||||
|
||||
private AudioPlayer? _audioPlayer;
|
||||
private string? _currentTrackId { get; set; }
|
||||
private bool _isPlaying = false;
|
||||
@@ -369,7 +349,7 @@
|
||||
}
|
||||
}
|
||||
|
||||
private async Task AddTrack()
|
||||
private async Task AddTrackByLink()
|
||||
{
|
||||
if (string.IsNullOrWhiteSpace(_trackLink))
|
||||
{
|
||||
@@ -404,6 +384,65 @@
|
||||
}
|
||||
}
|
||||
|
||||
private async Task OnTrackAdded(string trackId)
|
||||
{
|
||||
if (!_canAdd) return;
|
||||
|
||||
try
|
||||
{
|
||||
var request = new AddTracksRequest { TrackIds = new List<string> { trackId } };
|
||||
var response = await Http.PostAsJsonAsync($"/api/sharedplaylist/{Token}/add-tracks", request);
|
||||
if (response.IsSuccessStatusCode)
|
||||
{
|
||||
Snackbar.Add("Трек успешно добавлен", Severity.Success);
|
||||
await LoadTracks();
|
||||
}
|
||||
else
|
||||
{
|
||||
var error = await response.Content.ReadFromJsonAsync<ApiResponse<object>>();
|
||||
Snackbar.Add(error?.Error?.Message ?? "Ошибка добавления трека", Severity.Error);
|
||||
}
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
Snackbar.Add($"Ошибка: {ex.Message}", Severity.Error);
|
||||
}
|
||||
}
|
||||
|
||||
private async Task AddTrackById(string trackId)
|
||||
{
|
||||
if (!_canAdd)
|
||||
{
|
||||
Snackbar.Add("У вас нет прав на добавление треков", Severity.Warning);
|
||||
return;
|
||||
}
|
||||
|
||||
_addingTrack = true;
|
||||
try
|
||||
{
|
||||
var request = new AddTracksRequest { TrackIds = new List<string> { trackId } };
|
||||
var response = await Http.PostAsJsonAsync($"/api/sharedplaylist/{Token}/add-tracks", request);
|
||||
if (response.IsSuccessStatusCode)
|
||||
{
|
||||
Snackbar.Add("Трек успешно добавлен", Severity.Success);
|
||||
await LoadTracks();
|
||||
}
|
||||
else
|
||||
{
|
||||
var error = await response.Content.ReadFromJsonAsync<ApiResponse<object>>();
|
||||
Snackbar.Add(error?.Error?.Message ?? "Ошибка добавления трека", Severity.Error);
|
||||
}
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
Snackbar.Add($"Ошибка: {ex.Message}", Severity.Error);
|
||||
}
|
||||
finally
|
||||
{
|
||||
_addingTrack = false;
|
||||
}
|
||||
}
|
||||
|
||||
private async Task RemoveTrack(YandexTrackDisplay track)
|
||||
{
|
||||
var confirmed = await DialogService.ShowMessageBoxAsync(
|
||||
@@ -505,6 +544,4 @@
|
||||
_isPlaying = false;
|
||||
StateHasChanged();
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user