Доработан поиск артиста
This commit is contained in:
@@ -137,7 +137,13 @@ public class YandexMusicService
|
||||
{
|
||||
TrackId = t.Id,
|
||||
Title = t.Title,
|
||||
Artists = t.Artists?.Select(a => a.Name).ToList() ?? new List<string>(),
|
||||
Artists = t.Artists.Select(t => new YandexArtist()
|
||||
{
|
||||
Id = t.Id,
|
||||
Name = t.Name,
|
||||
CoverUrl = t.Cover.GetUrl(),
|
||||
Description = t.Description?.Text ?? string.Empty,
|
||||
}).ToList(),
|
||||
CoverUri = t.CoverUri,
|
||||
DurationMs = t.DurationMs,
|
||||
}).ToList(),
|
||||
@@ -149,7 +155,7 @@ public class YandexMusicService
|
||||
OwnerUid = p.Owner?.Uid ?? string.Empty,
|
||||
Title = p.Title,
|
||||
Description = p.Description,
|
||||
CoverUrl = p.CoverUri,
|
||||
CoverUrl = string.IsNullOrEmpty(p.CoverUri) ? p.Cover.GetUrl() : p.CoverUri,
|
||||
TrackCount = p.TrackCount,
|
||||
}).ToList(),
|
||||
|
||||
@@ -185,43 +191,114 @@ public class YandexMusicService
|
||||
int limit = 20
|
||||
)
|
||||
{
|
||||
YandexSearchResult result = new();
|
||||
|
||||
var client = await CreateClientAsync(user);
|
||||
if (client == null) return new YandexSearchResult();
|
||||
if (client == null) return result;
|
||||
|
||||
var ySerchType = searchType switch
|
||||
if (searchType == TrackSearchType.All)
|
||||
{
|
||||
TrackSearchType.Artist => YandexMusic.API.Models.Common.YSearchType.Artist,
|
||||
TrackSearchType.Album => YandexMusic.API.Models.Common.YSearchType.Album,
|
||||
TrackSearchType.Playlist => YandexMusic.API.Models.Common.YSearchType.Playlist,
|
||||
TrackSearchType.Track => YandexMusic.API.Models.Common.YSearchType.Track,
|
||||
_ => YandexMusic.API.Models.Common.YSearchType.All
|
||||
};
|
||||
|
||||
IEnumerable<YTrack> searchResult = searchType switch
|
||||
{
|
||||
TrackSearchType.Playlist => (await client.GetPlaylistAsync(id)).Tracks.Select(t => t.Track),
|
||||
TrackSearchType.Track => (await client.GetTracksAsync([id])),
|
||||
TrackSearchType.Album => (await client.GetAlbumAsync(id)).Volumes.SelectMany(t => t),
|
||||
TrackSearchType.Artist => (await client.GetArtistAsync(id)).Albums.SelectMany(t => t.Volumes.SelectMany(v => v)),
|
||||
_ => new List<YTrack>()
|
||||
};
|
||||
|
||||
if (searchType != TrackSearchType.Track)
|
||||
{
|
||||
searchResult = searchResult.Distinct();
|
||||
if (limit > 0) searchResult = searchResult.Take(limit);
|
||||
throw new Exception("Для поиска по ID необходимо указать конкретный тип (трек, альбом, исполнитель или плейлист).");
|
||||
}
|
||||
|
||||
return new YandexSearchResult()
|
||||
else if (searchType == TrackSearchType.Track)
|
||||
{
|
||||
Tracks = searchResult.Select(t => new YandexTrack
|
||||
var track = await client.GetTrackAsync(id);
|
||||
|
||||
if (track != null)
|
||||
{
|
||||
TrackId = t.Id,
|
||||
Title = t.Title,
|
||||
Artists = t.Artists?.Select(a => a.Name).ToList() ?? new List<string>(),
|
||||
CoverUri = t.CoverUri ?? string.Empty,
|
||||
DurationMs = t.DurationMs,
|
||||
}).ToList(),
|
||||
};
|
||||
result.Tracks = new List<YandexTrack>()
|
||||
{
|
||||
new()
|
||||
{
|
||||
TrackId = track.Id,
|
||||
Title = track.Title,
|
||||
Artists = track.Artists.Select(t => new YandexArtist()
|
||||
{
|
||||
Id = t.Id,
|
||||
Name = t.Name,
|
||||
CoverUrl = t.Cover.GetUrl(),
|
||||
Description = t.Description?.Text ?? string.Empty,
|
||||
}).ToList(),
|
||||
CoverUri = track.CoverUri ?? string.Empty,
|
||||
DurationMs = track.DurationMs,
|
||||
}
|
||||
};
|
||||
}
|
||||
}
|
||||
|
||||
else if (searchType == TrackSearchType.Album)
|
||||
{
|
||||
var album = await client.GetAlbumAsync(id);
|
||||
if (album != null)
|
||||
{
|
||||
result.Tracks = album.Volumes.SelectMany(v => v).Select(t => new YandexTrack
|
||||
{
|
||||
TrackId = t.Id,
|
||||
Title = t.Title,
|
||||
Artists = t.Artists.Select(t => new YandexArtist()
|
||||
{
|
||||
Id = t.Id,
|
||||
Name = t.Name,
|
||||
CoverUrl = t.Cover.GetUrl(),
|
||||
Description = t.Description?.Text ?? string.Empty,
|
||||
}).ToList(),
|
||||
CoverUri = t.CoverUri ?? string.Empty,
|
||||
DurationMs = t.DurationMs,
|
||||
}).ToList();
|
||||
}
|
||||
}
|
||||
|
||||
else if (searchType == TrackSearchType.Artist)
|
||||
{
|
||||
var artist = await client.GetArtistAsync(id);
|
||||
if (artist != null)
|
||||
{
|
||||
result.Albums = artist.Albums.Select(a => new YandexAlbum()
|
||||
{
|
||||
Id = a.Id,
|
||||
Title = a.Title,
|
||||
Artists = a.Artists.Select(t => new YandexArtist()
|
||||
{
|
||||
Id = t.Id,
|
||||
Name = t.Name,
|
||||
CoverUrl = t.Cover.GetUrl(),
|
||||
Description = t.Description?.Text ?? string.Empty,
|
||||
}).ToList(),
|
||||
CoverUrl = string.IsNullOrEmpty(a.CoverUri) ? a.Cover.GetUrl() : a.CoverUri,
|
||||
Description = a.Description,
|
||||
}).ToList();
|
||||
|
||||
result.Playlists = artist.Playlists.Select(p => new YandexPlaylist
|
||||
{
|
||||
Uuid = p.PlaylistUuid,
|
||||
Kind = p.Kind,
|
||||
OwnerUid = p.Owner?.Uid ?? string.Empty,
|
||||
Title = p.Title,
|
||||
Description = p.Description,
|
||||
CoverUrl = p.Cover.GetUrl(),
|
||||
TrackCount = p.TrackCount,
|
||||
}).ToList();
|
||||
|
||||
|
||||
|
||||
result.Tracks = artist.PopularTracks.Select(t => new YandexTrack
|
||||
{
|
||||
TrackId = t.Id,
|
||||
Title = t.Title,
|
||||
Artists = t.Artists.Select(a => new YandexArtist()
|
||||
{
|
||||
Id = a.Id,
|
||||
Name = a.Name,
|
||||
CoverUrl = a.Cover.GetUrl(),
|
||||
Description = a.Description?.Text ?? string.Empty,
|
||||
}).ToList(),
|
||||
CoverUri = t.CoverUri ?? string.Empty,
|
||||
DurationMs = t.DurationMs,
|
||||
}).ToList();
|
||||
}
|
||||
}
|
||||
|
||||
return result;
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user