Installation
material-react-table
requires Material UI V5 packages as dependencies in your project.If you are already using Material UI, you probably already have most of these peer dependencies installed.
Just double-check that you have the following in your package.json, or use the full install commands below.
@mui/material
(v5)
@mui/icons-material
(v5)
@emotion/react
(v11)
@emotion/styled
(v11)
react
andreact-dom
(v17 or v18) - MUI v5 requires React 17 or 18
Quick Install
NPM
npm install material-react-table
PNPM
pnpm add material-react-table
Yarn
yarn add material-react-table
Install With Required Peer Dependencies (Recommended)
NPM
npm install material-react-table @mui/material @mui/icons-material @emotion/react @emotion/styled
PNPM
pnpm add material-react-table @mui/material @mui/icons-material @emotion/react @emotion/styled
Yarn
yarn add material-react-table @mui/material @mui/icons-material @emotion/react @emotion/styled
You do NOT need to install
@tanstack/react-table
, as it is already an internal dependency ofmaterial-react-table
, and must use an exact version already specified internally.All internal dependencies:
@tanstack/match-sorter-utils
,@tanstack/react-table
,@tanstack/react-virtual
, andhighlight-words
Common Errors
If you get an error like this:
"Error: Element type is invalid: expected a string (for built-in components)or a class/function (for composite components) but got: undefined.You likely forgot to export your component from the file it's defined in,or you might have mixed up default and named imports.
You probably do not have the correct version of Material UI installed. Make sure all material ui packages are at least v5
If you are using an older version of webpack
or create-react-app
and get an error like this:
./node_modules/@tanstack/virtual-core/build/lib/index.esm.js 147:92Module parse failed: Unexpected token (147:92)File was processed with these loaders:
Then try upgrading either webpack
or react-scripts
to the latest versions.
FAQs
Why is React 17 or 18 required for Material React Table?
React 17 or later is required by Material UI v5 itself. Some event listeners on MUI TextField components will not work with React 16.x.
Should I install '@tanstack/react-table' in my package.json for Material React Table?
No, you do not need to install TanStack Table in your project manually, as the latest TanStack Table version automatically gets installed under the hood by MRT itself as an internal dependency. You can import types and functions from '@tanstack/react-table' too.
Is TypeScript required to use Material React Table?
No, TypeScript is not required to use Material React Table, but it is a whole lot easier to use Material React Table with TypeScript, especially when defining columns. If you do use TypeScript, try to keep the latest TypeScript version installed, or at least TS version 4.8 or higher.