From 0b21726d6d8e9a13d689863274a715c57e3f83bc Mon Sep 17 00:00:00 2001 From: Samuel Georges Date: Tue, 29 Oct 2024 12:59:01 +1100 Subject: [PATCH] Fixes structure propagation support --- src/Database/Traits/SimpleTree.php | 9 +++++++++ src/Database/Traits/Sortable.php | 12 +++++++++++- src/Database/TreeCollection.php | 22 +++++++++++++++++++--- 3 files changed, 39 insertions(+), 4 deletions(-) diff --git a/src/Database/Traits/SimpleTree.php b/src/Database/Traits/SimpleTree.php index 181525efb..e3a0aaf60 100644 --- a/src/Database/Traits/SimpleTree.php +++ b/src/Database/Traits/SimpleTree.php @@ -58,6 +58,15 @@ public function initializeSimpleTree() 'key' => $this->getParentColumnName(), 'replicate' => false ]; + + // Multisite + if ( + $this->isClassInstanceOf(\October\Contracts\Database\MultisiteInterface::class) && + $this->isMultisiteSyncEnabled() && + $this->getMultisiteConfig('structure', true) + ) { + $this->addPropagatable(['children', 'parent']); + } } /** diff --git a/src/Database/Traits/Sortable.php b/src/Database/Traits/Sortable.php index 2c274da47..c63d90daa 100644 --- a/src/Database/Traits/Sortable.php +++ b/src/Database/Traits/Sortable.php @@ -68,6 +68,16 @@ public function setSortableOrder($itemIds, $referencePool = null) throw new Exception('Invalid setSortableOrder call - count of itemIds do not match count of referencePool'); } + // Multisite + $keyName = $this->getKeyName(); + if ( + $this->isClassInstanceOf(\October\Contracts\Database\MultisiteInterface::class) && + $this->isMultisiteSyncEnabled() && + $this->getMultisiteConfig('structure', true) + ) { + $keyName = 'site_root_id'; + } + $upsert = []; foreach ($itemIds as $id) { $sortOrder = $sortKeyMap[$id] ?? null; @@ -79,7 +89,7 @@ public function setSortableOrder($itemIds, $referencePool = null) if ($upsert) { foreach ($upsert as $update) { $this->newQuery() - ->where($this->getKeyName(), $update['id']) + ->where($keyName, $update['id']) ->update([$this->getSortOrderColumn() => $update['sort_order']]); } } diff --git a/src/Database/TreeCollection.php b/src/Database/TreeCollection.php index 55ab24501..d67f7e421 100644 --- a/src/Database/TreeCollection.php +++ b/src/Database/TreeCollection.php @@ -19,8 +19,24 @@ class TreeCollection extends Collection */ public function toNested($removeOrphans = true) { + // Multisite + $keyMethod = 'getKey'; + if ( + ($model = $this->first()) && + $model->isClassInstanceOf(\October\Contracts\Database\MultisiteInterface::class) && + $model->isAttributePropagatable('children') && + $model->isAttributePropagatable('parent') + ) { + $keyMethod = 'getMultisiteKey'; + } + + // Get dictionary + $collection = []; + foreach ($this as $item) { + $collection[$item->{$keyMethod}()] = $item; + } + // Set new collection for "children" relations - $collection = $this->getDictionary(); foreach ($collection as $key => $model) { $model->setRelation('children', new Collection); } @@ -34,10 +50,10 @@ public function toNested($removeOrphans = true) if (array_key_exists($parentKey, $collection)) { $collection[$parentKey]->children[] = $model; - $nestedKeys[] = $model->getKey(); + $nestedKeys[] = $model->{$keyMethod}(); } elseif ($removeOrphans) { - $nestedKeys[] = $model->getKey(); + $nestedKeys[] = $model->{$keyMethod}(); } }