summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorsyeopite <syeopite@syeopite.dev>2025-02-26 14:13:22 -0800
committersyeopite <syeopite@syeopite.dev>2025-02-26 14:13:22 -0800
commit58ad848d569e4855c5c0ad9beae431a51e882c04 (patch)
tree2057681cda7b3c55706e1201df9ef77aa2bc8bc1
parentf9b9e85ee4768605bad5af9884a893afbd2985d2 (diff)
parentd70681538acac937a8bdcdba752cd6e431cfe799 (diff)
downloadinvidious-58ad848d569e4855c5c0ad9beae431a51e882c04.tar.gz
invidious-58ad848d569e4855c5c0ad9beae431a51e882c04.tar.bz2
invidious-58ad848d569e4855c5c0ad9beae431a51e882c04.zip
Channels: Support YouTube's change to from /community to /posts (#5183)
-rw-r--r--locales/en-US.json1
-rw-r--r--src/invidious/frontend/channel_page.cr2
-rw-r--r--src/invidious/routes/channels.cr5
-rw-r--r--src/invidious/routing.cr2
-rw-r--r--src/invidious/views/community.ecr2
5 files changed, 9 insertions, 3 deletions
diff --git a/locales/en-US.json b/locales/en-US.json
index 70a53e24..4f2c2770 100644
--- a/locales/en-US.json
+++ b/locales/en-US.json
@@ -496,6 +496,7 @@
"channel_tab_courses_label": "Courses",
"channel_tab_playlists_label": "Playlists",
"channel_tab_community_label": "Community",
+ "channel_tab_posts_label": "Posts",
"channel_tab_channels_label": "Channels",
"toggle_theme": "Toggle Theme",
"carousel_slide": "Slide {{current}} of {{total}}",
diff --git a/src/invidious/frontend/channel_page.cr b/src/invidious/frontend/channel_page.cr
index ee7ebe48..4fe21b96 100644
--- a/src/invidious/frontend/channel_page.cr
+++ b/src/invidious/frontend/channel_page.cr
@@ -9,7 +9,7 @@ module Invidious::Frontend::ChannelPage
Releases
Courses
Playlists
- Community
+ Posts
Channels
end
diff --git a/src/invidious/routes/channels.cr b/src/invidious/routes/channels.cr
index 9f280251..508aa3e4 100644
--- a/src/invidious/routes/channels.cr
+++ b/src/invidious/routes/channels.cr
@@ -218,6 +218,8 @@ module Invidious::Routes::Channels
end
def self.community(env)
+ return env.redirect env.request.path.sub("posts", "community") if env.request.path.split("/").last == "posts"
+
data = self.fetch_basic_information(env)
if !data.is_a?(Tuple)
return data
@@ -234,7 +236,7 @@ module Invidious::Routes::Channels
continuation = env.params.query["continuation"]?
- if !channel.tabs.includes? "community"
+ if !channel.tabs.includes? "community" && "posts"
return env.redirect "/channel/#{channel.ucid}"
end
@@ -328,6 +330,7 @@ module Invidious::Routes::Channels
private KNOWN_TABS = {
"home", "videos", "shorts", "streams", "podcasts",
"releases", "courses", "playlists", "community", "channels", "about",
+ "posts",
}
# Redirects brand url channels to a normal /channel/:ucid route
diff --git a/src/invidious/routing.cr b/src/invidious/routing.cr
index c3d6cd41..46b71f1f 100644
--- a/src/invidious/routing.cr
+++ b/src/invidious/routing.cr
@@ -123,6 +123,7 @@ module Invidious::Routing
get "/channel/:ucid/courses", Routes::Channels, :courses
get "/channel/:ucid/playlists", Routes::Channels, :playlists
get "/channel/:ucid/community", Routes::Channels, :community
+ get "/channel/:ucid/posts", Routes::Channels, :community
get "/channel/:ucid/channels", Routes::Channels, :channels
get "/channel/:ucid/about", Routes::Channels, :about
@@ -254,6 +255,7 @@ module Invidious::Routing
get "/api/v1/channels/:ucid/courses", {{namespace}}::Channels, :courses
get "/api/v1/channels/:ucid/playlists", {{namespace}}::Channels, :playlists
get "/api/v1/channels/:ucid/community", {{namespace}}::Channels, :community
+ get "/api/v1/channels/:ucid/posts", {{namespace}}::Channels, :community
get "/api/v1/channels/:ucid/channels", {{namespace}}::Channels, :channels
get "/api/v1/channels/:ucid/search", {{namespace}}::Channels, :search
diff --git a/src/invidious/views/community.ecr b/src/invidious/views/community.ecr
index d2a305d3..132e636c 100644
--- a/src/invidious/views/community.ecr
+++ b/src/invidious/views/community.ecr
@@ -7,7 +7,7 @@
youtube_url = "https://www.youtube.com#{relative_url}"
redirect_url = Invidious::Frontend::Misc.redirect_url(env)
- selected_tab = Invidious::Frontend::ChannelPage::TabsAvailable::Community
+ selected_tab = Invidious::Frontend::ChannelPage::TabsAvailable::Posts
-%>
<% content_for "header" do %>