Refreshing Set Filter items after data update when using Server-side data in ag-Grid

This post will show you how to refresh set filter items after a data update when you're using server-side row model in ag-Grid. Set filter items update automatically in response to data updates when you're using the client-side row model (use for datasets with fewer than 30,000 rows). However, when you're using the ag-Grid server-side row model, you need to implement this set filter update logic with user code.

In this blogpost we'll show you how to build exactly this user code. This way you can deliver a great filtering experience and make your application easy to use.

We will implement code for set filter refresh in response to adding, updating and deleting rows which match the filter condition.

Live example

Please see the live demo below, which is built in Vanilla JavaScript. In this sample, please edit the AGE column values or click the buttons above the grid to add/remove/update rows. Then, open the AGE column filter and see the filter values were updated in response to that data update.

You can also open the example implemented using other frameworks with the links below:

•  Angular
 •  React
 •  Vue

Let's see how to implement this for the different types of edits you can do.

Contents

How does the Set Filter refresh?

There are a couple of ways to refresh the Set Filter items when there is a data update. These methods are detailed in our documentation.

Refresh set filter every time it is opened

The examples in this blog are refreshing the values every time the Set Filter is opened by adding the property refreshValuesOnOpen to the filterParams:

var columnDefs = [
  // [...]
  {
    field: 'age',
    filter: true,
    filterParams: {
      values: function (params) {
        let asyncValues = fakeServer.getAges();
        setTimeout(function () {
          params.success(asyncValues);
        }, 500);
      },
      refreshValuesOnOpen: true,
    },
  },
];

Refresh set filter values at a later point

If you want to avoid refreshing the Set Filters every time, you can refresh manually by getting the instance of the filter and calling the method refreshFilterValues() as shown below:

let ageFilter = gridOptions.api.getFilterInstance('age');
ageFilter.refreshFilterValues();

See this in action in the sample below which has the Set Filter displayed at all times by enabling the Filter Tool Panel:

Adding a new row with a value matching the filter condition

When you add a new row which matches the filter condition, it needs to be displayed in the filtered grid.

Follow the steps below to see this in action:

  1. Open the Age column filter and select the value 20. The grid will then show all rows with age=20.
  2. Click on the Add Athlete button. The newly added row will be displayed in the filtered grid because it matches the filter condition (it also has an age of 20).

You can see this illustrated in the following GIF:

Adding a new athlete row whilst filtering on age

How it works

After adding the new row to the server-side data, we call purgeServerSideCache to update this on the server and refresh the grid:

let athleteNames = ['Michael Phelps', 'Cindy Klassen', 'Nastia Liukin'];

function onBtnAddRow() {
  // mimic server side adding row
  const data = fakeServer.getData();
  data.push({
    id: data.length === 0 ? 0 : data[data.length - 1].id + 1,
    athlete: athleteNames[data.length % athleteNames.length],
    age: 20,
  });

  gridOptions.api.purgeServerSideCache();
}

Updating the filtered column value of a row matching the filter condition

Let's now see how ag-Grid and the set filter react to an update to one of the filtered rows via API.

Learn how to perform update operations using the Server-Side Row Model in our documentation

Follow the steps below to see this in action:

  1. Open the Age column filter and check items 20 and 23. The grid will then show athletes with age of 20 OR 23
  2. Select an athlete with age=20 from the grid and click on the Update Selected Athlete Age button to update the age. The selected athlete will have its age incremented by 1 to now be 21.

This produces two effects:

  1. The selected athlete age has been updated to 21 and is subsequently removed from the view (as it no longer matches the filter condition - 20 OR 23)
  2. The Age set filter items are now 21 and 23, since the age value 20 is no longer present in the grid, and the value 21 is now present.

This is shown in the following GIF:

How it works

When the button is clicked, we find the selected rows in the grid based on their ID, increment the Age value, tell the server to update them (via mock method updateServerRows) and re-filter the grid by calling the onFilterChanged event. This is shown below:

function onBtnUpdateData() {
  var idsToUpdate = gridOptions.api.getSelectedNodes().map(function (node) {
    return node.data.id;
  });
  // we are updating all the data
  let updatedRows = [];
  gridOptions.api.forEachNode((node) => {
    if (idsToUpdate.indexOf(node.data.id) >= 0) {
      let updated = { ...node.data };
      updated.age += 1;
      node.setData(updated);
      updatedRows.push(updated);
    }
  });

  // mimic server side update
  updateServerRows(updatedRows);
  gridOptions.api.onFilterChanged();
}

Updating the filtered column of a row matching the filter condition via Cell Editing

Another way of updating cells is via cell editing by pressing the Enter key or double clicking on the selected cell. See this in action in the GIF below:

How it works

When a new value is set in the edited cell the grid event onCellValueChanged is fired and we send the updated row data to the mock method updateServerRows to update the data from the mock server, followed by re-filtering the grid using the onFilterChanged event.

var gridOptions = {
  // ...,
  onCellValueChanged: function (params) {
    // trigger filtering on cell edits
    let updatedRow = [{ ...params.data }];
    updateServerRows(updatedRow);
    params.api.onFilterChanged();
  },
};

Deleting a row which matches the filter condition

When we delete the last row containing a value that appears in the set filter items, the ag-Grid set filter will remove this value from its items as it no longer appears in the grid.

Follow the steps below:

  1. Open the Age filter and select value 20. There is one row which passes the filter condition.
  2. Select that row and click the button Delete Selected Athlete. This will delete the row from the grid and since it was the only row in the grid with Age value of 20, the value 20 will be removed from the Set Filter items. Thi way the filter will only show 21 and 23 - the only Age values present in the grid)

How it works

The row is deleted from the server-side data and the grid is refreshed by calling purgeServerSideCache as implemented in the code below:

function onBtnDeleteSelectedRow() {
  var selectedRows = gridOptions.api.getSelectedNodes();
  const data = fakeServer.getData();
  if (!selectedRows || selectedRows.length === 0) {
    return;
  }

  var selectedRow = selectedRows[0];
  var selectedRowId = selectedRow.data.id;

  let index = data.findIndex((row) => row.id == selectedRowId);

  if (index != -1) {
    data.splice(index, 1);
  }

  gridOptions.api.purgeServerSideCache();
}

What's next?

We hope that you find this article useful whenever you're looking to work with set filters and the server-side row model in ag-Grid. Please use the samples above and modify them as you see fit.

If you would like to try out ag-Grid check out our getting started guides (JS / React / Angular / Vue)