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

Downloads in past


1.3.422 days agoa year agoMinified + gzip package size for mantine-react-table in KB


Mantine React Table V1
View the Docs Site
An official fork of Material React Table
V1 released July 18, 2023


Quickly Create React Data Tables with Mantine

Built with Mantine V6 and TanStack Table V8


Learn More

Quick Examples

- Basic Table (See Default Features) - Minimal Table (Turn off Features like Pagination, Sorting, Filtering, and Toolbars) - Advanced Table (See some of the Advanced Features) - Aggregation/Grouping (Aggregation features such as Sum, Average, Count, etc.) - Data Export Table (Export to CSV, Excel, etc.) - Editing CRUD Table (Create, Edit, and Delete Rows) - Remote Data (Server-side Pagination, Sorting, and Filtering) - React Query (Server-side Pagination, Sorting, and Filtering, simplified) - Virtualized Rows (10,000 rows at once!) - Infinite Scrolling (Fetch data as you scroll) - Localization (i18n) (Over a dozen languages built-in)
View additional storybook examples


All features can easily be enabled/disabled
Fully Fleshed out Docs are available for all features
  • x < 44kb gzipped - Bundlephobia
  • x Advanced TypeScript Generics Support (TypeScript Optional)
  • x Aggregation and Grouping (Sum, Average, Count, etc.)
  • x Click To Copy Cell Values
  • x Column Action Dropdown Menu
  • x Column Hiding
  • x Column Ordering via Drag'n'Drop
  • x Column Pinning (Freeze Columns)
  • x Column Resizing
  • x Customize Icons
  • x Customize Styling of internal Mantine Components
  • x Data Editing (4 different editing modes)
  • x Density Toggle
  • x Detail Panels (Expansion)
  • x Filtering (supports client-side and server-side)
  • x Filter Match Highlighting
  • x Full Screen Mode
  • x Global Filtering (Search across all columns, rank by best match)
  • x Header Groups & Footers
  • x Localization (i18n) support
  • x Manage your own state or let the table manage it internally for you
  • x Pagination (supports client-side and server-side)
  • x Row Actions (Your Custom Action Buttons)
  • x Row Numbers
  • x Row Ordering via Drag'n'Drop
  • x Row Selection (Checkboxes)
  • x SSR compatible
  • x Sorting (supports client-side and server-side)
  • x Theming (Respects your Mantine Theme)
  • x Toolbars (Add your own action buttons)
  • x Tree Data / Expanding Sub-rows
  • x Virtualization (@tanstack/react-virtual)

Getting Started


View the full Installation Docs

  1. Ensure that you have React 17 or later installed

  1. Install Peer Dependencies (Mantine V6 and Tabler Icons)

npm install @mantine/core @mantine/hooks @mantine/dates @emotion/react @tabler/icons-react dayjs

  1. Install mantine-react-table

npm install mantine-react-table

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


Read the full usage docs here

import { useMemo, useState, useEffect } from 'react';
import { MantineReactTable, useMantineReactTable } from 'mantine-react-table';

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',
        mantineTableHeadCellProps: { 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 = useMantineReactTable({
    enableColumnOrdering: true, //enable some features
    enableRowSelection: true,
    enablePagination: false, //disable a default feature
    onRowSelectionChange: setRowSelection, //hoist row selection state to your state
    state: { rowSelection },
  return <MantineReactTable table={table} />;

Open in Code Sandbox


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.