75 lines
2.8 KiB
Sass
75 lines
2.8 KiB
Sass
|
@use 'sass:map'
|
||
|
@use 'sass:math'
|
||
|
@use '../../styles/settings'
|
||
|
@use '../../styles/tools'
|
||
|
|
||
|
@mixin make-container($padding-x: settings.$container-padding-x)
|
||
|
width: 100%
|
||
|
padding: $padding-x
|
||
|
margin-right: auto
|
||
|
margin-left: auto
|
||
|
|
||
|
// For each breakpoint, define the maximum width of the container in a media query
|
||
|
@mixin make-container-max-widths($max-widths: settings.$container-max-widths, $breakpoints: settings.$grid-breakpoints)
|
||
|
@each $breakpoint, $container-max-width in $max-widths
|
||
|
+tools.media-breakpoint-up($breakpoint, $breakpoints)
|
||
|
max-width: $container-max-width
|
||
|
|
||
|
@mixin make-row($gutter: settings.$grid-gutter)
|
||
|
display: flex
|
||
|
flex-wrap: wrap
|
||
|
flex: 1 1 auto
|
||
|
margin: -$gutter * .5
|
||
|
|
||
|
@mixin make-col-ready($gutter: settings.$grid-gutter)
|
||
|
// 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.
|
||
|
width: 100%
|
||
|
padding: $gutter * .5
|
||
|
|
||
|
@mixin make-col($size, $columns: settings.$grid-columns)
|
||
|
flex: 0 0 math.percentage(math.div($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: math.percentage(math.div($size, $columns))
|
||
|
|
||
|
@mixin make-col-offset($size, $columns: settings.$grid-columns)
|
||
|
$num: math.div($size, $columns)
|
||
|
margin-inline-start: if($num == 0, 0, math.percentage($num))
|
||
|
|
||
|
@mixin make-grid-columns($columns: settings.$grid-columns, $gutter: settings.$grid-gutter, $breakpoints: settings.$grid-breakpoints)
|
||
|
// Common properties for all breakpoints
|
||
|
%grid-column
|
||
|
width: 100%
|
||
|
padding: $gutter * .5
|
||
|
@each $breakpoint in map.keys($breakpoints)
|
||
|
$infix: tools.breakpoint-infix($breakpoint, $breakpoints)
|
||
|
// Allow columns to stretch full width below their breakpoints
|
||
|
@for $i from 1 through $columns
|
||
|
.v-col#{$infix}-#{$i}
|
||
|
@extend %grid-column
|
||
|
.v-col#{$infix},
|
||
|
.v-col#{$infix}-auto
|
||
|
@extend %grid-column
|
||
|
+tools.media-breakpoint-up($breakpoint, $breakpoints)
|
||
|
// Provide basic `.col-{bp}` classes for equal-width flexbox columns
|
||
|
.v-col#{$infix}
|
||
|
flex-basis: 0
|
||
|
flex-grow: 1
|
||
|
max-width: 100%
|
||
|
.v-col#{$infix}-auto
|
||
|
flex: 0 0 auto
|
||
|
width: auto
|
||
|
max-width: 100% // Reset earlier grid tiers
|
||
|
@for $i from 1 through $columns
|
||
|
.v-col#{$infix}-#{$i}
|
||
|
+make-col($i, $columns)
|
||
|
// `$columns - 1` because offsetting by the width of an entire row isn't possible
|
||
|
@for $i from 0 through $columns - 1
|
||
|
@if not ($infix == "" and $i == 0)
|
||
|
// Avoid emitting useless .offset-0
|
||
|
.offset#{$infix}-#{$i}
|
||
|
+make-col-offset($i, $columns)
|