ant-design/style/mixins/grid.less
2015-06-09 18:22:52 +08:00

73 lines
1.6 KiB
Plaintext

// mixins for grid system
// ------------------------
.container-fixed(@gutter: @grid-gutter-width) {
margin-right: auto;
margin-left: auto;
padding-left: (@gutter / 2);
padding-right: (@gutter / 2);
&:extend(.clearfix all);
}
.make-row(@gutter: @grid-gutter-width) {
position: relative;
width: 100%;
margin-left: (@gutter / -2);
margin-right: (@gutter / -2);
height: auto;
&:extend(.clearfix all);
}
.make-grid-columns() {
.col(@index) {
@item: ~".col-@{index}";
.col((@index + 1), @item);
}
.col(@index, @list) when (@index =< @grid-columns) {
@item: ~".col-@{index}";
.col((@index + 1), ~"@{list}, @{item}");
}
.col(@index, @list) when (@index > @grid-columns) {
@{list} {
position: relative;
display: block;
float: left;
flex: 0 0 auto;
padding-left: (@grid-gutter-width / 2);
padding-right: (@grid-gutter-width / 2);
}
}
.col(1);
}
.loop-grid-columns(@index) when (@index > 0) {
.col-@{index} {
width: percentage((@index / @grid-columns));
flex: 0 0 percentage(@index / @grid-columns);
}
.col-push-@{index} {
left: percentage((@index / @grid-columns));
}
.col-pull-@{index} {
right: percentage((@index / @grid-columns));
}
.col-offset-@{index} {
margin-left: percentage((@index / @grid-columns));
}
.col-order-@{index} {
order: @index;
}
.loop-grid-columns((@index - 1));
}
.loop-grid-columns(@index) when (@index = 0) {
.col-push-@{index} {
left: auto;
}
.col-pull-@{index} {
right: auto;
}
}
.make-grid() {
.loop-grid-columns(@grid-columns);
}