JavaScript Data GridRow Grouping - Grouping Data

Enterprise

Enable grouping on a column to group rows by equivalent values.

Enabling Row Grouping Copy Link

Row Grouping is enabled by setting rowGroup to true on one or more Column Definition. Parent rows are then introduced for each unique value in that column, containing the rows with that value.

The example above uses the following configuration to group rows by their country values:

const gridOptions = {
    columnDefs: [
        { field: 'country', rowGroup: true },
        // ...other column definitions
    ],

    // other grid options ...
}

Grouping by Multiple Columns Copy Link

When grouping on multiple columns using rowGroup, the order of columns within the column definitions is used to determine which column to group by first. This can be overridden with a custom order by providing the rowGroupIndex property in each grouped columns definition.

The example above demonstrates the following configuration for grouping rows by year first, and country second:

const gridOptions = {
    columnDefs: [
        { field: 'country', rowGroupIndex: 1 },
        { field: 'year', rowGroupIndex: 0 },
        // ...other column definitions
    ],

    // other grid options ...
}

Grouping on Object Data Copy Link

When grouping on object data, the grid needs a way to compare items to determine if they are equivalent. Setting a keyCreator on the grouped column definition provides the grid with string keys it can compare.

keyCreatorCopy Link
Function
Function to return a string key for a value. This string is used for grouping, Set filtering, and searching within cell editor dropdowns. When filtering and searching the string is exposed to the user, so make sure to return a human-readable value.

The following example uses a custom set of rows, each containing an athlete field that maps to objects with id and name properties.

This demonstrates the following configuration for grouping rows by the athlete objects by their id property:

const gridOptions = {
    columnDefs: [
        {
            field: 'athlete',
            rowGroup: true,
            keyCreator: (params) => params.value.id,
            valueFormatter: (params) => params.value.name,
        },
        // ...other column definitions
    ],

    // other grid options ...
}

Grouping by Dates and Times Copy Link

When grouping by date/time values, the grid can optionally group by components of the date/time.

To enable grouping by parts of the date for a particular column, use the groupHierarchy property of the Column Definition.

Specify a grouping hierarchy for this column. This generates one or more virtual columns to group or pivot by when this column is grouped or pivoted. This can be used to group/pivot by values derived from a source column. The grid provides hierarchy types related to date components. Users can provide their own hierarchy types by specifying a ColDef, or referring to the name of a hierarchy type defined in groupHierarchyConfig.
const gridOptions = {
    columnDefs: [
        {
            field: 'date',
            rowGroup: true,
            groupHierarchy: ['year', 'month']
        },
        // ...other column definitions
    ],

    // other grid options ...
}

This snippet is illustrated in the example below.

By default, the grid requires datetime values to be formatted using the ISO-8601 format in order to be correctly parsed into their components.

To use other date formats, provide a custom Cell Data Type Definition for the dateString and/or dateTimeString data types.

Defining Custom Grouping Hierarchies Copy Link

When using groupHierarchy as demonstrated in Grouping by Dates and Times, the grid provides built-in support for several components of a date/time value.

Users may instead provide definitions of their own components via the groupHierarchyConfig grid option. These definitions may then be used in the groupHierarchy property of a column definition.

groupHierarchyConfigCopy Link
{ [k: string]: ColDef }
Custom group hierarchy components can be defined here for later use in colDef.groupHierarchy

The following example illustrates this by defining a custom grouping hierarchy component that allows grouping by the week number:

Grouping on Null and Undefined Data Copy Link

When grouping null, undefined or "" (empty string) values the grid will group these together under the heading (Blanks) as the final group.

By setting the groupAllowUnbalanced property to true, the grid will instead display these rows without a group.

To enable unbalanced grouping, the following configuration is used:

const gridOptions = {
    groupAllowUnbalanced: true,

    // other grid options ...
}

Hiding Parents of Individual Rows Copy Link

Groups with only a single child can be hidden from the grid by setting the groupHideParentOfSingleChild grid option to true. To remove only groups with a single leaf child, set this option to "leafGroupsOnly" instead.

Filtering does not impact which groups get removed. Only groups containing a single child prior to filtering being applied are removed.

The following is an example of the configuration used to hide all parents of a single row:

const gridOptions = {
    groupHideParentOfSingleChild: true,

    // other grid options ...
}

The properties groupHideParentOfSingleChild and groupHideOpenParents are mutually exclusive.

Next Up Copy Link

Continue to the next section to learn about the different Row Grouping Display Types.