У меня есть dxDataGrid с 4 уровнями группировки. У меня также есть «сводная» конфигурация для «groupedItems» для суммирования различных полей и создания сводных данных для каждой группы. Однако по умолчанию devExpress будет пузырить эту СУММУ среди всех уровней группы (чего я не хочу), вместо этого я хотел бы использовать поведение «суммы» только для моих 4-й и 3-й групп, а затем иметь пользовательскую логику (a функция или что-то в этом роде), где я могу вычислить итоговые значения для моей 2-й группы.
В настоящее время у меня есть сводные данные 4-й и 3-й групп, отображаемые в сетке без проблем. Однако я не вижу какой-либо пользовательской опции, которую я могу включить, чтобы иметь пользовательскую сводку для определенной группы столбцов (в моем случае — «Практика»).
В настоящее время я использую DevExpress Extreme (JS) v16.1.6. Однако, если это выполнимо в другой технологии, такой как пользовательский интерфейс Kendo, было бы неплохо узнать, как это сделать там, поскольку в ближайшем будущем я планирую перейти с DevExpress на пользовательский интерфейс Kendo.
Я приложил скриншот, чтобы вы, ребята, могли немного лучше визуализировать мою проблему. Пример
Вот мой JS-код для DataGrid.
dxDataGrid: {
dataSource: myDataSource, //AJAX Call
grouping: {
autoExpandAll: false
},
rowAlternationEnabled: true,
allowColumnResizing: true,
columnAutoWidth: true,
sorting: { mode: 'multiple' },
searchPanel: { visible: true, width: 240, placeholder: 'Search...' },
filterRow: { visible: true },
loadPanel: { enabled: true },
export: { enabled: true, fileName: 'My Test Report' },
paging: { enabled: true },
grouping: {
autoExpandAll: false
},
groupPanel: {
visible: true,
allowColumnDragging: false
},
pager: {
showPageSizeSelector: true,
showNavigationButtons: true,
showInfo: true
},
onCellPrepared: function(e) {
if (e.rowType === 'group' && e.row.groupIndex <= 1 && e.columnIndex > e.row.groupIndex + 1) {
// e.cellElement.text(''); //This is bad, need to Find a solution now
}
else if (e.column.dataField === 'TotalPacCostPercentage') {
var pacPercentage = parseFloat(e.value) * 100;
if (pacPercentage >= 25 && pacPercentage <= 75) {
e.cellElement.addClass('medium-risk');
}
else if (pacPercentage > 75) {
e.cellElement.addClass('high-risk');
}
}
},
columns: [
{ dataField: 'CountyName', caption: 'County', groupIndex: 0},
{ dataField: 'PracticeNameAndTin', caption: 'Practice', groupIndex: 1 },
{ dataField: 'ProviderDisplayName', caption: 'Provider', groupIndex: 2 },
{ dataField: 'CcsGroupName', caption: 'CCS Group', groupIndex: 3 },
{ dataField: 'CcsName', caption: 'CCS Name', allowGrouping: false },
{ dataField: 'ClaimTypeName', caption: 'Claim Type', allowGrouping: false },
{ dataField: 'PlaceOfServiceName', caption: 'Place of Service', allowGrouping: false },
{ dataField: 'PreTriggerCost', caption: 'Average Pre-Trigger', format: 'currency', allowGrouping: false },
{ dataField: 'PreTriggerPacCostPercentage', caption: 'Pre-Trigger PAC %', format: 'percent', allowGrouping: false },
{ dataField: 'TriggerCost', caption: 'Average Trigger', format: 'currency', allowGrouping: false },
{ dataField: 'TriggerPacCostPercentage', caption: 'Trigger PAC %', format: 'percent', allowGrouping: false },
{ dataField: 'PostTriggerCost', caption: 'Average Post-Trigger', format: 'currency', allowGrouping: false },
{ dataField: 'PostTriggerPacCostPercentage', caption: 'Post-Trigger PAC %', format: 'percent', allowGrouping: false },
{ dataField: 'TotalCost', caption: 'Average Cost', format: 'currency', allowGrouping: false },
{ dataField: 'TotalPacCostPercentage', caption: 'PAC %', format: 'percent', allowGrouping: false }
],
summary: {
groupItems: [
{ column: 'PreTriggerCost', summaryType: 'sum', valueFormat: 'currency', displayFormat: '{0}', alignByColumn: true },
{ column: 'TriggerCost', summaryType: 'sum', valueFormat: 'currency', displayFormat: '{0}', alignByColumn: true },
{ column: 'PostTriggerCost', summaryType: 'sum', valueFormat: 'currency', displayFormat: '{0}', alignByColumn: true },
{ column: 'TotalCost', summaryType: 'sum', valueFormat: 'currency', displayFormat: '{0}', alignByColumn: true },
]
}
}