A semantic flexbox grid made with stylus. It provides seven mixins with the higher powers of flexbox.
Note: Is fully recommended the use of autoprefixer-stylus along with gridus, because it adds all vendor-prefixers necessary to flexbox works on every modern browser.
First of all install the gridus package using npm.
$ npm install gridus
Alternatively, you can install gridus with yarn.
$ yarn add gridus
The easiest way to use gridus is by importing the file directly.
@import 'node_modules/gridus/gridus'
To use gridus with the stylus cli you can use the following command.
$ stylus src/styl --out dist/css --use gridus
Simply require the stylus module and type. See the documentation for more info.
stylus(str)
.use(gridus)
.render(...)
Alternatively, you can use the render function.
stylus.render(str, { use: gridus }, function(err, css) {
if (err) throw err;
console.log(css);
});
To use gridus with gulp, you can use gulp-stylus and include gridus in use option.
const gulp = require('gulp');
const stylus = require('gulp-stylus');
const gridus = require('gridus');
gulp.task('stylus', function() {
gulp.src('src/styl/*.styl')
.pipe(stylus({
use: [gridus()]
}))
.pipe(gulp.dest('dist/css'))
})
Gridus has the same support that flexbox feature has. See the support at Can I Use.
In the parent node of all grids you must specify the behaviour of the container, if it will behaviour like a column or like a row.
// The grid will behave like a row
.row
row()
// The grid will behave like a column
.column
column()
After that you can specify the behaviour of the cells by adding as many as you want mixins in the container.
.row
row()
align() // optional
justify() // optional
.column
column()
align() // optional
justify() // optional
After that just create the cells and it's behaviuor.
.cell
cell()
gutter() // optional
offset() // optional
The align mixin accepts three value 'start', 'center' and 'end'. If passed any different value a error will be throwed.
If included in a row will make the elements be aligned horizontally on the top. If included in a column will make the elements be aligned vertically on the left.
.align-start
align('start')
The output from code above is.
.align-start {
align-content: flex-start;
align-items: flex-start;
}
If included in a row will make the elements be aligned horizontally on the center. If included in a column will make the elements be aligned vertically on the center.
.align-default
align()
.align-center
align('center')
The output from code above is.
.align-default {
align-content: center;
align-items: center;
}
.align-center {
align-content: center;
align-items: center;
}
If included in a row will make the elements be aligned horizontally on the bottom. If included in a column will make the elements be aligned vertically on the right.
.align-end
align('end')
The output from code above is.
.align-end {
align-content: flex-end;
align-items: flex-end;
}
The cell mixin accepts four kinds of parameters.
Create a cell that will automatic size inside his parent.
.cell-default
cell()
.cell-flex
cell('flex')
The output from code above is.
.cell-default {
flex: 1;
}
.cell-flex {
flex: 1;
}
The size of the cell. Example: 2/5 will occupy 2 cells of a 5 cells grid.
.cell-fraction
cell(2/5)
The output from code above is.
.cell-fraction {
flex: 0 0 40%;
}
The minimum width of a cell. In that way the cells will have the minimum width specified but will occupy all the free space and have the same size in different screens.
.cell-unit
cell(200px)
The output from code above is.
.cell-unit {
flex: 1 0 200px;
}
The mixin column will make a container of cells behave like a column.
.column
column()
The output from code above is.
.column {
display: flex;
flex: 0 1 auto;
flex-flow: column wrap;
}
The gutter mixins accepts two parameters, the first is the size of the gutter and the second is type of the gutter (inside or outside). By default the size is 1rem and the type is inside.
.gutter-default
gutter()
.gutter-size
gutter(10px)
.gutter-size-outside
gutter(10px, 'outside')
The output from code above is.
.gutter-default {
padding-left: 0.5rem;
padding-right: 0.5rem;
}
.gutter-size {
padding-left: 5px;
padding-right: 5px;
}
.gutter-size-outside {
margin-left: 5px;
margin-right: 5px;
}
The justify mixin accepts five different values 'center', 'left', 'right', 'between' and 'around'. Between and around will distribute the space between the elements or around the elements.
.justify-default
justify()
.justify-start
justify('start')
.justify-end
justify('end')
.justify-center
justify('center')
.justify-around
justify('around')
.justify-between
justify('between')
The output from code above is.
.justify-default {
justify-content: center;
text-align: center;
}
.justify-start {
justify-content: flex-start;
text-align: start;
}
.justify-end {
justify-content: flex-end;
text-align: end;
}
.justify-center {
justify-content: center;
text-align: center;
}
.justify-around {
justify-content: space-around;
}
.justify-between {
justify-content: space-between;
}
The mixin offset will add a margin left to the cell, so this just works together with the row mixin.
.offset-fraction
offset(2/5)
.offset-unit
offset(200px)
The output from code above is.
.offset-fraction {
margin-left: 40%;
}
.offset-unit {
margin-left: 200px;
}
The mixin row will make a container of cells behave like a row.
.row
row()
The output from code above is.
.row {
display: flex;
flex: 0 1 auto;
flex-flow: row wrap;
}
See the contributing file.