laraditz / laravel-tree
Hierarchical or tree database implementation using path enumeration model
Requires
- php: ^7.4|^8.0
- illuminate/database: ^7.0|^8.0|^9.0|^10.0|^11.0|^12.0
- illuminate/support: ^7.0|^8.0|^9.0|^10.0|^11.0|^12.0
Requires (Dev)
- orchestra/testbench: ^4.0|^5.0|^6.0|^7.0|^8.0|^9.0|^10.0
- phpunit/phpunit: ^8.0|^9.0|^10.0|^11.0
This package is auto-updated.
Last update: 2025-06-07 10:57:57 UTC
README
Hierarchical or tree database implementation using path enumeration model.
Installation
You can install the package via composer:
composer require laraditz/laravel-tree
Configuration
Add the tree columns to your table by adding addLaravelTreeColumns
to your database migration file.
For example, we add the tree columns to the trees
table as shown below.
Schema::create('trees', function (Blueprint $table) { ... $table->addLaravelTreeColumns(); ... });
Then, add the HasTreeNode
to the model.
use Laraditz\LaravelTree\HasTreeNode; class Tree extends Model { use HasTreeNode; }
Usage
Create node as root.
Tree::create([ 'user_id' => 1 ])->asRoot()
Create node as child.
// $tree is the parent object Tree::create([ 'user_id' => 2 ])->asChildOf($tree); // or $tree->appendChild([ 'user_id' => 2 ]);
Available Relationships
Below are all relationships under the HasTreeNode
.
Relationship name | Description |
---|---|
parent() | Parent of current node. (1-1) |
child() | Children of current node. (1-N) |
Available Attributes
Below are all attributes under the HasTreeNode
.
Attribute name | Description |
---|---|
child_count | Get number of children. |
direct_child_count | Get number of cirect children. |
has_child | Check if children exists. |
Available Methods
Below are all methods under the HasTreeNode
.
Method name | Description |
---|---|
getChildCount() | Count number of children. |
getChildCount(int $level) | Count number of children based on level. |
getDirectChildCount() | Count number of cirect children. |
getParentIds() | Get parent ids from bottom-up. |
moveNode($node) | Move node to new parent $node. |
isChildOf($node) | Check is current node is child or distinct child of $node. |
isSameTree($node) | Check is current node is from the same tree as $node. |
isRootNode() | Check if current node is a root node. |
isSameNode($node) | Compare two nodes is the same or not. |
Changelog
Please see CHANGELOG for more information what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security
If you discover any security related issues, please email raditzfarhan@gmail.com instead of using the issue tracker.
Credits
License
The MIT License (MIT). Please see License File for more information.