codrasil/tree

PHP Library to generate a hierarchical tree list from array.

v1.0.2 2019-06-06 06:06 UTC

This package is auto-updated.

Last update: 2024-04-21 20:15:30 UTC


README

Latest Stable Version Total Downloads Latest Unstable Version License

PHP Library to generate a hierarchical tree list from array. Ideal for creating menus, sidebars, and any nested resources.


Requirements

  • php: >=7.1

Installation

$ composer require codrasil/tree
{
    "require": {
        "codrasil/tree": "^1.*"
    }
}

Usage

use Codrasil\Tree\Tree;

$menus = [
  ['id' => 'menu:user', 'text' => 'Users', 'order' => 2, 'children' => [ ... ]],
  ['id' => 'menu:blog', 'text' => 'Blogs', 'order' => 1],
  ['id' => 'submenu:blog:category', 'parent' => 'menu:blog', 'text' => 'Blog Categories', 'order' => 1],
];

$options = [
  'key' => 'id',
  'parent' => 'parent',
  'children' => 'children',
];

$tree = new Tree($menus, $options);

$tree->build();

print_r($tree->get());
/*
output:

Array
(
    [menu:blog] => Codrasil\Tree\Branch Object
        (
            [key:protected] => menu:blog
            [parent:protected] => root
            [node:protected] => Array
                (
                    [name] => menu:blog
                    [parent] => root
                    [order] => 1
                    [children] => Array
                        (
                            [submenu:blog:category] => Codrasil\Tree\Branch Object
                                (
                                    ...
                                )
                        )
                    [left] => 2
                    [right] => 3
                )
        )
    [menu:user] => Codrasil\Tree\Branch Object ( ... )
*/

You may also run the demo inside the tests folder via cloning this repository, then starting a php server on the tests/ folder.

cd /path/to/codrasil/tree
php -S localhost:8080 -t tests/

Screenshot of demo server


Documentation

coming soon


License

The Codrasil/Tree PHP library is open-source software licensed under the MIT license.