Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

material-react-table

KevinVandy690.4kMIT3.2.1TypeScript support: included

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

react-table, material-ui, material-table, tanstack table, data table

readme

Material React Table V3

View Documentation

About

Quickly Create React Data Tables with Material Design

Built with Material UI V6 and TanStack Table V8

MRT

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

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

npm install @mui/material @mui/x-date-pickers @mui/icons-material @emotion/react @emotion/styled
  1. Install material-react-table
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

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

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.