JavaScript Data GridPivot Column Groups

Enterprise

The grid generates pivot column groups representing each unique pivoted value.

Customising Group Definitions Copy Link

Pivot Result Column Group definitions can be configured using the processPivotResultColGroupDef grid option.

processPivotResultColGroupDefCopy Link
Function
Callback for the mutation of the generated pivot result column group definitions

In the example below, the processPivotResultColGroupDef callback is used to apply a class to the group header cells, which is subsequently used to style them with a golden background.

This demonstrates the following configuration for applying a class to the group header cells:

const gridOptions = {
    pivotMode: true,
    processPivotResultColGroupDef: (colDef) => {
        colDef.headerClass = 'pivot-gold'; // the params are mutated directly, not returned
    },

    // other grid options ...
}

Ordering Groups Copy Link

The pivot result groups are initially displayed in alphabetical order. You can change this default order by providing a pivotComparator function to the pivoted column's definition.

pivotComparatorCopy Link
Function
Only for CSRM, see SSRM Pivoting. Comparator to use when ordering the pivot columns, when this column is used to pivot on. The values will always be strings, as the pivot service uses strings as keys for the pivot groups.

In the example below, note that a pivotComparator has been supplied to the sport column, and the pivot result groups are instead sorted in reversed alphabetical order.

This demonstrates the following configuration for modifying the resulting order of groups:

const gridOptions = {
    columnDefs: [
        // ...other column definitions
        {
            field: 'sport',
            pivot: true,
            pivotComparator: (a, b) => b.localeCompare(a),
        },
    ],
    pivotMode: true,

    // other grid options ...
}

If the pivotComparator returns 0, the order of the groups is then further determined by the order in which they appear in the data.

This means that writing a pivotComparator function that always returns 0 will result in the groups being ordered by the order in which they appear in the data.

Changing Data, Filters, and Configurations Copy Link

When changing data, filters, or configurations such as pivotRowTotals the generated column groups and their order is impacted. The grid will add new columns and column groups at the end of their parent groups. This is to maintain any changes the user may have made to their column order.

This behaviour can be toggled to instead reset the column order when the columns are generated by setting the enableStrictPivotColumnOrder grid option to true.

The example below demonstrates a changing data set while in pivot mode. Note that when enableStrictPivotColumnOrder is set to false, new columns are appended. When set to true all columns are re-sorted according to the pivotComparator (or alphanumerically if omitted).

This demonstrates the following configuration for changing the behaviour for new column groups:

const gridOptions = {
    enableStrictPivotColumnOrder: true,

    // other grid options ...
}

Pivoting by Dates and Times Copy Link

When pivoting by date/time values, the grid can optionally generate pivot group columns based on components of the date/time.

To enable this 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',
            pivot: true,
            groupHierarchy: ['year', 'month']
        },
        // ...other column definitions
    ],

    // other grid options ...
}

This snippet is illustrated in the example below.

Date values must be formatted as ISO-8601 dates in order to be correctly parsed into their components.

Filtering Pivoted Columns Copy Link

When pivoting is active, filters can be applied to columns defined within the column definitions by using the Filters Tool Panel and the Filter API.

In the example below, applying a filter to the Sport column (which has been pivoted) impacts the generated pivot column groups, instead of the grid rows or cell values.

When filtering a pivoted column, the resulting pivot result column group is removed from the grid. If the filter is subsequently removed, the column group will be re-added to the end of grid.

To configure this behaviour, refer to the section for Changing Data, Filters, and Configurations.

Expanded by Default Copy Link

Pivot Column Groups can be configured to expand by default, down to a given depth. This depth can be configured using the pivotDefaultExpanded grid option.

The example below demonstrates pivotDefaultExpanded being used to expand the first pivot group level by default. Providing -1 will expand all pivot group levels by default.

The example above demonstrates the following configuration for expanding pivot groups by default:

const gridOptions = {
    pivotDefaultExpanded: 1,

    // other grid options ...
}

Prevent Expanding Groups Copy Link

When using multiple pivot columns, groups become expandable by default. To prevent this and instead always show all columns, set the grid option suppressExpandablePivotGroups=true.

The example above demonstrates the following configuration:

const gridOptions = {
    pivotMode: true,
    suppressExpandablePivotGroups: true,

    // other grid options ...
}

Hide Group with Single Value Column Copy Link

When pivoting with only one aggregated column, you can simplify the grid column header layout by omitting pivot column groups with only one child column. Enabling the grid option removePivotHeaderRowWhenSingleValueColumn=true, when set to true will instead skip the group and use the pivot keys to label the pivot result column instead.

The example above demonstrates the following configuration:

const gridOptions = {
    columnDefs: [
        { field: 'country', rowGroup: true },
        { field: 'sport', pivot: true },
        { field: 'gold', aggFunc: 'sum' },
    ],
    pivotMode: true,
    removePivotHeaderRowWhenSingleValueColumn: true,

    // other grid options ...
}

Next Up Copy Link

Display the total aggregation of rows and columns when pivoting with Pivot Totals.