Localization (i18n) Guide
Material React Table has full support for localization (i18n). Some locales are included by default, but if your language is not yet supported, you can still easily add your own custom translations to the localization
table option.
Relevant Table Options
# | Prop Name | Type | Default Value | More Info Links | |
---|---|---|---|---|---|
1 |
| Localization (i18n) Guide | |||
Built-in Locales
The following locales are included and can be imported from 'material-react-table/locales/'
:
ar
, az
, bg
, cs
, da
, de
, el
, en
, es
, et
, fa
, fi
, fr
, he
, hr
, hu
, hy
, id
, it
, ja
, ko
, nl
, no
, np
, pl
, pt
, pt-BR
, ro
, ru
, sk
, sr-Cyrl-RS
, sr-Latn-RS
, sv
, tr
, uk
, vi
, zh-Hans
, zh-Hant
If your language is not yet supported, please consider making a PR to add it to the library! See here on GitHub.
Built-in Locale Examples
Scroll and find your language below to see an example of how to use it.
Acciones | Seleccionar | Primer nombre | Apellido | Años |
---|---|---|---|---|
Kevin | 26 | |||
Theodore | 28 | |||
Tanner | 33 |
1//Import Material React Table and its Types2import { MaterialReactTable, type MRT_ColumnDef } from 'material-react-table';34//Import Material React Table Translations5import { MRT_Localization_ES } from 'material-react-table/locales/es';67//mock data8import { data, type Person } from './makeData';910const columns: MRT_ColumnDef<Person>[] = [11 //column definitions...26];2728const Example = () => {29 return (30 <MaterialReactTable31 columns={columns}32 data={data}33 enableColumnFilterModes34 enableColumnOrdering35 enableEditing36 enableColumnPinning37 enableRowActions38 enableRowSelection39 enableSelectAll={false}40 initialState={{ showColumnFilters: true, showGlobalFilter: true }}41 localization={MRT_Localization_ES}42 />43 );44};4546//App.tsx or similar47import { createTheme, ThemeProvider, useTheme } from '@mui/material';48import { esES } from '@mui/material/locale';4950const ExampleWithThemeProvider = () => {51 const theme = useTheme(); //replace with your theme/createTheme52 return (53 //Setting Material UI locale as best practice to result in better accessibility54 <ThemeProvider theme={createTheme(theme, esES)}>55 <Example />56 </ThemeProvider>57 );58};5960export default ExampleWithThemeProvider;61
Note: In some frameworks like Remix, you may need to use a full import path like
import { MRT_Localization_ES } from 'material-react-table/locales/es/index.js';
or
import { MRT_Localization_ES } from 'material-react-table/locales/es/index.esm.js';
to properly import the locale.
Custom Non-Built-In Translations
If you want to use a language that is not included in the library, you can still easily add your own custom translations to the localization
table option.
const table = useMaterialReactTable({columns,data,localization: {language: 'pt', // BCP 47 language tag for number formattingactions: 'Ações',and: 'e',cancel: 'Cancelar',changeFilterMode: 'Alterar o modo de filtro',changeSearchMode: 'Alterar o modo de pesquisa',clearFilter: 'Limpar filtros',clearSearch: 'Limpar pesquisa',clearSort: 'Limpar classificações',clickToCopy: 'Clique para copiar',// ... and many more - see link below for full list of translation keys},});return <MaterialReactTable table={table} />;
For a full list of all available translation keys, see here.
Please note that each localization object should include a language
property containing a valid BCP 47 language tag to ensure proper number formatting.
If you end up fully translating MRT into another language that is not yet supported, please consider making a PR to add it to the library so that everyone can use it!