Skip to main content

WPF mvvm passing popup viewmodel value in to main viewmodel




I have a scenario that I have a WPF usercontrol UI, from this UI I will call a pop up usercontrol UI.
When I will select a value from pop up usercontrol UI Grid, then popup ui will be close and the selected popup grid value will get in main UI without visual state change of the main UI. 



Main UI ViewModel:

 private void OnInsplanPicker(object sender)  
     {  
       InsurancePlanLookup window = new InsurancePlanLookup();  
       window.BindEvent += window_BindEvent;  
       DockHelper.AddPanel(window,"Insuranceplan lookup");  
     }  
     void window_BindEvent(long insplanId)  
     {  
       Nhinsplanid_FK = insplanId;  
     }  




Popup code behind

 public partial class InsurancePlanLookup  
   {  
     public delegate void BindDelegate(long insplanId);  
     public event BindDelegate BindEvent;  
     VMInsurancePlanLookup vm ;  
     public InsurancePlanLookup()  
     {  
       InitializeComponent();  
       vm = new VMInsurancePlanLookup();  
       vm.BindEvent += vm_BindEvent;  
       vm.CloseEvent += vm_CloseEvent;  
       DataContext = vm;  
     }  
     void vm_BindEvent(long insplanId)  
     {  
       BindEvent(insplanId);  
       DockHelper.ClosePanel(Parent);  
     }  
     void vm_CloseEvent()  
     {  
       DockHelper.ClosePanel(Parent);  
     }  
   }  




Popup ViewModel

 public delegate void BindDelegate(long insplanId);  
 public event BindDelegate BindEvent;  
 public ICommand Close { set; get; }  
     public ICommand OkButtonCommand { set; get; }  
     public VMInsurancePlanLookup()  
     {  
       Close = new DelegateCommand(OnClose);  
       OkButtonCommand = new DelegateCommand(OnOkButton);  
       PrepareOriginalList();  
     }  
     private void OnOkButton(object obj)  
     {  
       BindEvent(SelectedInsplan.id);  
     }  
     private void OnClose(object obj)  
     {  
       if (CloseEvent != null)  
       {  
         CloseEvent();  
       }  
     }  







Comments

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=...