Searching and Filtering in Blazor TreeView Component

28 Aug 202412 minutes to read

The Blazor TreeView component allows for searching and filtering of TreeView nodes through an external input TextBox.

@using Syncfusion.Blazor.Inputs
@using Syncfusion.Blazor.Navigations

<div id="container">
    <div id="sample">
        <SfTextBox Placeholder="Filter" Input="@OnInput"></SfTextBox>
        <SfTreeView @ref="tree" ID="tree" TValue="Listdata">
            <TreeViewEvents TValue="Listdata" DataBound="dataBound"></TreeViewEvents>
            <TreeViewFieldsSettings DataSource="@ListDataSource" TValue="Listdata" Id="Id" IconCss="Icon" ParentID="Pid" Text="Name" HasChildren="HasChild" Expanded="Expanded"></TreeViewFieldsSettings>
        </SfTreeView>
    </div>
</div>
@code
{
    SfTreeView<Listdata> tree;
    List<Listdata> ListDataSource = new List<Listdata>();
    List<Listdata> Temp = new List<Listdata>();
    public bool isFiltered = false;
    List<Listdata> DataSource = new List<Listdata>();
    protected override void OnInitialized()
    {
        ListDataSource = GetData();
    }

    public List<Listdata> GetData()
    { 
        
        List<Listdata> TempDataSource = new List<Listdata>(){
                new Listdata
            {
                Id = 1,
                Name = "Australia",
                HasChild = true,
                Expanded = false,
                Icon = "folder"
            },new Listdata
    {
        Id = 2,
        Pid = 1,
        Name = "New South Wales",
         Icon = "folder"
    },new Listdata
    {
        Id = 3,
        Pid = 1,
        Name = "Victoria",
         Icon = "folder"
    },new Listdata
    {
        Id = 4,
        Pid = 1,
        Name = "South Australia",
        Icon = "folder"
    },new Listdata
    {
        Id = 6,
        Pid = 1,
        Name = "Western Australia",
        Icon = "folder"
    },new Listdata
    {
        Id = 7,
        Name = "Brazil",
        HasChild = true,
        Icon = "folder"
    },new Listdata
    {
        Id = 8,
        Pid = 7,
        Name = "ParanĂ¡",
        Icon = "folder"
    },new Listdata
    {
        Id = 9,
        Pid = 7,
        Name = "CearĂ¡",
        Icon = "folder"
    },new Listdata
    {
        Id = 10,
        Pid = 7,
        Name = "Acre",
        Icon = "folder"
    },new Listdata
    {
        Id = 11,
        Name = "China",
        HasChild = true,
        Icon = "folder"
    },new Listdata
    {
        Id = 12,
        Pid = 11,
        Name = "Guangzhou",
        Icon = "folder"
    },new Listdata
    {
        Id = 13,
        Pid = 11,
        Name = "Shanghai",
        Icon = "folder"
    },new Listdata
    {
        Id = 14,
        Pid = 11,
        Name = "Beijing",
        Icon = "folder"
    },new Listdata
    {
        Id = 15,
        Pid = 11,
        Name = "Shantou",
        Icon = "folder"
    },new Listdata
    {
        Id = 16,
        Name = "France",
        Icon = "folder",
        HasChild = true
    },new Listdata
    {
        Id = 17,
        Pid = 16,
        Name = "Pays de la Loire",
        Icon = "folder"
    },new Listdata
    {
        Id = 18,
        Pid = 16,
        Name = "Aquitaine",
         Icon = "folder"
    },new Listdata
    {
        Id = 19,
        Pid = 16,
        Name = "Brittany",
         Icon = "folder"
    },new Listdata
    {
        Id = 20,
        Pid = 16,
        Name = "Lorraine",
         Icon = "folder"
    },new Listdata
    {
        Id = 21,
        Name = "India",
        HasChild = true,
         Icon = "folder"
    },new Listdata
    {
        Id = 22,
        Pid = 21,
        Name = "Assam",
         Icon = "folder"
    },new Listdata
    {
        Id = 23,
        Pid = 21,
        Name = "Bihar",
         Icon = "folder"
    },new Listdata
    {
        Id = 24,
        Pid = 21,
        Name = "Tamil Nadu",
         Icon = "folder"
    }



};

        return TempDataSource;
    }

    public void OnInput(InputEventArgs eventArgs)
    {
        if (eventArgs.Value == "")
        {
            ListDataSource = GetData();
            isFiltered = false;
        }
        else
       {
            DataSource = GetData();
            // Filter all the nodes of the Searched ID.
            List<Listdata> filteredValues = DataSource.FindAll(e => e.Name.ToString().StartsWith(eventArgs.Value));
            List<Listdata> filteredDataSource = new List<Listdata>();
            Listdata data = new Listdata();
            for (int i = 0; i < filteredValues.Count; i++)
            {
                data = filteredValues[i];
                if(data.Pid == null)
                {
                    data.HasChild = false;
                    filteredDataSource.Add(data);
                    break;
                }
                while (data.Pid != null)
                {
                    if (filteredDataSource.Exists(e => e.Id.Equals(data.Id))) { break; }
                    filteredDataSource.Add(data);
                    data = DataSource.Find(e => e.Id.Equals(data.Pid));
                }
                if (!filteredDataSource.Exists(e => e.Id.Equals(data.Id)))
                {
                    filteredDataSource.Add(data);
                }
            }
            // Update the TreeView based on the searched ID value.
            ListDataSource = filteredDataSource;
            isFiltered = true;
        }
    }



    public void dataBound()
    {
        if (isFiltered)
        {
            this.tree.ExpandAll();
        }
        else
        {
            this.tree.CollapseAllAsync();
        }
    }



    public class Listdata
    {
        public int Id { get; set; }
        public int? Pid { get; set; } = null;
        public string Name { get; set; }
        public bool HasChild { get; set; }
        public bool Expanded { get; set; }
        public string Icon { get; set; }
    } 
}

<style>
    #tree {
        box-shadow: 0 1px 4px #ddd;
        border-bottom: 1px solid #ddd;
    }

    .e-treeview .e-list-icon {
        background-repeat: no-repeat;
        height: 20px;
        background-image: url();
    }

        .e-treeview .e-list-icon.folder {
            background-position: -10px -552px
        }
    #sample {
        height: 220px;
        margin: 0 auto;
        display: block;
        max-width: 350px;
    }
    .e-treeview .e-list-icon.docx {
        background-position: -10px -20px
    }
</style>

Searching and Filtering in Blazor TreeView Component