Skip to content

A React DataGrid written in TypeScript, by a team with 20+ years of experience building data grids

Notifications You must be signed in to change notification settings

flexicious/react-data-grid

Repository files navigation

React DataGrid

This is a monorepo of all the samples and examples for the ReactDataGrid component. If you wish to get started with a smaller example, please see the ReactDataGrid Starter repo.

Installation

To get started, first clone the repo:

git clone https://github.com/flexicious/react-data-grid

Then install the dependencies:

npm install 

Running the examples

To run the examples, run the following command:

npm run start

Dashboard Example App

This repo is a NX monorepo, which means it has multiple packages. The main package in this repo is the dashboard package. In this package, you will find all examples that are hosted on the ReactDataGrid website. This is also the main package, so when you run npm run start, it will start the dashboard application. The dashboard application has no server side code, and is a pure React application. The api calls are mocked.

NextJS Example App with Knex and Sqlite

The nextjs-knex-react example is a full stack application, with a server side API, and a client side React application. The server side API is built using NextJS, and the database is Sqlite. The database is managed using Knex. The client side application is built using React, and uses the ReactDataGrid component. The server side API is built using NextJS, and the database is Sqlite. This example demonstrates a real world application with server side paging, filtering, sorting, and even a batched export/pdf functionality.

Additionally, this application demonstrates lazy loading of hierarchical data, so when you expand a row, it will load the child data from the server.

To run the nextjs-knex-react example, run the following commands:

npx nx serve nextjs-knex-react

This will start both the server side API, and the client side React application. Once the application is running, you can access the application at http://localhost:3000.

GraphQL Example App with Apollo Server and Apollo Client

The graphql-apollo example is a full stack application, with a server side API, and a client side React application. The server side API is built using Apollo Server, and the database is Sqlite. The client side application is built using React, and uses the ReactDataGrid component. This example demonstrates a real world application with server side paging, filtering, sorting, and even a batched export/pdf functionality.

To run the graphql-apollo example, run the following commands:

npx nx serve graphql-apollo-react

This will start both the server side API, and the client side React application. Once the application is running, you can access the application at http://localhost:4200.

SQL Builder Example App with NextJS and Sqlite

The sql-reactdatagrid example is a full stack application, built using NextJS, and Reacct. The database is Sqlite. The client side application uses the ReactDataGrid component. This example demonstrates a real world application with server side paging, filtering, sorting, and even a batched export/pdf functionality.

This application demonstrates lazy loading of all data, including filter dropdowns that show distinct values for the user to pick from. They will populate only when the user clicks no the down arrow button.

To run the sql-reactdatagrid example, run the following commands:

npx nx serve sql-react-datagrid

This will start both the server side API, and the client side React application. Once the application is running, you can access the application at http://localhost:3000.

Window scroll

The window-scroll example demonstrates how to use the ReactDataGrid component with a window scroll. This example is a pure React application, with no server side code. The api calls are mocked. The ReactDataGrid component is configured to use the window as the scroll container, and the window scroll is used to scroll the grid. This ensures there is only one scroll bar, and the grid is always in sync with the window scroll. Multiple vertical scroll bars are not a good user experience, and this example demonstrates how to avoid that. What is unique about our ReactDataGrid component is that even with window scroll, the grid retains its virtualization, and only renders the rows that are visible in the window.

To run the window-scroll example, run the following commands:

npx nx serve window-scroll

Lambda Genie Demo

The lambda-genie-demo example is a full stack application that integrates the following technologies:

  • NextJS for the server side API
  • Postgres for the database. You can use the postgres.lzo file in the root of the application to restore the database. Once you do this,
  • LambdaGenie Lambda Genie is a Cloud Native, Serverless solution featuring a Node.js Rules Engine, Intelligent Feature Flags, and Dynamic Configuration Management for AWS Lambda and Node.js Applications. We use this tool to manage our columns to dynamically configure the ReactDataGrid component.
  • ReactDataGrid for the client side datagrid.

You can run this application without a Lambda Genie account, because we include a full mock config located at apps/lambda-genie-demo/shared/lambda-genie/mock.ts. But if you wish to run this application with a real Lambda Genie account, you will need to do the following: First ensure you have a lambda genie account, and you have created a project. In this project, use the files in the apps/lambda-genie-demo/shared/lambda-genie/setup folder to create the following features:

  • A Schema Definition called GRID_CONFIG from apps/lambda-genie-demo/shared/lambda-genie/setup/schema/GridConfig.json
  • A Schema Definition called GRID_COLUMNS from apps/lambda-genie-demo/shared/lambda-genie/setup/schema/ColumnConfig.json
  • A Service/Module called GET_SCHOOL_DETAILS, under which you will use the above two schemas to make 2 configuration values:
    • GRID_DEFINITION of type GRID_CONFIG using the file apps/lambda-genie-demo/shared/lambda-genie/setup/config/GRID_DEFINITION.json
    • GRID_COLUMN_DEFINITION of type GRID_COLUMNS using the file apps/lambda-genie-demo/shared/lambda-genie/setup/config/GRID_COLUMN_DEFINITION.json You can follow the video here to see how this is done.: https://www.youtube.com/watch?v=6ZQY9Z1ZQ0o

Then, you will need to create a .env file in the root of the application, and add the following environment variables:

LAMBDA_GENIE_API_KEY=GET_FROM_LAMBDA_GENIE
PG_CONNECTION_STRING=postgres://USER:PASSWORD@HOST/DATABASE

Once you have done this, you can run the application using the following command:

npx nx serve lambda-genie-demo

Documentation

Getting Started Guide: https://reactdatagrid.com/docs/intro

Information

  • ReactDataGrid is a React component for displaying tabular data, built from the ground up for 2023, by a team with 20+ years of experience building datagrids.
  • It integrates deeply with Material UI, but thanks to its highly customizable rendering engine, it can be used with any UI framework, or without any UI framework at all. If you are already using Material UI, this datagrid will seamlessly integrate with your application in terms of user experience, theming, and customization.
  • It is very light weight without compromising on features, thanks to a combination of thoughtful design, modern tooling & ecosystem, plugin architecture, and ES6 modules. More on this below.
  • Built in React for React, with TypeScript.

About

A React DataGrid written in TypeScript, by a team with 20+ years of experience building data grids

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published