diff -r 000000000000 -r 249d70e7b32d client/src/Iri.Modernisation.Controls/ViewModel/ConsultationView/ConsultationViewVM.cs --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/client/src/Iri.Modernisation.Controls/ViewModel/ConsultationView/ConsultationViewVM.cs Wed Nov 18 15:30:31 2009 +0100 @@ -0,0 +1,143 @@ +using System; +using System.Net; +using System.Windows; +using System.Windows.Controls; +using System.Windows.Documents; +using System.Windows.Ink; +using System.Windows.Input; +using System.Windows.Media; +using System.Windows.Media.Animation; +using System.Windows.Shapes; +using System.Collections.Generic; +using Iri.Modernisation.Data.Models; +using Iri.Modernisation.Data.LDTClass; +using Iri.Modernisation.BaseMVVM.Commands; +using Iri.Modernisation.BaseMVVM.ViewModel; +namespace Iri.Modernisation.Controls.ViewModel +{ + public class ConsultationViewVM : BaseMVVM.ViewModel.ViewModel + { + private PolemicElement _selectedElement; + public PolemicElement SelectedElement + { + get + { + return _selectedElement; + } + set + { + _selectedElement = value; + OnPropertyChanged("SelectedElement"); + } + } + + + + private SLExtensions.Collections.ObjectModel.ObservableCollection _selectedVideoBooks; + public SLExtensions.Collections.ObjectModel.ObservableCollection SelectedVideoBooks + { + get + { + + return _selectedVideoBooks; + } + set + { + _selectedVideoBooks = value; + OnPropertyChanged("SelectedVideoBooks"); + } + } + + private int _selectedVideoBookIndex=-1; + public int SelectedVideoBookIndex + { + get + { + return _selectedVideoBookIndex; + } + set + { + _selectedVideoBookIndex= value; + OnPropertyChanged("SelectedVideoBookIndex"); + ConsultationBookViewContextMenu.SelectedBookVM = (_selectedVideoBooks[value]); + + } + } + + private ConsultationBookViewVM _consultationBookViewContextMenu; + public ConsultationBookViewVM ConsultationBookViewContextMenu + { + get + { + return _consultationBookViewContextMenu; + } + set + { + _consultationBookViewContextMenu = value; + OnPropertyChanged(null); + } + } + + private void InitializeCommands() + { + Commands.ConsultMenu.ClickBook.Executed += new EventHandler(ClickBook_Executed); + Commands.PolemicElement.SelectPolemicElement.Executed += new EventHandler(SelectPolemicElement_Executed); + + Commands.ClickMenu.CreateNewTextualAnnotation.Executed += new EventHandler(CreateNewTextualAnnotation_Executed); + } + + void ClickBook_Executed(object sender, SLExtensions.Input.ExecutedEventArgs e) + { + BookTimeLineVM temp = new BookTimeLineVM((VideoBook)e.Parameter); + bool CanAdd = true; + foreach(BookTimeLineVM BookTLVM in SelectedVideoBooks) + { + if (BookTLVM.SelectedBook == (VideoBook)e.Parameter) + { + CanAdd = false; + } + } + if(CanAdd) + { + SelectedVideoBooks.Add(temp); + } + + } + + + private AnnotationMakerVM _annotationMakerVM; + public AnnotationMakerVM ViewModelAnnotationMaker + { + get + { + return _annotationMakerVM; + } + } + void CreateNewTextualAnnotation_Executed(object sender, SLExtensions.Input.ExecutedEventArgs e) + { + ViewModelAnnotationMaker.RefElement = SelectedElement; + } + public ConsultationViewVM() + { + InitializeCommands(); + _consultationBookViewContextMenu = new ConsultationBookViewVM(); + _annotationMakerVM = new AnnotationMakerVM(); + SelectedVideoBooks = new SLExtensions.Collections.ObjectModel.ObservableCollection(); + } + + void SelectPolemicElement_Executed(object sender, SLExtensions.Input.ExecutedEventArgs e) + { + SelectedElement= (PolemicElement)e.Parameter; + try + { + ConsultationBookViewContextMenu.SelectedIndex = (SegmentIndex)SelectedElement; + } + catch + { + } + + + + } + } +}