_grid-framework.scss 1.78 KB
Newer Older
Mark Otto's avatar
Mark Otto committed
1
2
3
4
5
// Framework grid generation
//
// Used only by Bootstrap to generate the correct number of grid classes given
// any value of `$grid-columns`.

Gleb Mazovetskiy's avatar
Gleb Mazovetskiy committed
6
7
@mixin make-grid-columns($columns: $grid-columns, $gutter: $grid-gutter-width, $breakpoints: $grid-breakpoints) {
  // Common properties for all breakpoints
8
9
10
11
12
  %grid-column {
    position: relative;
    // Prevent columns from collapsing when empty
    min-height: 1px;
    // Inner gutter via padding
Gleb Mazovetskiy's avatar
Gleb Mazovetskiy committed
13
14
    padding-left: ($gutter / 2);
    padding-right: ($gutter / 2);
Mark Otto's avatar
Mark Otto committed
15
  }
16
  $breakpoint-counter: 0;
Gleb Mazovetskiy's avatar
Gleb Mazovetskiy committed
17
  @each $breakpoint in map-keys($breakpoints) {
18
    $breakpoint-counter: ($breakpoint-counter + 1);
Gleb Mazovetskiy's avatar
Gleb Mazovetskiy committed
19
    @for $i from 1 through $columns {
20
21
22
      .col-#{$breakpoint}-#{$i} {
        @extend %grid-column;
      }
Gleb Mazovetskiy's avatar
Gleb Mazovetskiy committed
23
    }
24
    @include media-breakpoint-up($breakpoint, $breakpoints) {
Gleb Mazovetskiy's avatar
Gleb Mazovetskiy committed
25
26
      // Work around cross-media @extend (https://github.com/sass/sass/issues/1050)
      %grid-column-float-#{$breakpoint} {
27
        float: left;
Gleb Mazovetskiy's avatar
Gleb Mazovetskiy committed
28
29
30
      }
      @for $i from 1 through $columns {
        .col-#{$breakpoint}-#{$i} {
31
32
33
          @if not $enable-flex {
            @extend %grid-column-float-#{$breakpoint};
          }
Gleb Mazovetskiy's avatar
Gleb Mazovetskiy committed
34
35
36
          @include make-col-span($i, $columns);
        }
      }
37
      @each $modifier in (pull, push) {
Gleb Mazovetskiy's avatar
Gleb Mazovetskiy committed
38
39
40
41
42
        @for $i from 0 through $columns {
          .col-#{$breakpoint}-#{$modifier}-#{$i} {
            @include make-col-modifier($modifier, $i, $columns)
          }
        }
43
      }
44
45
46
47
48
49
50
51
      // `$columns - 1` because offsetting by the width of an entire row isn't possible
      @for $i from 0 through ($columns - 1) {
        @if $breakpoint-counter != 1 or $i != 0 { // Avoid emitting useless .col-xs-offset-0
          .col-#{$breakpoint}-offset-#{$i} {
            @include make-col-modifier(offset, $i, $columns)
          }
        }
      }
Mark Otto's avatar
Mark Otto committed
52
53
54
    }
  }
}