diff --git a/src/invidious/channels.cr b/src/invidious/channels.cr index 0bbd0eaab..129ff1923 100644 --- a/src/invidious/channels.cr +++ b/src/invidious/channels.cr @@ -375,13 +375,14 @@ def fetch_channel_playlists(ucid, author, auto_generated, continuation, sort_by) json = JSON.parse(response.body) if json["load_more_widget_html"].as_s.empty? - return [] of SearchItem, nil - end + continuation = nil + else + continuation = XML.parse_html(json["load_more_widget_html"].as_s) + continuation = continuation.xpath_node(%q(//button[@data-uix-load-more-href])) - continuation = XML.parse_html(json["load_more_widget_html"].as_s) - continuation = continuation.xpath_node(%q(//button[@data-uix-load-more-href])) - if continuation - continuation = extract_channel_playlists_cursor(continuation["data-uix-load-more-href"], auto_generated) + if continuation + continuation = extract_channel_playlists_cursor(continuation["data-uix-load-more-href"], auto_generated) + end end html = XML.parse_html(json["content_html"].as_s) diff --git a/src/invidious/views/playlists.ecr b/src/invidious/views/playlists.ecr index 0a5a0c139..1825bb485 100644 --- a/src/invidious/views/playlists.ecr +++ b/src/invidious/views/playlists.ecr @@ -85,7 +85,7 @@
- <% if items.size >= 28 %> + <% if continuation %> &sort_by=<%= sort_by %><% end %>"> <%= translate(locale, "Next page") %>