2017-06-13 22:30:33 -07:00
// Bootstrap functions
//
// Utility mixins and functions for evalutating source code across our variables, maps, and mixins.
// Ascending
// Used to evaluate Sass maps like our grid breakpoints.
2017-06-13 22:21:50 -07:00
@mixin _assert-ascending ( $map , $map-name ) {
$prev-key : null ;
$prev-num : null ;
@each $key , $num in $map {
@if $prev-num == null {
// Do nothing
} @else if not comparable ( $prev-num , $num ) {
@warn " Potentially invalid value for #{ $map-name } : This map must be in ascending order, but key ' #{ $key } ' has value #{ $num } whose unit makes it incomparable to #{ $prev-num } , the value of the previous key ' #{ $prev-key } ' ! " ;
} @else if $prev-num >= $num {
@warn " Invalid value for #{ $map-name } : This map must be in ascending order, but key ' #{ $key } ' has value #{ $num } which isn't greater than #{ $prev-num } , the value of the previous key ' #{ $prev-key } ' ! " ;
}
$prev-key : $key ;
$prev-num : $num ;
}
}
2017-06-13 22:30:33 -07:00
// Starts at zero
// Another grid mixin that ensures the min-width of the lowest breakpoint starts at 0.
@mixin _assert-starts-at-zero ( $map ) {
$values : map-values ( $map ) ;
$first-value : nth ( $values , 1 ) ;
@if $first-value != 0 {
@warn " First breakpoint in `$grid-breakpoints` must start at 0, but starts at #{ $first-value } . " ;
}
}
2017-06-13 22:21:50 -07:00
// Replace `$search` with `$replace` in `$string`
2017-06-13 22:30:33 -07:00
// Used on our SVG icon backgrounds for custom forms.
//
2017-06-13 22:21:50 -07:00
// @author Hugo Giraudel
// @param {String} $string - Initial string
// @param {String} $search - Substring to replace
// @param {String} $replace ('') - New value
// @return {String} - Updated string
@function str-replace ( $string , $search , $replace : " " ) {
$index : str-index ( $string , $search ) ;
@if $index {
@return str-slice ( $string , 1 , $index - 1 ) + $replace + str-replace ( str-slice ( $string , $index + str-length ( $search )) , $search , $replace ) ;
}
@return $string ;
}
2017-06-15 11:15:48 -07:00
// Color contrast
2017-09-13 17:32:44 +02:00
@function color-yiq ( $color ) {
2017-06-15 11:15:48 -07:00
$r : red ( $color ) ;
$g : green ( $color ) ;
$b : blue ( $color ) ;
$yiq : (( $r * 299 ) + ( $g * 587 ) + ( $b * 114 )) / 1000 ;
2017-12-02 00:26:10 -03:00
@if ( $yiq >= $yiq-contrasted-threshold ) {
2017-10-18 21:06:13 -07:00
@return $yiq-text-dark ;
2017-06-15 11:15:48 -07:00
} @else {
2017-10-18 21:06:13 -07:00
@return $yiq-text-light ;
2017-06-15 11:15:48 -07:00
}
}
2017-11-15 09:12:38 +00:00
// Retrieve color Sass maps
2017-06-15 11:15:48 -07:00
@function color ( $key : " blue " ) {
@return map-get ( $colors , $key ) ;
}
2017-06-25 18:31:03 -07:00
2017-06-15 11:15:48 -07:00
@function theme-color ( $key : " primary " ) {
@return map-get ( $theme-colors , $key ) ;
}
2017-06-25 18:31:03 -07:00
2017-08-20 14:18:11 -07:00
@function gray ( $key : " 100 " ) {
2017-06-29 23:06:46 -07:00
@return map-get ( $grays , $key ) ;
}
2017-06-25 18:31:03 -07:00
// Request a theme color level
@function theme-color-level ( $color-name : " primary " , $level : 0 ) {
$color : theme-color ( $color-name ) ;
2018-01-20 17:00:44 -08:00
$color-base : if ( $level > 0 , $black , $white ) ;
2017-09-26 14:05:59 +02:00
$level : abs ( $level ) ;
2017-06-25 18:31:03 -07:00
2017-09-26 14:05:59 +02:00
@return mix ( $color-base , $color , $level * $theme-color-interval ) ;
2017-06-25 18:31:03 -07:00
}