From fce9812f67b7673fd34225ee6cc7082b56a0f7fe Mon Sep 17 00:00:00 2001 From: Amol Wankhede Date: Thu, 2 May 2024 16:23:11 +1200 Subject: [PATCH] Update settings for SiteTree objects --- src/Extensions/SearchServiceExtension.php | 34 +++++++++++++++++++---- 1 file changed, 28 insertions(+), 6 deletions(-) diff --git a/src/Extensions/SearchServiceExtension.php b/src/Extensions/SearchServiceExtension.php index eaeb0bb..06291c8 100644 --- a/src/Extensions/SearchServiceExtension.php +++ b/src/Extensions/SearchServiceExtension.php @@ -60,9 +60,15 @@ public function __construct( $this->setBatchProcessor($batchProcessor); } + /** + * General DataObject Search settings + * + * @param FieldList $fields + * @return void + */ public function updateCMSFields(FieldList $fields): void { - if (!$this->getConfiguration()->isEnabled()) { + if ($this->owner instanceof SiteTree || !$this->getConfiguration()->isEnabled()) { return; } @@ -75,12 +81,28 @@ public function updateCMSFields(FieldList $fields): void _t(self::class . '.LastIndexed', 'Last indexed in search') ); - if ($this->owner instanceof SiteTree) { - $fields->addFieldToTab('Root.Main', $searchIndexedField); - } else { - $fields->push($showInSearchField); - $fields->push($searchIndexedField); + $fields->push($showInSearchField); + $fields->push($searchIndexedField); + } + + /** + * Specific settings for SiteTree + * + * @param FieldList $fields + * @return void + */ + public function updateSettingsFields(FieldList $fields): void + { + if (!$this->owner instanceof SiteTree || !$this->getConfiguration()->isEnabled()) { + return; } + + $searchIndexedField = ReadonlyField::create( + 'SearchIndexed', + _t(self::class . '.LastIndexed', 'Last indexed in search') + ); + + $fields->insertAfter('ShowInSearch', $searchIndexedField); } /**