A component to display hierarchized data in react-admin. This package is UI agnostic. It provides redux actions, reducers and a component using render prop.
npm install --save ra-tree-core
# or
yarn add ra-tree-core
With a categories ressource having this structure where a category may have a parent category referenced by the parent_id
field:
[
{ "id": 1, "name": "Clothing" },
{ "id": 2, "name": "Men", "parent_id": 1 },
{ "id": 3, "name": "Suits", "parent_id": 2 },
{ "id": 4, "name": "Slacks", "parent_id": 3 },
{ "id": 5, "name": "Jackets", "parent_id": 3 },
{ "id": 6, "name": "Women", "parent_id": 1 },
{ "id": 7, "name": "Dresses", "parent_id": 6 },
{ "id": 8, "name": "Evening Gowns", "parent_id": 7 },
{ "id": 9, "name": "Sun Dresses", "parent_id": 7 },
{ "id": 10, "name": "Skirts", "parent_id": 6 },
{ "id": 11, "name": "Blouses", "parent_id": 6 }
]
// in src/category/list.js
import React from 'react';
import {
List,
TextField,
} from 'react-admin';
import { TreeController } from 'ra-tree-core';
import TreeNode from './TreeNode';
export const CategoriesList = (props) => (
<List {...props}>
<TreeController>
{({ tree }) => (
<Fragment>
{tree.map(node => <TreeNode node={node} />)}
</Fragment>
)}
</TreeController>
</List>
);
react-admin
will fetch the data and the TreeController
component will build a tree from it. Note that every category which do not have a parent will be considered a root node. The TreeController
component will call its children function which is responsible for the actual rendering.
Meant to be used as the child of the List
, ReferenceManyField
or ReferenceArrayField components.
The TreeController
accepts the following props:
getTreeFromArray
: The function used to build the tree from the fetched data. It defaults to one using performant-array-to-treegetTreeState
: A function which must return the tree state root from the redux state in case you mounted it on a different key thantree
. It will be called with a singlestate
argument which is the redux state.children
: A function which will be called with a single object argument having the following propstree
: an array of the root nodes. Each node have the following properties:children
: an array of its child nodesdepth
: a number indicating its depth in the hierarchyrecord
: the node's original data
getIsNodeExpanded
: a function which takes a node identifier and returns a boolean indicating whether this node is expandedtoggleNode
: a function which takes a node identifier and toggles its expanded stateexpandNode
: a function which takes a node identifier and explicitly expands itcloseNode
: a function which takes a node identifier and explicitly closes it- any additional props received by the
TreeController
component
parentSource
: The field used as the parent identifier for each node. Defaults toparent_id
- Support nested set hierarchical data
TreeSelectInputController
to select a value inside the hierarchical data (with autocomplete showing the matched nodes)TreeInputController
to edit a field containing hierarchical data as jsonTreeNodeFieldController
to show a node and its hierarchie. It should recursively fetch the parents by default, accepting a custom function to fetch them in one call (fetchHierarchy
).
This library is licensed under the MIT License, and sponsored by marmelab.