diff options
author | 2025-01-02 16:33:56 +0100 | |
---|---|---|
committer | 2025-01-02 16:33:56 +0100 | |
commit | 7d544f1fab0e7c2d7518f0a6e3495dbc4f8e7cb3 (patch) | |
tree | cc9702d5e732a636b69b1f0f9d354c6794ebc977 | |
parent | 152e96d3d06b626574ecc79781479d46c7d9867d (diff) | |
download | rss-bridge-7d544f1fab0e7c2d7518f0a6e3495dbc4f8e7cb3.tar.gz rss-bridge-7d544f1fab0e7c2d7518f0a6e3495dbc4f8e7cb3.tar.zst rss-bridge-7d544f1fab0e7c2d7518f0a6e3495dbc4f8e7cb3.zip |
feat(reddit): support video (#4380)
-rw-r--r-- | bridges/RedditBridge.php | 23 |
1 files changed, 18 insertions, 5 deletions
diff --git a/bridges/RedditBridge.php b/bridges/RedditBridge.php index 03f279d8..2a3824f4 100644 --- a/bridges/RedditBridge.php +++ b/bridges/RedditBridge.php @@ -234,11 +234,14 @@ class RedditBridge extends BridgeAbstract } elseif ($data->is_video) { // Video - // Higher index -> Higher resolution - end($data->preview->images[0]->resolutions); - $index = key($data->preview->images[0]->resolutions); - - $item['content'] = $this->createFigureLink($data->url, $data->preview->images[0]->resolutions[$index]->url, 'Video'); + if ($data->media->reddit_video) { + $item['content'] = $this->createVideoContent($data->media->reddit_video); + } else { + // Higher index -> Higher resolution + end($data->preview->images[0]->resolutions); + $index = key($data->preview->images[0]->resolutions); + $item['content'] = $this->createFigureLink($data->url, $data->preview->images[0]->resolutions[$index]->url, 'Video'); + } } elseif (isset($data->media) && $data->media->type == 'youtube.com') { // Youtube link $item['content'] = $this->createFigureLink($data->url, $data->media->oembed->thumbnail_url, 'YouTube'); @@ -318,6 +321,16 @@ class RedditBridge extends BridgeAbstract return sprintf('<a href="%s">%s</a>', $href, $text); } + private function createVideoContent(\stdClass $video): string + { + return <<<HTML + <video width="$video->width" height="$video->height" controls> + <source src="$video->fallback_url" type="video/mp4"> + Your browser does not support the video tag. + </video> + HTML; + } + public function detectParameters($url) { try { |