Overriding AngularJS MDriven Turnkey Views
No edit summary
No edit summary
Line 1: Line 1:
! Consider to use [[Fashion with tagexpander|tagexpander]] logic that is newer and easier to use than what is described here
Consider using [[Fashion with tagexpander|tagexpander]] logic that is newer and easier to use than what is described here!!


This is the original generic view we use – use this as a starting point when stirring things up:
This is the original generic view we use – use this as a starting point when stirring things up:
Line 28: Line 28:


</html>
</html>
Taking a closer look at the parts:
Take a closer look at the parts:
[[File:Overriding angular -1.png|none|frame]]
[[File:Overriding angular -1.png|none|frame]]


We use Bootstrap to make the original UI responsive – that is why there are no table elements , only div elements.
We use Bootstrap to make the original UI responsive – that is why there are no table elements, only div elements.


The data you have access to in your html page is strictly derived from the ViewModel.
The data you have access to in your HTML page is strictly derived from the ViewModel.


If your ViewModel is defined like this:
If your ViewModel is defined like this:
Line 40: Line 40:
then you can expect to find data bindable with AngularJS like this:
then you can expect to find data bindable with AngularJS like this:


<blockquote>root.RegistrationNumber, root.KilometersRun etc</blockquote>To declare an input id that binds to RegistrationNumber you would go:<blockquote><input ng-model=”root.RegistrationNumber”/></blockquote>But in the ViewModel you also have the '''enable''' expression that you probably want to use:<blockquote><input ng-model=”root.RegistrationNumber” ng-disabled=”!root.VM_Status.EditOneCar_RegistrationNumber_Enabled”/></blockquote>And then you have the '''visible''' expression:<blockquote><input ng-model=”root.RegistrationNumber” ng-disabled=”!root.VM_Status.EditOneCar_RegistrationNumber_Enabled” ng-show="root.VM_Status.EditOneCar_RegistrationNumber_Visible" /></blockquote>… do not forget the '''style''':<blockquote><input ng-model=”root.RegistrationNumber” ng-disabled=”!root.VM_Status.EditOneCar_RegistrationNumber_Enabled” ng-show="root.VM_Status.EditOneCar_RegistrationNumber_Visible" ng-class="root.VM_Status.EditOneCar_RegistrationNumber_Style"/></blockquote>This is how we define '''select''' controls ('''Combobox''') for setting the Brand in the above ViewModel:<blockquote><select ng-model="root.Brand" ng-options="opt.GetOId() as opt.Name for opt in root.BrandPickList" ></select></blockquote>Of course you may use disable, show and style for this as well.
<blockquote>root.RegistrationNumber, root.KilometersRun etc</blockquote>To declare an input id that binds to RegistrationNumber, do this:<blockquote><input ng-model=”root.RegistrationNumber”/></blockquote>But in the ViewModel you also have the '''enable''' expression that you probably want to use:<blockquote><input ng-model=”root.RegistrationNumber” ng-disabled=”!root.VM_Status.EditOneCar_RegistrationNumber_Enabled”/></blockquote>And then you have the '''visible''' expression:<blockquote><input ng-model=”root.RegistrationNumber” ng-disabled=”!root.VM_Status.EditOneCar_RegistrationNumber_Enabled” ng-show="root.VM_Status.EditOneCar_RegistrationNumber_Visible" /></blockquote>… do not forget the '''style''':<blockquote><input ng-model=”root.RegistrationNumber” ng-disabled=”!root.VM_Status.EditOneCar_RegistrationNumber_Enabled” ng-show="root.VM_Status.EditOneCar_RegistrationNumber_Visible" ng-class="root.VM_Status.EditOneCar_RegistrationNumber_Style"/></blockquote>This is how we define '''select''' controls ('''Combobox''') for setting the Brand in the above ViewModel:<blockquote><select ng-model="root.Brand" ng-options="opt.GetOId() as opt.Name for opt in root.BrandPickList" ></select></blockquote>You may use disable, show, and style for this as well.


This is how we do grids:
This is how we do grids:
Line 67: Line 67:


</html>
</html>
Notice the first column that use the vCurrent property that all objects has. This is a boolean value that sets the vCurrent_NAMEOFVMCLASS variable that is how currency is handled in master-detail UI’s.
Notice the first column that uses the vCurrent property that all objects have. This is a boolean value that sets the vCurrent_NAMEOFVMCLASS variable which is how currency is handled in master-detail UI’s.


If your data is not in the root ViewModelClass but further down in the master-detail chain the correct way to bind to it is by finding the vCurrent value of that ViewModelClass. This is so common that there is a function declared for it on the _Admin object:
If your data is not in the root ViewModelClass, but further down in the master-detail chain, the correct way to bind to it is by finding the vCurrent value of that ViewModelClass. This is so common that there is a function declared for it on the _Admin object:


root._Admin.GetCurrentForVMClass('EditOneCar')['RegistrationNumber']
root._Admin.GetCurrentForVMClass('EditOneCar')['RegistrationNumber']


In the case above this will be equivalent to root.RegistrationNumber – but if EditOneCar was further down in the hierarchy  the proper way to access the currently focused object is with root._Admin.GetCurrentForVMClass('EditOneCar')['RegistrationNumber'].
In the case above, this will be equivalent to root.RegistrationNumber – but if EditOneCar was further down in the hierarchy, the proper way to access the currently focused object is with root._Admin.GetCurrentForVMClass('EditOneCar')['RegistrationNumber'].


== No limits ==
== No Limits ==
Since MDriven Turnkey is like any other html javascript application there are no limits on what you can use the data for.
Since MDriven Turnkey is like any other HTML javascript application there are no limits on what you can use the data for.


You should think of MDriven Turnkey as a tool that does the heavy lifting for you – it will free up your time to work with creative things like modeling at one end of the spectrum and special UI design at the other end. The ambition of MDriven Turnkey is to swallow everything in between and thus removing the need for slow and low quality out-sourcing schemes.
You should consider MDriven Turnkey as a tool that does the heavy lifting for you – it will free up your time to work with creative things like modeling at one end of the spectrum and special UI design at the other end. The ambition of MDriven Turnkey is to swallow everything in between and thus, remove the need for slow and low-quality out-sourcing schemes.
[[Category:MDriven Turnkey]]
[[Category:MDriven Turnkey]]

Revision as of 07:13, 15 February 2023

Consider using tagexpander logic that is newer and easier to use than what is described here!!

This is the original generic view we use – use this as a starting point when stirring things up:

@using Eco.MVC
@model AngularModel
@{ Layout = null; }

<h3>{{root._ViewModelPresentation}}</h3>
<form > <!--The only reason for having a form is the ability to simulate a 
postback so that validation is triggered and the error bubbles may show--> <!--Body content-->
<div id="floatingRectangle" ng-show='root._Admin.Loading()'>
<
img src='~/Content/ajax-loader.gif' /></div> <div class="container-fluid"> <div class="row"> <div class="col-md-2" style="vertical-align:top;"> @Html.AngualarUIActions(Model) </div> <div class="col-md-10" style="padding:10px;border-left: lightgray thin solid ;">
@Html.AngualarUI(Model)</div> </div> <div class="row"> <div class="col-md-offset-2 col-md-10">
@Html.DisplayErrorsWarningsInfos(Model)@*Error,Warning,Info constraints*@</div> </div> </div> </form> @Html.Partial("_DeveloperInfoPartial")

Take a closer look at the parts:

Overriding angular -1.png

We use Bootstrap to make the original UI responsive – that is why there are no table elements, only div elements.

The data you have access to in your HTML page is strictly derived from the ViewModel.

If your ViewModel is defined like this:

Overriding angular - 2.png

then you can expect to find data bindable with AngularJS like this:

root.RegistrationNumber, root.KilometersRun etc

To declare an input id that binds to RegistrationNumber, do this:

<input ng-model=”root.RegistrationNumber”/>

But in the ViewModel you also have the enable expression that you probably want to use:

<input ng-model=”root.RegistrationNumber” ng-disabled=”!root.VM_Status.EditOneCar_RegistrationNumber_Enabled”/>

And then you have the visible expression:

<input ng-model=”root.RegistrationNumber” ng-disabled=”!root.VM_Status.EditOneCar_RegistrationNumber_Enabled” ng-show="root.VM_Status.EditOneCar_RegistrationNumber_Visible" />

… do not forget the style:

<input ng-model=”root.RegistrationNumber” ng-disabled=”!root.VM_Status.EditOneCar_RegistrationNumber_Enabled” ng-show="root.VM_Status.EditOneCar_RegistrationNumber_Visible" ng-class="root.VM_Status.EditOneCar_RegistrationNumber_Style"/>

This is how we define select controls (Combobox) for setting the Brand in the above ViewModel:

<select ng-model="root.Brand" ng-options="opt.GetOId() as opt.Name for opt in root.BrandPickList" ></select>

You may use disable, show, and style for this as well.

This is how we do grids:

       <table>
        <thead>
          <tr>
            <th></th>
            <th>Name</th>
            <th>Length</th>
            <th>Genre</th>
          </tr>
        </thead>
        <tbody>
          <tr ng-repeat="video in root.AllVideo">
            <td>  <input type="checkbox" name="input" ng-model="video.vCurrent"></td>
            <td>  {{ video.Name }}        </td>
            <td>  {{ video.Length }}  </td>
            <td>  {{ video.Genre }}         </td>
          </tr>
        </tbody>
      </table>

Notice the first column that uses the vCurrent property that all objects have. This is a boolean value that sets the vCurrent_NAMEOFVMCLASS variable which is how currency is handled in master-detail UI’s.

If your data is not in the root ViewModelClass, but further down in the master-detail chain, the correct way to bind to it is by finding the vCurrent value of that ViewModelClass. This is so common that there is a function declared for it on the _Admin object:

root._Admin.GetCurrentForVMClass('EditOneCar')['RegistrationNumber']

In the case above, this will be equivalent to root.RegistrationNumber – but if EditOneCar was further down in the hierarchy, the proper way to access the currently focused object is with root._Admin.GetCurrentForVMClass('EditOneCar')['RegistrationNumber'].

No Limits

Since MDriven Turnkey is like any other HTML javascript application there are no limits on what you can use the data for.

You should consider MDriven Turnkey as a tool that does the heavy lifting for you – it will free up your time to work with creative things like modeling at one end of the spectrum and special UI design at the other end. The ambition of MDriven Turnkey is to swallow everything in between and thus, remove the need for slow and low-quality out-sourcing schemes.

This page was edited more than 11 months ago on 02/10/2024. What links here