Data Grid - Translated components
The data grid allows to support users from different locales, with formatting, and localized strings.
The default locale of MUI is English (United States). If you want to use other locales, follow the instructions below.
Translation keys
You can use the localeText
prop to pass in your own text and translations.
You can find all the translation keys supported in the source
in the GitHub repository.
In the following example, the labels of the density selector are customized.
Locale text
The default locale of MUI is English (United States).
You can use the theme to configure the locale text:
import { createTheme, ThemeProvider } from '@mui/material/styles';
import { DataGrid, bgBG } from '@mui/x-data-grid';
const theme = createTheme(
{
palette: {
primary: { main: '#1976d2' },
},
},
bgBG,
);
<ThemeProvider theme={theme}>
<DataGrid />
</ThemeProvider>;
Note that createTheme
accepts any number of arguments.
If you are already using the translations of the core components, you can add bgBG
as a new argument.
The same import works for DataGridPro
as it's an extension of DataGrid
.
import { createTheme, ThemeProvider } from '@mui/material/styles';
import { DataGrid, bgBG } from '@mui/x-data-grid';
import { bgBG as pickersBgBG } from '@mui/x-date-pickers/locales';
import { bgBG as coreBgBG } from '@mui/material/locale';
const theme = createTheme(
{
palette: {
primary: { main: '#1976d2' },
},
},
bgBG, // x-data-grid translations
pickersBgBG, // x-date-pickers translations
coreBgBG, // core translations
);
<ThemeProvider theme={theme}>
<DataGrid />
</ThemeProvider>;
If you want to pass language translations directly to the data grid without using createTheme
and ThemeProvider
, you can directly load the language translations from the @mui/x-data-grid
or @mui/x-data-grid-pro
package.
import { DataGrid, nlNL } from '@mui/x-data-grid';
<DataGrid localeText={nlNL.components.MuiDataGrid.defaultProps.localeText} />;
Supported locales
Locale | BCP 47 language tag | Import name | Completion | Source file |
---|---|---|---|---|
Arabic (Sudan) | ar-SD | arSD | 118/119 | Edit |
Belarusian | be-BY | beBY | 93/119 | Edit |
Bulgarian | bg-BG | bgBG | 87/119 | Edit |
Chinese (Simplified) | zh-CN | zhCN | Done ๐ | Edit |
Chinese (Taiwan) | zh-TW | zhTW | Done ๐ | Edit |
Czech | cs-CZ | csCZ | Done ๐ | Edit |
Danish | da-DK | daDK | 94/119 | Edit |
Dutch | nl-NL | nlNL | Done ๐ | Edit |
Finnish | fi-FI | fiFI | Done ๐ | Edit |
French | fr-FR | frFR | Done ๐ | Edit |
German | de-DE | deDE | Done ๐ | Edit |
Greek | el-GR | elGR | Done ๐ | Edit |
Hebrew | he-IL | heIL | 111/119 | Edit |
Hungarian | hu-HU | huHU | 117/119 | Edit |
Italian | it-IT | itIT | Done ๐ | Edit |
Japanese | ja-JP | jaJP | Done ๐ | Edit |
Korean | ko-KR | koKR | 92/119 | Edit |
Norwegian (Bokmรฅl) | nb-NO | nbNO | 94/119 | Edit |
Persian | fa-IR | faIR | Done ๐ | Edit |
Polish | pl-PL | plPL | 92/119 | Edit |
Portuguese (Brazil) | pt-BR | ptBR | Done ๐ | Edit |
Romanian | ro-RO | roRO | Done ๐ | Edit |
Russian | ru-RU | ruRU | Done ๐ | Edit |
Slovak | sk-SK | skSK | Done ๐ | Edit |
Spanish | es-ES | esES | Done ๐ | Edit |
Swedish | sv-SE | svSE | 94/119 | Edit |
Turkish | tr-TR | trTR | 104/119 | Edit |
Ukrainian | uk-UA | ukUA | Done ๐ | Edit |
Urdu (Pakistan) | ur-PK | urPK | 93/119 | Edit |
Vietnamese | vi-VN | viVN | Done ๐ | Edit |
You can find the source in the GitHub repository.
To create your own translation or to customize the English text, copy this file to your project, make any changes needed and import the locale from there. Note that these translations of the Data Grid component depend on the Localization strategy of the whole library.
RTL Support
Right-to-left languages such as Arabic, Persian, or Hebrew are supported. Follow this guide to use them.
The example below demonstrates how to use an RTL language (Arabic) with the data grid.