Add support for multiple songs

This commit is contained in:
techmetx11 2023-01-16 13:58:05 +01:00
parent 1b5fbfc13e
commit fe5b81f2c3
No known key found for this signature in database
GPG key ID: 20E0C88A0E7E5AF2
6 changed files with 97 additions and 42 deletions

View file

@ -490,26 +490,31 @@ hr {
} }
/* Description Expansion Styling*/ /* Description Expansion Styling*/
#descexpansionbutton { #descexpansionbutton,
#musicdescexpansionbutton {
display: none display: none
} }
#descexpansionbutton ~ div { #descexpansionbutton ~ div,
#musicdescexpansionbutton ~ div {
overflow: hidden; overflow: hidden;
height: 8.3em; height: 8.3em;
} }
#descexpansionbutton:checked ~ div { #descexpansionbutton:checked ~ div,
#musicdescexpansionbutton:checked ~ div {
overflow: unset; overflow: unset;
height: 100%; height: 100%;
} }
#descexpansionbutton ~ label { #descexpansionbutton ~ label,
#musicdescexpansionbutton ~ label {
order: 1; order: 1;
margin-top: 20px; margin-top: 20px;
} }
label[for="descexpansionbutton"]:hover { label[for="descexpansionbutton"]:hover,
label[for="musicdescexpansionbutton"]:hover {
cursor: pointer; cursor: pointer;
} }
@ -521,14 +526,24 @@ h4,
h5, h5,
p, p,
#descriptionWrapper, #descriptionWrapper,
#description-box { #description-box,
unicode-bidi: plaintext; #music-description-box,
text-align: start; #musicDescriptionWrapper {
unicode-bidi: plaintext;
text-align: start;
} }
#descriptionWrapper { #descriptionWrapper {
max-width: 600px; max-width: 600px;
white-space: pre-wrap; white-space: pre-wrap;
}
#musicDescriptionWrapper {
max-width: 600px;
}
#music-description-title {
margin-bottom: 0px;
} }
/* Center the "invidious" logo on the search page */ /* Center the "invidious" logo on the search page */

View file

@ -188,9 +188,8 @@
"Engagement: ": "Engagement: ", "Engagement: ": "Engagement: ",
"Whitelisted regions: ": "Whitelisted regions: ", "Whitelisted regions: ": "Whitelisted regions: ",
"Blacklisted regions: ": "Blacklisted regions: ", "Blacklisted regions: ": "Blacklisted regions: ",
"Music artist: ": "Music artist: ", "Artist: ": "Artist: ",
"Music album: ": "Music album: ", "Album: ": "Album: ",
"Music licenses: ": "Music licenses: ",
"Shared `x`": "Shared `x`", "Shared `x`": "Shared `x`",
"Premieres in `x`": "Premieres in `x`", "Premieres in `x`": "Premieres in `x`",
"Premieres `x`": "Premieres `x`", "Premieres `x`": "Premieres `x`",

View file

@ -247,6 +247,15 @@ struct Video
info["reason"]?.try &.as_s info["reason"]?.try &.as_s
end end
def music : Array(VideoMusic)
music_list = Array(VideoMusic).new
info["music"].as_a.each do |music_json|
music_list << VideoMusic.new(music_json["album"].as_s, music_json["artist"].as_s, music_json["license"].as_s)
end
return music_list
end
# Macros defining getters/setters for various types of data # Macros defining getters/setters for various types of data
private macro getset_string(name) private macro getset_string(name)
@ -314,9 +323,6 @@ struct Video
getset_string genre getset_string genre
getset_string genreUcid getset_string genreUcid
getset_string license getset_string license
getset_string music_artist
getset_string music_album
getset_string music_licenses
getset_string shortDescription getset_string shortDescription
getset_string subCountText getset_string subCountText
getset_string title getset_string title

View file

@ -0,0 +1,12 @@
require "json"
struct VideoMusic
include JSON::Serializable
property album : String
property artist : String
property license : String
def initialize(@album : String, @artist : String, @license : String)
end
end

View file

@ -311,20 +311,25 @@ def parse_video_info(video_id : String, player_response : Hash(String, JSON::Any
# Music section # Music section
music_desc = player_response.dig?("engagementPanels", 1, "engagementPanelSectionListRenderer", "content", "structuredDescriptionContentRenderer", "items", 2, "videoDescriptionMusicSectionRenderer", "carouselLockups", 0, "carouselLockupRenderer", "infoRows").try &.as_a music_list = [] of VideoMusic
artist = nil music_desclist = player_response.dig?("engagementPanels", 1, "engagementPanelSectionListRenderer", "content", "structuredDescriptionContentRenderer", "items", 2, "videoDescriptionMusicSectionRenderer", "carouselLockups").try &.as_a
album = nil music_desclist.try &.each do |music_desc|
music_licenses = nil artist = nil
album = nil
music_license = nil
music_desc.try &.each do |desc| music_desc.dig?("carouselLockupRenderer", "infoRows").try &.as_a.try &.each do |desc|
desc_title = extract_text(desc.dig?("infoRowRenderer", "title")) desc_title = extract_text(desc.dig?("infoRowRenderer", "title"))
if desc_title == "ARTIST" if desc_title == "ARTIST"
artist = extract_text(desc.dig?("infoRowRenderer", "defaultMetadata")) artist = extract_text(desc.dig?("infoRowRenderer", "defaultMetadata"))
elsif desc_title == "ALBUM" elsif desc_title == "ALBUM"
album = extract_text(desc.dig?("infoRowRenderer", "defaultMetadata")) album = extract_text(desc.dig?("infoRowRenderer", "defaultMetadata"))
elsif desc_title == "LICENSES" elsif desc_title == "LICENSES"
music_licenses = extract_text(desc.dig?("infoRowRenderer", "expandedMetadata")) music_license = extract_text(desc.dig?("infoRowRenderer", "expandedMetadata"))
end
end end
music = VideoMusic.new(album.to_s, artist.to_s, music_license.to_s)
music_list << music
end end
# Author infos # Author infos
@ -378,9 +383,7 @@ def parse_video_info(video_id : String, player_response : Hash(String, JSON::Any
"genreUcid" => JSON::Any.new(genre_ucid.try &.as_s || ""), "genreUcid" => JSON::Any.new(genre_ucid.try &.as_s || ""),
"license" => JSON::Any.new(license.try &.as_s || ""), "license" => JSON::Any.new(license.try &.as_s || ""),
# Music section # Music section
"music_artist" => JSON::Any.new(artist || ""), "music" => JSON.parse(music_list.to_json),
"music_album" => JSON::Any.new(album || ""),
"music_licenses" => JSON::Any.new(music_licenses || ""),
# Author infos # Author infos
"author" => JSON::Any.new(author || ""), "author" => JSON::Any.new(author || ""),
"ucid" => JSON::Any.new(ucid || ""), "ucid" => JSON::Any.new(ucid || ""),

View file

@ -34,11 +34,13 @@
we're going to need to do it here in order to allow for translations. we're going to need to do it here in order to allow for translations.
--> -->
<style> <style>
#descexpansionbutton ~ label > a::after { #descexpansionbutton ~ label > a::after,
#musicdescexpansionbutton ~ label > a::after {
content: "<%= translate(locale, "Show more") %>" content: "<%= translate(locale, "Show more") %>"
} }
#descexpansionbutton:checked ~ label > a::after { #descexpansionbutton:checked ~ label > a::after,
#musicdescexpansionbutton:checked ~ label > a::after {
content: "<%= translate(locale, "Show less") %>" content: "<%= translate(locale, "Show less") %>"
} }
</style> </style>
@ -196,15 +198,6 @@ we're going to need to do it here in order to allow for translations.
<% end %> <% end %>
</p> </p>
<% end %> <% end %>
<% if !video.music_artist.empty? %>
<p id="music_artist"><%= translate(locale, "Music artist: ") %><%= video.music_artist %></p>
<% end %>
<% if !video.music_album.empty? %>
<p id="music_album"><%= translate(locale, "Music album: ") %><%= video.music_album %></p>
<% end %>
<% if !video.music_licenses.empty? %>
<p id="music_licenses"><%= translate(locale, "Music licenses: ") %><%= video.music_licenses %></p>
<% end %>
</div> </div>
</div> </div>
@ -244,6 +237,33 @@ we're going to need to do it here in order to allow for translations.
<hr> <hr>
<% if !video.music.empty? %>
<h3 id="music-description-title"><%= translate(locale, "Music") %></h3>
<div id="music-description-box">
<% if video.music.size == 1 %>
<div id="musicDescriptionWrapper">
<p id="music-artist"><%= translate(locale, "Artist: ") %><%= video.music[0].artist %></p>
<p id="music-album"><%= translate(locale, "Album: ") %><%= video.music[0].album %></p>
<p id="music-license"><%= translate(locale, "License: ") %><%= video.music[0].license %></p>
</div>
<% else %>
<input id="musicdescexpansionbutton" type="checkbox"/>
<div id="musicDescriptionWrapper">
<% video.music.each do |music| %>
<p id="music-artist"><%= translate(locale, "Artist: ") %><%= music.artist %></p>
<p id="music-album"><%= translate(locale, "Album: ") %><%= music.album %></p>
<p id="music-license"><%= translate(locale, "License: ") %><%= music.license %></p>
<hr>
<% end %>
</div>
<label for="musicdescexpansionbutton">
<a></a>
</label>
<% end %>
</div>
<hr>
<% end %>
<div id="comments"> <div id="comments">
<% if nojs %> <% if nojs %>
<%= comment_html %> <%= comment_html %>