ViewModel
No edit summary
No edit summary
Line 1: Line 1:
''Example''  
''Example:''  


[[File:View_Model_PNG0.png|frameless|501x501px]]
[[File:View_Model_PNG0.png|frameless|501x501px]]


Presented with a model that I got from colleague, that incidentally helps out as a Hockey Referee when he is not coding, I wanted to create a ViewModel for the use-case “Set up new Hockey game”.
Presented with a model that I got from a colleague, that incidentally helps out as a Hockey referee when he is not coding, I wanted to create a ViewModel for the use-case “Set up new Hockey game”.


[[File:Image 11 GAME.png|frameless|407x407px]]       
[[File:Image 11 GAME.png|frameless|407x407px]]       
Line 15: Line 15:
Now I know what the requirements are on the ViewModel since I can see from the drawing what data the ViewModel needs to hold.  
Now I know what the requirements are on the ViewModel since I can see from the drawing what data the ViewModel needs to hold.  


And then created this ViewModel That I named GameSetup:
Then I created this ViewModel that I named GameSetup:


[[File:Image 5.png|frameless|393x393px]]
[[File:Image 5.png|frameless|393x393px]]


Notice that it is just a series of named ocl expressions. Some expressions are nested to other list definitions like Home_PickList that states that if the Game has a picked GameType, then we know what teams that can be picked – namely those teams that are associated to that GameType.
Notice that it is just a series of named OCL expressions. Some expressions are nested to list other definitions like Home_PickList which state that if the game has a picked game type, then we know what teams can be chosen – namely those teams that are associated with that game type.


I created some test data so that UI can show something. My first attempt was to manually code a WPF UI and bind the values to the ViewModel:
I created some test data so that UI can show something. My first attempt was to manually code a WPF UI and bind the values to the ViewModel:
Line 27: Line 27:
[[File:GAME UI.png|frameless|417x417px]]
[[File:GAME UI.png|frameless|417x417px]]


This has minimal amount of fashion acceptable styling. The good thing is that you can hand it to any WPF savvy designer in the world – the data and the rules are safe in the ViewModel.
This has a minimal amount of fashionably acceptable styling. The good thing is that you can hand it to any WPF-savvy designer in the world – the data and the rules are safe in the ViewModel.


It already shows some of the good effects of separating UI from logic.
It already shows some of the good effects of separating UI from logic.
# The PickLists for Home and Visitor are filtered based on Type of Game
# The PickLists for Home and Visitor are filtered based on the type of game.
# The Picklist for Home team filters away the Visitor team if set (and vice versa)  
# The Picklist for the Home team filters away the Visitor team if set (and vice versa).
# Start game is enabled only after both home and visitor are set  
# The Start game button is enabled only after both home and visitor are set.
# The End game button is disabled until the Game is started  
# The End game button is disabled until the game has started.
These are some examples of business logic that would have easily ended up in the UI if we did not have a good place to define it.
These are some examples of business logic that would have easily ended up in the UI if we did not have a good place to define it.


===== '''Taking it further still''' =====
===== '''Taking it further still''' =====
If the cost of creating and maintaining a ViewModel is high fewer ViewModels will be created. So our mission is to reduce the cost of creating and maintaining them.
If the cost of creating and maintaining a ViewModel were high, fewer ViewModels would be created. Our mission is to reduce the cost of creating and maintaining them.


WPF is a declarative way to describe the UI. This mean that the same basic lookless components like TextBlock, TextBox, CheckBox, Combobox and Image etc will be used again and again and they will be given a look by an external style or template.
WPF is a declarative way to describe the UI. This means that the same basic look-less components like TextBlock, TextBox, CheckBox, Combobox, and Image, etc will be used again and again and they will be given a look by an external style or template.


What if we use this fact and provide some basic rendering/placing hints for the ViewModel columns? We could then use those clues to spill out the correct lookless control in the intended relative position so we would not need to mess about with xaml every 5 minutes. This is what the ViewModel-Editor looks like without rendering hints:
What if we use this fact to provide some basic rendering/placing hints for the ViewModel columns? We could then use those clues to spill out the correct look-less control in the intended relative position; we would not need to mess about with XAML every 5 minutes. This is what the ViewModel-Editor looks like without rendering hints:


[[File:View Model Further still.png|frameless|448x448px]]
[[File:View Model Further still.png|frameless|448x448px]]


And this is the way it looks when I have checked the “Use Placing Hints” checkbox:
And this is the way it looks like when I have checked the “Use Placing Hints” checkbox:


[[File:VM UI.png|frameless|453x453px]]
[[File:VM UI.png|frameless|453x453px]]


Given the extra fields for “Presentation”, “Column”,”Row”,”Span” etc I can work the ViewModel – preview to look like this:
Given the extra fields for “Presentation”, “Column”,”Row”,”Span” etc,I can work the ViewModel –review to look like this:


[[File:MV UI 2.png|frameless|450x450px]]
[[File:MV UI 2.png|frameless|450x450px]]


Now I really need to stress this so that I do not get misunderstood: We are not designing the presentation here at all. We are describing what data is available, which values are valid, possible selection lists of data, and, if the UI designer wishes to take notice of it, *hints* as to how to arrange the controls in relation to each other which happens to give the option of generating the userinterface automatically by whatever front end is currently in fashion. This is all natural information we have in mind while designing the ViewModel.
Now, I really need to stress this so that I do not get misunderstood: We are not designing the presentation here at all. We are describing what data is available, which values are valid, possible selection lists of data, and, if the UI designer wishes to take notice of it, *hints* as to how to arrange the controls in relation to each other, which happens to give the option of generating the user-interface automatically by whatever front end is currently in fashion. This is all the natural information we have in mind while designing the ViewModel.


Having a ViewModel with placing hints, you can add a ViewModelWPFUserControl to your form with just one row:
Having a ViewModel with placing hints, you can add a ViewModelWPFUserControl to your form with just one row:
Line 63: Line 63:
[[File:VM UI The game.png|frameless|392x392px]]
[[File:VM UI The game.png|frameless|392x392px]]


And remember that these auto layout controls also adheres to external set styles.
Remember that these auto layout controls also adhere to external set styles.


Having the ability to get simple UI automatically derived from the ViewModel placing hints lowers the effort to produce and maintain. Experience has shown that a lot of the administrative parts of your application is left as automated so that more time can be spent on the signature screens that are most important for your users.
Having the ability to get simple UI automatically derived from the ViewModel, placing hints lowers the effort to produce and maintain. Experience has shown that a lot of the administrative parts of your application are left as automated so that more time can be spent on the signature screens that are most important for your users.
[[Category:View Model]]
[[Category:View Model]]
[[Category:Beginner]]
[[Category:Beginner]]

Revision as of 08:03, 11 January 2023

Example:

View Model PNG0.png

Presented with a model that I got from a colleague, that incidentally helps out as a Hockey referee when he is not coding, I wanted to create a ViewModel for the use-case “Set up new Hockey game”.

Image 11 GAME.png

The Game class has a state machine: Image 3 GAME.png

I took a piece of paper and draw the UI I wanted to achieve:

Image 4 GAME.png

Now I know what the requirements are on the ViewModel since I can see from the drawing what data the ViewModel needs to hold.

Then I created this ViewModel that I named GameSetup:

Image 5.png

Notice that it is just a series of named OCL expressions. Some expressions are nested to list other definitions like Home_PickList which state that if the game has a picked game type, then we know what teams can be chosen – namely those teams that are associated with that game type.

I created some test data so that UI can show something. My first attempt was to manually code a WPF UI and bind the values to the ViewModel:

The UI looks like this:

GAME UI.png

This has a minimal amount of fashionably acceptable styling. The good thing is that you can hand it to any WPF-savvy designer in the world – the data and the rules are safe in the ViewModel.

It already shows some of the good effects of separating UI from logic.

  1. The PickLists for Home and Visitor are filtered based on the type of game.
  2. The Picklist for the Home team filters away the Visitor team if set (and vice versa).
  3. The Start game button is enabled only after both home and visitor are set.
  4. The End game button is disabled until the game has started.

These are some examples of business logic that would have easily ended up in the UI if we did not have a good place to define it.

Taking it further still

If the cost of creating and maintaining a ViewModel were high, fewer ViewModels would be created. Our mission is to reduce the cost of creating and maintaining them.

WPF is a declarative way to describe the UI. This means that the same basic look-less components like TextBlock, TextBox, CheckBox, Combobox, and Image, etc will be used again and again and they will be given a look by an external style or template.

What if we use this fact to provide some basic rendering/placing hints for the ViewModel columns? We could then use those clues to spill out the correct look-less control in the intended relative position; we would not need to mess about with XAML every 5 minutes. This is what the ViewModel-Editor looks like without rendering hints:

View Model Further still.png

And this is the way it looks like when I have checked the “Use Placing Hints” checkbox:

VM UI.png

Given the extra fields for “Presentation”, “Column”,”Row”,”Span” etc,I can work the ViewModel –review to look like this:

MV UI 2.png

Now, I really need to stress this so that I do not get misunderstood: We are not designing the presentation here at all. We are describing what data is available, which values are valid, possible selection lists of data, and, if the UI designer wishes to take notice of it, *hints* as to how to arrange the controls in relation to each other, which happens to give the option of generating the user-interface automatically by whatever front end is currently in fashion. This is all the natural information we have in mind while designing the ViewModel.

Having a ViewModel with placing hints, you can add a ViewModelWPFUserControl to your form with just one row:

<ecoVM:ViewModelWPFUserControl Grid.Row=”2″ x:Name=”VMU1″
  EcoSpaceType=”{x:Type ecospace:WPFBindingEcoSpace}”
    ViewModelName=”GameSetup” >

And the result is:

VM UI The game.png

Remember that these auto layout controls also adhere to external set styles.

Having the ability to get simple UI automatically derived from the ViewModel, placing hints lowers the effort to produce and maintain. Experience has shown that a lot of the administrative parts of your application are left as automated so that more time can be spent on the signature screens that are most important for your users.

This page was edited more than 7 months ago on 05/31/2024. What links here