DataGridPremium API
API reference docs for the React DataGridPremium component. Learn about the props, CSS, and other APIs of this exported module.
For examples and details on the usage of this React component, visit the component demo pages:
import { DataGridPremium } from '@mui/x-data-grid-premium/DataGridPremium';
import { DataGridPremium } from '@mui/x-data-grid-premium';
Learn about the difference by reading this guide on minimizing bundle size.
Column region in pixels to render before/after the viewport
Sets the height in pixel of the column headers in the Data Grid.
Set the column visibility model of the Data Grid. If defined, the Data Grid will ignore the hide
property in GridColDef.
The row ids to show the detail panel.
Type:Array<number
| string>
If true
, column filters are disabled.
If true
, the column menu is disabled.
If true
, the column pinning is disabled.
If true
, reordering columns is disabled.
If true
, resizing columns is disabled.
If true
, hiding/showing columns is disabled.
If true
, the column sorting feature will be disabled.
If true
, filtering with multiple columns is disabled.
If true
, the sorting with multiple columns is disabled.
Determines if a group should be expanded after its creation. This prop takes priority over the defaultGroupingExpansionDepth
prop.
Type:func
Signature:function(node: GridGroupNode) => boolean
node
The node of the group to test.
Returns: A boolean indicating if the group is expanded.
If true
, moving the mouse pointer outside the grid before releasing the mouse button in a column re-order action will not cause the column to jump back to its original position.
Callback fired when a click event comes from a column header element.
Type:func
Signature:function(params: GridColumnHeaderParams, event: MuiEvent, details: GridCallbackDetails) => void
params
With all properties from GridColumnHeaderParams.event
The event object.details
Additional details for this callback.
Callback fired when a double click event comes from a column header element.
Type:func
Signature:function(params: GridColumnHeaderParams, event: MuiEvent, details: GridCallbackDetails) => void
params
With all properties from GridColumnHeaderParams.event
The event object.details
Additional details for this callback.
Callback fired when a mouse enter event comes from a column header element.
Type:func
Signature:function(params: GridColumnHeaderParams, event: MuiEvent, details: GridCallbackDetails) => void
params
With all properties from GridColumnHeaderParams.event
The event object.details
Additional details for this callback.
Callback fired when a mouse leave event comes from a column header element.
Type:func
Signature:function(params: GridColumnHeaderParams, event: MuiEvent, details: GridCallbackDetails) => void
params
With all properties from GridColumnHeaderParams.event
The event object.details
Additional details for this callback.
Callback fired when a mouseout event comes from a column header element.
Type:func
Signature:function(params: GridColumnHeaderParams, event: MuiEvent, details: GridCallbackDetails) => void
params
With all properties from GridColumnHeaderParams.event
The event object.details
Additional details for this callback.
Callback fired when a mouseover event comes from a column header element.
Type:func
Signature:function(params: GridColumnHeaderParams, event: MuiEvent, details: GridCallbackDetails) => void
params
With all properties from GridColumnHeaderParams.event
The event object.details
Additional details for this callback.
Callback fired when a column is reordered.
Type:func
Signature:function(params: GridColumnOrderChangeParams, event: MuiEvent<{}>, details: GridCallbackDetails) => void
params
With all properties from GridColumnOrderChangeParams.event
The event object.details
Additional details for this callback.
Callback fired while a column is being resized.
Type:func
Signature:function(params: GridColumnResizeParams, event: MuiEvent, details: GridCallbackDetails) => void
params
With all properties from GridColumnResizeParams.event
The event object.details
Additional details for this callback.
Callback fired when the column visibility model changes.
Type:func
Signature:function(model: GridColumnVisibilityModel, details: GridCallbackDetails) => void
model
The new model.details
Additional details for this callback.
Callback fired when the width of a column is changed.
Type:func
Signature:function(params: GridColumnResizeParams, event: MuiEvent, details: GridCallbackDetails) => void
params
With all properties from GridColumnResizeParams.event
The event object.details
Additional details for this callback.
Callback fired when the detail panel of a row is opened or closed.
Type:func
Signature:function(ids: Array, details: GridCallbackDetails) => void
ids
The ids of the rows which have the detail panel open.details
Additional details for this callback.
Callback fired when the pinned columns have changed.
Type:func
Signature:function(pinnedColumns: GridPinnedColumnFields, details: GridCallbackDetails) => void
pinnedColumns
The changed pinned columns.details
Additional details for this callback.
The column fields to display pinned to left or right.
If single
, all the columns that are grouped are represented in the same grid column. If multiple
, each column that is grouped is represented in its own grid column.
Type:'multiple'
| 'single'
Default:'single'
If true
, vertical borders will be displayed between column header items.
The ref
is forwarded to the root element.
Sort icon component rendered in each column header.
Default component: GridColumnHeaderSortIcon
Column menu component rendered by clicking on the 3 dots "kebab" icon in column headers.
Default component: GridColumnMenu
Component responsible for rendering the column headers.
Class name: .MuiDataGridPremium-columnHeaders
Default component: GridColumnHeaders
GridColumns panel component rendered when clicking the columns button.
Default component: GridColumnsPanel
Component used inside Grid Columns panel to manage columns.
Class name: .MuiDataGridPremium-columnsManagement
Default component: GridColumnsManagement
Icon displayed on the side of the column header title to display the filter input component.
Default component: GridTripleDotsVerticalIcon
Icon displayed on the column header menu to show that a filter has been applied to the column.
Default component: GridFilterAltIcon
Icon displayed on the column menu selector tab.
Default component: GridColumnIcon
Icon displayed on the side of the column header title when unsorted.
Default component: GridColumnUnsortedIcon
Icon displayed on the side of the column header title when sorted in ascending order.
Default component: GridArrowUpwardIcon
Icon displayed on the side of the column header title when sorted in descending order.
Default component: GridArrowDownwardIcon
Icon displayed in between two column headers that allows to resize the column header.
Default component: GridSeparatorIcon
Icon displayed on the standard density option in the toolbar.
Default component: GridTableRowsIcon
Icon displayed on the tree data toggling column when the children are collapsed
Default component: GridKeyboardArrowRight
Icon displayed on the grouping column when the children are collapsed
Default component: GridKeyboardArrowRight
Icon displayed on the detail panel toggle column when collapsed.
Default component: GridAddIcon
Icon displayed in column menu for hiding column
Default component: GridVisibilityOffIcon
Icon displayed in column menu for ascending sort
Default component: GridArrowUpwardIcon
Icon displayed in column menu for descending sort
Default component: GridArrowDownwardIcon
Icon displayed in column menu for filter
Default component: GridFilterAltIcon
Icon displayed in column menu for showing all columns
Default component: GridViewColumnIcon
Icon displayed in column menu for clearing values
Default component: GridClearIcon
Icon displayed on the column reorder button.
Default component: GridDragIcon
Icon displayed in column menu for left pinning
Default component: GridPushPinLeftIcon
Icon displayed in column menu for right pinning
Default component: GridPushPinRightIcon
Icon displayed in column menu for ungrouping
Default component: GridWorkspacesIcon
Icon displayed in column menu for grouping
Default component: GridGroupWorkIcon
Icon displayed in column menu for aggregation
Default component: GridFunctionsIcon
These class names are useful for styling with CSS. They are applied to the component's slots when specific states are triggered.
Styles applied to the root element of the column header when aggregated.
Rule name:aggregationColumnHeader
Styles applied to the root element of the header when aggregation if headerAlign="center"
.
Rule name:aggregationColumnHeader--alignCenter
Styles applied to the root element of the header when aggregation if headerAlign="left"
.
Rule name:aggregationColumnHeader--alignLeft
Styles applied to the root element of the header when aggregation if headerAlign="right"
.
Rule name:aggregationColumnHeader--alignRight
Styles applied to the aggregation label in the column header when aggregated.
Rule name:aggregationColumnHeaderLabel
Styles applied to the column header element.
Rule name:columnHeader
Styles applied to the column header if headerAlign="center"
.
Rule name:columnHeader--alignCenter
Styles applied to the column header if headerAlign="left"
.
Rule name:columnHeader--alignLeft
Styles applied to the column header if headerAlign="right"
.
Rule name:columnHeader--alignRight
Styles applied to the floating column header element when it is dragged.
Rule name:columnHeader--dragging
Styles applied to the empty column group header cell.
Rule name:columnHeader--emptyGroup
Styles applied to the column group header cell if not empty.
Rule name:columnHeader--filledGroup
Styles applied to the column header if the column has a filter applied to it.
Rule name:columnHeader--filtered
Styles applied to the last column header element.
Rule name:columnHeader--last
Styles applied to the column header if it is being dragged.
Rule name:columnHeader--moving
Styles applied to the column header if the type of the column is number
.
Rule name:columnHeader--numeric
Rule name:columnHeader--pinnedLeft
Rule name:columnHeader--pinnedRight
Styles applied to the column header if the column is sortable.
Rule name:columnHeader--sortable
Styles applied to the column header if the column is sorted.
Rule name:columnHeader--sorted
Rule name:columnHeader--withLeftBorder
Styles applied the column header if showColumnVerticalBorder={true}
.
Rule name:columnHeader--withRightBorder
Styles applied to the header checkbox cell element.
Rule name:columnHeaderCheckbox
Styles applied to the column header's draggable container element.
Rule name:columnHeaderDraggableContainer
Styles applied to the column header's title element;
Rule name:columnHeaderTitle
Styles applied to the column header's title container element.
Rule name:columnHeaderTitleContainer
Styles applied to the column header's title excepted buttons.
Rule name:columnHeaderTitleContainerContent
Styles applied to the column header separator element.
Rule name:columnSeparator
Styles applied to the column header separator if the column is resizable.
Rule name:columnSeparator--resizable
Styles applied to the column header separator if the column is being resized.
Rule name:columnSeparator--resizing
Styles applied to the column header separator if the side is "left".
Rule name:columnSeparator--sideLeft
Styles applied to the column header separator if the side is "right".
Rule name:columnSeparator--sideRight
Styles applied to the columns management header element.
Rule name:columnsManagementHeader
Styles applied to the columns management row element.
Rule name:columnsManagementRow
Styles applied to the detail panel toggle cell element if expanded.
Rule name:detailPanelToggleCell--expanded
Styles applied to the main container element.
Rule name:main
Styles applied to the main container element when it has right pinned columns.
Rule name:main--hasPinnedRight
Styles applied to the pinned columns.
Rule name:pinnedColumns
Styles applied to the root element if density is "standard" (default).
Rule name:root--densityStandard
Styles applied to the row if its detail panel is open.
Rule name:row--detailPanelExpanded
You can override the style of the component using one of these customization options: