Last active
February 15, 2016 08:32
-
-
Save mindplay-dk/6795939 to your computer and use it in GitHub Desktop.
Simplified semantic grid calculation for SASS (based on http://semantic.gs/)
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
#layout { | |
display: block; | |
width: 940px; } | |
#left { | |
display: inline; | |
float: left; | |
width: 60px; } | |
#content { | |
display: inline; | |
float: left; | |
width: 620px; | |
margin-left: 20px; } | |
#right { | |
display: inline; | |
float: left; | |
width: 220px; | |
margin-left: 20px; } | |
#content-columns { | |
display: block; | |
width: 620px; } | |
#content-left { | |
display: inline; | |
float: left; | |
width: 300px; } | |
#content-right { | |
display: inline; | |
float: left; | |
width: 300px; | |
margin-left: 20px; } |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<div class="layout"> | |
<div class="left"> | |
Left column... | |
</div> | |
<div class="content"> | |
Content goes here... | |
<div class="content-columns"> | |
<div class="content-left"> | |
More content in two columns - left... | |
</div> | |
<div class="content-right"> | |
And right... | |
</div> | |
</div> | |
</div> | |
<div class="right"> | |
Right column... | |
</div> | |
</div> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// Note that each grid has to be defined in sequence, e.g. one row() and | |
// then all of the col() columns inside that row - you can't interrupt | |
// this flow when defining nested grids. | |
#layout { @include row(); } | |
#left { @include col(1); } | |
#content { @include col(8); } | |
#right { @include col(3); } | |
#content-columns { @include row(8); } | |
#content-left { @include col(4); } | |
#content-right { @include col(4); } |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// Global settings - you can override these after including this file: | |
$grid-col: 60px; | |
$grid-gutter: 20px; | |
$grid-cols: 12; | |
// Internals: | |
$grid-index: 0; | |
$grid-max: 0; | |
@function grid-width($span: $grid-cols) { | |
@if $span > 1 { | |
@return ($grid-col * $span) + ($grid-gutter * ($span - 1)); | |
} @else { | |
@return $grid-col; | |
} | |
} | |
// Mix-in to start a row (optionally with a specified total number of columns) | |
@mixin row($cols: $grid-cols) { | |
$grid-index: 0 !global; | |
$grid-max: $cols !global; | |
display: block; | |
width: grid-width($cols); | |
} | |
// Mix-in to add a column (optionally spanning a given number of columns) | |
@mixin col($span: 1) { | |
display: inline; | |
float: left; | |
width: grid-width($span); | |
@if $grid-index > 0 { | |
margin-left: $grid-gutter; | |
} | |
$grid-index: $grid-index + $span !global; | |
@if $grid-index > $grid-max { | |
@warn "grid overflow: you have #{$grid-index} total columns in the current row of #{$grid-max} columns"; | |
} | |
} |
A combined fluent/fixed grid-calculator now lives here:
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Fluid version here:
https://gist.github.com/mindplay-dk/6798866