Having trouble getting help?
Contact Support
Contact Support
Filtering tree nodes in EJ2 TypeScript TreeView control
28 Jan 202510 minutes to read
You can filter the tree nodes based on their text using the DataManager
plugin and the fields
property of the TreeView.
The following code example demonstrates how to filter the tree nodes in a TreeView.
import { enableRipple } from '@syncfusion/ej2-base';
import { TreeView } from '@syncfusion/ej2-navigations';
import { MaskedTextBox } from '@syncfusion/ej2-inputs';
import { DataManager, Query, Predicate } from '@syncfusion/ej2-data';
enableRipple(true);
// local data source for TreeView control
let localData: { [key: string]: Object }[] = [
{ id: 1, name: "Australia", hasChild: true },
{ id: 2, pid: 1, name: "New South Wales" },
{ id: 3, pid: 1, name: "Victoria" },
{ id: 4, pid: 1, name: "South Australia" },
{ id: 6, pid: 1, name: "Western Australia" },
{ id: 7, name: "Brazil", hasChild: true },
{ id: 8, pid: 7, name: "Paraná" },
{ id: 9, pid: 7, name: "Ceará" },
{ id: 10, pid: 7, name: "Acre" },
{ id: 11, name: "China", hasChild: true },
{ id: 12, pid: 11, name: "Guangzhou" },
{ id: 13, pid: 11, name: "Shanghai" },
{ id: 14, pid: 11, name: "Beijing" },
{ id: 15, pid: 11, name: "Shantou" },
{ id: 16, name: "France", hasChild: true },
{ id: 17, pid: 16, name: "Pays de la Loire" },
{ id: 18, pid: 16, name: "Aquitaine" },
{ id: 19, pid: 16, name: "Brittany" },
{ id: 20, pid: 16, name: "Lorraine" },
{ id: 21, name: "India", hasChild: true },
{ id: 22, pid: 21, name: "Assam" },
{ id: 23, pid: 21, name: "Bihar" },
{ id: 24, pid: 21, name: "Tamil Nadu" },
{ id: 25, pid: 21, name: "Punjab" }
];
// Render the TreeView with image icons
let listTreeObj: TreeView = new TreeView({
fields: { dataSource: localData, id: 'id', parentID: 'pid', text: 'name', hasChildren: 'hasChild' },
});
listTreeObj.appendTo('#treeView');
let mask: MaskedTextBox = new MaskedTextBox({
placeholder: "Enter the tree node to search",
change: searchNodes
});
mask.appendTo('#mask');
//Change the dataSource for TreeView
function changeDataSource(data) {
listTreeObj.fields = {
dataSource: data, id: 'id', text: 'name',
parentID: 'pid', hasChildren: 'hasChild'
}
}
//Filtering the TreeNodes
function searchNodes(args: { value: string }) {
const _text = args.value.trim();
if (_text === "") {
changeDataSource(localData);
return;
}
const filteredList = new DataManager(localData)
.executeLocal(new Query().where(new Predicate('name', 'contains', _text, true)));
if (!filteredList.length) {
changeDataSource([]);
return;
}
const _array = new Set<number | string>();
const predicates: Predicate[] = [];
filteredList.forEach(item => {
const filters = getFilterItems(item, localData);
filters.forEach(filter => {
if (filter !== null && !_array.has(filter)) {
_array.add(filter);
predicates.push(new Predicate('id', 'equal', filter, false));
}
});
});
if (predicates.length > 0) {
const query = new Query().where(Predicate.or(...predicates));
const newList = new DataManager(localData).executeLocal(query);
changeDataSource(newList);
setTimeout(() => {
listTreeObj.expandAll();
}, 400);
} else {
changeDataSource([]);
}
}
//Find the Parent Nodes for corresponding childs
function getFilterItems(fList, list) {
let nodes: any = [];
nodes.push(fList["id"]);
let query2 = new Query().where('id', 'equal', fList["pid"], false);
let fList1 = new DataManager(list).executeLocal(query2);
if (fList1.length != 0) {
let pNode = getFilterItems(fList1[0], list);
for (let i = 0; i < pNode.length; i++) {
if (nodes.indexOf(pNode[i]) == -1 && pNode[i] != null)
nodes.push(pNode[i]);
}
return nodes;
}
return nodes;
}
<!DOCTYPE html>
<html lang="en">
<head>
<title>Essential JS 2 for TreeView </title>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<meta name="description" content="Essential JS 2 for TreeView UI Control" />
<meta name="author" content="Syncfusion" />
<link href="index.css" rel="stylesheet" />
<link href="https://cdn.syncfusion.com/ej2/29.1.33/ej2-base/styles/material.css" rel="stylesheet" />
<link href="https://cdn.syncfusion.com/ej2/29.1.33/ej2-navigations/styles/material.css" rel="stylesheet" />
<link href="https://cdn.syncfusion.com/ej2/29.1.33/ej2-inputs/styles/material.css" rel="stylesheet" />
<script src="https://cdnjs.cloudflare.com/ajax/libs/systemjs/0.19.38/system.js"></script>
<script src="systemjs.config.js"></script>
<script src="https://cdn.syncfusion.com/ej2/syncfusion-helper.js" type ="text/javascript"></script>
</head>
<body>
<div id='loader'>Loading....</div>
<div id="container">
<div style="margin: 20px; padding: 20px;">
<div class="treeviewfilter">
<!-- TextBox Element -->
<input id="mask" type="text" />
<!-- TreeView Element -->
<div id="treeView"></div>
</div>
</div>
</div>
<style>
.treeviewfilter {
width: 200px;
min-height: 300px;
max-height: auto;
border: 1px solid #bbbbbb;
margin: 0 auto;
}
.e-mask .e-input {
border: none;
border-bottom: 1px solid #bbbbbb;
}
.heading {
font-size: 22px;
margin: 0 auto;
width: 300px;
margin-bottom: 10px;
}
</style>
</body>
</html>