112 lines
4.4 KiB
Plaintext
112 lines
4.4 KiB
Plaintext
@using PlaylistShared.Shared.Shared
|
|
@inject HttpClient Http
|
|
@inject ISnackbar Snackbar
|
|
|
|
<MudPaper Class="mb-4" Elevation="0" Style="background-color: rgba(0,0,0,0.05); border-radius: 8px;">
|
|
<MudTabs @bind-ActivePanelIndex="_activeTabIndex" Elevation="0" Style="border-bottom: 1px solid rgba(0,0,0,0.1);">
|
|
<MudTabPanel Text="По ссылке" Style="padding: 16px;">
|
|
<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="AddTrackByLink"
|
|
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>
|
|
</MudTabPanel>
|
|
<MudTabPanel Text="Поиск" Style="padding: 16px;">
|
|
<AddTrackBySearch OnAddTrack="AddTrackById"
|
|
OnPlayTrack="PlayTrack"
|
|
CurrentPlayingTrackId="CurrentPlayingTrackId"
|
|
IsPlaying="IsPlaying"
|
|
ShareToken="@ShareToken" />
|
|
</MudTabPanel>
|
|
</MudTabs>
|
|
</MudPaper>
|
|
|
|
@code {
|
|
private int _activeTabIndex = 0;
|
|
private string _trackLink = "";
|
|
private bool _addingTrack = false;
|
|
|
|
[Parameter] public string ShareToken { get; set; } = string.Empty;
|
|
[Parameter] public EventCallback OnTrackAdded { get; set; }
|
|
[Parameter] public EventCallback<string> OnPlayTrack { get; set; }
|
|
[Parameter] public string? CurrentPlayingTrackId { get; set; }
|
|
[Parameter] public bool IsPlaying { get; set; }
|
|
|
|
private async Task AddTrackByLink()
|
|
{
|
|
if (string.IsNullOrWhiteSpace(_trackLink))
|
|
{
|
|
Snackbar.Add("Введите ссылку на трек", Severity.Warning);
|
|
return;
|
|
}
|
|
|
|
var trackId = ExtractTrackIdFromLink(_trackLink);
|
|
if (string.IsNullOrEmpty(trackId))
|
|
{
|
|
Snackbar.Add("Неверный формат ссылки", Severity.Warning);
|
|
return;
|
|
}
|
|
|
|
await AddTrackById(trackId);
|
|
if (!_addingTrack) // если не было ошибки
|
|
_trackLink = "";
|
|
}
|
|
|
|
private async Task AddTrackById(string trackId)
|
|
{
|
|
_addingTrack = true;
|
|
try
|
|
{
|
|
var request = new AddTracksRequest { TrackIds = new List<string> { trackId } };
|
|
var response = await Http.PostAsJsonAsync($"/api/sharedplaylist/{ShareToken}/add-tracks", request);
|
|
if (response.IsSuccessStatusCode)
|
|
{
|
|
Snackbar.Add("Трек успешно добавлен", Severity.Success);
|
|
await OnTrackAdded.InvokeAsync(); // уведомляем родителя, что список треков изменился
|
|
}
|
|
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;
|
|
StateHasChanged();
|
|
}
|
|
}
|
|
|
|
private async Task PlayTrack(string trackId)
|
|
{
|
|
OnPlayTrack.InvokeAsync(trackId);
|
|
}
|
|
|
|
private string? ExtractTrackIdFromLink(string link)
|
|
{
|
|
var match = System.Text.RegularExpressions.Regex.Match(link, @"/track/(\d+)");
|
|
return match.Success ? match.Groups[1].Value : null;
|
|
}
|
|
} |