From d03a62641f20a8dfd15fc9fe50373a5e75ee3d6e Mon Sep 17 00:00:00 2001
From: ChunkyProgrammer <78101139+ChunkyProgrammer@users.noreply.github.com>
Date: Wed, 15 Feb 2023 00:20:45 -0500
Subject: [PATCH] Add support for custom emojis in comments
---
src/invidious/comments.cr | 14 +++++++++++++-
1 file changed, 13 insertions(+), 1 deletion(-)
diff --git a/src/invidious/comments.cr b/src/invidious/comments.cr
index 357a461c..5749248e 100644
--- a/src/invidious/comments.cr
+++ b/src/invidious/comments.cr
@@ -182,7 +182,11 @@ def fetch_youtube_comments(id, cursor, format, locale, thin_mode, region, sort_b
json.field "contentHtml", content_html
json.field "isPinned", (node_comment["pinnedCommentBadge"]? != nil)
-
+ json.field "isMember", (node_comment["sponsorCommentBadge"]? != nil)
+ if node_comment["sponsorCommentBadge"]?
+ # Member icon thumbnails always have one object and there's only ever the url property in it
+ json.field "memberIconUrl", node_comment["sponsorCommentBadge"]["sponsorCommentBadgeRenderer"]["customBadge"]["thumbnails"][0]["url"].to_s
+ end
json.field "published", published.to_unix
json.field "publishedText", translate(locale, "`x` ago", recode_date(published, locale))
@@ -674,6 +678,14 @@ def content_to_comment_html(content, video_id : String? = "")
text = "#{text}" if run["bold"]?
text = "#{text}" if run["strikethrough"]?
text = "#{text}" if run["italics"]?
+ if emojiImage = run.dig?("emoji", "image")
+ emojiAlt = emojiImage.dig?("accessibility", "accessibilityData", "label").try &.as_s || text
+ emojiThumb = emojiImage["thumbnails"][0]
+ emojiUrl = "/ggpht#{URI.parse(emojiThumb["url"].as_s).request_target}"
+ emojiWidth = emojiThumb["width"]
+ emojiHeight = emojiThumb["height"]
+ text = ""
+ end
text
end