I have two columns in my data source that is editable and is a boolean value. My data object implement INotifyPropertyChanged. Two questions:
1. When I initially run the app, all checkboxes are kinda grayed out, in some intermediate state, even though my data objects certain have values fro those boolean properties. How can I make sure they properly load?
2. The value of one bool depends on the other. The two properties cannot be true, but any other combination is possible. To this end, my data object has logic so if: valA is set to true, if valB is true, property valB is set to false and vice-versa. The issue is that the actual setter is not called by the Check Editor until the checkbox is unfocused. What's my best way to go around this? Should I attach custom event handlers to valuechanged? Should I create an unbound column and create a control template that displays my own custom checkbox with custom handlers?
Thanks,
-Szymon
Hello Szymon,
Are you binding the check editor directly to your CLR object (which has INotifyPropertyChanged) or to a DependencyProperty? When the data changes, the INotifyPropertyChanged event should trigger the data to update in the UI and if using a DependencyProperty you get the same behavior. If you could post or attach some code or a sample project which demonstrates the problem, I might see what is going on and offer a solution.
Ok. I have attached a project that replicates both issues I am seeing. So basically I'm not doing any of the binding myself; I let the grid do it for me. In my actual xaml, I define my own field, editor types and edit as, but the behavior is exactly the same as allowing the grid to create the fields on its own.
I see the issue you are talking about. The internal binding UpdateSourceTrigger needs to be changed from the default "LostFocus" to "PropertyChanged". I will look into how to do this and post the solution.
For now, I'm using the following workaround:
1. Add the following Field settings to my boolean fields:
<igDP:Field.Settings> <igDP:FieldSettings AllowEdit="True" EditAsType="{x:Type sys:Boolean}" EditorType="{x:Type igEditors:XamCheckEditor}" LabelWidth="60" CellWidth="60"> <igDP:FieldSettings.EditorStyle> <Style TargetType="{x:Type igEditors:XamCheckEditor}"> <EventSetter Event="ValueChanged" Handler="HandleValueChangedAccept" /> </Style> </igDP:FieldSettings.EditorStyle> </igDP:FieldSettings> </igDP:Field.Settings>
and:
<igDP:Field.Settings> <igDP:FieldSettings AllowEdit="True" EditAsType="{x:Type sys:Boolean}" EditorType="{x:Type igEditors:XamCheckEditor}" LabelWidth="60" CellWidth="60" > <igDP:FieldSettings.EditorStyle> <Style TargetType="{x:Type igEditors:XamCheckEditor}"> <EventSetter Event="ValueChanged" Handler="HandleValueChangedRollback" /> </Style> </igDP:FieldSettings.EditorStyle> </igDP:FieldSettings> </igDP:Field.Settings>
I am hooking a handler to the ValueChanged event on the XamCheckEditor.
2. Implement the handling methods:
void HandleValueChangedAccept(object sender, RoutedPropertyChangedEventArgs<object> e) { bool newValue = (bool)e.NewValue; if (!newValue) return; DependencyObject o = Infragistics.Windows.Utilities.GetAncestorFromType(e.OriginalSource as DependencyObject, typeof(DataRecordCellArea), true); DataRecordCellArea dataRecord = o as DataRecordCellArea; if (dataRecord == null) return; DAO dao = dataRecord.Record.DataItem as DAO ; dao.Accept = (bool)e.NewValue; } void HandleValueChangedRollback(object sender, RoutedPropertyChangedEventArgs<object> e) { bool newValue = (bool)e.NewValue; if (!newValue) return; DependencyObject o = Infragistics.Windows.Utilities.GetAncestorFromType(e.OriginalSource as DependencyObject, typeof(DataRecordCellArea), true); DataRecordCellArea dataRecord = o as DataRecordCellArea; if (dataRecord == null) return; DAO dao = dataRecord.Record.DataItem as DAO ; dao .Rollback = (bool)e.NewValue; }
Notice that my logic dictates that two values cannot be set to true. My DAO setters handle this logic. But this creates an opportunity for an infinite loop. Since dao.Rollback may change the value of dao.Accept, the ValueChanged handlers for the checkboxes may keep on calling each other infinitely. For this purpose, I make sure that the handler doesn't do anything if the new value is false.
So this is a bit of a hackish way to do this, but it works. Chris, let me know if there's a more elegant way to do this using the UpdateSourceTrigger property of the internal binding.
I'm having same issues with bool type values I add to XamDataGrid. Here's the simple project I made with same thing.
Any updates on this topic ?
Glad to know this works!
I implemented the xamdatagrid with checkboxes (placed in Cellvalue presenter) I added checked unchecked events for the check box. But i am facing one problem . On scroll of the xamdatagrid scroll bar level. I am seeing some of the check boxes are checked and unchecked. My application is behaving differntly. Can you please give some inputs on this.
I implemented the sample like this
<Window x:Class="Scrollbarissue_OnlyCheckBox.Window2"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:igDP="http://infragistics.com/DataPresenter"
xmlns:sys="clr-namespace:System;assembly=mscorlib"
Title="Window2" Height="300" Width="300">
<Grid>
<igDP:XamDataGrid Name="myGrid" Height="250">
<igDP:XamDataGrid.Resources>
<Style TargetType="{x:Type igDP:CellValuePresenter}" x:Key="BoolFieldOverride">
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type igDP:CellValuePresenter}">
<CheckBox HorizontalAlignment="Center" VerticalAlignment="Center"
IsChecked="{Binding RelativeSource={RelativeSource TemplatedParent}, Path=Content}"/>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
</igDP:XamDataGrid.Resources>
<igDP:XamDataGrid.FieldLayoutSettings>
<igDP:FieldLayoutSettings AutoGenerateFields="False" />
</igDP:XamDataGrid.FieldLayoutSettings>
<igDP:XamDataGrid.FieldLayouts>
<igDP:FieldLayout>
<igDP:FieldLayout.Fields>
<igDP:Field Name="Id" Label="GUID" >
<igDP:Field.Settings>
<igDP:FieldSettings CellMinWidth="250" CellWidth="250" />
</igDP:Field.Settings>
</igDP:Field>
<igDP:Field Name="Rollback" Label="Option Rollback" >
CellValuePresenterStyle="{StaticResource BoolFieldOverride}"/>
<igDP:Field Name="Accept" Label="Option Accept" >
<igDP:FieldSettings CellMinWidth="50" CellWidth="50"
</igDP:FieldLayout.Fields>
</igDP:FieldLayout>
</igDP:XamDataGrid.FieldLayouts>
</igDP:XamDataGrid>
</Window>
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Shapes;
{
/// <summary>
/// Interaction logic for Window2.xaml
/// </summary>
public partial class Window2 : Window
InitializeComponent();
DataObject dataObj;
dataObj.Id = Guid.NewGuid().ToString();
l.Add(dataObj);
}
dataObj = new DataObject();
dataObj.Rollback = false;
myGrid.DataSource = l;
public class DataObject
public bool Accept { get; set; }
In this sample i ddint added the events for check boxes. On scroll of the xamdatagrid scroll bar my check box checked and unched events are firing .
This sounds like a bug. Please report this issue to our developer support department (http://es.infragistics.com/support/default.aspx) and ask them for a work-around. To get help immediately, we have chat and telephone support.
Thank you!