From 5ccf65da403232da5be69b662e31b9a1e7d6c88c Mon Sep 17 00:00:00 2001 From: Loz Calver Date: Thu, 20 Apr 2023 17:12:41 +0100 Subject: [PATCH] FIX: Error when using AlgoliaObjectExtension on record without stages --- src/Extensions/AlgoliaObjectExtension.php | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/src/Extensions/AlgoliaObjectExtension.php b/src/Extensions/AlgoliaObjectExtension.php index ae32afc..28f6875 100644 --- a/src/Extensions/AlgoliaObjectExtension.php +++ b/src/Extensions/AlgoliaObjectExtension.php @@ -12,6 +12,7 @@ use SilverStripe\ORM\DB; use Ramsey\Uuid\Uuid; use SilverStripe\Core\Convert; +use SilverStripe\Versioned\Versioned; use Symbiote\QueuedJobs\Services\QueuedJobService; use Throwable; use Wilr\Silverstripe\Algolia\Jobs\AlgoliaDeleteItemJob; @@ -78,9 +79,9 @@ public function updateSettingsFields(FieldList $fields) $fields->addFieldsToTab( 'Root.Search', [ - ReadonlyField::create('AlgoliaIndexed', _t(__CLASS__.'.LastIndexed', 'Last indexed in Algolia')) - ->setDescription($this->owner->AlgoliaError), - ReadonlyField::create('AlgoliaUUID', _t(__CLASS__.'.UUID', 'Algolia UUID')) + ReadonlyField::create('AlgoliaIndexed', _t(__CLASS__.'.LastIndexed', 'Last indexed in Algolia')) + ->setDescription($this->owner->AlgoliaError), + ReadonlyField::create('AlgoliaUUID', _t(__CLASS__.'.UUID', 'Algolia UUID')) ] ); } @@ -174,7 +175,7 @@ private function updateAlgoliaFields($fields) $set = implode(', ', $sets); DB::query(sprintf('UPDATE %s SET %s WHERE ID = %s', $table, $set, $this->owner->ID)); - if ($this->owner->hasExtension('SilverStripe\Versioned\Versioned')) { + if ($this->owner->hasExtension(Versioned::class) && $this->owner->hasStages()) { DB::query( sprintf( 'UPDATE %s_Live SET %s WHERE ID = %s',