From fdf8e2e51f8d3f9c376167265c34d080d0af6fc0 Mon Sep 17 00:00:00 2001 From: Nebulino Date: Thu, 16 Apr 2020 17:33:39 +0200 Subject: [PATCH] Fix TrackMethods. - Fixed TrackMethods.getTags() - Added new track example. --- .../track_methods_example.dart | 124 ++++++++++++++++++ lib/src/methods/track_methods.dart | 3 +- 2 files changed, 126 insertions(+), 1 deletion(-) create mode 100644 example/applied_methods_example/track_methods_example.dart diff --git a/example/applied_methods_example/track_methods_example.dart b/example/applied_methods_example/track_methods_example.dart new file mode 100644 index 0000000..0cca5cc --- /dev/null +++ b/example/applied_methods_example/track_methods_example.dart @@ -0,0 +1,124 @@ +/** + * Scrobblenaut - A deadly simple Last.FM API Wrapper for Dart. + * Copyright (c) 2020 Nebulino + */ + +import 'package:scrobblenaut/lastfm.dart'; +import 'package:scrobblenaut/scrobblenaut.dart'; +import 'package:scrobblenaut/scrobblenaut_helpers.dart'; + +import '../api_values.dart'; + +// Just an example of use. +void main() async { + print('####################################################################'); + + final lastFMAuth = await LastFM.authenticate( + apiKey: APIValues.API, + apiSecret: APIValues.secret, + username: APIValues.username, + password: APIValues.password, + sessionKey: APIValues.sessionKey, + ); + + final scrobblenaut = Scrobblenaut(lastFM: lastFMAuth); + + final trackInstance = (await scrobblenaut.track.getInfo( + track: 'Tomoyo', + artist: 'Zekk', + autoCorrect: true, + )); + + print('##########################track.addTags#############################'); + + // track.addTags + print('Result of addTag request: ' + + (await trackInstance.addTags(tags: ['anime'])).toString()); + + print('######################track.getCorrection###########################'); + + // track.getCorrection + (await trackInstance.getCorrection())?.forEach((Track track) { + print('Track Correction Name: ${track.name} |' + ' Track Correction URL: ${track.url}'); + }); + + print('#########################track.getInfo##############################'); + + // track.getInfo + final trackGetInfo = (await trackInstance.getInfo( + username: 'nebulino', + autoCorrect: true, + )); + + print('Track Info Name: ${trackGetInfo.name} ' + '| Track URL: ${trackGetInfo.url} ' + '| Track Duration: ${trackGetInfo.duration}'); + + print('#########################track.getSimilar###########################'); + + // track.getSimilar + (await trackInstance.getSimilar())?.forEach((Track track) { + print('Similar Track Name: ${track.name}'); + }); + + print('###########################track.getTags############################'); + + // track.getTags + (await trackInstance.getTags(user: 'nebulino'))?.forEach((Tag tag) { + print('Tag name: ${tag.name} | Tag url: ${tag.url}'); + }); + + print('#########################track.getTopTags###########################'); + + // track.getTopTags + (await trackInstance.getTopTags())?.forEach((Tag tag) { + print('Tag name: ${tag.name} | Tag url: ${tag.url}'); + }); + + print('#############################track.love#############################'); + + // track.love + print('Result of love request: ' + (await trackInstance.love()).toString()); + + print('########################track.removeTag#############################'); + + // track.removeTag + print('Result of removeTag request: ' + + (await trackInstance.removeTag(tag: 'anime')).toString()); + + print('#########################track.scrobble#############################'); + + // track.scrobble + final scrobbleResponse = + await trackInstance.scrobble(timestamp: DateTime.now()); + // YAY. IT WORKS! + + scrobbleResponse.scrobbleResponses?.forEach((ScrobbledTrack scrobbledTrack) { + print('Scrobbled Title: ${scrobbledTrack.track}'); + }); + + print('###########################track.search#############################'); + + // track.search + (await trackInstance.search()).tracks?.forEach((Track track) { + print('Track Name from search: ${track.name}'); + }); + + print('##########################track.unlove##############################'); + + // track.unlove + print( + 'Result of unlove request: ' + (await trackInstance.unLove()).toString()); + + print('#####################track.updateNowPlaying#########################'); + + // track.updateNowPlaying + final nowPlayingResponse = await trackInstance.updateNowPlaying(); + // YAY. IT WORKS! + + print('Result of updateNowPlaying request: ${nowPlayingResponse.status} | ' + '${nowPlayingResponse.track}'); + + print('####################################################################'); +} diff --git a/lib/src/methods/track_methods.dart b/lib/src/methods/track_methods.dart index 10f7b45..d95bc49 100644 --- a/lib/src/methods/track_methods.dart +++ b/lib/src/methods/track_methods.dart @@ -205,7 +205,8 @@ class TrackMethods { return tags['tag'] == null ? null - : List.generate((tags as List).length, (i) => Tag.fromJson(tags[i])); + : List.generate( + (tags['tag'] as List).length, (i) => Tag.fromJson(tags['tag'][i])); } /// Get the top tags for this track on Last.fm, ordered by tag count.