Dynamic Data List Filtering on Click in Angular

In this article, you will learn how to filter a dynamic data list using an Input field only when the filter or search button is clicked. There will also be a reset button to clear the Input control and show all the results.

Generally, we create a filter list where the results are filtered live as the user types in the Input control that is triggered on key press events. But sometimes, we may require a feature where the data list needs to be filtered only when a user clicks on the Filter or Search button or it can be a predefined filter selection like Radio buttons.

[lwptoc]

This tutorial will focus on filtering the Data list only when a button is clicked. We will learn how to achieve this functionality in our component class. Also, we will see Bootstrap styling classes to quickly add UI style to our filter data list.

 

How to Filter Data List on Button Click in Angular?

Follow these quick steps to create a button-triggered filter list in the Angular application:

  • Install and Configure Bootstrap Style
  • Setting up the Component
  • Creating the Template
  • Defining Data Types
  • Implementing Filtering Logic
  • Resetting the Filter

 

Install and Configure Bootstrap Style

First, will install the Bootstrap package in our Angular application by executing the below npm command:

npm install bootstrap

 

Now, we will add the Bootstrap CSS file in the angular.json file’s styles array as shown below:

"styles": [
  "src/styles.css",
  "node_modules/bootstrap/dist/css/bootstrap.min.css"
]

 

Setting up the Component

Thereafter, let’s setup the Angular component which will have the soul of our dynamic data list. We will define the required properties and methods to handle the data filter and reset functionality.

import { Component } from '@angular/core';

interface DataItem {
  name: string;
  description: string;
  // Add other properties as needed
}

@Component({
  selector: 'app-root',
  templateUrl: './app.component.html',
  styleUrls: ['./app.component.css'],
})
export class AppComponent {
  originalData: DataItem[] = []; // Define the type of originalData array
  filteredData: DataItem[] = []; // Define the type of filteredData array
  filterText = '';

  constructor() {
    // Initialize your originalData array with some data
    this.originalData = [
      { name: 'Item 1', description: 'Description 1' },
      { name: 'Item 2', description: 'Description 2' },
      // Add more data items
    ];
    this.filteredData = [...this.originalData]; // Initialize filteredData with original data
  }

  filterData() {
    this.filteredData = this.originalData.filter((item) => {
      return item.name.toLowerCase().includes(this.filterText.toLowerCase());
    });
  }

  resetFilter() {
    this.filterText = '';
    this.filteredData = [...this.originalData];
  }
}

In the above code, we have the DataItem interface to represent the data structure of each item in our data list. The originalData array keeps the full data list whereas the filterData array populates the filtered results based on the term entered in the input control. The filterText model stores the term entered by user inside the Input field.

 

Creating the Template

After setting up the class, we will add the required elements in the HTML template including the Input control, buttons for Filter and Reset, and the iteration list with *ngFor directive. Open the app.component.html file and update it with the following:

<div>
  <input type="text" [(ngModel)]="filterText" placeholder="Enter a filter term">
  <button (click)="filterData()">Filter</button>
  <button (click)="resetFilter()">Reset</button>
</div>

<ul>
  <li *ngFor="let item of filteredData">
    {{ item.name }} - {{ item.description }}
  </li>
</ul>

 

Defining Data Types

To help TypeScript infer and validate types we need to add the DataItem interface for our data list which can be different in your case. This makes the code error-free, easy to maintain and robust. In our case, to keep the tutorial at ease we have added the interface in the component itself as shown below:

interface DataItem {
  name: string;
  description: string;
}

 

Implementing Filtering Logic

The special feature of our tutorial is that we only update the filtered list when a user clicks on the Filter button, this is achieved here by the way we used the filterData() method, that filters the originalData array based on the user’s input and updates the filteredData array. Which is triggered on click on the Filter button.

  filterData() {
    this.filteredData = this.originalData.filter((item) => {
      return item.name.toLowerCase().includes(this.filterText.toLowerCase());
    });
  }

Here we are comparing each item by lowercase conversion and then comparing it with the user-searched term to filter the list and populate it in the filteredData.

 

Resetting the Filter

The Reset button is also called a resetFilter function which is clearing out the Input model value and re-assigning the original data that is whole data list to the filterData to display all the items:

  resetFilter() {
    this.filterText = '';
    this.filteredData = [...this.originalData];
  }

 

Conclusion

We have successfully implemented the Filter data list which is getting triggered only when a user clicks on a button which can be any kind of user action. The main thing to focus on here is how we can control the live filter process of data lists as types in the Input control.

Leave a Comment

Your email address will not be published. Required fields are marked *