Well, it was not quite a straight plug and play as I hoped it would be but with some minor changes, I managed to “plug” the view in with the view model. There are many minor changes with the code but here are the ones worth noting:
C# | public Club CurrentClub; <toolkit:DataForm CurrentItem="{Binding CurrentClub, Mode=TwoWay}"/> |
VB | Public CurrentClub As Club Private ReadOnly Property CurrentItem () As <toolkit:DataForm CurrentItem="{Binding CurrentClub, Mode=TwoWay}"/> |
2. This may not be obvious from the solution but DevForce entities already implement the IEditableObject interface. This means that I don’t have to do anything extra to undo my changes. DevForce implementation of the interface already takes care of that.
3. I had to modify each entity’s primary key to be an identity column in order to maintain it easier.
4. Modified my call to _mgr.SaveChangesAsync by passing in a delegate, _mgr.SaveChangesAsync(OnSaveCompleted) instead of subscribing to an event, op.Completed += Completed_Handler. I believe this provides a cleaner and better code testability.
5. And finally if you look at all the view’s xaml.cs files (MainPage.xaml.cs, ClubView.xaml.cs, PlayerView.xaml.cs and GameStatView.xaml.cs), you will see that there is absolutely no code here that reference the view model (MainPageViewModel.cs). It is all done in the xaml. This means that so far, I’ve successfully implemented a view that is independent of its view model.
6. One of my future code refactoring is to separate each entity’s view model into its own view model. Currently the MainPageViewModel class is handling the Club, Player and GameStat views.
Next up, validation!