Data Grid - Localization
The Data Grid's localization features provide the appropriate translations and formatting for users around the world.
The default locale of MUI X is English (United States). 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 label of the quick filter placeholder is customized.
Locale text
The default locale of MUI X is English (United States).
You can use the theme to configure the locale text:
import { createTheme, ThemeProvider } from '@mui/material/styles';
import { DataGrid } from '@mui/x-data-grid';
import { bgBG } from '@mui/x-data-grid/locales';
// Or import { bgBG } from '@mui/x-data-grid-pro/locales';
// Or import { bgBG } from '@mui/x-data-grid-premium/locales';
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 Data Grid Pro as it's an extension of Data Grid.
import { createTheme, ThemeProvider } from '@mui/material/styles';
import { DataGrid } from '@mui/x-data-grid';
import { bgBG } from '@mui/x-data-grid/locales';
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 @mui/x-data-grid/locales
.
import { DataGrid } from '@mui/x-data-grid';
import { nlNL } from '@mui/x-data-grid/locales';
<DataGrid localeText={nlNL.components.MuiDataGrid.defaultProps.localeText} />;
Supported locales
Locale | BCP 47 language tag | Import name | Completion | Source file |
---|---|---|---|---|
Arabic (Sudan) | ar-SD | arSD | 121/219 | Edit |
Armenian | hy-AM | hyAM | 124/219 | Edit |
Bangla | bn-BD | bnBD | 133/219 | Edit |
Belarusian | be-BY | beBY | 90/219 | Edit |
Bulgarian | bg-BG | bgBG | 124/219 | Edit |
Chinese (Hong Kong) | zh-HK | zhHK | 137/219 | Edit |
Chinese (Simplified) | zh-CN | zhCN | 137/219 | Edit |
Chinese (Taiwan) | zh-TW | zhTW | 137/219 | Edit |
Croatian | hr-HR | hrHR | 142/219 | Edit |
Czech | cs-CZ | csCZ | 137/219 | Edit |
Danish | da-DK | daDK | 124/219 | Edit |
Dutch | nl-NL | nlNL | 127/219 | Edit |
Finnish | fi-FI | fiFI | 126/219 | Edit |
French | fr-FR | frFR | 154/219 | Edit |
German | de-DE | deDE | 191/219 | Edit |
Greek | el-GR | elGR | 116/219 | Edit |
Hebrew | he-IL | heIL | 133/219 | Edit |
Hungarian | hu-HU | huHU | 128/219 | Edit |
Icelandic | is-IS | isIS | 120/219 | Edit |
Indonesian | id-ID | idID | 191/219 | Edit |
Italian | it-IT | itIT | 215/219 | Edit |
Japanese | ja-JP | jaJP | 124/219 | Edit |
Korean | ko-KR | koKR | 188/219 | Edit |
Norwegian (Bokmål) | nb-NO | nbNO | 130/219 | Edit |
Norwegian (Nynorsk) | nn-NO | nnNO | 191/219 | Edit |
Persian | fa-IR | faIR | 125/219 | Edit |
Polish | pl-PL | plPL | 145/219 | Edit |
Portuguese | pt-PT | ptPT | 132/219 | Edit |
Portuguese (Brazil) | pt-BR | ptBR | 218/219 | Edit |
Romanian | ro-RO | roRO | 132/219 | Edit |
Russian | ru-RU | ruRU | 135/219 | Edit |
Slovak | sk-SK | skSK | 137/219 | Edit |
Spanish | es-ES | esES | 132/219 | Edit |
Swedish | sv-SE | svSE | 124/219 | Edit |
Turkish | tr-TR | trTR | 132/219 | Edit |
Ukrainian | uk-UA | ukUA | 135/219 | Edit |
Urdu (Pakistan) | ur-PK | urPK | 124/219 | Edit |
Vietnamese | vi-VN | viVN | 124/219 | 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.
Pagination number formatting
To format large numbers in the pagination component, customize the paginationDisplayedRows
with the following code:
import { DataGrid } from '@mui/x-data-grid';
// ======================================================
// TODO: replace with your locale
import { frFR as locale } from '@mui/x-data-grid/locales';
const LOCALE = 'fr-FR';
// ======================================================
function formatNumber(value: number | string) {
if (typeof Intl !== 'undefined' && Intl.NumberFormat) {
try {
const result = new Intl.NumberFormat(LOCALE).format(Number(value));
return result === 'NaN' ? String(value) : result;
} catch {
return String(value);
}
}
return String(value);
}
function paginationDisplayedRows({
from,
to,
count,
estimated,
}: {
from: number;
to: number;
count: number;
estimated?: number;
}) {
if (!estimated) {
return `${formatNumber(from)}–${formatNumber(to)} sur ${
count !== -1 ? formatNumber(count) : `plus de ${formatNumber(to)}`
}`;
}
const estimatedLabel =
estimated && estimated > to
? `environ ${formatNumber(estimated)}`
: `plus de ${formatNumber(to)}`;
return `${formatNumber(from)}–${formatNumber(to)} sur ${
count !== -1 ? formatNumber(count) : estimatedLabel
}`;
}
const localeText = {
...locale.components.MuiDataGrid.defaultProps.localeText,
paginationDisplayedRows,
};
function App() {
return (
<DataGrid
rowCount={1000000}
localeText={localeText}
/>
)
}