|
|
|
@ -32,7 +32,7 @@ class MusicViewModel {
|
|
|
|
|
responseData['name'],
|
|
|
|
|
responseData['album']['images'][0]['url'],
|
|
|
|
|
responseData['preview_url'],
|
|
|
|
|
DateTime.parse(responseData['album']['release_date']),
|
|
|
|
|
int.parse(responseData['album']['release_date'].split('-')[0]),
|
|
|
|
|
responseData['duration_ms'] / 1000,
|
|
|
|
|
responseData['explicit'],
|
|
|
|
|
artists);
|
|
|
|
@ -50,14 +50,12 @@ class MusicViewModel {
|
|
|
|
|
return Artist(artist['id'], artist['name'], '');
|
|
|
|
|
}));
|
|
|
|
|
|
|
|
|
|
DateTime releaseDate = DateTime.parse(track['album']['release_date']);
|
|
|
|
|
|
|
|
|
|
musics.add(Music(
|
|
|
|
|
track['id'],
|
|
|
|
|
track['name'],
|
|
|
|
|
track['album']['images'][0]['url'],
|
|
|
|
|
track['preview_url'],
|
|
|
|
|
releaseDate,
|
|
|
|
|
int.parse(track['album']['release_date'].split('-')[0]),
|
|
|
|
|
track['duration_ms'] / 1000,
|
|
|
|
|
track['explicit'],
|
|
|
|
|
artists));
|
|
|
|
@ -198,22 +196,27 @@ class MusicViewModel {
|
|
|
|
|
|
|
|
|
|
List<dynamic> tracks = responseData['tracks']['items'];
|
|
|
|
|
for (var track in tracks) {
|
|
|
|
|
List<Artist> artists = List<Artist>.from(track['track']['artists'].map((artist) {
|
|
|
|
|
List<Artist> artists =
|
|
|
|
|
List<Artist>.from(track['track']['artists'].map((artist) {
|
|
|
|
|
return Artist(artist['id'], artist['name'], '');
|
|
|
|
|
}));
|
|
|
|
|
|
|
|
|
|
DateTime releaseDate = DateTime.parse(track['track']['album']['release_date']);
|
|
|
|
|
DateTime releaseDate =
|
|
|
|
|
DateTime.parse(track['track']['album']['release_date']);
|
|
|
|
|
|
|
|
|
|
musics.add(Music(
|
|
|
|
|
track['track']['id'],
|
|
|
|
|
track['track']['name'],
|
|
|
|
|
track['track']['album']['images'][0]['url'],
|
|
|
|
|
track['track']['preview_url'],
|
|
|
|
|
releaseDate,
|
|
|
|
|
int.parse(responseData['album']['release_date'].split('-')[0]),
|
|
|
|
|
track['track']['duration_ms'] / 1000,
|
|
|
|
|
track['track']['explicit'],
|
|
|
|
|
artists));
|
|
|
|
|
}
|
|
|
|
|
/*
|
|
|
|
|
List<Music> musics = _getMusicsFromResponse(responseData['tracks']['items']);
|
|
|
|
|
}*/
|
|
|
|
|
|
|
|
|
|
return musics;
|
|
|
|
|
} else {
|
|
|
|
@ -225,7 +228,7 @@ class MusicViewModel {
|
|
|
|
|
Future<List<Music>> getMusicsWithIds(List<String> ids,
|
|
|
|
|
{String market = "FR"}) async {
|
|
|
|
|
var accessToken = await _token.getAccessToken();
|
|
|
|
|
String url = API_URL+'/tracks?market=$market&ids=';
|
|
|
|
|
String url = API_URL + '/tracks?market=$market&ids=';
|
|
|
|
|
|
|
|
|
|
if (ids.length == 0) return [];
|
|
|
|
|
|
|
|
|
@ -233,8 +236,7 @@ class MusicViewModel {
|
|
|
|
|
|
|
|
|
|
print(url);
|
|
|
|
|
|
|
|
|
|
var response = await http
|
|
|
|
|
.get(Uri.parse(url), headers: {
|
|
|
|
|
var response = await http.get(Uri.parse(url), headers: {
|
|
|
|
|
'Authorization': 'Bearer $accessToken',
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
@ -246,5 +248,4 @@ class MusicViewModel {
|
|
|
|
|
'Error while retrieving music : ${response.statusCode} ${response.reasonPhrase}');
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|