storybooks/react-treebeard

Name: react-treebeard

Owner: Storybook

Description: React Tree View Component. Data-Driven, Fast, Efficient and Customisable.

Forked from: alexcurtis/react-treebeard

Created: 2017-07-01 08:38:33.0

Updated: 2017-11-16 03:03:08.0

Pushed: 2017-07-06 18:38:20.0

Homepage: http://alexcurtis.github.io/react-treebeard

Size: 240

Language: JavaScript

GitHub Committers

UserMost Recent Commit# Commits

Other Committers

UserEmailMost Recent Commit# Commits

README

react-treebeard

Build Status Coverage Status

React Tree View Component. Data-Driven, Fast, Efficient and Customisable.

Install
install react-treebeard --save
Example

An online example from the /example directory can be found here: Here

Quick Start
 strict';

rt React from 'react';
rt ReactDOM from 'react-dom';
rt {Treebeard} from 'react-treebeard';

t data = {
name: 'root',
toggled: true,
children: [
    {
        name: 'parent',
        children: [
            { name: 'child1' },
            { name: 'child2' }
        ]
    },
    {
        name: 'loading parent',
        loading: true,
        children: []
    },
    {
        name: 'parent',
        children: [
            {
                name: 'nested parent',
                children: [
                    { name: 'nested child 1' },
                    { name: 'nested child 2' }
                ]
            }
        ]
    }
]


s TreeExample extends React.Component {
constructor(props){
    super(props);
    this.state = {};
    this.onToggle = this.onToggle.bind(this);
}
onToggle(node, toggled){
    if(this.state.cursor){this.state.cursor.active = false;}
    node.active = true;
    if(node.children){ node.toggled = toggled; }
    this.setState({ cursor: node });
}
render(){
    return (
        <Treebeard
            data={data}
            onToggle={this.onToggle}
        />
    );
}


t content = document.getElementById('content');
tDOM.render(<TreeExample/>, content);
Prop Values
data

PropTypes.oneOfType([PropTypes.object,PropTypes.array]).isRequired

Data that drives the tree view. State-driven effects can be built by manipulating the attributes in this object. Also supports an array for multiple nodes at the root level. An example can be found in example/data.js

onToggle

PropTypes.func

Callback function when a node is toggled / clicked. Passes 2 attributes: the data node and it's toggled boolean state.

style

PropTypes.object

Sets the treeview styling. Defaults to src/themes/default.

animations

PropTypes.oneOfType([PropTypes.object, PropTypes.bool])

Sets the treeview animations. Set to false if you want to turn off animations. See velocity-react for more details. Defaults to src/themes/animations.

decorators

PropTypes.object

Decorates the treeview. Here you can use your own Container, Header, Toggle and Loading components. Defaults to src/decorators. See example below:

t decorators = {
Loading: (props) => {
    return (
        <div style={props.style}>
            loading...
        </div>
    );
},
Toggle: (props) => {
    return (
        <div style={props.style}>
            <svg height={props.height} width={props.width}>
                // Vector Toggle Here
            </svg>
        </div>
    );
},
Header: (props) => {
    return (
        <div style={props.style}>
            {props.node.name}
        </div>
    );
},
Container: (props) => {
    return (
        <div onClick={this.props.onClick}>
            // Hide Toggle When Terminal Here
            <this.props.decorators.Toggle/>
            <this.props.decorators.Header/>
        </div>
    );
}


ebeard data={...} decorators={decorators}/>
Data Attributes

id: '[optional] string',
name: 'string',
children: '[optional] array',
toggled: '[optional] boolean',
active: '[optional] boolean',
loading: '[optional] boolean',
decorators: '[optional] object',
animations: '[optional] object'

id

The component key. If not defined, an auto-generated index is used.

name

The name prop passed into the Header component.

children

The children attached to the node. This value populates the subtree at the specific node. Each child is built from the same basic data structure. Tip: Make this an empty array, if you want to asynchronously load a potential parent.

toggled

Toggled flag. Sets the visibility of a node's children. It also sets the state for the toggle decorator.

active

Active flag. If active, the node will be highlighted. The highlight is derived from the node.activeLink style object in the theme.

loading

Loading flag. It will populate the treeview with the loading component. Useful when asynchronously pulling the data into the treeview.

decorators / animations

Attach specific decorators / animations to a node. Provides the low level functionality to create visuals on a node-by-node basis. These structures are the same as the top level props, described above.


This work is supported by the National Institutes of Health's National Center for Advancing Translational Sciences, Grant Number U24TR002306. This work is solely the responsibility of the creators and does not necessarily represent the official views of the National Institutes of Health.