rezident/yii2-nested-set-plus

This extension allows you to get functional for nested set trees and widget for show and manipulate nested data in view.

Installs: 12

Dependents: 0

Suggesters: 0

Security: 0

Stars: 0

Watchers: 0

Forks: 6

Type:yii2-extension

v0.2.6 2016-04-17 22:52 UTC

This package is auto-updated.

Last update: 2024-12-29 00:58:32 UTC


README

This extension is a fork of wbraganca/yii2-nested-set-behavior.

It is developed for use in our internal project, but you can use and/or modify it on your own.

Just like Nested Set behavior by wbraganca, this extension allows you to get functional for nested set trees and also includes a widget for show Drag & drop hierarchical list with mouse and touch compatibility based on dbushell/Nestable jQuery plugin.

Installation

The preferred way to install this extension is through composer.

Either run

php composer.phar require rezident/yii2-nested-set-plus "*"

or add

"rezident/yii2-nested-set-plus": "*"

to the require section of your composer.json file.

Configuring

First you need to configure model as follows:

use kgladkiy\behaviors\NestedSetBehavior;
use kgladkiy\behaviors\NestedSetQuery; 

class Category extends ActiveRecord
{
    public function behaviors()
    {
        return [
            [
                'class' => NestedSetBehavior::className(),
                // 'rootAttribute' => 'root',
                // 'levelAttribute' => 'level',
                // 'hasManyRoots' => true
            ],
        ];
    }

    public static function find()
    {
        return new NestedSetQuery(get_called_class());
    }
}

There is no need to validate fields specified in leftAttribute, rightAttribute, rootAttribute and levelAttribute options. Moreover, there could be problems if there are validation rules for these. Please check if there are no rules for fields mentioned in model's rules() method.

In case of storing a single tree per database, DB structure can be built with schema/schema.sql. If you're going to store multiple trees you'll need schema/schema-many-roots.sql.

By default leftAttribute, rightAttribute and levelAttribute values are matching field names in default DB schemas so you can skip configuring these.

There are two ways this behavior can work: one tree per table and multiple trees per table. The mode is selected based on the value of hasManyRoots option that is false by default meaning single tree mode. In multiple trees mode you can set rootAttribute option to match existing field in the table storing the tree.

Work with Nested Set behavior

Please read the original plugin documentation for get an information about work with the nested data.

Note that method for fetch and prepare data for use with Fancytree was removed from NestedSetQueryBehavior class.

Instead of was added method NestedSetQueryBehavior::tree() that returns tree data for Nested Draggable List widget.

Using Nested Draggable List widget

use kgladkiy\widgets\NestedList;

echo NestedList::widget([
    'items' => $treeData, // $treeData = Category::find()->tree();
    'actions' => true, // set to false for disable 'edit' and 'delete' buttons
]);