3 layouts Layouts
The layout styling for major parts of the page that are included with the theme. Note: some Panels layouts are included in other parts of the system and are not documented.
styles.scss
, line 30
3.1 layouts.layout-center Layout Center
All other layouts should be nested inside this centered layout to ensure that content does not get too wide on very large screens.
Applying a .layout-*
class to the same HTML element as .layout-center
would cause that element's grid to mis-align with the rest of the grid on the
page, but this component will automatically detect the other .layout-*
class and automatically use the .layout-center--shared-grid
variant
instead.
.layout-center
is applied to the same div as another .layout-* class, then this variant should be used to prevent the shared layout's grid from mis-aligning. Note: Each time a new .layout-* component is created, this component will need to be modified.
Markup: layouts/layout-center/layout-center.twig
<span class="xml"><span class="hljs-tag"><<span class="hljs-name">div</span> <span class="hljs-attr">class</span>=<span class="hljs-string">"layout-center </span></span></span><span class="hljs-template-variable">{{modifier_class}}</span><span class="xml"><span class="hljs-tag"><span class="hljs-string">"</span>></span>
This is layout center that has content is centered on larger screens.
<span class="hljs-tag"></<span class="hljs-name">div</span>></span>
</span>
layouts/layout-center/_layout-center.scss
, line 5
3.2 layouts.layout-3col Responsive 3-column grid
The .layout-3col
layout is a responsive grid layout that is:
- 1 column at mobile sizes
- 2 columns at tablet sizes
- 3 columns at desktop sizes
The .layout-3col
class is used on the container div for the layout. A grid
item in the container can be created using one of the following classes:
.layout-3col__full
: 3-column wide grid item; starts a new row.layout-3col__left-content
: 2-column wide grid item, spanning columns 1 and 2; starts a new row.layout-3col__right-content
: 2-column wide grid item, spanning columns 2 and 3; starts a new row.layout-3col__left-sidebar
: 1-column wide grid item spanning column 1; starts a new row on tablet screens.layout-3col__first-left-sidebar
: 1-column wide grid item spanning column 1; spans column 1 and starts a new row on tablet screens only.layout-3col__second-left-sidebar
: 1-column wide grid item spanning column 1; spans column 2 on tablet screens only.layout-3col__right-sidebar
: 1-column wide grid item spanning column 3; starts a new row on tablet screens.layout-3col__col-1
: 1-column wide grid item spanning column 1; starts a new row.layout-3col__col-2
: 1-column wide grid item spanning column 2.layout-3col__col-3
: 1-column wide grid item spanning column 3; starts a new row on tablet screens.layout-3col__col-4
: At tablet sizes, the__col-x
grid items will form an irregular layout of 2 items in the first row and 1 item in the second row. The__col-4
is a "hidden" item that does not appear on the large-screen 3-column grid, but is a 1-column wide grid item spanning column 2 on tablet screens..layout-3col__col-x
: 1-column wide grid item spanning column 1; when several of these are used inside a.layout-3col__grid-item-container
or.layout-3col
, the first one is positioned like__col-1
, the second like__col-2
, etc.
There are 2 ways to do a nested grid:
- Place a grid container div inside a grid item. Just apply the normal classes to the nested grid container and its grid items.
- The grid item's div is also the grid container for the nested grid. In
this case, the
.layout3-col__grid-item-container
class should be added to the div to ensure its nested grid items align with the parent grid.
.layout-3col__full
grid item.
.layout-3col__left-content
grid item.
.layout-3col__right-content
grid item.
.layout-3col__right-content
grid item.
.layout-3col__col-1
grid item.
.layout-3col__col-2
grid item.
.layout-3col__col-3
grid item. Don't forget to look for the .layout-3col__col-4
grid item at tablet sizes.
.layout-3col__col-4
grid item.
.layout-3col__col-x
grid item in this nested grid.
.layout-3col__col-x
grid item in this nested grid.
.layout-3col__col-x
grid item in this nested grid.
.layout-3col__col-x
grid item in this nested grid.
.layout-3col__col-x
grid item in this nested grid.
.layout-3col__col-x
grid item in this nested grid.
Markup: layouts/layout-3col/layout-3col.twig
<span class="xml"><span class="hljs-tag"><<span class="hljs-name">div</span> <span class="hljs-attr">class</span>=<span class="hljs-string">"layout-3col </span></span></span><span class="hljs-template-variable">{{modifier_class}}</span><span class="xml"><span class="hljs-tag"><span class="hljs-string">"</span>></span>
<span class="hljs-tag"><<span class="hljs-name">div</span> <span class="hljs-attr">class</span>=<span class="hljs-string">"layout-3col__full"</span>></span>
The <span class="hljs-tag"><<span class="hljs-name">code</span>></span>.layout-3col__full<span class="hljs-tag"></<span class="hljs-name">code</span>></span> grid item.
<span class="hljs-tag"></<span class="hljs-name">div</span>></span>
<span class="hljs-tag"><<span class="hljs-name">div</span> <span class="hljs-attr">class</span>=<span class="hljs-string">"layout-3col__left-content"</span>></span>
The <span class="hljs-tag"><<span class="hljs-name">code</span>></span>.layout-3col__left-content<span class="hljs-tag"></<span class="hljs-name">code</span>></span> grid item.
<span class="hljs-tag"></<span class="hljs-name">div</span>></span>
<span class="hljs-tag"><<span class="hljs-name">div</span> <span class="hljs-attr">class</span>=<span class="hljs-string">"layout-3col__right-sidebar"</span>></span>
The <span class="hljs-tag"><<span class="hljs-name">code</span>></span>.layout-3col__right-sidebar<span class="hljs-tag"></<span class="hljs-name">code</span>></span> grid item.
<span class="hljs-tag"></<span class="hljs-name">div</span>></span>
<span class="hljs-tag"><<span class="hljs-name">div</span> <span class="hljs-attr">class</span>=<span class="hljs-string">"layout-3col__right-content"</span>></span>
The <span class="hljs-tag"><<span class="hljs-name">code</span>></span>.layout-3col__right-content<span class="hljs-tag"></<span class="hljs-name">code</span>></span> grid item.
<span class="hljs-tag"></<span class="hljs-name">div</span>></span>
<span class="hljs-tag"><<span class="hljs-name">div</span> <span class="hljs-attr">class</span>=<span class="hljs-string">"layout-3col__left-sidebar"</span>></span>
The <span class="hljs-tag"><<span class="hljs-name">code</span>></span>.layout-3col__left-sidebar<span class="hljs-tag"></<span class="hljs-name">code</span>></span> grid item.
<span class="hljs-tag"></<span class="hljs-name">div</span>></span>
<span class="hljs-tag"><<span class="hljs-name">div</span> <span class="hljs-attr">class</span>=<span class="hljs-string">"layout-3col__right-content"</span>></span>
The <span class="hljs-tag"><<span class="hljs-name">code</span>></span>.layout-3col__right-content<span class="hljs-tag"></<span class="hljs-name">code</span>></span> grid item.
<span class="hljs-tag"></<span class="hljs-name">div</span>></span>
<span class="hljs-tag"><<span class="hljs-name">div</span> <span class="hljs-attr">class</span>=<span class="hljs-string">"layout-3col__first-left-sidebar"</span>></span>
The <span class="hljs-tag"><<span class="hljs-name">code</span>></span>.layout-3col__first-left-sidebar<span class="hljs-tag"></<span class="hljs-name">code</span>></span> grid item.
<span class="hljs-tag"></<span class="hljs-name">div</span>></span>
<span class="hljs-tag"><<span class="hljs-name">div</span> <span class="hljs-attr">class</span>=<span class="hljs-string">"layout-3col__second-left-sidebar"</span>></span>
The <span class="hljs-tag"><<span class="hljs-name">code</span>></span>.layout-3col__second-left-sidebar<span class="hljs-tag"></<span class="hljs-name">code</span>></span> grid item.
<span class="hljs-tag"></<span class="hljs-name">div</span>></span>
<span class="hljs-tag"><<span class="hljs-name">div</span> <span class="hljs-attr">class</span>=<span class="hljs-string">"layout-3col__col-1"</span>></span>
The <span class="hljs-tag"><<span class="hljs-name">code</span>></span>.layout-3col__col-1<span class="hljs-tag"></<span class="hljs-name">code</span>></span> grid item.
<span class="hljs-tag"></<span class="hljs-name">div</span>></span>
<span class="hljs-tag"><<span class="hljs-name">div</span> <span class="hljs-attr">class</span>=<span class="hljs-string">"layout-3col__col-2"</span>></span>
The <span class="hljs-tag"><<span class="hljs-name">code</span>></span>.layout-3col__col-2<span class="hljs-tag"></<span class="hljs-name">code</span>></span> grid item.
<span class="hljs-tag"></<span class="hljs-name">div</span>></span>
<span class="hljs-tag"><<span class="hljs-name">div</span> <span class="hljs-attr">class</span>=<span class="hljs-string">"layout-3col__col-3"</span>></span>
The <span class="hljs-tag"><<span class="hljs-name">code</span>></span>.layout-3col__col-3<span class="hljs-tag"></<span class="hljs-name">code</span>></span> grid item. Don't forget to look for the <span class="hljs-tag"><<span class="hljs-name">code</span>></span>.layout-3col__col-4<span class="hljs-tag"></<span class="hljs-name">code</span>></span> grid item at tablet sizes.
<span class="hljs-tag"></<span class="hljs-name">div</span>></span>
<span class="hljs-tag"><<span class="hljs-name">div</span> <span class="hljs-attr">class</span>=<span class="hljs-string">"layout-3col__col-4"</span>></span>
The <span class="hljs-tag"><<span class="hljs-name">code</span>></span>.layout-3col__col-4<span class="hljs-tag"></<span class="hljs-name">code</span>></span> grid item.
<span class="hljs-tag"></<span class="hljs-name">div</span>></span>
<span class="hljs-tag"><<span class="hljs-name">div</span> <span class="hljs-attr">class</span>=<span class="hljs-string">"layout-3col__full layout-3col__grid-item-container"</span>></span>
<span class="hljs-tag"><<span class="hljs-name">div</span> <span class="hljs-attr">class</span>=<span class="hljs-string">"layout-3col__col-x"</span>></span>
The first <span class="hljs-tag"><<span class="hljs-name">code</span>></span>.layout-3col__col-x<span class="hljs-tag"></<span class="hljs-name">code</span>></span> grid item in this nested grid.
<span class="hljs-tag"></<span class="hljs-name">div</span>></span>
<span class="hljs-tag"><<span class="hljs-name">div</span> <span class="hljs-attr">class</span>=<span class="hljs-string">"layout-3col__col-x"</span>></span>
The second <span class="hljs-tag"><<span class="hljs-name">code</span>></span>.layout-3col__col-x<span class="hljs-tag"></<span class="hljs-name">code</span>></span> grid item in this nested grid.
<span class="hljs-tag"></<span class="hljs-name">div</span>></span>
<span class="hljs-tag"><<span class="hljs-name">div</span> <span class="hljs-attr">class</span>=<span class="hljs-string">"layout-3col__col-x"</span>></span>
The third <span class="hljs-tag"><<span class="hljs-name">code</span>></span>.layout-3col__col-x<span class="hljs-tag"></<span class="hljs-name">code</span>></span> grid item in this nested grid.
<span class="hljs-tag"></<span class="hljs-name">div</span>></span>
<span class="hljs-tag"><<span class="hljs-name">div</span> <span class="hljs-attr">class</span>=<span class="hljs-string">"layout-3col__col-x"</span>></span>
The fourth <span class="hljs-tag"><<span class="hljs-name">code</span>></span>.layout-3col__col-x<span class="hljs-tag"></<span class="hljs-name">code</span>></span> grid item in this nested grid.
<span class="hljs-tag"></<span class="hljs-name">div</span>></span>
<span class="hljs-tag"><<span class="hljs-name">div</span> <span class="hljs-attr">class</span>=<span class="hljs-string">"layout-3col__col-x"</span>></span>
The fifth <span class="hljs-tag"><<span class="hljs-name">code</span>></span>.layout-3col__col-x<span class="hljs-tag"></<span class="hljs-name">code</span>></span> grid item in this nested grid.
<span class="hljs-tag"></<span class="hljs-name">div</span>></span>
<span class="hljs-tag"><<span class="hljs-name">div</span> <span class="hljs-attr">class</span>=<span class="hljs-string">"layout-3col__col-x"</span>></span>
The sixth <span class="hljs-tag"><<span class="hljs-name">code</span>></span>.layout-3col__col-x<span class="hljs-tag"></<span class="hljs-name">code</span>></span> grid item in this nested grid.
<span class="hljs-tag"></<span class="hljs-name">div</span>></span>
<span class="hljs-tag"></<span class="hljs-name">div</span>></span>
<span class="hljs-tag"></<span class="hljs-name">div</span>></span>
</span>
layouts/layout-3col/_layout-3col.scss
, line 1
3.3 layouts.layout-swap Layout swap
Uses absolute positioning and selective padding to make 2 elements appear to swap places in the visual order while maintaining their original HTML source order.
Markup: layouts/layout-swap/layout-swap.twig
<span class="xml"><span class="hljs-tag"><<span class="hljs-name">div</span> <span class="hljs-attr">class</span>=<span class="hljs-string">"layout-swap"</span>></span>
<span class="hljs-tag"><<span class="hljs-name">div</span>></span>This element comes <span class="hljs-tag"><<span class="hljs-name">strong</span>></span>first<span class="hljs-tag"></<span class="hljs-name">strong</span>></span> in the HTML source order.<span class="hljs-tag"></<span class="hljs-name">div</span>></span>
<span class="hljs-tag"><<span class="hljs-name">div</span> <span class="hljs-attr">class</span>=<span class="hljs-string">"layout-swap__top"</span>></span>This element comes <span class="hljs-tag"><<span class="hljs-name">strong</span>></span>second<span class="hljs-tag"></<span class="hljs-name">strong</span>></span> in the HTML source order.<span class="hljs-tag"></<span class="hljs-name">div</span>></span>
<span class="hljs-tag"></<span class="hljs-name">div</span>></span>
</span>
layouts/layout-swap/_layout-swap.scss
, line 4