Clue Mediator

How to set datasource to server side React AG Grid

📅August 25, 2022

In this article, we will show you how to set datasource to server side React AG Grid. Here, we will walk you through the process of setting up an external datasource to the server side AG Grid.

Here, we will add button to set the external datasource to the AG Grid on button click event.

Checkout more articles on React

Demo Application

How to set datasource to server side React AG Grid - Clue Mediator

Output - How to set datasource to server side React AG Grid - Clue Mediator

Package Version

ag-grid-react

^28.1.1

ag-grid-community

^28.1.1

Steps to set datasource to server side React AG Grid

  1. Add AG Grid in React component
  2. Create server side AG Grid
  3. Render the button to set the external datasource
  4. Output

1. Add AG Grid in React component

Let’s create a react application using the `create-react-app` and implement AG Grid in React. Check the following article for more information.

How to implement AG Grid in React

2. Create server side AG Grid

In the next step, we need to implement the REST API to render the AG Grid. Refer to the following article to implement server side AG Grid.

pagination-in-react-ag-grid" title="Implement server side pagination in React AG Grid">Implement server side pagination in React AG Grid

3. Render the button to set the external datasource

Let’s add the button to set external datasource to React AG Grid on button click. Here, we’ll use the following JSON data to render in Grid. Ensure that the external data source is in the same format as the listed columns.

[{
  id: 1,
  email: "[email protected]",
  first_name: "Julietta",
  last_name: "Norker",
  avatar: "https://robohash.org/eumporroexercitationem.png?size=50x50&set=set1"
}, {
  id: 2,
  email: "[email protected]",
  first_name: "Ros",
  last_name: "Beadel",
  avatar: "https://robohash.org/quaeratsedet.png?size=50x50&set=set1"
}, {
  id: 3,
  email: "[email protected]",
  first_name: "Ker",
  last_name: "Clemenson",
  avatar: "https://robohash.org/fugabeataepossimus.png?size=50x50&set=set1"
}]

Now, we have to use the `setDatasource()` method to set the data dynamically on button click. Check the following code.

const changeDataSource = () => {
  const data = [{
    id: 1,
    email: "[email protected]",
    first_name: "Julietta",
    last_name: "Norker",
    avatar: "https://robohash.org/eumporroexercitationem.png?size=50x50&set=set1"
  }, {
    id: 2,
    email: "[email protected]",
    first_name: "Ros",
    last_name: "Beadel",
    avatar: "https://robohash.org/quaeratsedet.png?size=50x50&set=set1"
  }, {
    id: 3,
    email: "[email protected]",
    first_name: "Ker",
    last_name: "Clemenson",
    avatar: "https://robohash.org/fugabeataepossimus.png?size=50x50&set=set1"
  }];

  const dataSource = {
    getRows: function (params) {
      params.successCallback(data, data.length);
    }
  };
  gridApi.setDatasource(dataSource);
}

Invoke the above function on button click and you will notice that the grid will change.

4. Output

Run the application and check the output in the browser.

I hope you find this article helpful.
Thank you for reading. Happy Coding..!! 🙂

Demo & Source Code

GitHub Repository StackBlitz Project