A Brick layout component.
-
Import Web Components polyfill:
<script src="bower_components/platform/platform.js"></script>
-
Import Custom Element:
<link rel="import" href="dist/brick-layout.html">
-
Start using it:
<brick-layout></brick-layout>
See Examples for detailed examples.
Attribute | Type | Description |
---|---|---|
horizontal |
boolean | Use a horizontal layout instead of the default vertical layout. |
open |
boolean | Open child drawer elements. |
Attribute | Type | Description |
---|---|---|
flex |
boolean | Set flex: 1 for this element. |
drawer |
boolean | Use this element as a drawer. Drawers can he hidden and shown by setting the show attribute on the parent <brick-layout> . |
Attribute | Type | Description |
---|---|---|
hide |
boolean | Hide this element. |
All mentioned attributes except open
can be set to only apply on certain page widths:
Attribute | < 768px (xs) | ≥ 768px (s) | ≥ 992px (m) | ≥ 1200px (l) |
---|---|---|---|---|
attribute |
yes | yes | yes | yes |
attribute-xs |
yes | no | no | no |
attribute-s |
no | yes | no | no |
attribute-m |
no | no | yes | no |
attribute-l |
no | no | no | yes |
attribute-lt-s |
yes | no | no | no |
attribute-lt-m |
yes | yes | no | no |
attribute-lt-l |
yes | yes | yes | no |
attribute-gt-xs |
no | yes | yes | yes |
attribute-gt-s |
no | no | yes | yes |
attribute-gt-m |
no | no | no | yes |
Example:
The attribute hide-gt-xs
hides an element when the page-width is greater than 768px.
Method | Description |
---|---|
toggleDrawer() |
Toggle the drawer state. |
openDrawer() |
Open the drawer. |
closeDrawer() |
Close the drawer. |
- Headerbar on the top of the page.
- Below the Header:
- Menu on the left side, taking up as much space as the menu items need.
- Content taking up the rest of the space.
We start with the outmost brick-layout
to split the page vertically into the Header and the rest below it. We insert a header
and a div
.
To make the header take up as much space as it needs and the rest below we put the attribute flex
on the div below the header
.
<brick-layout>
<header>
Brick-Layout Basic Examples: Simple
</header>
<div flex>
<!-- menu and content will go here -->
</div>
</brick-layout>
To add the menu and the content horizontally positioned next to each other, we replace the div
with another brick-layout
this time with the attribute horizontal
. Inside we add a div
for the menu and one for the content. We also add the attribute flex
to the content-div.
<brick-layout>
<header>
Brick-Layout Basic Examples: Simple
</header>
<brick-layout horizontal flex>
<div id="menu">
<ul>
<li>Menu Item 1</li>
<li>Menu Item 2</li>
<li>Menu Item 3</li>
</ul>
</div>
<div id="content" flex>
Content goes here.
</div>
</brick-layout>
</brick-layout>
To make it all work we need some css. We do not want to have a padding
and margin
outside of our layout and we want our layout to be able fill the whole page, so we add the following css to the html and body.
html, body {
padding: 0;
margin: 0;
height: 100%;
}
To visualize the layout we add some borders:
header {
border-bottom: 1px solid #ccc;
}
#menu {
border-right: 1px solid #ccc;
}
- Split the page equally into 4 columns
<brick-layout horizontal>
<div class="column" flex>1</div>
<div class="column" flex>2</div>
<div class="column" flex>3</div>
<div class="column" flex>4</div>
</brick-layout>
html, body {
padding: 0;
margin: 0;
height: 100%;
}
.column {
border-left: 1px solid #ccc;
text-align: center;
}
.columns:first-of-type {
border: none;
}
- Headerbar on the top of the page.
- Below the Header:
- Menu on the left side, turns into a drawer when the page-width is below 768px.
- Menu-Button to control the Menu when the page-width is below 768px.
- Content taking up the rest of the space.
<brick-layout>
<header>
<brick-action target="main" action="toggleDrawer">
<button hide-gt-xs>M</button>
</brick-action>
Brick Layout Example: Simple responsive Drawer
</header>
<brick-layout horizontal id="main" flex>
<brick-menu id="menu" drawer-lt-s>
<brick-menu-item selected>Menu Item 1</brick-menu-item>
<brick-menu-item>Menu Item 2</brick-menu-item>
<brick-menu-item>Menu Item 3</brick-menu-item>
</brick-menu>
<div id="article" flex>
article
</div>
</brick-layout>
</brick-layout>
html, body {
padding: 0;
margin: 0;
height: 100%;
}
#header {
border-bottom: 1px solid #ccc;
padding: 12px 9px 9px 9px;
}
#menu {
border-right: 1px solid #ccc;
padding: 9px;
background: white;
}
#menu brick-menu-item {
padding: 3px 0;
}
#menu brick-menu-item[selected] {
font-weight: bold;
}
#article {
padding: 9px;
}
- Headerbar on the top of the page.
- Below the Header:
- Menu on the left side, turns into a tabbar at the bottom of the page when the page-width is below 768px.
- Content taking up the rest of the space.
<brick-layout>
<header>
Brick Layout Example: Responsive Tabs
</header>
<brick-layout horizontal-gt-xs flex>
<brick-menu id="menu" horizontal-lt-s>
<brick-action selected target="card1" action="reveal">
Menu Item 1
</brick-action>
<brick-action target="card2" action="reveal">
Menu Item 2
</brick-action>
<brick-action target="card3" action="reveal">
Menu Item 3
</brick-action>
</brick-menu>
<brick-deck id="content" flex selected-index="0">
<brick-card id="card1" selected>1</brick-card>
<brick-card id="card2">2</brick-card>
<brick-card id="card3">3</brick-card>
</brick-deck>
</brick-layout>
</brick-layout>
html, body {
padding: 0;
margin: 0;
height: 100%;
box-sizing: border-box;
}
#header {
border-bottom: 1px solid #ccc;
padding: 12px 9px 9px 9px;
}
#menu {
border-right: 1px solid #ccc;
background: white;
}
#menu > * {
padding: 9px;
width: 100%;
}
#menu [selected] {
font-weight: bold;
}
brick-card {
padding: 9px;
font-size: 6em;
text-align: center;
}
@media (max-width: 768px) {
#content {
order: 1;
}
#menu {
border: none;
border-top: 1px solid #ccc;
order: 2;
}
#menu > * {
border-left: 1px solid #ccc;
}
#menu > *:first-child {
border-left: none;
}
}
Brick components use Stylus to generate their CSS.
This repository comes outfitted with a set of tools to ease the development process.
To get started:
-
$ npm install -g bower gulp
-
Install local dependencies:
$ npm install && bower install
While developing your component, there is a development server that will watch your files for changes and automatically re-build your styles and re-lint your code.
To run the development server:
- Run
gulp server
- Navigate to
http://localhost:3001
To simply build and lint your code, run gulp build
.
You can also push your code to GitHub Pages by running gulp deploy
.