Materialized Path Tree trait for Yii2 ActiveRecord.
The preferred way to install this extension is through composer.
Either run
$ composer require matperez/yii2-materialized-path
or add
"matperez/yii2-materialized-path": "*"
to the require
section of your composer.json
file.
Run the following command
$ yii migrate/create create_tree_table
Open the /path/to/migrations/m_xxxxxx_xxxxxx_create_tree_table.php
file,
inside the up()
method add the following
$this->createTable('tree', [
'id' => Schema::TYPE_PK,
'name' => Schema::TYPE_STRING.' NOT NULL',
'path' => Schema::TYPE_STRING.' NOT NULL DEFAULT \'.\'',
'position' => Schema::TYPE_INTEGER.' NOT NULL DEFAULT 0',
'level' => Schema::TYPE_INTEGER.' NOT NULL DEFAULT 0',
]);
Configure model as follow:
use matperez\mp\MaterializedPathBehavior;
use matperez\mp\MaterializedPathQuery;
class Tree extends \yii\db\ActiveRecord
{
/**
* @inheritdoc
*/
public function behaviors()
{
return [
[
'class' => MaterializedPathBehavior::className(),
],
];
}
/**
* @inheritdoc
*/
public function rules()
{
return [
[['position', 'level'], 'integer'],
[['path'], 'string', 'max' => 255]
];
}
/**
* Query factory
* @return MaterializedPathQuery
*/
public static function find()
{
return new MaterializedPathQuery(get_called_class());
}
}
To make a root node
$root = new Tree(['name' => 'root']);
$root->makeRoot();
The tree will look like this
- root
To prepend a node as the first child of another node
$child = new Tree(['name' => 'child']);
$child->appendTo($root);
The tree will look like this
- root
- child
$node = Tree::findOne(['name' => 'child']);
// move node up
$node->setPosition($node->position - 1);
// move node down
$node->setPosition($node->position + 1);
To get all the root nodes
$roots = Tree::find()->roots()->all();
To get all the children of a node
$root = Tree::find()->roots()->one();
foreach($root->children as $child) {
foreach($child->children as $subchild) {
// do the things with a subchild
}
}
To get all the parents of a node
$node = Tree::findOne(['name' => 'child']);
$parents = Tree::find()->andWhere(['id' => $node->parentIds])->all();
To get the first parent of a node
$node = Tree::findOne(['name' => 'child']);
$parent = $node->parent();
To delete node with children
$node->delete();
./vendor/bin/codeception build
./vendor/bin/codeception run unit
more tests, mode examples
Comments