Skip to main content

WPF DataGrid XAML Binding

DataGrid in one of the powerfull control in WPF. we can easily load our Datagrid if we bind the DataGrid with our Class property. consider the DataGrid.


To bind this DataGrid i have use this class & hare i also Implement INotifyPropertyChanged property for datagrids cell property change event. hare Apv from & Apv To Datepicker change event will change the value of Apv Days.




  

   public class ELeaveApprove : INotifyPropertyChanged  
   {  
     public long Appr_LeaveId { get; set; }  
     public string Appr_LeaveType { get; set; }  
     public int? Appr_RemainLeave { get; set; }  
     public DateTime Appr_FromDate { get; set; }  
     public DateTime Appr_ToDate { get; set; }  
     public string Appr_Action { get; set; }  
     public long Appr_EmpId { get; set; }  
     public int? Apply_Day { get; set; }  
     public string Appr_Status { get; set; }  
     private int apvNoOfdays;  
     public string Emp_Name { get; set; }  
     public string Emp_Department { get; set; }  
     public string Department_Name { get; set; }  
     public string Designation_Name { get; set; }  
     public long Apply_ID { get; set; }  
     public int Appr_TotalLeave  
     {  
       get  
       {  
         return this.apvNoOfdays;  
       }  
       set  
       {  
         if (value != this.apvNoOfdays)  
         {  
           this.apvNoOfdays = value;  
           NotifyPropertyChanged("Appr_TotalLeave");  
         }  
       }  
     }  
     private void NotifyPropertyChanged(string info)  
     {  
       if (PropertyChanged != null)  
       {  
         PropertyChanged(this, new PropertyChangedEventArgs(info));  
       }  
     }  
     public event PropertyChangedEventHandler PropertyChanged;  
   }  
XAML:

      <DataGrid AutoGenerateColumns="False" Height="264" HorizontalAlignment="Left" Margin="2,1,0,0" Name="approveDataGrid" VerticalAlignment="Top" Width="1033" CanUserAddRows="False">  
           <DataGrid.Columns>  
             <DataGridTextColumn Header="Apply Id" Binding="{Binding Path=Apply_ID}" Width="70"/>  
             <DataGridTextColumn Header="Name" Binding="{Binding Path=Emp_Name}" Width="70"/>  
             <DataGridTextColumn Header="Department" Binding="{Binding Path=Department_Name}" Width="70"/>  
             <DataGridTextColumn Header="Designation" Binding="{Binding Path=Designation_Name}" Width="70"/>  
             <DataGridTextColumn Header="Leave For" Binding="{Binding Path=Appr_LeaveType}" Width="70"/>  
             <DataGridTextColumn Header="Apy Day's" Binding="{Binding Path=Apply_Day}" Width="70"/>  
             <DataGridTextColumn Header="Apy From " Binding="{Binding Path=Appr_FromDate,StringFormat={}{0:MM/dd/yyyy}}" Width="70"/>  
             <DataGridTextColumn Header="Apy To " Binding="{Binding Path=Appr_ToDate,StringFormat={}{0:MM/dd/yyyy}}" Width="70"/>  
             <DataGridTemplateColumn Header="Status" Width="70">  
               <DataGridTemplateColumn.CellTemplate>  
                 <DataTemplate>  
                   <Border x:Name="brdBroder" VerticalAlignment="Stretch" Margin="1">  
                     <TextBlock Text="{Binding Appr_Status}" Margin="3,1" x:Name="txtTextBlock"/>  
                   </Border>  
                   <DataTemplate.Triggers>  
                     <DataTrigger Binding="{Binding Appr_Status}" Value="Pending">  
                       <Setter TargetName="brdBroder" Property="Background" Value="Green"/>  
                       <Setter TargetName="txtTextBlock" Property="Foreground" Value="White"/>  
                     </DataTrigger>  
                   </DataTemplate.Triggers>  
                 </DataTemplate>  
               </DataGridTemplateColumn.CellTemplate>  
             </DataGridTemplateColumn>  
             <DataGridTemplateColumn Header="Apv From" Width="100">  
               <DataGridTemplateColumn.CellTemplate>  
                 <DataTemplate>  
                   <TextBlock Text="{Binding Path=Appr_FromDate, Mode=TwoWay,StringFormat={}{0:MM/dd/yyyy}}" />  
                 </DataTemplate>  
               </DataGridTemplateColumn.CellTemplate>  
               <DataGridTemplateColumn.CellEditingTemplate>  
                 <DataTemplate>  
                   <DatePicker Text="{Binding Path=Appr_FromDate,Mode=TwoWay,UpdateSourceTrigger=PropertyChanged}"  
                 SelectedDate="{x:Static System:DateTime.Now}" SelectedDateChanged="DatePicker_SelectedDateChanged_1"/>  
                 </DataTemplate>  
               </DataGridTemplateColumn.CellEditingTemplate>  
             </DataGridTemplateColumn>  
             <DataGridTemplateColumn Header="Apv To " Width="100">  
               <DataGridTemplateColumn.CellTemplate>  
                 <DataTemplate>  
                   <TextBlock Text="{Binding Path=Appr_ToDate, Mode=TwoWay,StringFormat={}{0:MM/dd/yyyy}}" />  
                 </DataTemplate>  
               </DataGridTemplateColumn.CellTemplate>  
               <DataGridTemplateColumn.CellEditingTemplate>  
                 <DataTemplate>  
                   <DatePicker Text="{Binding Path=Appr_ToDate,Mode=TwoWay,UpdateSourceTrigger=PropertyChanged}"  
                 SelectedDate="{x:Static System:DateTime.Now}" SelectedDateChanged="DatePicker_SelectedDateChanged"/>  
                 </DataTemplate>  
               </DataGridTemplateColumn.CellEditingTemplate>  
             </DataGridTemplateColumn>  
             <DataGridTextColumn Header="Apv Day" Binding="{Binding Path=Appr_TotalLeave}" Width="70"/>  
             <DataGridTemplateColumn Header="Action" Width="120">  
               <DataGridTemplateColumn.CellTemplate>  
                 <DataTemplate>  
                   <TextBlock Text="{Binding Path=Appr_Action}"/>  
                 </DataTemplate>  
               </DataGridTemplateColumn.CellTemplate>  
               <DataGridTemplateColumn.CellEditingTemplate>  
                 <DataTemplate>  
                   <ComboBox SelectedItem="{Binding Path=Appr_Action}" Name="cmbLeaveType" ItemsSource="{Binding Source={StaticResource ResourceKey=LeaveApproveActionList}}" Text="Appr_Action"/>  
                 </DataTemplate>  
               </DataGridTemplateColumn.CellEditingTemplate>  
             </DataGridTemplateColumn>  
           </DataGrid.Columns>  
         </DataGrid>  

        

Cast the DataGrid With Class for Get DataGrid Value :

 List<ELeaveApprove> leaveApvList = new List<ELeaveApprove>();  
       for (int i = 0; i < approveDataGrid.Items.Count; i++)  
       {  
         ELeaveApprove eLeaveApproveObj = (ELeaveApprove)approveDataGrid.Items[i];  
         if (eLeaveApproveObj.Appr_Action == "Approve")  
         {  
           leaveApvList.Add(eLeaveApproveObj);  
         }  
         if (eLeaveApproveObj.Appr_Action == "Reject")  
         {  
           leaveApvList.Add(eLeaveApproveObj);  
         }  
       }  


Using leaveApvList you can also filter you datagrid value.






Comments

  1. hey nice one post.....this helped me alot to come out problem.!!
    thanks alot.
    Daewoo Lanos AC Compressor

    ReplyDelete
  2. Please paste the project into your post to better understand your code.

    Greetings.

    User Done.

    ReplyDelete

Post a Comment

Popular posts from this blog

WPF datagrid cell textbox change event

Entity/Class: public class FeesDetails : INotifyPropertyChanged { public int Id { get; set; } public string FeesName { get; set;} public string FeesDetailsName { get; set; } public int? PaidAmount { get; set; } public event PropertyChangedEventHandler PropertyChanged; private void NotifyPropertyChanged(System.String info) { if (PropertyChanged != null) { PropertyChanged(this, new PropertyChangedEventArgs(info)); } } public int feesAmount { get; set; } public int FeesAmount { get { return this.feesAmount; } set { if (value != this.feesAmount) { this.feesAmount = value; NotifyPropertyChanged("FeesAmount"); } } } } XAML: <DataGrid AutoGenerateColumns="False" Height="21...

mvc razor textboxfor change event change another textboxfor value

Based on value of Weight, Rate , CNF & AWB it will change the value of Freight , TTLCNF anfd TTLFright . Freight= Weight*Rate; TTLCNF  = Weight*CNF; TTLFright=  Freight+ TTLCNF  + AWB; @Html.TextBoxFor(model => model.Weight, new { onChange="return GetWight(this);"}) @Html.TextBoxFor(model => model.Rate, new { onChange="return GetWight(this);"})/Kg @Html.TextBoxFor(model => model.Freight, new {disabled = "disabled" , @readonly = "readonly" ,onChange="return GetTTLFright(this);"}) @Html.TextBoxFor(model => model.CNFPK, new { onChange="return GetCNFPK(this);"}) @Html.TextBoxFor(model => model.TTLCNF, new {disabled = "disabled" , @readonly = "readonly",onChange="return GetTTLFright(this);" }) @Html.TextBoxFor(model => model.AWB, new { onChange="return GetTTLFright(this);"}) and script <script> function GetW...

mvvm double click event in listview

If you want to get the double click event on a listview item you can try with this code; <ListView Grid.Row="0" Grid.RowSpan="3" Grid.Column="0" Width="250" Height="200" HorizontalAlignment="Stretch" VerticalAlignment="Top" AlternationCount="2" BorderBrush="#FFA8CC7B" ItemContainerStyle="{StaticResource alternatingStyle}" ItemsSource="{Binding FromPayerNameList}" SelectedItem="{Binding SelectedFromPayer, Mode=TwoWay}"> <ListView.ItemTemplate> <DataTemplate> <TextBlock Width="{Binding Path=ActualWidth, RelativeSource={RelativeSource FindAncestor, AncestorType={x:Type ListView}}}" Text=...