alex-kalanis / nested-tree-nette
PHP Library to process nested tree structures - for Nette
Requires
- php: >=8.1.0
- alex-kalanis/nested-tree: ^1.0
- nette/database: >=3.1 <4
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3
- nette/bootstrap: ^3.2
- nette/caching: ^3.3
- nette/di: ^3.2
- nette/tester: ^2.5
- phpstan/phpstan: ^1
- rector/rector: ^1.2
- shipmonk/composer-dependency-analyser: ^1.7
This package is auto-updated.
Last update: 2025-04-04 15:43:39 UTC
README
Library to work with Nested tree set. Adapter for Nette and its database connection. Extension of Nested tree package.
About
This is connection between Nested tree package and Nette framework. It exists due differences in accessing DB underneath, because Nette has own Database package and layer and not raw PDO.
Requirements
- PHP version 8.1 or higher
- Nette database 3.2
Basic usage
Basic usage is about to same as Nested Tree
package. The only difference is
in datasource.
class MyNodes extends \kalanis\nested_tree\Support\Node { public ?string $my_column = null; } class MyTable extends \kalanis\nested_tree\Support\TableSettings { public string $tableName = 'my_menu'; } $myNodes = new MyNodes(); $myTable = new MyTable(); // this is usually set via DI $actions = new \kalanis\nested_tree\Actions( new \kalanis\nested_tree\NestedSet( new \kalanis\nested_tree_nette\Sources\Nette\MySql( $netteExplorer, $myNodes, $myTable, ), $myNodes, $myTable, ), ); // now work: // repair the whole structure $actions->fixStructure(); // move node in row $actions->movePosition(25, 3); // change parent node for the one chosen $actions->changeParent(13, 7);
DB structure
Basic usage is about to same as Nested Tree
package.
Running tests
The package contains tests written in Nette Tester.
tester
- runs all tests
Caveats
As said in Nested Tree
package, you must choose if you go with MariaDB or MySQL,
because default implementation uses function ANY_VALUE() to go around the
problem with non-standard GROUP_BY
implementation. So you may either use MySQL 5.7+
or disable ONLY_FULL_GROUP_BY
directive in MariaDB. Or write custom query source
which itself will go around this particular problem.