Skip to main content

TreeGrid mode

Pro version only

The TreeGrid mode of the Grid component is available in the PRO version only.

TreeGrid mode of the Grid component allows showing the nested tabular data.

Initialization

To initialize Grid in the TreeGrid mode, make use of the type: "tree" configuration option.

index.js
const Grid = new dhx.Grid("grid_container", {
type: "tree",
columns: [
{ id: "name", header: [{ text: "Name" }], gravity: 1.5 },
{ id: "native", type: "string", header: [{ text: "Native name" }], gravity: 1.5 },
{ id: "capital", type: "string", header: [{ text: "Capital" }] },
{ id: "currency", type: "string", header: [{ text: "Currency" }] }
],
data: dataset,
autoWidth: true
});

Configuration

Grid in the TreeGrid mode uses all the same configuration options available in the API of the default Grid.

There is also a set of properties you can provide for Grid in the TreeGrid mode to optimize its configuration for your needs.

Collapsed mode

To initialize Grid in the TreeGrid mode in the collapsed state, use the collapsed property:

const grid = new dhx.Grid("grid_container", {
type: "tree",
columns: [
// columns config
],
data: dataset,
collapsed: true
});

Related sample: Grid (TreeGrid). Collapsed mode

Expanding collapsed rows on drag-n-drop

If you have collapsed rows in your Grid in the TreeGrid mode, they will expand automatically when you move the mouse pointer over them during drag-n-drop. To disable this functionality, set the dragExpand property to false:

const grid = new dhx.Grid("grid_container", {
type: "tree",
columns: [
// columns config
],
dragItem: "row",
dragExpand: false,
data: dataset
});

Related sample: Grid (TreeGrid). Multiselection and drag-n-drop

Defining the id of the root parent

To define the id of the root parent, use the rootParent configuration property:

const grid = new dhx.Grid("grid_container", {
type: "tree",
rootParent: "root",
columns: [
{ width: 340, id: "name", header: [{ text: "Name" }] },
{ width: 340, id: "native", type: "string", header: [{ text: "Native name" }] },
{ width: 260, id: "capital", type: "string", header: [{ text: "Capital" }] },
{ width: 260, id: "currency", type: "string", header: [{ text: "Currency" }] }
],
data: dataset
});

When Grid is initialized in the TreeGrid mode, the root parent takes the id of the Grid container by default. If the id of the container is set to null or defined as an HTML element, the value of the root parent will be auto-generated.

Data loading

There are several simple ways of loading data into Grid in the TreeGrid mode:

First, you need to prepare a data set that will be loaded into Grid in the TreeGrid mode.

Preparing data set

Grid in the TreeGrid mode expects loaded data in the JSON format.

info

Please note that if you specify the id fields in the tree collection, their values should be unique. You can also omit the id fields in the tree collection. In this case they will be generated automatically.

Here is an example of an appropriate data set:

const dataset = [
{
"id": 0,
"a": 1,
"b": "Linwood Long long long",
"c": "Petersen",
"d": "Dahlgreen Place"
},
{
"id": 1,
"parent": 0,
"a": 2,
"b": "Edenburg",
"c": "Agnes",
"d": "Gem Street"
},
// more columns
];

Each object in the data set contains configuration of a grid row. The structure of a row is rather flexible. It may include:

rowId(string | number) optional, the id of a row. In case you haven't specified ids of rows, they will be auto-generated
parent(string | number) the ID of the parent row
columnContent(string | number) content of a column as key:value pairs, where key is the id of a column and value is any content you want to add into the column

Loading data on Grid initialization

You can specify data you want to load into Grid in the TreeGrid mode on the initialization stage. Make use of the data configuration property, as in:

const grid = new dhx.Grid("grid_container", {
type: "tree",
columns: [
// columns config
],
data: dataset
});

Related sample: Grid (TreeGrid). Initialization with config.data

Loading data after initialization

There are two ways to load data into Grid in the TreeGrid mode after its initialization:

Loading from local source

To load data from a local data source, use the parse() method of Tree Collection. Pass a predefined data set as a parameter of this method:

const grid = new dhx.Grid("grid_container", {
type: "tree",
columns: [
// columns config
]
});
grid.data.parse(dataset);

Related sample: Grid (TreeGrid). Initialization with data.parse()

External data loading

To load data from an external file, make use of the load() method of Tree Collection. It takes the URL of the file with data as a parameter:

const grid = new dhx.Grid("grid_container", {
type: "tree",
columns: [
// columns config
]
});
grid.data.load("../common/dataset.json");

Related sample: Grid (TreeGrid). Initialization with data.load()

The component will make an AJAX call and expect the remote URL to provide valid JSON data.

Data loading is asynchronous, so you need to wrap any after-loading code into a promise:

grid.data.load("/some/data").then(function(){
// some logic here
});

Work with Grid in the TreeGrid mode

While working with Grid in the TreeGrid mode, you can use the API methods of DHTMLX Grid which allow setting configuration of columns, getting an object of a particular column as well as the parameters of a certain cell. Besides, there are some methods specific for the TreeGrid mode of Grid. These are the methods for expanding/collapsing nodes.

Expanding/collapsing nodes

Expanding/collapsing a certain node

To expand a particular node in a Grid in the TreeGrid mode by its id, use the expand() method:

const grid = new dhx.Grid("grid_container", {
type: "tree",
columns: [
{ id: "name", header: [{ text: "Name" }], gravity: 1.5 },
{ id: "native", type: "string", header: [{ text: "Native name" }] },
{ id: "capital", type: "string", header: [{ text: "Capital" }] },
{ id: "currency", type: "string", header: [{ text: "Currency" }] }
],
data: dataset,
autoWidth: true
});

grid.expand("native");

To collapse a grid node, make use of the collapse() method:

const grid = new dhx.Grid("grid_container", {
type: "tree",
columns: [
{ id: "name", header: [{ text: "Name" }], gravity: 1.5 },
{ id: "native", type: "string", header: [{ text: "Native name" }] },
{ id: "capital", type: "string", header: [{ text: "Capital" }] },
{ id: "currency", type: "string", header: [{ text: "Currency" }] }
],
data: dataset,
autoWidth: true
});

grid.collapse("native");

Related sample: Grid (TreeGrid). Expand / collapse rows

Expanding/collapsing all nodes

It is also possible to expand/collapse all the nodes of the Grid in the TreeGrid mode using the two corresponding methods - expandAll() and collapseAll():

const grid = new dhx.Grid("grid_container", {
type: "tree",
columns: [
{ id: "name", header: [{ text: "Name" }], gravity: 1.5 },
{ id: "native", type: "string", header: [{ text: "Native name" }] },
{ id: "capital", type: "string", header: [{ text: "Capital" }] },
{ id: "currency", type: "string", header: [{ text: "Currency" }] }
],
data: dataset,
autoWidth: true
});

// expanding all the nodes
grid.expandAll();
// collapsing all the nodes
grid.collapseAll();

Related sample: Grid (TreeGrid). Expand / collapse rows

Event handling

When you work with Grid in the TreeGrid mode, you can use the API Events of DHTMLX Grid. There is also a set of events specific for the TreeGrid mode of Grid that allow handling collapsing and expanding of nodes:

NameDescription
afterCollapsefires after collapsing Grid in the TreeGrid mode
afterExpandfires after expanding Grid in the TreeGrid mode
beforeCollapsefires before collapsing Grid in the TreeGrid mode
beforeExpandfires before expanding Grid in the TreeGrid mode
expandfires before collapsing Grid in the TreeGrid mode

You can learn how to work with Grid events in the related guide.