Turnkey session 9: View Override
(Automatically adding template at the end of the page.)
 
(24 intermediate revisions by 4 users not shown)
Line 1: Line 1:
== View Override ==
<html>
<html>


<h4>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. In Session 9 I show how to replace the auto generated UI with html of your own. I show how to include a google map and how to pick up the location of the device using your application. </h4>
<h4>Since MDriven Turnkey is like any other HTML javascript application, there are no limits to what you can use the data for.
<p class="warn">
  Think of MDriven Turnkey as a tool that does the heavy lifting for you – it will free up your navigation item
<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>
  to work with creative things like modeling on one end of the spectrum and special UI design on the other end. MDriven Turnkey's ambition is to swallow everything in between and thus, remove the need for slow and low-quality outsourcing
<style type="text/css">
  schemes. In Session 9, I show how to replace the auto-generated UI with HTML of your own; how to include a Google
p.warn {
  map; and how to pick up the location of the device using your application. </h4>
opacity: 0.7;
<p class="video-warn">
text-align: justify;
  <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>
width: 90%
}
</style>
</p>
</p>


<style>
#video12 {
  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.time {
    font-size: 18;
    display:block;
  padding: 2px 10px 2px 10px;
    padding-bottom: 0.5;
    padding-top: 0.5;
  opacity: 0.7;
}
span.time:hover {
  color: #0000FF;
  cursor: pointer;
}
span.time:focus {
  color: blue;
</style>
<br>
<br>
<div id="video12">
<div class="video">
<iframe width="740" height="500" src="https://www.youtube.com/embed/zQxkt2KBM3Q?rel=0&autoplay=0" frameborder="0" allowfullscreen></iframe>
  <div class="video__wrapper">
   <div>
    <iframe src="https://www.youtube.com/embed/Wu9nP3x7cYM?rel=0&autoplay=0" frameborder="0" allowfullscreen></iframe>
     <span class="time" data-video="zQxkt2KBM3Q" data-start="14" tabindex="0"> Create View Override</span>
  </div>
     <span class="time" data-video="zQxkt2KBM3Q" data-start="31" tabindex="0"> view Override HTML </span>
   <div class="video__navigation">
     <span class="time" data-video="zQxkt2KBM3Q" data-start="84" tabindex="0"> Fine Tuning </span>
     <span class="navigation-item" data-video="Wu9nP3x7cYM" data-start="19" tabindex="0"> Create View Override</span>
     <span class="time" data-video="zQxkt2KBM3Q" data-start="121" tabindex="0"> Adding an input control </span>
     <span class="navigation-item" data-video="Wu9nP3x7cYM" data-start="36" tabindex="0"> View Override HTML </span>
     <span class="time" data-video="zQxkt2KBM3Q" data-start="151" tabindex="0"> Style </span>
     <span class="navigation-item" data-video="Wu9nP3x7cYM" data-start="89" tabindex="0"> Fine Tuning </span>
     <span class="time" data-video="zQxkt2KBM3Q" data-start="177" tabindex="0"> Boxes or combo boxes</span>
     <span class="navigation-item" data-video="Wu9nP3x7cYM" data-start="126" tabindex="0"> Adding an input control </span>
     <span class="time" data-video="zQxkt2KBM3Q" data-start="216" tabindex="0"> Tables </span>
     <span class="navigation-item" data-video="Wu9nP3x7cYM" data-start="156" tabindex="0"> Style </span>
     <span class="time" data-video="zQxkt2KBM3Q" data-start="306" tabindex="0"> removing the information </span>
     <span class="navigation-item" data-video="Wu9nP3x7cYM" data-start="182" tabindex="0"> Boxes or combo boxes</span>
     <span class="time" data-video="zQxkt2KBM3Q" data-start="353" tabindex="0"> complex action: location </span>
     <span class="navigation-item" data-video="Wu9nP3x7cYM" data-start="221" tabindex="0"> Tables </span>
     <span class="time" data-video="zQxkt2KBM3Q" data-start="426" tabindex="0"> HTML adding scripts </span>  
     <span class="navigation-item" data-video="Wu9nP3x7cYM" data-start="311" tabindex="0"> Removing the information </span>
     <span class="time" data-video="zQxkt2KBM3Q" data-start="426" tabindex="0"> VClientLatitude and vClientLongitude variables </span>  
     <span class="navigation-item" data-video="Wu9nP3x7cYM" data-start="358" tabindex="0"> Complex action: location </span>
     <span class="time" data-video="zQxkt2KBM3Q" data-start="524" tabindex="0"> Mobile Device UI</span>    
     <span class="navigation-item" data-video="Wu9nP3x7cYM" data-start="431" tabindex="0"> HTML adding scripts </span>
     <span class="navigation-item" data-video="Wu9nP3x7cYM" data-start="431" tabindex="0"> VClientLatitude and vClientLongitude variables </span>
     <span class="navigation-item" data-video="Wu9nP3x7cYM" data-start="529" tabindex="0"> Mobile Device UI</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>


<p> This is the original generic view we use – use this as a starting point when stirring things up:</p>
<p> This is the original generic view – use this as a starting point when stirring things up:
@using Eco.MVC
</p>
@model AngularModel
 
@{ Layout = null; }
<html>


<nowiki><h3>{{root._ViewModelPresentation}}</nowiki><nowiki></h3></nowiki>
<pre class="code"><span style="background: yellow; color: black">@</span><span style="background: white; color: blue">using </span><span style="background: white; color: black">Eco.MVC
<nowiki><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-->
</span><span style="background: yellow; color: black">@model </span><span style="background: white; color: #2b91af">AngularModel
          <div id="floatingRectangle" ng-show='root._Admin.Loading()'>          
@{ Layout = null; }</span></pre><pre class="code"><span style="background: white; color: #2b91af">
            <img src='~/Content/ajax-loader.gif' /></nowiki><nowiki></div></nowiki>      
</span><span style="background: white; color: blue">&lt;</span><span style="background: white; color: maroon">h3</span><span style="background: white; color: blue">&gt;</span><span style="background: white; color: black">{{</span><span style="background: white; color: purple">root._ViewModelPresentation</span><span style="background: white; color: black">}}</span><span style="background: white; color: blue">&lt;/</span><span style="background: white; color: maroon">h3</span><span style="background: white; color: blue">&gt;
<nowiki> </nowiki> <nowiki><div class="container-fluid">        
&lt;</span><span style="background: white; color: maroon">form </span><span style="background: white; color: blue">&gt; </span><span style="background: white; color: #006400">&lt;!--The only reason for having a form is the ability to simulate a <br>            postback so that validation is triggered and the error bubbles may show--&gt;
              <div class="row">          
        &lt;!--Body content--&gt;
                <div class="col-md-2" style="vertical-align:top;">              
        </span><span style="background: white; color: blue">&lt;</span><span style="background: white; color: maroon">div </span><span style="background: white; color: red">id</span><span style="background: white; color: blue">="floatingRectangle" </span><span style="background: white; color: red">ng-show</span><span style="background: white; color: blue">='root._Admin.Loading()'&gt;<br>            &lt;</span><span style="background: white; color: maroon">img </span><span style="background: white; color: red">src</span><span style="background: white; color: blue">='~/Content/ajax-loader.gif' /&gt;&lt;/</span><span style="background: white; color: maroon">div</span><span style="background: white; color: blue">&gt;
                @Html.AngualarUIActions(Model)</div></nowiki>          
        &lt;</span><span style="background: white; color: maroon">div </span><span style="background: white; color: red">class</span><span style="background: white; color: blue">="container-fluid"&gt;
<nowiki> </nowiki>       <nowiki><div class="col-md-10" style="padding:10px;border-left: lightgray thin solid ;">  
          &lt;</span><span style="background: white; color: maroon">div </span><span style="background: white; color: red">class</span><span style="background: white; color: blue">="row"&gt;
                @Html.AngualarUI(Model)</div></nowiki>        
            &lt;</span><span style="background: white; color: maroon">div </span><span style="background: white; color: red">class</span><span style="background: white; color: blue">="col-md-2" </span><span style="background: white; color: red">style</span><span style="background: white; color: blue">="</span><span style="background: white; color: red">vertical-align</span><span style="background: white; color: black">:</span><span style="background: white; color: blue">top</span><span style="background: white; color: black">;</span><span style="background: white; color: blue">"&gt;
<nowiki> </nowiki>     <nowiki></div></nowiki>        
                </span><span style="background: yellow; color: black">@</span><span style="background: white; color: black">Html.AngualarUIActions(Model)
<nowiki> </nowiki>     <nowiki><div class="row">          
            </span><span style="background: white; color: blue">&lt;/</span><span style="background: white; color: maroon">div</span><span style="background: white; color: blue">&gt;
                <div class="col-md-offset-2 col-md-10">                    
            &lt;</span><span style="background: white; color: maroon">div </span><span style="background: white; color: red">class</span><span style="background: white; color: blue">="col-md-10" </span><span style="background: white; color: red">style</span><span style="background: white; color: blue">="</span><span style="background: white; color: red">padding</span><span style="background: white; color: black">:</span><span style="background: white; color: blue">10px</span><span style="background: white; color: black">;</span><span style="background: white; color: red">border-left</span><span style="background: white; color: black">: </span><span style="background: white; color: blue">lightgray thin solid </span><span style="background: white; color: black">;</span><span style="background: white; color: blue">"&gt;<br>                                      </span><span style="background: yellow; color: black">@</span><span style="background: white; color: black">Html.AngualarUI(Model)</span><span style="background: white; color: blue">&lt;/</span><span style="background: white; color: maroon">div</span><span style="background: white; color: blue">&gt;
                @Html.DisplayErrorsWarningsInfos(Model)@*Error,Warning,Info constraints*@</div></nowiki>        
          &lt;/</span><span style="background: white; color: maroon">div</span><span style="background: white; color: blue">&gt;
<nowiki> </nowiki>     <nowiki></div></nowiki>      
          &lt;</span><span style="background: white; color: maroon">div </span><span style="background: white; color: red">class</span><span style="background: white; color: blue">="row"&gt;
<nowiki> </nowiki>   <nowiki></div></nowiki>   
            &lt;</span><span style="background: white; color: maroon">div </span><span style="background: white; color: red">class</span><span style="background: white; color: blue">="col-md-offset-2 col-md-10"&gt;<br>                      </span><span style="background: yellow; color: black">@</span><span style="background: white; color: black">Html.DisplayErrorsWarningsInfos(Model)</span><span style="background: yellow; color: black">@*</span><span style="background: white; color: #006400">Error,Warning,Info constraints</span><span style="background: yellow; color: black">*@</span><span style="background: white; color: blue">&lt;/</span><span style="background: white; color: maroon">div</span><span style="background: white; color: blue">&gt;
<nowiki></form></nowiki>  
          &lt;/</span><span style="background: white; color: maroon">div</span><span style="background: white; color: blue">&gt;
@Html.Partial("_DeveloperInfoPartial")
        &lt;/</span><span style="background: white; color: maroon">div</span><span style="background: white; color: blue">&gt;  
Taking a closer look at the parts:
&lt;/</span><span style="background: white; color: maroon">form</span><span style="background: white; color: blue">&gt;
</span><span style="background: yellow; color: black">@</span><span style="background: white; color: black">Html.Partial(</span><span style="background: white; color: #a31515">"_DeveloperInfoPartial"</span><span style="background: white; color: black">)
</span></pre>


[[File:Image4.png|frameless|1024x1024px]]
</html>


We use Bootstrap to make the original UI responsive – that is why there are no table elements , only div elements.
Take a closer look at the parts:[[File:Overriding angular -1.png|none|frame|link=https://wiki.mdriven.net/index.php/File: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.
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:[[File:Overriding angular - 2.png|none|frame|link=https://wiki.mdriven.net/index.php/File:Overriding_angular_-_2.png]]then you can expect to find data bindable with AngularJS like this:
[[File:Image thumb5.png|left|frameless|307x307px]]
  root.RegistrationNumber, root.KilometersRun etc
then you can expect to find data bindable with AngularJS like this:
To declare an input id that binds to RegistrationNumber, you would do this:
  root.RegistrationNumber, root.KilometersRun      
To declare an input id that binds to RegistrationNumber you would go:
  <input ng-model=”root.RegistrationNumber”/>
  <input ng-model=”root.RegistrationNumber”/>
But in the ViewModel you also have the '''enable''' expression that you probably want to use:
In the ViewModel, you also have the '''enable''' expression you probably want to use:
  <input ng-model=”root.RegistrationNumber” ng-disabled=”!root.VM_Status.EditOneCar_RegistrationNumber_Enabled”/>
  <input ng-model=”root.RegistrationNumber” ng-disabled=”!root.VM_Status.EditOneCar_RegistrationNumber_Enabled”/>
And then you have the '''visible''' expression:
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” />
  <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''':
… 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”/>
  <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:
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>
  <select ng-model="root.Brand" ng-options="opt.GetOId() as opt.Name for opt in root.BrandPickList" ></select>
Of course you may use disable, show and style for this as well.
You may use disable, show, and style for this as well.


This is how we do grids:
This is how we make grids:
        <nowiki><table>
                  <thead>         
                    <tr></nowiki>           
<nowiki> </nowiki>          <nowiki><th></th></nowiki>           
<nowiki> </nowiki>          <nowiki><th>Name</th></nowiki>           
<nowiki> </nowiki>          <nowiki><th>Length</th></nowiki>           
<nowiki> </nowiki>          <nowiki><th>Genre</th></nowiki>       
<nowiki> </nowiki>          <nowiki></tr></nowiki>       
<nowiki> </nowiki>        <nowiki></thead></nowiki>       
<nowiki> </nowiki>          <nowiki><tbody>         
                        <tr ng-repeat="video in root.AllVideo"></nowiki>           
<nowiki> </nowiki>                <nowiki><td></nowiki> <nowiki><input type="checkbox" name="input" ng-model="video.vCurrent"></nowiki><nowiki></td></nowiki>         
<nowiki> </nowiki>                <nowiki><td></nowiki>  <nowiki>{{ video.Name }}</nowiki> <nowiki></td></nowiki>           
<nowiki> </nowiki>                <nowiki><td></nowiki>  <nowiki>{{ video.Length }}</nowiki> <nowiki></td></nowiki>           
<nowiki> </nowiki>                <nowiki><td></nowiki>  <nowiki>{{ video.Genre }}</nowiki> <nowiki></td></nowiki>       
<nowiki> </nowiki>              <nowiki></tr></nowiki>       
<nowiki> </nowiki>            <nowiki></tbody></nowiki>     
<nowiki> </nowiki>        <nowiki></table></nowiki>
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.


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:
<html>
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'].
<pre class="code"><span style="background: white; color: green;">      &lt;table&gt;
'''This is how you override one view in MDriven Turnkey'''
        &lt;thead&gt;
          &lt;tr&gt;
            &lt;th&gt;&lt;/th&gt;
            &lt;th&gt;Name&lt;/th&gt;
            &lt;th&gt;Length&lt;/th&gt;
            &lt;th&gt;Genre&lt;/th&gt;
          &lt;/tr&gt;
        &lt;/thead&gt;
        &lt;tbody&gt;
          &lt;tr <span style="background-color: #ffff00;">ng-repeat="video in root.AllVideo"&gt;</span>
            &lt;td&gt; &lt;input type="checkbox" name="input" ng-model="video.<span style="background-color: #ffff00;">vCurrent</span>"&gt;&lt;/td&gt;
            &lt;td&gt;  {{ video.Name }}        &lt;/td&gt;
            &lt;td&gt;  {{ video.Length }}  &lt;/td&gt;
            &lt;td&gt;  {{ video.Genre }}        &lt;/td&gt;
          &lt;/tr&gt;
        &lt;/tbody&gt;
      &lt;/table&gt;
</span></pre>


Log into LicenseAndTicket then lis your sites, select the one you want to work with:
</html>
 
[[File:Image_thumb6.png|frameless|644x644px]]
 
Click the action View Overrides, in the new window create a new override by clicking “Create”:
 
[[File:Image_thumb7.png|frameless|644x644px]]


Fill in the values – Name is the Name of your ViewModel, Extension is cshtml. When you are done click “Send Settings and restart”
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.


Your application will then show your overridden page.
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'].
==This Is How You Override One View in MDriven Turnkey==
# Create a cshtml file with the same name as your ViewModel. Save it in youmodels_AssetsTK/Views//EXT_OverridePages.
# Name is the Name of your ViewModel, Extension is cshtml.
# When you are done, upload your model
# Your application will then show your overridden page.


==No Limits==
Since MDriven Turnkey is like any other HTML javascript application, there are no limits to what you can use the data for. 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 on one end of the spectrum and special UI design on the other end. MDriven Turnkey's ambition is to swallow everything in between and thus, remove the need for slow and low-quality out-sourcing schemes.
== More on View Override ==
== More on View Override ==
<html> <h4> Another part of overriding discussion. Here is additional example of the UI improvement by means of different features like adding new actions, using site assets and specifing your own script. </h4>
<html>
<h4> Here's another part of the overriding discussion: an additional example of the UI improvement by means of different features
  like adding new actions, using site assets, and specifying your own script. </h4>


<p class="warn">
<p class="video-warn">
<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>
  <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>
<style type="text/css">
  <br>
p.warn {
  <div class="video">
opacity: 0.7;
     <div class="video__wrapper">
text-align: justify;
    <iframe src="https://www.youtube.com/embed/Lxbg7P--5u4?rel=0&autoplay=0" frameborder="0" allowfullscreen></iframe>
width: 90%
   </div>
}
  <div class="video__navigation">
</style>
      <span class="time" data-video="Lxbg7P--5u4" data-start="18" tabindex="0"> Car Damages action </span>
</p>
      <span class="time" data-video="Lxbg7P--5u4" data-start="70" tabindex="0"> Page content/Inject Content in Standart </span>
 
      <span class="time" data-video="Lxbg7P--5u4" data-start="107" tabindex="0"> Page style section/image as a site asset</span>
<style>
      <span class="time" data-video="Lxbg7P--5u4" data-start="156" tabindex="0"> Java Script section </span>
#video12 {
      <span class="time" data-video="Lxbg7P--5u4" data-start="280" tabindex="0"> Multiple instances </span>
  position: relative;
    </div>
  height: 500px;
  </div>
  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.time {
    font-size: 18;
    display:block;
  padding: 2px 10px 0.5px 10px;
     padding-bottom: 0.5;
    padding-top: 0.5;
  opacity: 0.7;
}
span.time:hover {
  color: #0000FF;
  cursor: pointer;
}
span.time:focus {
  color: blue;
</style>
<br>
<div id="video12">
<iframe width="740" height="500" src="https://www.youtube.com/embed/r0cot5p_nxs?rel=0&autoplay=0" frameborder="0" allowfullscreen></iframe>
   <div>
    <span class="time" data-video="r0cot5p_nxs" data-start="13" tabindex="0"> Car Damages action </span>
    <span class="time" data-video="r0cot5p_nxs" data-start="65" tabindex="0"> Page content / Inject Content in Standart </span>  
    <span class="time" data-video="r0cot5p_nxs" data-start="102" tabindex="0"> Page style section / image as a site asset</span>
    <span class="time" data-video="r0cot5p_nxs" data-start="151" tabindex="0"> Java Script section </span>
    <span class="time" data-video="r0cot5p_nxs" data-start="275" tabindex="0"> Multiple instances </span>
</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:UI]]
[[Category:MDriven Turnkey Sessions]]
[[Category:MDriven Turnkey]]
[[Category:Content Override]]
[[Category:MVC]]
[[Category:Mobile UI]]
[[Category:AngularJS]]
{{Edited|July|12|2024}}

Latest revision as of 15:49, 10 February 2024

Since MDriven Turnkey is like any other HTML javascript application, there are no limits to what you can use the data for. Think of MDriven Turnkey as a tool that does the heavy lifting for you – it will free up your navigation item to work with creative things like modeling on one end of the spectrum and special UI design on the other end. MDriven Turnkey's ambition is to swallow everything in between and thus, remove the need for slow and low-quality outsourcing schemes. In Session 9, I show how to replace the auto-generated UI with HTML of your own; how to include a Google map; and how to pick up the location of the device using your application.

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.


Create View Override View Override HTML Fine Tuning Adding an input control Style Boxes or combo boxes Tables Removing the information Complex action: location HTML adding scripts VClientLatitude and vClientLongitude variables Mobile Device UI

This is the original generic view – 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, you would do this:

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

In the ViewModel, you also have the enable expression you probably want to use:

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

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 make 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'].

This Is How You Override One View in MDriven Turnkey

  1. Create a cshtml file with the same name as your ViewModel. Save it in youmodels_AssetsTK/Views//EXT_OverridePages.
  2. Name is the Name of your ViewModel, Extension is cshtml.
  3. When you are done, upload your model
  4. Your application will then show your overridden page.

No Limits

Since MDriven Turnkey is like any other HTML javascript application, there are no limits to what you can use the data for. 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 on one end of the spectrum and special UI design on the other end. MDriven Turnkey's ambition is to swallow everything in between and thus, remove the need for slow and low-quality out-sourcing schemes.

More on View Override

Here's another part of the overriding discussion: an additional example of the UI improvement by means of different features like adding new actions, using site assets, and specifying your own script.

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.


Car Damages action Page content/Inject Content in Standart Page style section/image as a site asset Java Script section Multiple instances

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