feature: unify into album option in config works now

This commit is contained in:
Cooper Hammond 2020-05-21 16:23:30 -07:00
parent 2479777cee
commit 616e8d7117
5 changed files with 55 additions and 15 deletions

View file

@ -14,7 +14,7 @@ EXAMPLE_CONFIG = <<-EOP
#{Style.blue "single_folder_playlist"}: #{Style.blue "single_folder_playlist"}:
#{Style.blue "enabled"}: #{Style.green "true"} #{Style.blue "enabled"}: #{Style.green "true"}
#{Style.blue "retain_playlist_order"}: #{Style.green "true"} #{Style.blue "retain_playlist_order"}: #{Style.green "true"}
#{Style.blue "overwrite_album"}: #{Style.green "false"} #{Style.blue "unify_into_album"}: #{Style.green "false"}
#{Style.dim "===="} #{Style.dim "===="}
EOP EOP
@ -28,7 +28,7 @@ module Config
"client_secret", "client_secret",
"single_folder_playlist: enabled", "single_folder_playlist: enabled",
"single_folder_playlist: retain_playlist_order", "single_folder_playlist: retain_playlist_order",
"single_folder_playlist: overwrite_album", "single_folder_playlist: unify_into_album",
] ]
@@conf = YAML.parse("") @@conf = YAML.parse("")
@ -67,8 +67,8 @@ module Config
return @@conf["single_folder_playlist"]["retain_playlist_order"].as_bool return @@conf["single_folder_playlist"]["retain_playlist_order"].as_bool
end end
def overwrite_album? : Bool def unify_into_album? : Bool
return @@conf["single_folder_playlist"]["overwrite_album"].as_bool return @@conf["single_folder_playlist"]["unify_into_album"].as_bool
end end
def check_necessities def check_necessities

View file

@ -33,7 +33,7 @@ class Album < SpotifyList
} }
)) ))
prepped_data = AlbumTracksMapper.from_json(datum.to_json) prepped_data = TrackMapper.from_json(datum.to_json)
prepped_data.album = album_metadata prepped_data.album = album_metadata
data = parse_to_json(prepped_data.to_json) data = parse_to_json(prepped_data.to_json)

View file

@ -24,18 +24,27 @@ class PlaylistTracksMapper
) )
end end
class AlbumTracksMapper class TrackMapper
JSON.mapping( JSON.mapping(
album: { album: {
type: JSON::Any, type: JSON::Any,
nilable: true, nilable: true,
setter: true, setter: true,
}, },
artists: JSON::Any, artists: {
disc_number: Int32, type: Array(JSON::Any),
setter: true
},
disc_number: {
type: Int32,
setter: true
},
id: String, id: String,
name: String, name: String,
track_number: Int32, track_number: {
type: Int32,
setter: true
},
type: String, type: String,
uri: String uri: String
) )

View file

@ -1,9 +1,13 @@
require "json"
require "../bottle/config" require "../bottle/config"
require "./song" require "./song"
require "./list" require "./list"
require "./mapper"
class Playlist < SpotifyList class Playlist < SpotifyList
@song_index = 1
@home_music_directory = Config.music_directory @home_music_directory = Config.music_directory
@playlist : JSON::Any? @playlist : JSON::Any?
@ -28,6 +32,28 @@ class Playlist < SpotifyList
def organize_song_metadata(list : JSON::Any, datum : JSON::Any) : JSON::Any def organize_song_metadata(list : JSON::Any, datum : JSON::Any) : JSON::Any
data = datum data = datum
if Config.retain_playlist_order?
track = TrackMapper.from_json(data.to_json)
track.track_number = @song_index
track.disc_number = 1
data = JSON.parse(track.to_json)
end
if Config.unify_into_album?
track = TrackMapper.from_json(data.to_json)
track.album = JSON.parse(%({
"name": "#{list["name"]}",
"images": [{"url": "#{list["images"][0]["url"]}"}]
}))
track.artists.push(JSON.parse(%({
"name": "#{list["owner"]["display_name"]}",
"owner": true
})))
data = JSON.parse(track.to_json)
end
@song_index += 1
return data return data
end end

View file

@ -40,8 +40,8 @@ class Song
}) })
if !@metadata if !@metadata
raise("There was no metadata found on Spotify for\n" + raise("There was no metadata found on Spotify for " +
%("#{@song_name}" by "#{@artist_name}\n) + %("#{@song_name}" by "#{@artist_name}". ) +
"Check your input and try again.") "Check your input and try again.")
end end
end end
@ -54,8 +54,8 @@ class Song
url = Youtube.find_url(@song_name, @artist_name, search_terms: "lyrics") url = Youtube.find_url(@song_name, @artist_name, search_terms: "lyrics")
if !url if !url
raise("There was no url found on youtube for\n" + raise("There was no url found on youtube for " +
%("#{@song_name}" by "#{@artist_name}\n) + %("#{@song_name}" by "#{@artist_name}. ) +
"Check your input and try again.") "Check your input and try again.")
end end
@ -67,7 +67,12 @@ class Song
File.write(temp_albumart_filename, response.body_io) File.write(temp_albumart_filename, response.body_io)
end end
@artist = data["artists"][0]["name"].to_s # check if song's metadata has been modded in playlist, update artist accordingly
if data["artists"][-1]["owner"]?
@artist = data["artists"][-1]["name"].to_s
else
@artist = data["artists"][0]["name"].to_s
end
@album = data["album"]["name"].to_s @album = data["album"]["name"].to_s
tagger = Tags.new(@filename) tagger = Tags.new(@filename)
@ -75,7 +80,7 @@ class Song
tagger.add_text_tag("title", data["name"].to_s) tagger.add_text_tag("title", data["name"].to_s)
tagger.add_text_tag("artist", @artist) tagger.add_text_tag("artist", @artist)
tagger.add_text_tag("album", @album) tagger.add_text_tag("album", @album)
tagger.add_text_tag("genre", tagger.add_text_tag("genre",
@spotify_searcher.find_genre(data["artists"][0]["id"].to_s)) @spotify_searcher.find_genre(data["artists"][0]["id"].to_s))
tagger.add_text_tag("track", data["track_number"].to_s) tagger.add_text_tag("track", data["track_number"].to_s)
tagger.add_text_tag("disc", data["disc_number"].to_s) tagger.add_text_tag("disc", data["disc_number"].to_s)