|
|
(26 intermediate revisions by 5 users not shown) |
Line 1: |
Line 1: |
| <html> | | <html> |
| <style> | | <p class="video-warn"> |
| #video12 {
| | <em>To make your experience smooth, we set the main tags mentioned in the video to the right bar menu of this mini-player. Choose an interesting subtitle on the list and immediately get to the exact theme navigation item place in the video. Now you can pick any topic to be instructed on without watching the whole video.</em> </p> |
| position: relative;
| |
| height: 500px;
| |
| width:560px;
| |
| padding-bottom: 10px;
| |
| }
| |
| #video12 iframe {
| |
| position: absolute;
| |
| min-height: auto;
| |
| min-width: auto;
| |
| }
| |
| #video12 div {
| |
| position: absolute;
| |
| top: 0;
| |
| left:760px;
| |
| width: 260px;
| |
| height: 100%;
| |
| padding-left: 10px;
| |
| overflow-y: auto;
| |
| }
| |
| span {
| |
| font-size: 18;
| |
| display:block;
| |
| padding: 2px 10px 2px 10px;
| |
| padding-bottom: 0.5;
| |
| padding-top: 0.5;
| |
| opacity: 0.7;
| |
| }
| |
| span:hover {
| |
| color: #0000FF;
| |
| cursor: pointer;
| |
| }
| |
| span:focus {
| |
| color: blue;
| |
| </style> | |
|
| |
|
| <h5> Review on the WECPOF prototyper application and continue on prototyping with actions and viewmodels.</h5> | | <div class="video"> |
| <p>
| | <div class="video__wrapper"> |
| <em>To make your experience more comfortable, we set the main tags mentioned in the video to the right bar menu of this mini player. Choose the interesting subtitle on the list and immediately get to the exact theme timeplace in the video. Now you can pick any topic to be instructed without watching the whole video.</em>
| | <iframe src="https://www.youtube.com/embed/it0ZD7gtjnE?rel=0&autoplay=0"frameborder="0" allowfullscreen></iframe> |
| <style type="text/css">
| | </div> |
| p {
| | <div class="video__navigation"> |
| opacity: 0.7;
| | <span class="navigation-item" data-video="it0ZD7gtjnE" data-start="41" tabindex="0"> Running prototyper application</span> |
| text-align: justify;
| | <span class="navigation-item" data-video="it0ZD7gtjnE" data-start="1620" tabindex="0"> More on WECPOF</span> |
| width: 90%
| | <span class="navigation-item" data-video="it0ZD7gtjnE" data-start="118" tabindex="0"> Action Definitions editor</span> |
| }
| | <span class="navigation-item" data-video="it0ZD7gtjnE" data-start="123" tabindex="0"> • Global actions</span> |
| </style>
| | <span class="navigation-item" data-video="it0ZD7gtjnE" data-start="213" tabindex="0"> Bring Up a View Model</span> |
| </p>
| | <span class="navigation-item" data-video="it0ZD7gtjnE" data-start="549" tabindex="0"> • ViewModel root object</span> |
| </br>
| | <span class="navigation-item" data-video="it0ZD7gtjnE" data-start="691" tabindex="0"> • Menu groups </span> |
| <div id="video12"> | | <span class="navigation-item" data-video="it0ZD7gtjnE" data-start="804" tabindex="0"> • Create/Init standart actions </span> |
| <iframe width="740" height="500" src="https://www.youtube.com/embed/Tnlk5nENWQc?rel=0&autoplay=0" frameborder="0" allowfullscreen></iframe> | | <span class="navigation-item" data-video="it0ZD7gtjnE" data-start="844" tabindex="0"> • Framework actions</span> |
| <div>
| | <span class="navigation-item" data-video="it0ZD7gtjnE" data-start="1771" tabindex="0"> Nested ViewModel class </span> |
| <span data-video="Tnlk5nENWQc" data-start="36" tabindex="0">Running prototyper application</span> | | <span class="navigation-item" data-video="it0ZD7gtjnE" data-start="1928" tabindex="0"> • Grid options</span> |
| <span data-video="Tnlk5nENWQc" data-start="1615" tabindex="0"> More on WECPOF</span> | | <span class="navigation-item" data-video="it0ZD7gtjnE" data-start="2058" tabindex="0"> • Expressions </span> |
| <span data-video="Tnlk5nENWQc" data-start="113" tabindex="0">Action Definitions editor</span> | | <span class="navigation-item" data-video="it0ZD7gtjnE" data-start="2234" tabindex="0"> • Global Action for Create/Global Action for show </span> |
| <span data-video="Tnlk5nENWQc" data-start="118" tabindex="0"> • Global actions</span> | | <span class="navigation-item" data-video="it0ZD7gtjnE" data-start="2443" tabindex="0"> ViewModel action</span> |
| <span data-video="Tnlk5nENWQc" data-start="208" tabindex="0">Bring Up a View Model</span> | | <span class="navigation-item" data-video="it0ZD7gtjnE" data-start="3233" tabindex="0"> Class action </span> |
| <span data-video="Tnlk5nENWQc" data-start="544" tabindex="0"> • ViewModel root object</span> | | <span class="navigation-item" data-video="it0ZD7gtjnE" data-start="3694" tabindex="0"> Navigating Actions </span> |
| <span data-video="Tnlk5nENWQc" data-start="686" tabindex="0"> • Menu groups </span> | | <span class="navigation-item" data-video="it0ZD7gtjnE" data-start="3725" tabindex="0"> 3d rendering </span> |
| <span data-video="Tnlk5nENWQc" data-start="799" tabindex="0"> • Create/Init standart actions </span> | |
| <span data-video="Tnlk5nENWQc" data-start="839" tabindex="0"> • Framework actions</span> | |
| <span data-video="Tnlk5nENWQc" data-start="1766" tabindex="0">Nested ViewModel class </span> | |
| <span data-video="Tnlk5nENWQc" data-start="1923" tabindex="0"> • Grid options</span> | |
| <span data-video="Tnlk5nENWQc" data-start="2053" tabindex="0"> • Expressions </span> | |
| <span data-video="Tnlk5nENWQc" data-start="2229" tabindex="0"> • Global Action for Create/Global Action for show </span> | |
| <span data-video="Tnlk5nENWQc" data-start="2438" tabindex="0">ViewModel action</span> | |
| <span data-video="Tnlk5nENWQc" data-start="3228" tabindex="0"> Class action </span> | |
| <span data-video="Tnlk5nENWQc" data-start="3689" tabindex="0"> Navigating Actions </span> | |
| <span data-video="Tnlk5nENWQc" data-start="3720" tabindex="0"> 3d rendering </span> | |
| </div> | | </div> |
| </div> | | </div> |
|
| |
|
| <script>
| |
| var IMG = document.querySelectorAll('#video12 span'),
| |
| IFRAME = document.querySelector('#video12 iframe');
| |
| for (var i = 0; i < IMG.length; i++) {
| |
| IMG[i].onclick = function() {
| |
| IFRAME.src = 'http://www.youtube.com/embed/' + this.dataset.video + '?rel=0&autoplay=1';
| |
| if(this.dataset.end) IFRAME.src = IFRAME.src.replace(/([\s\S]*)/g, '$1&end=' + this.dataset.end);
| |
| if(this.dataset.start) IFRAME.src = IFRAME.src.replace(/([\s\S]*)/g, '$1&start=' + this.dataset.start);
| |
| this.style.backgroundColor='rgba(0,0,0,.2)';
| |
| }
| |
| }
| |
| </script>
| |
| </html> | | </html> |
| | | [[Category:WECPOF]] |
| '''Raw video subtitles'''
| | [[Category:View Model]] |
| | | [[Category:Actions]] |
| I welcome back this is part three of
| | [[Category:MDriven Designer]] |
| | | [[Category:MDriven Designer Sessions]] |
| the MDriven overview
| | {{Edited|July|12|2024}} |
| | |
| let's have the right back in them on the
| |
| | |
| day the play button where we have their
| |
| | |
| system prototyper we have looked at the
| |
| | |
| the new debugger that look like this but
| |
| | |
| this button wrong model and continue
| |
| | |
| modeling is also interesting if we push that one we get there
| |
| | |
| this window and that actually is
| |
| | |
| possibly our running application and
| |
| | |
| this also has a model refresh, so if we
| |
| | |
| do changes in our model this one can
| |
| | |
| re-read to to reflect the changes to
| |
| | |
| actually execute an application we need some kind of menu
| |
| | |
| this is just the administrative manual
| |
| | |
| way you can issues sties and refreshed
| |
| | |
| models but how do we get there and a
| |
| | |
| menu in here so that we could view our
| |
| | |
| and view model or rendered view of our view model actually
| |
| | |
| we do that by adding an action in the
| |
| | |
| action dialogue so actions editor click that one up
| |
| | |
| it looks like this and and that we could
| |
| | |
| create a new global action global
| |
| | |
| actions are actions that show up in the
| |
| | |
| global menu in her in a prototype
| |
| | |
| application so I'm going to add a new
| |
| | |
| global action when I select that in the grid
| |
| | |
| I get the properties here to change if I need to
| |
| | |
| so if this is just "Default" name new global action
| |
| | |
| it has the ability to have an enable
| |
| | |
| expression and again it's the ocl it has
| |
| | |
| the ability to have access groups we're
| |
| | |
| going to look at that later on and
| |
| | |
| there's also a possible execute
| |
| | |
| expression again it's ocl but the action
| |
| | |
| language remember ocl with side effects
| |
| | |
| that actually can change data but we are
| |
| | |
| going to use now is bring up a few more
| |
| | |
| the house view the one that with it so
| |
| | |
| let's leave it at that first and we head
| |
| | |
| back to this window and we re-read the model
| |
| | |
| for some reason it big again and now we
| |
| | |
| have the new global action as a menu and
| |
| | |
| this is as we see it here it's rendered
| |
| | |
| with spaces between each camel case part
| |
| | |
| of the world word new global action one
| |
| | |
| but what we named it too was just a
| |
| | |
| camel case new global action 1
| |
| | |
| why is that that is because we left the
| |
| | |
| presentation as the "Default" and and when
| |
| | |
| it's the presentation is left like this
| |
| | |
| just stating that we should use the name
| |
| | |
| we run this their algorithm to hack up
| |
| | |
| the name on each capital case so now
| |
| | |
| this action what it should do is bring
| |
| | |
| up the house view so let's see if it
| |
| | |
| does that and it does so we see a couple
| |
| | |
| of interesting things here and this side
| |
| | |
| is the view and this side is saved for
| |
| | |
| any actions that are valid in this view
| |
| | |
| they will be listed here what we notice
| |
| | |
| immediately is that they create street
| |
| | |
| button got really launched and that is
| |
| | |
| because it's at the end of the at the
| |
| | |
| bottom of the view mom and anything that
| |
| | |
| and is at the end of the view model
| |
| | |
| and rendered by this rendering engine
| |
| | |
| which uses wpf windows presentation
| |
| | |
| foundation will be extended to the
| |
| | |
| bottom so that's actually a feature to
| |
| | |
| enable us to have you I that fills out
| |
| | |
| the view and scales with the view we were to drive like this
| |
| | |
| so in order to mitigate this we should
| |
| | |
| make sure that this isn't touching the
| |
| | |
| end there's couple of ways of doing that
| |
| | |
| but I'm going to choose to say that
| |
| | |
| there's a explicit row count in this
| |
| | |
| view model if I turn on the grid lines I
| |
| | |
| can see that it has one two three four
| |
| | |
| five rows that he Ritt States 00 just
| |
| | |
| means that it will adapt to the highest
| |
| | |
| needed position from the things that we
| |
| | |
| have placed here so if we look at our
| |
| | |
| action that is rendered as the button
| |
| | |
| it's actually set its place on road 400
| |
| | |
| 1234 and that's great if we were to move
| |
| | |
| this to hear it would say row five and
| |
| | |
| then this one expanse but what we want
| |
| | |
| to do is to avoid having this at the
| |
| | |
| body so let's say there's seven rows in
| |
| | |
| the grid now there's an empty row in
| |
| | |
| between can move that up again there's
| |
| | |
| two empty rows and that would be
| |
| | |
| rendered as if we will work to refresh the model
| |
| | |
| like that so that's more like what we
| |
| | |
| want to see so now what we'll notice
| |
| | |
| here is that and this won't take any
| |
| | |
| edits as of yet everything disappears
| |
| | |
| even if we do the create street nothing
| |
| | |
| sticks and this was expected because if
| |
| | |
| we look at that our view model it's
| |
| | |
| rooted in a house but if we look at the
| |
| | |
| action the view model root object is
| |
| | |
| not set so what we see here is an empty
| |
| | |
| shell it isn't back by the house to
| |
| | |
| mitigate this we can either create the
| |
| | |
| house as part of the action
| |
| | |
| so in the human root object we would do
| |
| | |
| house create and if we then
| |
| | |
| if we then we read the model first asked
| |
| | |
| me since I have changes and the changes
| |
| | |
| are actually created a street that I try
| |
| | |
| to tie to an empty house or to the new
| |
| | |
| house would you like to save it now and every time
| |
| | |
| let's see every time I push the model
| |
| | |
| refresh this view goes really big
| |
| | |
| why is that let's fix that once and for
| |
| | |
| all it's actually this one screen size
| |
| | |
| that we have set to something quite
| |
| | |
| large if we were to change it to let's
| |
| | |
| say 800 x 600 and do the model refresh
| |
| | |
| then it sticks this way, ok but what we were working at at state
| |
| | |
| new global action is actually backed by
| |
| | |
| house, so now when I click and the street
| |
| | |
| number should stake they create street
| |
| | |
| should state but not about is also that
| |
| | |
| the Save button is lit up and the cancel button
| |
| | |
| so if I were to save this and do a new
| |
| | |
| global action I actually create a house
| |
| | |
| by clicking this action
| |
| | |
| ok and normally you wouldn't like the
| |
| | |
| action to be placed like this this is
| |
| | |
| more like you expect the submenu from it
| |
| | |
| to create the the submenus we could
| |
| | |
| assign the global action to the menu
| |
| | |
| group menu group we don't have any as of
| |
| | |
| yet so we could create some pick up this
| |
| | |
| dialog and add a menu group let's call this one and five
| |
| | |
| that's add another one called views and
| |
| | |
| we want to sort these so that five let's
| |
| | |
| add not want and hey we want to have
| |
| | |
| this one first and this one second and
| |
| | |
| this one third so now we have some
| |
| | |
| groups that are global to our model and
| |
| | |
| we can assign our action to a group
| |
| | |
| going to assign it to the views group
| |
| | |
| and if I now reload their model I got
| |
| | |
| the views with the new global action
| |
| | |
| under it so that's better but I didn't
| |
| | |
| get the file or the edit menus because
| |
| | |
| those are just groups without any actions in
| |
| | |
| there's actually a button here create
| |
| | |
| and int standard actions let's see what it does
| |
| | |
| so it says you already have some actions
| |
| | |
| defined you still want to create standard actions
| |
| | |
| yes, he added some actions
| |
| | |
| maybe it also added some groups
| |
| | |
| yes it's added one group but that's fine
| |
| | |
| so let's look at what the actions were
| |
| | |
| that it added the same action
| |
| | |
| that's not back by anything but a
| |
| | |
| framework action framework actions are
| |
| | |
| safe refresh undo/redo exit business
| |
| | |
| delete and do model ok so those are the
| |
| | |
| choices for the framework work actions
| |
| | |
| same is actually just saving the state
| |
| | |
| of the view the Refresh will in an
| |
| | |
| environment where we work against at
| |
| | |
| persistence server like the am driven
| |
| | |
| server or turkey application refresh
| |
| | |
| will re-read data that has changed in the
| |
| | |
| database since we read it to the view
| |
| | |
| exit will try and exit the application
| |
| | |
| undo and redo obvious they will try to
| |
| | |
| undo the latest changes that the usage
| |
| | |
| has done or redo them and then we have
| |
| | |
| our new global action that we started
| |
| | |
| so refreshing the the prototype will
| |
| | |
| give us five exit refresh safe and add
| |
| | |
| it will have redo an undue and the views
| |
| | |
| will have the new global action and the
| |
| | |
| Stice allow us to optionally and set
| |
| | |
| another wpf style
| |
| | |
| ok so new global action and we could
| |
| | |
| create street and set something here now
| |
| | |
| we could go edit undo or added reading
| |
| | |
| or we could go safe like this right
| |
| | |
| and normally redo an undue is backed by
| |
| | |
| control set and control y so if we would
| |
| | |
| want to do something like that we could
| |
| | |
| say that down here menu group the on
| |
| | |
| this is the undo
| |
| | |
| it's in the menu group edit and shortcut
| |
| | |
| key set and control and the redo should
| |
| | |
| have a shortcut key like and control
| |
| | |
| let's see that that stuff yeah and then
| |
| | |
| if we were to re-read the model we see
| |
| | |
| that they have been back by these
| |
| | |
| shortcut keys so view new global action
| |
| | |
| undo that wasn't what I was supposed to
| |
| | |
| show I should press ctrl + set like that
| |
| | |
| alright if I now save the changes that
| |
| | |
| we have so far I will notice there's an
| |
| | |
| error showing up and what it says is
| |
| | |
| there's a new global action that sets a
| |
| | |
| root object for the house view but the
| |
| | |
| house view doesn't require the root
| |
| | |
| object so why do we set one this is just
| |
| | |
| a helper to make our design consistent
| |
| | |
| so to address this warning we should
| |
| | |
| open up the house
| |
| | |
| view and say that it requires root topic
| |
| | |
| because this view is no good without a
| |
| | |
| packing house so if we were to shake
| |
| | |
| this one it quick
| |
| | |
| it requires a root object and save again
| |
| | |
| that triggers the error finding in the
| |
| | |
| model we could have pushed that one as
| |
| | |
| well of course and we see that there
| |
| | |
| the warning is gone
| |
| | |
| ok so
| |
| | |
| our model looks kind of weird
| |
| | |
| we're going clean it up a bit and and
| |
| | |
| remember if I'm just press delete and
| |
| | |
| not control the elite I only remove
| |
| | |
| things from view press Delete deep I
| |
| | |
| only remove these from from this diagram
| |
| | |
| and this one is not squared line and I
| |
| | |
| would like it to be squared so I press
| |
| | |
| the shortcut key for that control our
| |
| | |
| this and this one as well that and class
| |
| | |
| 2 doesn't really help us anything
| |
| | |
| let's say that this is a person with a
| |
| | |
| first-name lost like that and the
| |
| | |
| association class between person and
| |
| | |
| house could be yeah lease contract that
| |
| | |
| we have a lease on and department in the
| |
| | |
| house maybe so that would state a hard
| |
| | |
| then number as an integer that's
| |
| | |
| possibly inaudible and maybe it should
| |
| | |
| state the rent
| |
| | |
| is that double now I just press ctrl
| |
| | |
| while using the thumb thumb wheel on the
| |
| | |
| mouse to scroll in scroll up with scroll
| |
| | |
| where my mouse is pointing so if I pump
| |
| | |
| . here and scroll it will stay in you
| |
| | |
| strong out I want to look closer to this
| |
| | |
| one pointed and control and mouse wheel
| |
| | |
| in a root so on the lease contract it
| |
| | |
| will be important to also give some
| |
| | |
| dates so gonna add a start and this is
| |
| | |
| actually featured at them when we parts
| |
| | |
| the the data that you put in to this
| |
| | |
| edit we start from left to right so in
| |
| | |
| order to be quick so if you just start
| |
| | |
| to write start date and then continue
| |
| | |
| with colon day time ? and that's what
| |
| | |
| you will get a little bit faster
| |
| | |
| and they question like that so that
| |
| | |
| might be a good lease contract
| |
| | |
| so we should probably em call this one
| |
| | |
| and this is Bella way I don't know going
| |
| | |
| to pounce and group should be one that
| |
| | |
| and I would call this and apart man so
| |
| | |
| the person can have multiple rented
| |
| | |
| apartments multiple each one is backed
| |
| | |
| by a lease contract and the house can
| |
| | |
| have multiple tenants that are persons
| |
| | |
| and that makes sense to me and now when
| |
| | |
| I'm doing this model but of course
| |
| | |
| depending on the requirements each maybe
| |
| | |
| we'll look totally different when
| |
| | |
| meeting an actual domain doing actual
| |
| | |
| work so that's the the point of modeling
| |
| | |
| finding the requirements that are right
| |
| | |
| for a particular use case so what about
| |
| | |
| this link what you mean maybe if we
| |
| | |
| change this one to owned houses and we
| |
| | |
| would change this one to both
| |
| | |
| so now the rules say that house only has
| |
| | |
| one owner owned by but a person can own
| |
| | |
| many houses
| |
| | |
| ok so now we have just cleaned up a
| |
| | |
| little bit gonna move in this tree
| |
| | |
| closer that didn't turn out very well
| |
| | |
| that and the location so what about the
| |
| | |
| location maybe to motivate the
| |
| | |
| generalization of location maybe we just
| |
| | |
| should add a city like that and a name
| |
| | |
| of the city that also is back but that
| |
| | |
| has a position property and then it
| |
| | |
| would be appropriate to have that street
| |
| | |
| is in 101 city and the city has multiple
| |
| | |
| sweet that would make sense
| |
| | |
| say we haven't done any thing to
| |
| | |
| actually change the views so adding back
| |
| | |
| to their prototype which we often
| |
| | |
| referred to as like path and why is it
| |
| | |
| called wake up off
| |
| | |
| well when we started m/m driven
| |
| | |
| framework was named eco enterprise core
| |
| | |
| objects ec ok and then when we found
| |
| | |
| that it was a good match to render
| |
| | |
| things in wpf we sort of much and the ID
| |
| | |
| to enterprise core objects and the wpf so
| |
| | |
| that's the story behind the crazy name
| |
| | |
| that and bothers some but hey it's just
| |
| | |
| a name it's not important but when you
| |
| | |
| hear us refer to the engine back of we
| |
| | |
| often talk about the the idea to take
| |
| | |
| purely decorative design with the view
| |
| | |
| models to running application and
| |
| | |
| actually the idea to do this is
| |
| | |
| implemented in many more ways than just
| |
| | |
| the wpf windows presentation foundation
| |
| | |
| it's implemented in like in turn key
| |
| | |
| with the angularjs and MVC for the web
| |
| | |
| and and actually we have it all over the
| |
| | |
| place it's also in in windows for us and
| |
| | |
| I speed of that so the idea is larger
| |
| | |
| than windows presentation foundation
| |
| | |
| let's add a slightly more day and
| |
| | |
| another view model to give us an access point to the houses
| |
| | |
| let's call this one "AllHouses" to start
| |
| | |
| with and we say that it's in the type
| |
| | |
| context of house but now we can add the
| |
| | |
| column or then the nested viewmodel
| |
| | |
| column multiple links get a problem with
| |
| | |
| this showing outside of the screen house
| |
| | |
| all instances, let's see what happens if
| |
| | |
| we just follow the model so that and
| |
| | |
| this pops out because we said it was of
| |
| | |
| glass house so then and there
| |
| | |
| view model editor suggest that maybe you
| |
| | |
| want to use house or instances in all
| |
| | |
| instances is an OCL operator to show
| |
| | |
| everything of that particular class so
| |
| | |
| that's a practical way to start on in
| |
| | |
| information sets that there are small
| |
| | |
| and initially everything is small so
| |
| | |
| it's a good start, so what happened here
| |
| | |
| it added the this view model call you
| |
| | |
| with the ocl expression house all
| |
| | |
| instances and if we were to look at the
| |
| | |
| resulting type of days it's a collection
| |
| | |
| of house so it's basically houses and
| |
| | |
| then it added this blue nesting
| |
| | |
| viewmodel claws and it connected this
| |
| | |
| column to this one so how come the sound
| |
| | |
| connected it should look like this as
| |
| | |
| was a new one I haven't seen that before
| |
| | |
| so the house all instances points out
| |
| | |
| associated to all house so these are all
| |
| | |
| made up names that let's call this one
| |
| | |
| house grit and whenever they're in the
| |
| | |
| view rendering engine seized this type
| |
| | |
| of construction there's something that
| |
| | |
| is creating a list and you have
| |
| | |
| properties on each object for in the
| |
| | |
| list it will suggest that we should
| |
| | |
| render it as a great and to make they're
| |
| | |
| going to switch off the grid lines the
| |
| | |
| grid lines are for the complete the area
| |
| | |
| that we rendering and this is a rented
| |
| | |
| great if we switched the designer style
| |
| | |
| of the render that they take might be
| |
| | |
| more clear what happens all that in work as expected
| |
| | |
| let's see if I switch, yeah like this I had to switch back and
| |
| | |
| forth to make it stick, so this is and rendered as a grid and if
| |
| | |
| I add properties I can either just add a
| |
| | |
| eunuch volume and then I will have to
| |
| | |
| write my expression ocl expression what
| |
| | |
| should be in it myself where I can just
| |
| | |
| pick from what the view model editor
| |
| | |
| suggest based on the based on the type
| |
| | |
| information so let's pick the street
| |
| | |
| number and now did the street number and
| |
| | |
| up here and it ends up as a column in
| |
| | |
| the grid so if I continue like this at
| |
| | |
| the state than the state ends up here
| |
| | |
| and I'm gonna add a unary call you that
| |
| | |
| I can name to something but first we're
| |
| | |
| going to do the expression so what it wouldn't do
| |
| | |
| maybe we want to list who owns it so
| |
| | |
| as we are in context of house we have
| |
| | |
| access to the roles of the associations
| |
| | |
| of house house has an association owned
| |
| | |
| by as we see here so let's follow that
| |
| | |
| one and then we are in context of the
| |
| | |
| resulting type is person and person has
| |
| | |
| a first name and lost me
| |
| | |
| ok so let's take the the last name of that wasn't
| |
| | |
| let's take the the last name like that
| |
| | |
| so self owned by and last name and this
| |
| | |
| is really easy to navigate through
| |
| | |
| associations like this we can navigate
| |
| | |
| as far as we want and need in ocl so
| |
| | |
| that is really great when designing a
| |
| | |
| fully normalized information model where
| |
| | |
| everything is stored only once and
| |
| | |
| reused whenever needed so that forces us
| |
| | |
| to collect things together to present
| |
| | |
| the needed information in one context or
| |
| | |
| as we would like to call it in one view
| |
| | |
| model so now when I have the last name
| |
| | |
| of the owner I can name the call you last name of home
| |
| | |
| so this is another view and I would like
| |
| | |
| to have a global action for bringing up
| |
| | |
| this view this view actually isn't
| |
| | |
| backed by doesn't need to be backed by a
| |
| | |
| specific house because it doesn't make
| |
| | |
| use of anything of the root
| |
| | |
| the root object it just use the class and use the
| |
| | |
| class operator all instances if I right
| |
| | |
| click this one I get an option to add a
| |
| | |
| "Global Action for Create" or a global action for show
| |
| | |
| so this is just a shortcut to let's see
| |
| | |
| what happens if I do it is and in the
| |
| | |
| action dialogue and you action was
| |
| | |
| created "show.allhouses" so that was what
| |
| | |
| that helper method did show all
| |
| | |
| houses it brings up the viewmodel all
| |
| | |
| houses but what it didn't do is sorted
| |
| | |
| into a menu group so I will add that myself
| |
| | |
| it should be in the views like that so
| |
| | |
| that would mean that if I had back here
| |
| | |
| and refresh the model I should have
| |
| | |
| another one called "show.allhouses" that
| |
| | |
| shows a grip where all the houses that I
| |
| | |
| have created before are available all right
| |
| | |
| so now something interesting happens
| |
| | |
| what we really wanted to do with showing
| |
| | |
| a single house that we have in our other viewmodel this one
| |
| | |
| ideally we would just like to point and
| |
| | |
| one here and have this one backing this
| |
| | |
| one so maybe this one shouldn't be
| |
| | |
| brought up by a global action at all is
| |
| | |
| that it should be brought up by and
| |
| | |
| either an action of of this object or an action of this view
| |
| | |
| alright so we have two options we could
| |
| | |
| either do a viewmodel action that is
| |
| | |
| endemic to a specific view let's try
| |
| | |
| that first in the old houses that we can
| |
| | |
| push this button actions action
| |
| | |
| definitions with which just applies a
| |
| | |
| filter to the actions definitions that
| |
| | |
| is this show you model actions only
| |
| | |
| not the global actions and not the class
| |
| | |
| actions and filter on this human all
| |
| | |
| houses so the only thing this did was to
| |
| | |
| fill three days that initially looked
| |
| | |
| like this shows all actions and
| |
| | |
| incidentally we can push this one to
| |
| | |
| show all actions but from here action definitions for this view
| |
| | |
| are these show all actions but we want to do itfor this view
| |
| | |
| alright so we want to do a new view
| |
| | |
| model action that's an action
| |
| | |
| that only exists in a certain view so when I
| |
| | |
| create one, I get a new view model action
| |
| | |
| that only in viewmodel all houses and
| |
| | |
| within all houses I only wanted to show
| |
| | |
| in-house grid and when it's executed
| |
| | |
| I wanted to bring up the house view and
| |
| | |
| the view model root object for the house view
| |
| | |
| should be, yeah, what should it be
| |
| | |
| let's bring up the ocl editor it should
| |
| | |
| be the current object of the house grid
| |
| | |
| that would make sense, we're going
| |
| | |
| to get back to the vCurrent and vSelected soon
| |
| | |
| so now we have created a new action
| |
| | |
| that's only visible in the "AllHouses"
| |
| | |
| view model and only four objects of the
| |
| | |
| house grid and will bring up the
| |
| | |
| viewmodel house view and setting the root of the house
| |
| | |
| view to the current row of the house
| |
| | |
| grid let's see how that plays out in
| |
| | |
| the prototyper refreshing the model, views
| |
| | |
| "show.allhouses", so when I select one here
| |
| | |
| this one should bring up just the
| |
| | |
| one on pointing it so this is did one with
| |
| | |
| let's go back and now I see that the street number 444, that's the
| |
| | |
| street number 444, back so if I were to
| |
| | |
| bring this one up like that and set the
| |
| | |
| street number 123 save that, hit back and
| |
| | |
| then I see it's 123 so this is a way
| |
| | |
| to tie view models or views roller
| |
| | |
| together so this is a really bad name
| |
| | |
| for this action let's name it "ShowHouse"
| |
| | |
| model refresh, views, "show.allhouses", show house
| |
| | |
| just a few short notes on how
| |
| | |
| the back of engine works if we were to
| |
| | |
| down "ctrl" and while we press the action show house it would actually
| |
| | |
| add another tab to show the date so this way we could bring up another one like that
| |
| | |
| and notice this green "." it's actually
| |
| | |
| the it signals that there's a object root connected to this view
| |
| | |
| so this one doesn't have a green dot
| |
| | |
| because that doesn't have a rooted house
| |
| | |
| to start with but these stood
| |
| | |
| and also double-click on a row in the
| |
| | |
| grip will check the actions list for
| |
| | |
| actions that navigates like this one it
| |
| | |
| will take the first navigating enabled
| |
| | |
| action and executed so if I were to
| |
| | |
| double click on this one while holding
| |
| | |
| "ctrl" it would bring that one up and I don't need to use the action that's a
| |
| | |
| practical way to navigate and
| |
| | |
| double-clicking without holding control
| |
| | |
| of course will replace the content in
| |
| | |
| this view like this but the back will
| |
| | |
| bring me once that back just like in a
| |
| | |
| web browser so I'm back to the old
| |
| | |
| houses like that so these are some of
| |
| | |
| the functionalities of the UI engine that we use here
| |
| | |
| also notice that the text on the tabs
| |
| | |
| here are actually the "asstring"
| |
| | |
| representation of the rooted object and do
| |
| | |
| you remember from part one where we got
| |
| | |
| that from in the house we had set the
| |
| | |
| "Default" string representation as
| |
| | |
| an OCL expression to the street name and
| |
| | |
| this stree has street number "asstring" and
| |
| | |
| just to prove a point we could add
| |
| | |
| something else here "ForReal" like that
| |
| | |
| and heading back to here and refreshing the model and showing "AllHouses"
| |
| | |
| we have the "ForReal" representation here and if we
| |
| | |
| were to double click one you have the
| |
| | |
| "ForReal" representation there okay
| |
| | |
| as I said with the action that we added
| |
| | |
| we had two options either do in action
| |
| | |
| that's also the actions are visible here
| |
| | |
| and you use this one to fold it or to show it
| |
| | |
| we could either have done an action and
| |
| | |
| endemic to this view as within the
| |
| | |
| viewmodel action and if we will
| |
| | |
| double-click this we would get that
| |
| | |
| selected and see that it is a viewmodel
| |
| | |
| action, action type navigates from "AllHouses" to house view
| |
| | |
| and if we were to click this it will
| |
| | |
| actually show us the view model that it
| |
| | |
| navigates tool and that's the house you
| |
| | |
| and then we could click there to jump
| |
| | |
| back to the ones that we have looked at
| |
| | |
| before and this I can actually to
| |
| | |
| opt it out not to show it in this scenario
| |
| | |
| and opted out are available here and we
| |
| | |
| can opt back in up here we see all the
| |
| | |
| actions that leads to a certain view so
| |
| | |
| actions leading here or from the main
| |
| | |
| menu views of you group views and show
| |
| | |
| all house and if I were to jump to the house viewmodel
| |
| | |
| I can see there are two actions leaving here either one of views new global action
| |
| | |
| that we did as a starter action or the viewmodel action
| |
| | |
| in "AllHouses" called show house and I
| |
| | |
| can navigate to these two by clicking them
| |
| | |
| actually we might as well drop
| |
| | |
| this global action from the main menu
| |
| | |
| that created "House" it's not really
| |
| | |
| the correct way to do it
| |
| | |
| delete action, which leaves us in an
| |
| | |
| interesting situation we have no way to
| |
| | |
| create new house currently and we
| |
| | |
| will need to add that to the
| |
| | |
| maybe to the "AllHouses" view so in here
| |
| | |
| we might as well add a new view model action
| |
| | |
| with a different purpose
| |
| | |
| add new house and instead of having
| |
| | |
| navigate that it should do if we
| |
| | |
| have set to bring up the view model we
| |
| | |
| might as well give it and execute
| |
| | |
| expression instead, execute expression
| |
| | |
| and what we wanted to do is just house.create
| |
| | |
| and that would be enough
| |
| | |
| so not saying only in this will give us this look
| |
| | |
| "AddNewHouse" is available on the
| |
| | |
| allhouses under this one the root but
| |
| | |
| also in the house grip at new house so
| |
| | |
| that's not very and intuitive for the
| |
| | |
| user to see the "AddNewHouse" in two
| |
| | |
| places, so we could either opt one of them
| |
| | |
| out, or we might as well instruct the action that it should only
| |
| | |
| show in the "AllHouses" on the root that
| |
| | |
| said if you think about it it's the only
| |
| | |
| place where it makes sense - on the root
| |
| | |
| because, if you have no houses, we still
| |
| | |
| want to be able to create a house
| |
| | |
| so even if the grid is empty, so only in this "AllHouses"
| |
| | |
| made it disappear from the HouseGrid
| |
| | |
| heading back to the "Prototyper"
| |
| | |
| refreshing the model views show all
| |
| | |
| houses, I now have a new action "add new house"
| |
| | |
| and as you see house.create was
| |
| | |
| all it took to create new house and
| |
| | |
| they all instances picks this up by
| |
| | |
| subscription and adds a road to the grid
| |
| | |
| a rendering of the new house that we created and of course I
| |
| | |
| can immediately double-click it to
| |
| | |
| execute the first navigate action to
| |
| | |
| set some properties 456 and head back four five six but I
| |
| | |
| can just cancel all this out, like that
| |
| | |
| discard changes, yes please, ok but then
| |
| | |
| what I actually were about to say is
| |
| | |
| that we had two options before to either
| |
| | |
| do view model actions that are endemic to
| |
| | |
| a certain view or a class action which
| |
| | |
| are available wherever a class is visible
| |
| | |
| let's do a class action that does the
| |
| | |
| same thing as show house just to see
| |
| | |
| what the difference is "show house from object"
| |
| | |
| but it's really from object so it's an action on the
| |
| | |
| class "house and the bring up the view
| |
| | |
| model should be "house view and the view
| |
| | |
| model root object and now it's
| |
| | |
| interesting because now we are in the
| |
| | |
| context of the house so we might as well
| |
| | |
| just to "self", so the root object
| |
| | |
| expression is just "self", in this case and
| |
| | |
| if we head back to the view mode left
| |
| | |
| there we see that show house from object
| |
| | |
| will show up in these two places and if
| |
| | |
| we were to re-read the model here and
| |
| | |
| "show all houses" we see that it's
| |
| | |
| available here and it's available here
| |
| | |
| but both are disabled because even if
| |
| | |
| the action is potentially available, it
| |
| | |
| needs an object to act on and this one
| |
| | |
| will never have an object because our
| |
| | |
| view is not rooted in a house it's null
| |
| | |
| but this one that supports the grid
| |
| | |
| should be able to get an object once we've select one
| |
| | |
| so when I select one this one
| |
| | |
| is enable and this one will do the same
| |
| | |
| thing as the other one here we see an interesting thing that
| |
| | |
| since this action is available wherever
| |
| | |
| the object is shown is also available
| |
| | |
| from here so show house from object will
| |
| | |
| automatically show up here because this
| |
| | |
| is the house so heading back to view
| |
| | |
| model editor we probably first would like
| |
| | |
| to opt out the show house from object
| |
| | |
| on the root level because that we always
| |
| | |
| be disabled away with that now it lives here
| |
| | |
| that's fine and in the house
| |
| | |
| view it's not really helpful to the user
| |
| | |
| to have an action that points back at
| |
| | |
| the same object in this case so we want
| |
| | |
| to opt that out as well the fresh
| |
| | |
| so once we select one it's enabled and
| |
| | |
| we can click it and it's not shown here
| |
| | |
| so that's more like what we want so
| |
| | |
| keeping track of actions and what's
| |
| | |
| available and opted out etc can be quite the work in the end and this is
| |
| | |
| true for all applications what navigates
| |
| | |
| where we're to track things and how
| |
| | |
| can you get here at least with our
| |
| | |
| strategy fully modeled and the fully
| |
| | |
| decorative, you will have all the
| |
| | |
| information readily available for you
| |
| | |
| and also we have a special view the action
| |
| | |
| crossref that renders like this so
| |
| | |
| actions leading here our show house and
| |
| | |
| show house from object so that's one way
| |
| | |
| of getting to the house view but and
| |
| | |
| there is an action show house from
| |
| | |
| object that is opted out if I would like to opt it in
| |
| | |
| I can just click the line and that would
| |
| | |
| be great so that would mean that this
| |
| | |
| action is available again from here but
| |
| | |
| since I don't want that I will opt it out
| |
| | |
| and then it's gone, so from the old houses
| |
| | |
| I see that there is an action show "all
| |
| | |
| houses" that leads here and there are
| |
| | |
| these actions available to the user from
| |
| | |
| this UI there's one called "AddNewHouse"
| |
| | |
| and there is a show house from object
| |
| | |
| which potentially is available from the
| |
| | |
| root but in our case it's not we don't
| |
| | |
| want that so that's opted out red and
| |
| | |
| there are these two that are available
| |
| | |
| from objects in the grid
| |
| | |
| so that's one way to define cross references
| |
| | |
| for the actions, another way to follow through is 22
| |
| | |
| let's show all actions here and show
| |
| | |
| house from object and here we see a hint
| |
| | |
| that action shows in one place to places
| |
| | |
| are opted out let's get an overview by
| |
| | |
| following this view and that it's rendered
| |
| | |
| like this all the view models where this
| |
| | |
| action may come into play and remember
| |
| | |
| that was a class action so it will come
| |
| | |
| into play wherever the class is viewed
| |
| | |
| and if it's opted out red or opted-in
| |
| | |
| green so here we get a a way to see how
| |
| | |
| the actions interact with each other we
| |
| | |
| also have closed up one and go
| |
| | |
| back to the overview if you remember
| |
| | |
| from part 1 of this series we had the
| |
| | |
| view models option here in the overview
| |
| | |
| it didn't show anything when we showed it before that
| |
| | |
| now it shows the to view models and we
| |
| | |
| also have the action navigations and the
| |
| | |
| ones that we could refresh like this and
| |
| | |
| then we see that we have a navigation
| |
| | |
| tree or a storyboard or something like that
| |
| | |
| views "show.allhouses" goes to the show
| |
| | |
| houses from there we have show house and
| |
| | |
| show house from object but this one is
| |
| | |
| shown elsewhere
| |
| | |
| namely here so as your application grows
| |
| | |
| this tree will grow and if we were to
| |
| | |
| have any view models that has been stale
| |
| | |
| not able to reach them from any action
| |
| | |
| they would show up here and the last one
| |
| | |
| that live 3d rendering should ok it is
| |
| | |
| so these are all the classes that are
| |
| | |
| available in the model and an
| |
| | |
| auto generated diagram for that and
| |
| | |
| this is the view models available and
| |
| | |
| the classes and the diagrams so as I
| |
| | |
| said this is still working progress
| |
| | |
| we're going to find a way to make this usable but currently it's just like eye candy
| |
| | |
| alright, so whenever round this session up it was a session on how action stays
| |
| | |
| together with view models basically
| |
| | |
| thank you very much for watching and then I'll be back
| |