React Data GridGrid State

This section covers saving and restoring the grid state, such as the filter model, selected rows, etc.

Saving and Restoring State Copy Link

The initial state is provided via the grid option initialState. It is only read once when the grid is created.

const initialState = {
    filter: {
        filterModel: { 
            year: {
                filterType: 'set',
                values: ['2012'],
            }
        }
    },
    columnVisibility: {
        hiddenColIds: ['athlete'],
    },
    rowGroup: {
        groupColIds: ['athlete'],
    }
};

<AgGridReact initialState={initialState} />

The current grid state can be retrieved by listening to the state updated event, which is fired with the latest state when it changes, or via api.getState().

The state is also passed in the Grid Pre-Destroyed Event, which can be used to get the state when the grid is destroyed.

gridPreDestroyedCopy Link
GridPreDestroyedEvent
Invoked immediately before the grid is destroyed. This is useful for cleanup logic that needs to run before the grid is torn down.
stateUpdatedCopy Link
StateUpdatedEvent
Grid state has been updated.

State Contents Copy Link

The following is captured in the grid state:

When restoring the current page using the Server Side Row Model or Infinite Row Model, additional configuration is required:

  • For the Server Side Row Model - set the serverSideInitialRowCount property to a value which includes the rows to be shown.
  • For the Infinite Row Model - set the infiniteInitialRowCount property to a value which includes the rows to be shown.

All state properties are optional, so a property can be excluded if you do not want to restore it.

If applying some but not all of the column state properties, then initialState.partialColumnState must be set to true.

The state also contains the grid version number. When applying state with older version numbers, any old state properties will be automatically migrated to the current format.

The grid state is designed to be serialisable, so any functions will be stripped out. For example, aggregation functions should be Registered as Custom Functions to work with state rather than being set as Directly Applied Functions.

Properties available on the GridState interface.

versionCopy Link
string
Grid version number
aggregationCopy Link
AggregationState
Includes aggregation functions (column state)
columnGroupCopy Link
ColumnGroupState
Includes opened groups
columnOrderCopy Link
ColumnOrderState
Includes column ordering (column state)
columnPinningCopy Link
ColumnPinningState
Includes left/right pinned columns (column state)
columnSizingCopy Link
ColumnSizingState
Includes column width/flex (column state)
columnVisibilityCopy Link
ColumnVisibilityState
Includes hidden columns (column state)
filterCopy Link
FilterState
Includes Column Filters and Advanced Filter
focusedCellCopy Link
FocusedCellState
Includes currently focused cell. Works for Client-Side Row Model only
paginationCopy Link
PaginationState
Includes current page
rowPinningCopy Link
RowPinningState
Includes currently manually pinned rows
PivotState
Includes current pivot mode and pivot columns (column state)
cellSelectionCopy Link
CellSelectionState
Includes currently selected cell ranges
rowGroupCopy Link
RowGroupState
Includes current row group columns (column state)
rowGroupExpansionCopy Link
RowGroupExpansionState
Includes currently expanded group rows
rowSelectionCopy Link
string[] | ServerSideRowSelectionState | ServerSideRowGroupSelectionState
Includes currently selected rows. For Server-Side Row Model, will be ServerSideRowSelectionState | ServerSideRowGroupSelectionState, for other row models, will be an array of row IDs. Can only be set for Client-Side Row Model and Server-Side Row Model.
scrollCopy Link
ScrollState
Includes current scroll position. Works for Client-Side Row Model only
sideBarCopy Link
SideBarState
Includes current Side Bar positioning and opened tool panel
SortState
Includes current sort columns and direction (column state)
partialColumnStateCopy Link
boolean
When providing a partial initialState with some but not all column state properties, set this to true. Not required if passing the whole state object retrieved from the grid.

Converting Column State to Grid State Copy Link

State retrieved via the Column State APIs can be converted into grid state via the helper functions convertColumnState and convertColumnGroupState.

const state = {
    ...convertColumnState(columnState),
    ...convertColumnGroupState(columnGroupState)
};