From 1faa51dd95285bc255d82677478e751ba12c370e Mon Sep 17 00:00:00 2001 From: Michael Aerni Date: Tue, 28 May 2024 08:03:32 -0400 Subject: [PATCH] Fix preview targets issue on certain routes (#149) --- .../SocialImagesGeneratorSubscriber.php | 23 +++++++++++++++---- 1 file changed, 19 insertions(+), 4 deletions(-) diff --git a/src/Subscribers/SocialImagesGeneratorSubscriber.php b/src/Subscribers/SocialImagesGeneratorSubscriber.php index a6103721..1fc01b6b 100644 --- a/src/Subscribers/SocialImagesGeneratorSubscriber.php +++ b/src/Subscribers/SocialImagesGeneratorSubscriber.php @@ -9,9 +9,11 @@ use Aerni\AdvancedSeo\Jobs\DeleteSocialImagesJob; use Aerni\AdvancedSeo\Jobs\GenerateSocialImagesJob; use Illuminate\Events\Dispatcher; +use Illuminate\Support\Str; use Statamic\Events; use Statamic\Events\Event; use Statamic\Facades\CP\Toast; +use Statamic\Statamic; class SocialImagesGeneratorSubscriber { @@ -50,13 +52,26 @@ public function generateSocialImages(Event $event): void public function addPreviewTargets(Event $event): void { - $data = $this->getDataFromEvent($event); - - if (! SocialImagesGenerator::enabled($data)) { + if (! $this->shouldAddPreviewTargets($event)) { return; } - // TODO: This has to change when implementing for taxonomies. $this->getProperty($event)?->collection()->addPreviewTargets(SocialImage::previewTargets($event->entry)); } + + protected function shouldAddPreviewTargets(Event $event): bool + { + // Only add preview targets in the CP. + if (! Statamic::isCpRoute()) { + return false; + } + + // Only add preview targets when editing an existing entry. + if (! Str::containsAll(request()->path(), ['collections', $event->entry?->id()])) { + return false; + } + + // Only add preview targets when the generator is enabled. + return SocialImagesGenerator::enabled($this->getDataFromEvent($event)); + } }