Не запускать RelayCommand - PullRequest
       19

Не запускать RelayCommand

0 голосов
/ 10 апреля 2019

У меня есть список и релейная команда viewmodel,

private List<PurchaseInvoiceDetail> detailList = new List<PurchaseInvoiceDetail>();
public RelayCommand AddCommand { get; set; }
   ICollectionView _detailCollection;

    public ICollectionView DetailCollection
    {
        get { return _detailCollection; }
        set
        {
            if (value != _detailCollection)
            {
                _detailCollection = value;
                RaisePropertyChanged("DetailCollection");
            }
        }
    }

, когда я использую DetailCollection в конструкторе, не запускаю relaycommand.

public PurchaseInvoiceDetailViewModel(PurchaseInvoice item)
 {
  if (item != null)
   {
    Number = item.Number;
    CustomerId = item.CustomerId;
    Date = new PersianDate((DateTime)item.Date);
    _purchaseInvoice = item.Id;
    detailList = _db.PurchaseInvoiceDetails.Where(m => m.PurchaseInvoiceId == item.Id).ToList();
    CollectionViewSource.GetDefaultView(detailList).Refresh();
    DetailCollection = CollectionViewSource.GetDefaultView(detailList);
   }
   AddCommand=new RelayCommand(() =>
        {
              var goods = _db.Goods.Find(GoodsId);
                detailList.Add(new PurchaseInvoiceDetail(){GoodsId = GoodsId,Goods = goods,Count = Count,Price = Price,Id=0,PurchaseInvoiceId = 0});
                CollectionViewSource.GetDefaultView(detailList).Refresh();
                DetailCollection = CollectionViewSource.GetDefaultView(detailList);

        });
  }

, но когда я комментирую DetailCollection, все работает нормально..

в поле зрения

 <Button Margin="0 0 5 0 " Width="90" Command="{Binding AddCommand}" 
   Style="{StaticResource MaterialDesignRaisedButton}"  >
  <StackPanel Orientation="Horizontal">
    <materialDesign:PackIcon  Kind="Plus" />
    <TextBlock >َAdd</TextBlock>
  </StackPanel>
 </Button>
 <DataGrid  CanUserDeleteRows="True" CellStyle="{StaticResource MaterialDesignDataGridCell}"  Name="ListView" 
 IsReadOnly="True" BorderBrush="{DynamicResource MaterialDesignDivider}"  VerticalAlignment="Top" BorderThickness="1"    Height="200"  Margin="0"   AutoGenerateColumns="False"   
                       ItemsSource="{Binding Path=DetailCollection}" 
            >
     <DataGrid  CanUserDeleteRows="True" CellStyle="{StaticResource MaterialDesignDataGridCell}"  Name="ListView" 
                       IsReadOnly="True" BorderBrush="{DynamicResource MaterialDesignDivider}"  VerticalAlignment="Top"
                       BorderThickness="1"    Height="200"  Margin="0"   AutoGenerateColumns="False"   
                       ItemsSource="{Binding Path=DetailCollection}" 
            >
                <DataGrid.Columns>
                    <DataGridTextColumn  Width="100"
                                         Header="کد کالا" Binding="{Binding Path=Goods.Code}"/>

                    <DataGridTextColumn Header="نام کالا" Binding="{Binding Path=Goods.Name}" Width="200"/>

                    <DataGridTextColumn Binding="{Binding Path=Count}" Width="150"
                                        dataGridFilterLibrary:DataGridColumnExtensions.IsCaseSensitiveSearch="True"
                                        Header="تعداد"/>
                    <DataGridTextColumn Header="قیمت" Binding="{Binding Path=Price}" Width="*"/>
                </DataGrid.Columns>
                <DataGrid.InputBindings>
                    <KeyBinding 
                        Key="Delete"
                        Command="{Binding DeleteCommand}" CommandParameter="{Binding SelectedIndex, ElementName=ListView}"/>

                </DataGrid.InputBindings>
            </DataGrid>
...