Framework:Javascript Data GridAngular Data GridReact Data GridVue Data Grid

React Data Grid: Full Width Rows

Under normal operation, AG Grid will render each row as a horizontal list of cells. Each cell in the row will correspond to one column definition. It is possible to switch this off and allow you to provide one component to span the entire width of the grid and not use columns. This is useful if you want to embed a complex component inside the grid instead of rendering a list of cells. This technique can be used for displaying panels of information.

You may be wondering what full width rows are useful for. Their usage is very rare and most applications will not use them. If you cannot think of a use case for it, then don't worry, do not use it. Full width rows were initially introduced into AG Grid to support Master / Detail before the grid provided direct support for master / detail. Now that master / detail is directly supported, the usefulness of full width is reduced.

Simple Example of Full Width Rows

Below shows a simple example using full width. The following can be noted:

  • The rows for countries France, Italy and Peru have full width components instead of cells.
  • Sorting and filtering all work as if the data was displayed as normal.

Understanding Full Width

A fullWidth (full width) component takes up the entire width of the grid. A full width component:

  • is not impacted by horizontal scrolling.
  • is the width of the grid, regardless of what columns are present.
  • is not impacted by pinned sections of the grid, will span left and right pinned areas regardless.
  • does not participate in the navigation, rangeSelection (AG Grid Enterprise) or contextMenu (AG Grid Enterprise) of the main grid.

To use fullWidth, you must:

  1. Implement the isFullWidthCell(rowNode) callback, to tell the grid which rows should be treated as fullWidth.
  2. Provide a fullWidthCellRenderer, to tell the grid what cellRenderer to use when doing fullWidth rendering.

The cell renderer can be any AG Grid cell renderer. Refer to Cell Rendering on how to build cell renderers. The cell renderer for fullWidth has one difference to normal cell renderers: the parameters passed are missing the value and column information as the cellRenderer, by definition, is not tied to a particular column. Instead you should work off the data parameter, which represents the value for the entire row.

The isFullWidthCell(rowNode) callback takes a rowNode as input and should return a boolean true (use fullWidth) or false (do not use fullWidth and render as normal).

Sorting and Filtering

Sorting and Filtering are NOT impacted by full width. Full width is a rendering time feature. The sorting and filtering applied to the data is done before rendering and is not impacted.

Detailed Full Width Example

Below shows a detailed full width example including pinned rows and columns. The example's data is minimalistic to focus on how the full width impacts rows. For demonstration, the pinned rows are shaded blue (with full width a darker shade of blue) and body full width rows are green. The following points should be noted:

  • Full width can be applied to any row, including pinned rows. The example demonstrates full width in pinned top, pinned bottom and body rows.
  • Full width rows can be of any height, which is specified in the usual way using the getRowHeight() callback. The example sets body fullWidth rows to 55px.
  • The pinned full width rows are not impacted by either the vertical or horizontal scrolling.
  • The body full width rows are impacted by vertical scrolling only, and not the horizontal scrolling.
  • The full width rows span the entire grid, including the pinned left and pinned right sections.
  • The full width rows are the width of the grid, despite the grid requiring horizontal scrolling to show the cells.
  • The example is showing a flat list of data. There is no grouping or parent / child relationships between the full width and normal rows.