 
            | Intersoft ClientUI 8 > ClientUI Fundamentals > MVVM Pattern Overview > MVVM Pattern Walkthroughs > Walkthrough: Data Binding to UXDockButton using MVVM Pattern | 
This walkthrough shows you how to bind a data collection to UXDockButton using MVVM pattern.
In this walkthrough, you perform the following tasks:
You need the following components to complete this walkthrough:
You also need the following resource to complete this walkthrough:
|  | The assembly is required for the XML data source and images | 
The first step is to create a new ClientUI MVVM Application project using Intersoft ClientUI MVVM Application project template in Visual Studio.
This section shows how to create a Model class in Book.cs. The model will map each information in the data entity to a property.
| C# | 
                    Copy Code
                 | 
|---|---|
| private string _author; public string Author { get { return _author; } set { if (_author != value) { _author = value; OnPropertyChanged("Author"); } } } | |
| C# | 
                    Copy Code
                 | 
|---|---|
| public Book(XElement x) : this() { this._author = x.Element("Author").Value.Trim(); this._title = x.Element("Title").Value.Trim(); this._category = x.Element("Category").Value.Trim(); this._ID = x.Element("ID").Value.Trim(); this._price = double.Parse(x.Element("Price").Value.Trim()); this._image = new Uri("/Intersoft.ClientUI.Samples.Assets;component/Images/Books/" + x.Element("Image").Value.Trim(), UriKind.RelativeOrAbsolute); } | |
This section shows how to create a ViewModel to hold the collection of Book model object.
| C# | 
                    Copy Code
                 | 
|---|---|
| public ObservableCollection<Book> FilteredBooks{ get; set; } | |
| C# | 
                    Copy Code
                 | 
|---|---|
| private void LoadBooks() { // loads book data from xml file StreamResourceInfo resource = System.Windows.Application.GetResourceStream( new Uri("Intersoft.ClientUI.Samples.Assets;component/Data/BookDataSource.xml", UriKind.Relative)); XDocument doc = XDocument.Load(resource.Stream); var filteredBooks = (from x in doc.Descendants("Book") where x.Element("Category").Value.Trim() == "Science and Nature" select new Book(x)).Take(8); FilteredBooks = new ObservableCollection<Book>(filteredBooks); } | |
This section show how to create a View used in the application interface using the BookFlow.xaml.
|  | For more information on how to add a new item in Visual Studio, see Walkthrough: Add New Item such as Page, Dialog Box and Window in VS 2010 | 
| XAML | 
                    Copy Code
                 | 
|---|---|
| <Intersoft:UXPage ... xmlns:ViewModels="clr-namespace:UXDockMVVM.ViewModels" ... > ... </Intersoft:UXPage> | |
| XAML | 
                    Copy Code
                 | 
|---|---|
| <Intersoft:UXPage.DataContext> <ViewModels:BookFlowViewModel /> </Intersoft:UXPage.DataContext> | |
| Property | Value | 
|---|---|
| HorizontalAlignment | Left | 
| VerticalAlignment | Top | 
| Height | 264 | 
| Property | Value | 
|---|---|
| Icon | /Intersoft.ClientUI.Samples.Assets;component/Images/Navigation/Products.png | 
| Text | Products | 
| StackMode | GridStyle | 
| DisplayMemberPath | Author | 
| ImageMemberPath | Image | 
| XAML | 
                    Copy Code
                 | 
|---|---|
| <Intersoft:UXDock Height="264" HorizontalAlignment="Left" Margin="174,0,466,-1" Name="uXDock1" VerticalAlignment="Top"> <Intersoft:UXDockButton Icon="/Intersoft.ClientUI.Samples.Assets;component/Images/Navigation/Products.png" Text="Products" ItemsSource="{Binding Path=FilteredBooks}" DisplayMemberPath="Author" ImageMemberPath="Image" StackMode="GridStyle" IsOpen="False"></Intersoft:UXDockButton> </Intersoft:UXDock> | |
 
 In this walkthrough, you have learned how to create ClientUI MVVM Application project using Intersoft ClientUI MVVM Application project template, and create classes and page based on the MVVM pattern. You also learned how to bind UXDockButton to a collection of data.
For more information about application development using MVVM pattern, see MVVM Pattern Overview.
This section lists the complete code used in this walkthrough.
| C# | 
                    Copy Code
                 | 
|---|---|
| using System.Collections.ObjectModel; using System.Linq; using UXDockMVVM.Models; using Intersoft.Client.Framework.Input; using Intersoft.Client.Framework; using System.Windows.Resources; using System; using System.Xml.Linq; namespace UXDockMVVM.ViewModels { public class BookFlowViewModel : ViewModelBase { public ObservableCollection<Book> FilteredBooks { get; set; } public BookFlowViewModel() { this.LoadBooks(); } private void LoadBooks() { // loads book data from xml file StreamResourceInfo resource = System.Windows.Application.GetResourceStream( new Uri("Intersoft.ClientUI.Samples.Assets;component/Data/BookDataSource.xml", UriKind.Relative)); XDocument doc = XDocument.Load(resource.Stream); var filteredBooks = (from x in doc.Descendants("Book") where x.Element("Category").Value.Trim() == "Science and Nature" select new Book(x)).Take(8); FilteredBooks = new ObservableCollection<Book>(filteredBooks); } } } | |
| C# | 
                    Copy Code
                 | 
|---|---|
| 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 UXDockMVVM.ViewModels; using System.Xml.Linq; namespace UXDockMVVM.Models { public class Book : ModelBase { public Book() { } public Book(XElement x) : this() { this._author = x.Element("Author").Value.Trim(); this._title = x.Element("Title").Value.Trim(); this._category = x.Element("Category").Value.Trim(); this._ID = x.Element("ID").Value.Trim(); this._price = double.Parse(x.Element("Price").Value.Trim()); this._image = new Uri("/Intersoft.ClientUI.Samples.Assets;component/Images/Books/" + x.Element("Image").Value.Trim(), UriKind.RelativeOrAbsolute); } private Uri _image = null; private string _author; private string _title; private string _category; private string _ID; private double _price; public string Author { get { return _author; } set { if (_author != value) { _author = value; OnPropertyChanged("Author"); } } } public string Title { get { return _title; } set { if (_title != value) { _title = value; OnPropertyChanged("Title"); } } } public string Category { get { return _category; } set { if (_category != value) { _category = value; OnPropertyChanged("Category"); } } } public string ID { get { return _ID; } set { if (_ID != value) { _ID = value; OnPropertyChanged("ID"); } } } public double Price { get { return _price; } set { if (_price != value) { _price = value; OnPropertyChanged("Price"); } } } public Uri Image { get { return _image; } set { if (_image != value) { _image = value; OnPropertyChanged("Image"); } } } } } | |
| XAML | 
                    Copy Code
                 | 
|---|---|
| <Intersoft:UXPage xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:ViewModels="clr-namespace:UXDockMVVM.ViewModels" mc:Ignorable="d" xmlns:Intersoft="http://intersoft.clientui.com/schemas" x:Class="UXDockMVVM.Views.BookFlow" Title="BookFlow Page" d:DesignWidth="640" d:DesignHeight="480"> <Intersoft:UXPage.DataContext> <ViewModels:BookFlowViewModel /> </Intersoft:UXPage.DataContext> <Grid x:Name="LayoutRoot"> <Intersoft:UXDock Height="264" HorizontalAlignment="Left" Name="uXDock1" VerticalAlignment="Top"> <Intersoft:UXDockButton Icon="/Intersoft.ClientUI.Samples.Assets;component/Images/Navigation/Products.png" Text="Products" ItemsSource="{Binding Path=FilteredBooks}" DisplayMemberPath="Author" ImageMemberPath="Image" StackMode="GridStyle" IsOpen="False"></Intersoft:UXDockButton> </Intersoft:UXDock> </Grid> </Intersoft:UXPage> | |