aboutsummaryrefslogtreecommitdiff
path: root/lib/models/RangeTreeNode.php
diff options
context:
space:
mode:
Diffstat (limited to 'lib/models/RangeTreeNode.php')
-rw-r--r--lib/models/RangeTreeNode.php18
1 files changed, 5 insertions, 13 deletions
diff --git a/lib/models/RangeTreeNode.php b/lib/models/RangeTreeNode.php
index 4d52fed..c142579 100644
--- a/lib/models/RangeTreeNode.php
+++ b/lib/models/RangeTreeNode.php
@@ -27,6 +27,8 @@
*/
class RangeTreeNode extends SimpleORMap implements StudipTreeNode
{
+ use StudipTreeNodeCachableTrait;
+
protected static function configure($config = [])
{
$config['db_table'] = 'range_tree';
@@ -41,12 +43,13 @@ class RangeTreeNode extends SimpleORMap implements StudipTreeNode
];
$config['has_many']['children'] = [
'class_name' => RangeTreeNode::class,
- 'foreign_key' => 'item_id',
'assoc_foreign_key' => 'parent_id',
'order_by' => 'ORDER BY priority, name',
- 'on_delete' => 'delete'
+ 'on_delete' => 'delete',
];
+ $config = self::registerCachableCallbacks($config);
+
parent::configure($config);
}
@@ -240,17 +243,6 @@ class RangeTreeNode extends SimpleORMap implements StudipTreeNode
return DBManager::get()->fetchAll($query, $parameters, 'Course::buildExisting');
}
- public function getDescendantIds()
- {
- $ids = [];
-
- foreach ($this->children as $child) {
- $ids = array_merge($ids, [$child->id], $child->getDescendantIds());
- }
-
- return $ids;
- }
-
public function getAncestors(): array
{
$path = [