Layout and CSS
No edit summary
(Automatically adding template at the end of the page.)
 
(6 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 41: Line 41:
           5. Validation messages formating (#validationMessages)
           5. Validation messages formating (#validationMessages)
                 The actual infors, warnings and errors (AngularJS data bound)
                 The actual infors, warnings and errors (AngularJS data bound)


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


Note that we add a css class with the name of the ViewModel high up in the html hierarcy:
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]]
[[File:2018-08-27 20h56 37.png|none|thumb]]
This enables you to do css rules that apply only to selected views.
This enables you to make CSS rules that apply only to selected views.


If the ViewModel is named "WorkBoard" a css rule like this:
If the ViewModel is named "WorkBoard", a CSS rule like this:
   .WorkBoard #sidebarWrapper{ visibility: hidden;}  
   .WorkBoard #sidebar{ visibility: hidden;}  
The above CSS rule will effectively hide the whole sidebar menu - but only for the WorkBoard view
The above CSS rule will effectively hide the whole sidebar menu - but only for the WorkBoard view.


==== Updates Nov 2018 ====
==== Updates Nov 2018 ====
In order to apply a 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:
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 };  
  public enum CSSControlType { ctStaticText,ctImage,ctTextEdit,ctDatePicker,ctCheckbox,ctCombobox,ctButton,ctGrid,ctGroupbox,ctFile,ctLink, ctTextArea, ctNumberEdit, ctFloatNumberEdit };  
This css-class will be applied on the div that enclose the whole control including the label.  
This CSS-class will be applied to the div that encloses the whole control including the label.  


Since the label may be omitted in design of certain controls we also tell you this by adding the css-class = "NoLabel" on the div enclosing the control.
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 CSS-Grid this is the same div that is placed in the CSS-Grid, if you use Bootstrap it is the bootstraped div that is placed in the 12-table.
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