GitPedia

Material react table

A fully featured Material UI V5 implementation of TanStack React Table V8, written from the ground up in TypeScript

From KevinVandy·Updated June 13, 2026·View on GitHub·

**material react table** is A fully featured Material UI V5 implementation of TanStack React Table V8, written from the ground up in TypeScript The project is written primarily in TypeScript, distributed under the MIT License license, first published in 2022. It has gained significant community traction with 1,793 stars and 535 forks on GitHub. Key topics include: data-table, datagrid, material-table, material-ui, react.

Latest release: v3.2.1
March 1, 2025View Changelog →

Material React Table V3

View Documentation

<a href="https://npmjs.com/package/material-react-table" target="_blank"> <img alt="" src="https://badgen.net/npm/v/material-react-table?color=blue" /> </a> <a href="https://npmtrends.com/material-react-table" target="_blank"> <img alt="" src="https://badgen.net/npm/dt/material-react-table?label=installs&icon=npm&color=blue" /> </a> <a href="https://bundlephobia.com/result?p=material-react-table" target="_blank"> <img alt="" src="https://badgen.net/bundlephobia/minzip/material-react-table@latest?color=blue" /> </a> <a href="https://star-history.com/#kevinvandy/material-react-table&Date" target="_blank"> <img alt="" src="https://badgen.net/github/stars/KevinVandy/material-react-table?color=blue" /> </a> <a href="https://github.com/KevinVandy/material-react-table/blob/v3/LICENSE" target="_blank"> <img alt="" src="https://badgen.net/github/license/KevinVandy/material-react-table?color=blue" /> </a> <a href="https://github.com/sponsors/kevinvandy" target="_blank" rel="noopener" > <img alt="" src="https://img.shields.io/badge/sponsor-violet" /> </a> <a href="https://discord.gg/5wqyRx6fnm" target="_blank" rel="noopener" > <img alt="" src="https://dcbadge.vercel.app/api/server/5wqyRx6fnm?style=flat"> </a>

About

Quickly Create React Data Tables with Material Design

Built with Material UI <sup>V6</sup> and TanStack Table <sup>V8</sup>

<img src="https://material-react-table.com/banner.png" alt="MRT" height="50" />

Want to use Mantine instead of Material UI? Check out Mantine React Table

Learn More

Quick Examples

View additional storybook examples

Features

All features can easily be enabled/disabled

Fully Fleshed out Docs are available for all features

  • 30-56kb gzipped - Bundlephobia
  • Advanced TypeScript Generics Support (TypeScript Optional)
  • Aggregation and Grouping (Sum, Average, Count, etc.)
  • Cell Actions (Right-click Context Menu)
  • Click To Copy Cell Values
  • Column Action Dropdown Menu
  • Column Hiding
  • Column Ordering via Drag'n'Drop
  • Column Pinning (Freeze Columns)
  • Column Resizing
  • Customize Icons
  • Customize Styling of internal Mui Components
  • Data Editing and Creating (5 different editing modes)
  • Density Toggle
  • Detail Panels (Expansion)
  • Faceted Value Generation for Filter Options
  • Filtering (supports client-side and server-side)
  • Filter Match Highlighting
  • Full Screen Mode
  • Global Filtering (Search across all columns, rank by best match)
  • Header Groups & Footers
  • Localization (i18n) support
  • Manage your own state or let the table manage it internally for you
  • Pagination (supports client-side and server-side)
  • Row Actions (Your Custom Action Buttons)
  • Row Numbers
  • Row Ordering via Drag'n'Drop
  • Row Pinning
  • Row Selection (Checkboxes)
  • SSR compatible
  • Sorting (supports client-side and server-side)
  • Theming (Respects your Material UI Theme)
  • Toolbars (Add your own action buttons)
  • Tree Data / Expanding Sub-rows
  • Virtualization (@tanstack/react-virtual)

Getting Started

Installation

View the full Installation Docs

  1. Ensure that you have React 18 or later installed

  2. Install Peer Dependencies (Material UI V6)

bash
npm install @mui/material @mui/x-date-pickers @mui/icons-material @emotion/react @emotion/styled
  1. Install material-react-table
bash
npm install material-react-table

@tanstack/react-table, @tanstack/react-virtual, and @tanstack/match-sorter-utils are internal dependencies, so you do NOT need to install them yourself.

Usage

Read the full usage docs here

jsx
import { useMemo, useState, useEffect } from 'react'; import { MaterialReactTable, useMaterialReactTable, } from 'material-react-table'; //data must be stable reference (useState, useMemo, useQuery, defined outside of component, etc.) const data = [ { name: 'John', age: 30, }, { name: 'Sara', age: 25, }, ]; export default function App() { const columns = useMemo( () => [ { accessorKey: 'name', //simple recommended way to define a column header: 'Name', muiTableHeadCellProps: { sx: { color: 'green' } }, //optional custom props Cell: ({ cell }) => <span>{cell.getValue()}</span>, //optional custom cell render }, { accessorFn: (row) => row.age, //alternate way id: 'age', //id required if you use accessorFn instead of accessorKey header: 'Age', Header: () => <i>Age</i>, //optional custom header render }, ], [], ); //optionally, you can manage any/all of the table state yourself const [rowSelection, setRowSelection] = useState({}); useEffect(() => { //do something when the row selection changes }, [rowSelection]); const table = useMaterialReactTable({ columns, data, enableColumnOrdering: true, //enable some features enableRowSelection: true, enablePagination: false, //disable a default feature onRowSelectionChange: setRowSelection, //hoist internal state to your own state (optional) state: { rowSelection }, //manage your own state, pass it back to the table (optional) }); const someEventHandler = () => { //read the table state during an event from the table instance console.log(table.getState().sorting); }; return ( <MaterialReactTable table={table} /> //other more lightweight MRT sub components also available ); }

Open in Code Sandbox

Contributors

<a href="https://github.com/kevinvandy/material-react-table/graphs/contributors"> <img src="https://contrib.rocks/image?repo=kevinvandy/material-react-table" /> </a>

PRs are Welcome, but please discuss in GitHub Discussions or the Discord Server first if it is a large change!

Read the Contributing Guide to learn how to run this project locally.

<!-- Use the FORCE, Luke! -->

Contributors

Showing top 12 contributors by commit count.

View all contributors on GitHub →

This article is auto-generated from KevinVandy/material-react-table via the GitHub API.Last fetched: 6/16/2026