Layout and CSS
No edit summary
(Automatically adding template at the end of the page.)
 
(9 intermediate revisions by 3 users not shown)
Line 1: Line 1:
This is the layout of the turnkey web client.
This is the layout of the Turnkey web client.


The names are the CSS selectors (id's using # in CSS, classes using . in CSS)
The names are the CSS selectors (IDs using # in CSS, classes using . in CSS)


Copy from the Site.css file with explanation;
Copy from the Site.css file with an explanation:


   Div and stylesheet structure
   Div and stylesheet structure
Line 9: Line 9:
   1. Body wrapper (#bodyWrapper)
   1. Body wrapper (#bodyWrapper)
     2. Global navigation (#globalNavWrapper)
     2. Global navigation (#globalNavWrapper)
       The top menu (MVC generated, modified by Angular JS code)
       The top menu, or main menu  (MVC generated, modified by Angular JS code)
     2. Global content wrapper (#globalContentWrapper)  
     2. Global content wrapper (#globalContentWrapper)  
   
   
Line 25: Line 25:
           * For MVC, this is part of the complete rendered page coming from the server
           * For MVC, this is part of the complete rendered page coming from the server
   
   
           5. Sidebar wrapper (#sidebarWrapper)
           5. Sidebar wrapper (#sidebar)
             For non-flex handling, introduces scrollbars and manual height handling (Safari and Edge)
             For non-flex handling, introduces scrollbars and manual height handling (Safari and Edge)
             6. Sidebar (#sidebar)
             6. Sidebar (#sidebar)
Line 42: Line 42:
                 The actual infors, warnings and errors (AngularJS data bound)
                 The actual infors, warnings and errors (AngularJS data bound)


[[File:TurnkeyContentLayout.png|frameless|832x832px]]


Note - we add a CSS class with the name of the ViewModel high up in the HTML hierarchy:
[[File:2018-08-27 20h56 37.png|none|thumb]]
This enables you to make CSS rules that apply only to selected views.


[[File:TurnkeyContentLayout.png|frameless|832x832px]]
If the ViewModel is named "WorkBoard", a CSS rule like this:
  .WorkBoard #sidebar{ visibility: hidden;}
The above CSS rule will effectively hide the whole sidebar menu - but only for the WorkBoard view.


Note that we add a css class with the name of the ViewModel high up in the html hierarcy:
==== Updates Nov 2018 ====
[[File:2018-08-27 20h56 37.png|none|thumb]]
To apply your own generic style sheet, we have introduced a CSS-class unique per control type. The CSS names are taken from the names of this enum:
This enables you to do css rules that apply only to selected views.
public enum CSSControlType { ctStaticText,ctImage,ctTextEdit,ctDatePicker,ctCheckbox,ctCombobox,ctButton,ctGrid,ctGroupbox,ctFile,ctLink, ctTextArea, ctNumberEdit, ctFloatNumberEdit };
This CSS-class will be applied to the div that encloses the whole control including the label.  


If the ViewModel is named "WorkBoard" a css rule like this:
Since the label may be omitted in the design of certain controls, we also tell you this by adding the CSS-class = "NoLabel" on the div enclosing the control.
  .WorkBoard .sidebarWrapper{ visibility: hidden;}
The above CSS rule will effectively hide the whole sidebar menu - but only for the WorkBoard view


If you use the CSS-Grid, this is the same div that is placed in the CSS-Grid; if you use Bootstrap, it is the bootstrapped div that is placed in the 12-table.
[[Category:MDriven Turnkey]]
[[Category:MDriven Turnkey]]
[[Category:UI]]
[[Category:UI]]
{{Edited|July|12|2024}}

Latest revision as of 15:36, 10 February 2024

This is the layout of the Turnkey web client.

The names are the CSS selectors (IDs using # in CSS, classes using . in CSS)

Copy from the Site.css file with an explanation:

 Div and stylesheet structure

 1. Body wrapper (#bodyWrapper)
   2. Global navigation (#globalNavWrapper)
     The top menu, or main menu  (MVC generated, modified by Angular JS code)
   2. Global content wrapper (#globalContentWrapper) 

     For non-viewmodel views (login for example)
       Content starts directly under #globalContentWrapper

     3. Recover margin from above (#flexLayoutWrapper)
       * For AngularJS, the AngularJS App starts (ng-app and ng-view) with here with #flexLayoutWrapper
       * For MVC, definition for form and field posting to server directly below #flexLayoutWrapper. These are both full-height
         <form>
           <fieldset>

       4. Content wrapper (#contentWrapper) 
         * For AngularJS, html generated serverside, injected into the DOM by AngularJS, and databound client-side
         * For MVC, this is part of the complete rendered page coming from the server

         5. Sidebar wrapper (#sidebar)
           For non-flex handling, introduces scrollbars and manual height handling (Safari and Edge)
           6. Sidebar (#sidebar)
             Taking space as needed, using scrollbar for vertical axis
         5. Viewmodel wrapper (#viewmodelWrapper)
           For non-flex handling, introduces scrollbars and manual height handling (Safari and Edge)
           6. Section for the viewmodel (#viewmodelSection)
               Either of
                 * Ordinary one block of content, using scrollbar for both axis, all scrolling
                 * Two, three or more x and/or y -segmented gridboxes, middle sections scrolling
                     First and Last segment taking the space they need
                     Middle segment, using scrollbar for both axis
                     Note that vmGridBox* classes are only present if the design includes splitters.
       4. Validation messages wrapper (#validationMessageWrapper)
         5. Validation messages formating (#validationMessages)
               The actual infors, warnings and errors (AngularJS data bound)

TurnkeyContentLayout.png

Note - we add a CSS class with the name of the ViewModel high up in the HTML hierarchy:

2018-08-27 20h56 37.png

This enables you to make CSS rules that apply only to selected views.

If the ViewModel is named "WorkBoard", a CSS rule like this:

 .WorkBoard #sidebar{ visibility: hidden;} 

The above CSS rule will effectively hide the whole sidebar menu - but only for the WorkBoard view.

Updates Nov 2018

To apply your own generic style sheet, we have introduced a CSS-class unique per control type. The CSS names are taken from the names of this enum:

public enum CSSControlType { ctStaticText,ctImage,ctTextEdit,ctDatePicker,ctCheckbox,ctCombobox,ctButton,ctGrid,ctGroupbox,ctFile,ctLink, ctTextArea, ctNumberEdit, ctFloatNumberEdit }; 

This CSS-class will be applied to the div that encloses the whole control including the label.

Since the label may be omitted in the design of certain controls, we also tell you this by adding the CSS-class = "NoLabel" on the div enclosing the control.

If you use the CSS-Grid, this is the same div that is placed in the CSS-Grid; if you use Bootstrap, it is the bootstrapped div that is placed in the 12-table.

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