_grid.scss 1.82 KB
Newer Older
Mark Otto's avatar
Mark Otto committed
1
2
3
4
/// Grid system
//
// Generate semantic grid columns with these mixins.

5
@mixin make-container($padding-x: $container-padding-x) {
6
  width: 100%;
7
8
  padding-right: $padding-x;
  padding-left: $padding-x;
XhmikosR's avatar
XhmikosR committed
9
10
  margin-right: auto;
  margin-left: auto;
Mark Otto's avatar
Mark Otto committed
11
12
}

13
14

// For each breakpoint, define the maximum width of the container in a media query
15
@mixin make-container-max-widths($max-widths: $container-max-widths, $breakpoints: $grid-breakpoints) {
16
  @each $breakpoint, $container-max-width in $max-widths {
17
    @include media-breakpoint-up($breakpoint, $breakpoints) {
18
      max-width: $container-max-width;
19
20
21
22
    }
  }
}

23
@mixin make-row($gutter: $grid-gutter-width) {
24
25
  display: flex;
  flex-wrap: wrap;
26
27
  margin-right: -$gutter / 2;
  margin-left: -$gutter / 2;
Mark Otto's avatar
Mark Otto committed
28
29
}

30
@mixin make-col-ready($gutter: $grid-gutter-width) {
Mark Otto's avatar
Mark Otto committed
31
  position: relative;
32
33
34
  // Prevent columns from becoming too narrow when at smaller grid tiers by
  // always setting `width: 100%;`. This works because we use `flex` values
  // later on to override this initial width.
35
  width: 100%;
36
37
  padding-right: $gutter / 2;
  padding-left: $gutter / 2;
38
39
}

40
@mixin make-col($size, $columns: $grid-columns) {
41
42
43
44
45
  flex: 0 0 percentage($size / $columns);
  // Add a `max-width` to ensure content within each column does not blow out
  // the width of the column. Applies to IE10+ and Firefox. Chrome and Safari
  // do not appear to require this.
  max-width: percentage($size / $columns);
Mark Otto's avatar
Mark Otto committed
46
}
Mark Otto's avatar
Mark Otto committed
47
48

@mixin make-col-offset($size, $columns: $grid-columns) {
49
50
  $num: $size / $columns;
  margin-left: if($num == 0, 0, percentage($num));
Mark Otto's avatar
Mark Otto committed
51
}
Mark Otto's avatar
Cleanup    
Mark Otto committed
52
53
54
55
56
57
58

// Row columns
//
// Specify on a parent element(e.g., .row) to force immediate children into NN
// numberof columns. Supports wrapping to new lines, but does not do a Masonry
// style grid.
@mixin row-cols($count) {
ysds's avatar
ysds committed
59
60
61
  & > * {
    flex: 0 0 100% / $count;
    max-width: 100% / $count;
Mark Otto's avatar
Cleanup    
Mark Otto committed
62
63
  }
}