From 5491163b92f2a42a01c6ca24c659c178e9952b4b Mon Sep 17 00:00:00 2001 From: marlo Date: Fri, 30 Sep 2022 14:16:09 +0800 Subject: [PATCH 1/2] Add `Medialibrary` Field on constructor parameter Patterned on `DmitryBubyakin\NovaMedialibraryField\Fields\Support\MediaPresenter` --- .../Support/AttachableMediaPresenter.php | 24 +++++++++++++++++-- 1 file changed, 22 insertions(+), 2 deletions(-) diff --git a/src/Fields/Support/AttachableMediaPresenter.php b/src/Fields/Support/AttachableMediaPresenter.php index 31aab6a..6922093 100644 --- a/src/Fields/Support/AttachableMediaPresenter.php +++ b/src/Fields/Support/AttachableMediaPresenter.php @@ -2,16 +2,21 @@ namespace DmitryBubyakin\NovaMedialibraryField\Fields\Support; +use function DmitryBubyakin\NovaMedialibraryField\call_or_default; +use DmitryBubyakin\NovaMedialibraryField\Fields\Medialibrary; use Illuminate\Contracts\Support\Arrayable; +use Illuminate\Support\Str; use Spatie\MediaLibrary\MediaCollections\Models\Media; class AttachableMediaPresenter implements Arrayable { private $media; + private $field; - public function __construct(Media $media) + public function __construct(Media $media, Medialibrary $field) { $this->media = $media; + $this->field = $field; } public function toArray(): array @@ -23,7 +28,22 @@ public function toArray(): array 'fileName' => $this->media->file_name, 'collectionName' => $this->media->collection_name, 'extension' => $this->media->extension, - 'previewUrl' => $this->media->getFullUrl(), + 'previewUrl' => $this->previewUrl(), ]); } + + public function previewUrl(): ?string + { + return transform(call_or_default($this->field->previewCallback, [$this->media], function () { + return Str::is('image/*', $this->media->mime_type) + ? $this->media->getFullUrl() + : null; + }), function (string $url): string { + if ($this->field->appendTimestampToPreview) { + return $url . '?timestamp=' . $this->media->updated_at->getTimestamp(); + } + + return $url; + }); + } } From 902588181fe528f523a7b23ab6fab4daa2433d89 Mon Sep 17 00:00:00 2001 From: mcorridor Date: Fri, 30 Sep 2022 14:10:34 +0800 Subject: [PATCH 2/2] Update AttachableController for AttachableMediaPresenter Implememt `$field` parameter --- src/Http/Controllers/AttachableController.php | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/Http/Controllers/AttachableController.php b/src/Http/Controllers/AttachableController.php index 1437ccf..5b6da43 100644 --- a/src/Http/Controllers/AttachableController.php +++ b/src/Http/Controllers/AttachableController.php @@ -27,7 +27,9 @@ public function __invoke(MedialibraryRequest $request): JsonResponse return response()->json( $paginator->setCollection( - $paginator->getCollection()->mapInto(AttachableMediaPresenter::class) + $paginator->getCollection()->map( function ($media) use ($field) { + return new AttachableMediaPresenter($media, $field); + }) ) ); }