Category / Section
How to update the table summary value when the cell in edit mode in WPF DataGrid (SfDataGrid) ?
1 min read
You can update the summary values when you are changing the value by overriding OnInitializeEditElement method and DoubleTextBox.ValueChanging event in GridNumericCellRenderer in WPF DataGrid (SfDataGrid).
dataGrid.LiveDataUpdateMode = LiveDataUpdateMode.AllowSummaryUpdate; this.dataGrid.CellRenderers.Remove("Numeric"); this.dataGrid.CellRenderers.Add("Numeric", new CustomizedGridCellNumericRenderer(dataGrid));internal class CustomizedGridCellNumericRenderer : GridCellNumericRenderer { RowColumnIndex RowColumnIndex; SfDataGrid DataGrid { get; set; } string newvalue = null; public CustomizedGridCellNumericRenderer(SfDataGrid dataGrid) { DataGrid = dataGrid; } public override void OnInitializeEditElement(DataColumnBase dataColumn, DoubleTextBox uiElement, object dataContext) { base.OnInitializeEditElement(dataColumn, uiElement, dataContext); uiElement.ValueChanging += UiElement_ValueChanging; this.RowColumnIndex.ColumnIndex = dataColumn.ColumnIndex; this.RowColumnIndex.RowIndex = dataColumn.RowIndex; } private void UiElement_ValueChanging(object sender, Syncfusion.Windows.Shared.ValueChangingEventArgs e) { newvalue = e.NewValue.ToString(); UpdateSummaryValues(this.RowColumnIndex.RowIndex, this.RowColumnIndex.ColumnIndex); } private void UpdateSummaryValues(int rowIndex, int columnIndex) { string editEelementText = newvalue=="0" ? "0" : newvalue; columnIndex = this.DataGrid.ResolveToGridVisibleColumnIndex(columnIndex); if (columnIndex < 0) return; var mappingName = DataGrid.Columns[columnIndex].MappingName; var recordIndex = this.DataGrid.ResolveToRecordIndex(rowIndex); if (recordIndex < 0) return; if (DataGrid.View.TopLevelGroup != null) { var record = DataGrid.View.TopLevelGroup.DisplayElements[recordIndex]; if (!record.IsRecords) return; var data = (record as RecordEntry).Data; data.GetType().GetProperty(mappingName).SetValue(data, (int.Parse(editEelementText))); } else { var record1 = DataGrid.View.Records.GetItemAt(recordIndex); record1.GetType().GetProperty(mappingName).SetValue(record1, (int.Parse(editEelementText))); } } }