From 9fbb1b874ecd773649bb27f9eea145b017614e51 Mon Sep 17 00:00:00 2001 From: ndudenhoeffer Date: Wed, 6 May 2015 08:14:44 -0500 Subject: [PATCH] feat(grouping): Add option groupingNullLabel, to group null and undefined values together. Fixes #3271 --- src/features/grouping/js/grouping.js | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) diff --git a/src/features/grouping/js/grouping.js b/src/features/grouping/js/grouping.js index f4c63d4448..e7b31b38ab 100644 --- a/src/features/grouping/js/grouping.js +++ b/src/features/grouping/js/grouping.js @@ -449,6 +449,15 @@ *
Defaults to true */ gridOptions.groupingShowCounts = gridOptions.groupingShowCounts !== false; + + /** + * @ngdoc object + * @name groupingNullLabel + * @propertyOf ui.grid.grouping.api:GridOptions + * @description The string to use for the grouping header row label on rows which contain a null or undefined value in the grouped column. + *
Defaults to "Null" + */ + gridOptions.groupingNullLabel = gridOptions.groupingNullLabel || 'Null'; }, @@ -1140,7 +1149,7 @@ var updateProcessingState = function( groupFieldState, stateIndex ) { var fieldValue = grid.getCellValue(row, groupFieldState.col); if ( typeof(fieldValue) === 'undefined' || fieldValue === null ){ - return; + fieldValue = grid.options.groupingNullLabel; } if ( !row.visible ){ @@ -1287,6 +1296,9 @@ // TODO: can't just use entity like this, have to use get cell value, need col for that var newValue = grid.getCellValue(renderableRows[rowIndex], col); + if ( typeof(newValue) === 'undefined' || newValue === null ) { + newValue = grid.options.groupingNullLabel; + } headerRow.entity[fieldName] = newValue; headerRow.groupLevel = stateIndex; headerRow.groupHeader = true;