diff options
| -rw-r--r-- | CHANGELOG.md | 1 | ||||
| -rw-r--r-- | app/Models/Entry.php | 13 |
2 files changed, 14 insertions, 0 deletions
diff --git a/CHANGELOG.md b/CHANGELOG.md index fef33948c..1526cef75 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -6,6 +6,7 @@ * Require PHP 7.4+, and implement *typed properties* [#5720](https://github.com/FreshRSS/FreshRSS/pull/5720) * Require Apache 2.4+ (but repair minimal compatibility with Apache 2.2) [#5791](https://github.com/FreshRSS/FreshRSS/pull/5791), [#5804](https://github.com/FreshRSS/FreshRSS/pull/5804) * Features + * Add support for more thumbnail types [#5806](https://github.com/FreshRSS/FreshRSS/pull/5806) * Increase SQL (`VARCHAR`) text fields length to maximum possible [#5788](https://github.com/FreshRSS/FreshRSS/pull/5788) * Increase SQL date fields to 64-bit to be ready for year 2038+ [#5570](https://github.com/FreshRSS/FreshRSS/pull/5570) * Bug fixing diff --git a/app/Models/Entry.php b/app/Models/Entry.php index e3e61fb00..3e9cee4e2 100644 --- a/app/Models/Entry.php +++ b/app/Models/Entry.php @@ -298,11 +298,24 @@ HTML; */ public function thumbnail(bool $searchEnclosures = true): ?array { $thumbnail = $this->attributes('thumbnail'); + // First, use the provided thumbnail, if any if (!empty($thumbnail['url'])) { return $thumbnail; } if ($searchEnclosures) { foreach ($this->enclosures(true) as $enclosure) { + // Second, search each enclosure’s thumbnails + if (!empty($enclosure['thumbnails'][0])) { + foreach ($enclosure['thumbnails'] as $src) { + if (is_string($src)) { + return [ + 'url' => $src, + 'medium' => 'image', + ]; + } + } + } + // Third, check whether each enclosure itself is an appropriate image if (self::enclosureIsImage($enclosure)) { return $enclosure; } |
