|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
$rfs-base-value: 1.25rem !default; |
|
$rfs-unit: rem !default; |
|
|
|
@if $rfs-unit != rem and $rfs-unit != px { |
|
@error "`#{$rfs-unit}` is not a valid unit for $rfs-unit. Use `px` or `rem`."; |
|
} |
|
|
|
|
|
$rfs-breakpoint: 1200px !default; |
|
$rfs-breakpoint-unit: px !default; |
|
|
|
@if $rfs-breakpoint-unit != px and $rfs-breakpoint-unit != em and $rfs-breakpoint-unit != rem { |
|
@error "`#{$rfs-breakpoint-unit}` is not a valid unit for $rfs-breakpoint-unit. Use `px`, `em` or `rem`."; |
|
} |
|
|
|
|
|
$rfs-two-dimensional: false !default; |
|
|
|
|
|
$rfs-factor: 10 !default; |
|
|
|
@if type-of($rfs-factor) != number or $rfs-factor <= 1 { |
|
@error "`#{$rfs-factor}` is not a valid $rfs-factor, it must be greater than 1."; |
|
} |
|
|
|
|
|
$rfs-mode: min-media-query !default; |
|
|
|
|
|
$rfs-class: false !default; |
|
|
|
|
|
$rfs-rem-value: 16 !default; |
|
|
|
|
|
$rfs-safari-iframe-resize-bug-fix: false !default; |
|
|
|
|
|
$enable-rfs: true !default; |
|
|
|
|
|
$rfs-base-value-unit: unit($rfs-base-value); |
|
|
|
|
|
@if $rfs-base-value-unit == px { |
|
$rfs-base-value: $rfs-base-value / ($rfs-base-value * 0 + 1); |
|
} |
|
@else if $rfs-base-value-unit == rem { |
|
$rfs-base-value: $rfs-base-value / ($rfs-base-value * 0 + 1 / $rfs-rem-value); |
|
} |
|
|
|
|
|
$rfs-breakpoint-unit-cache: unit($rfs-breakpoint); |
|
|
|
|
|
@if $rfs-breakpoint-unit-cache == px { |
|
$rfs-breakpoint: $rfs-breakpoint / ($rfs-breakpoint * 0 + 1); |
|
} |
|
@else if $rfs-breakpoint-unit-cache == rem or $rfs-breakpoint-unit-cache == "em" { |
|
$rfs-breakpoint: $rfs-breakpoint / ($rfs-breakpoint * 0 + 1 / $rfs-rem-value); |
|
} |
|
|
|
|
|
$rfs-mq-value: if($rfs-breakpoint-unit == px, #{$rfs-breakpoint}px, #{$rfs-breakpoint / $rfs-rem-value}#{$rfs-breakpoint-unit}); |
|
$rfs-mq-property-width: if($rfs-mode == max-media-query, max-width, min-width); |
|
$rfs-mq-property-height: if($rfs-mode == max-media-query, max-height, min-height); |
|
|
|
|
|
@mixin _rfs-media-query { |
|
@if $rfs-two-dimensional { |
|
@if $rfs-mode == max-media-query { |
|
@media (#{$rfs-mq-property-width}: #{$rfs-mq-value}), (#{$rfs-mq-property-height}: #{$rfs-mq-value}) { |
|
@content; |
|
} |
|
} |
|
@else { |
|
@media (#{$rfs-mq-property-width}: #{$rfs-mq-value}) and (#{$rfs-mq-property-height}: #{$rfs-mq-value}) { |
|
@content; |
|
} |
|
} |
|
} |
|
@else { |
|
@media (#{$rfs-mq-property-width}: #{$rfs-mq-value}) { |
|
@content; |
|
} |
|
} |
|
} |
|
|
|
|
|
@mixin _rfs-rule { |
|
@if $rfs-class == disable and $rfs-mode == max-media-query { |
|
|
|
&, |
|
.disable-rfs &, |
|
&.disable-rfs { |
|
@content; |
|
} |
|
} |
|
@else if $rfs-class == enable and $rfs-mode == min-media-query { |
|
.enable-rfs &, |
|
&.enable-rfs { |
|
@content; |
|
} |
|
} |
|
@else { |
|
@content; |
|
} |
|
} |
|
|
|
|
|
@mixin _rfs-media-query-rule { |
|
|
|
@if $rfs-class == enable { |
|
@if $rfs-mode == min-media-query { |
|
@content; |
|
} |
|
|
|
@include _rfs-media-query { |
|
.enable-rfs &, |
|
&.enable-rfs { |
|
@content; |
|
} |
|
} |
|
} |
|
@else { |
|
@if $rfs-class == disable and $rfs-mode == min-media-query { |
|
.disable-rfs &, |
|
&.disable-rfs { |
|
@content; |
|
} |
|
} |
|
@include _rfs-media-query { |
|
@content; |
|
} |
|
} |
|
} |
|
|
|
|
|
@function rfs-value($values) { |
|
|
|
$values: if(type-of($values) != list, ($values,), $values); |
|
|
|
$val: ''; |
|
|
|
|
|
@each $value in $values { |
|
@if $value == 0 { |
|
$val: $val + ' 0'; |
|
} |
|
@else { |
|
|
|
$unit: if(type-of($value) == "number", unit($value), false); |
|
|
|
@if $unit == px { |
|
|
|
$val: $val + ' ' + if($rfs-unit == rem, #{$value / ($value * 0 + $rfs-rem-value)}rem, $value); |
|
} |
|
@else if $unit == rem { |
|
|
|
$val: $val + ' ' + if($rfs-unit == px, #{$value / ($value * 0 + 1) * $rfs-rem-value}px, $value); |
|
} |
|
@else { |
|
|
|
$val: $val + ' ' + $value; |
|
} |
|
} |
|
} |
|
|
|
|
|
@return unquote(str-slice($val, 2)); |
|
} |
|
|
|
|
|
@function rfs-fluid-value($values) { |
|
|
|
$values: if(type-of($values) != list, ($values,), $values); |
|
|
|
$val: ''; |
|
|
|
|
|
@each $value in $values { |
|
@if $value == 0 { |
|
$val: $val + ' 0'; |
|
} |
|
|
|
@else { |
|
|
|
$unit: if(type-of($value) == "number", unit($value), false); |
|
|
|
|
|
@if not $unit or $unit != px and $unit != rem { |
|
$val: $val + ' ' + $value; |
|
} |
|
|
|
@else { |
|
|
|
$value: $value / ($value * 0 + if($unit == px, 1, 1 / $rfs-rem-value)); |
|
|
|
|
|
@if abs($value) <= $rfs-base-value or not $enable-rfs { |
|
$val: $val + ' ' + if($rfs-unit == rem, #{$value / $rfs-rem-value}rem, #{$value}px); |
|
} |
|
@else { |
|
|
|
$value-min: $rfs-base-value + (abs($value) - $rfs-base-value) / $rfs-factor; |
|
|
|
|
|
$value-diff: abs($value) - $value-min; |
|
|
|
|
|
$min-width: if($rfs-unit == rem, #{$value-min / $rfs-rem-value}rem, #{$value-min}px); |
|
|
|
|
|
$min-width: if($value < 0, -$min-width, $min-width); |
|
|
|
|
|
$variable-unit: if($rfs-two-dimensional, vmin, vw); |
|
|
|
|
|
$variable-width: #{$value-diff * 100 / $rfs-breakpoint}#{$variable-unit}; |
|
|
|
|
|
$val: $val + ' calc(' + $min-width + if($value < 0, ' - ', ' + ') + $variable-width + ')'; |
|
} |
|
} |
|
} |
|
} |
|
|
|
|
|
@return unquote(str-slice($val, 2)); |
|
} |
|
|
|
|
|
@mixin rfs($values, $property: font-size) { |
|
@if $values != null { |
|
$val: rfs-value($values); |
|
$fluidVal: rfs-fluid-value($values); |
|
|
|
|
|
@if $val == $fluidVal { |
|
#{$property}: $val; |
|
} |
|
@else { |
|
@include _rfs-rule { |
|
#{$property}: if($rfs-mode == max-media-query, $val, $fluidVal); |
|
|
|
|
|
min-width: if($rfs-safari-iframe-resize-bug-fix, (0 * 1vw), null); |
|
} |
|
|
|
@include _rfs-media-query-rule { |
|
#{$property}: if($rfs-mode == max-media-query, $fluidVal, $val); |
|
} |
|
} |
|
} |
|
} |
|
|
|
|
|
@mixin font-size($value) { |
|
@include rfs($value); |
|
} |
|
|
|
@mixin padding($value) { |
|
@include rfs($value, padding); |
|
} |
|
|
|
@mixin padding-top($value) { |
|
@include rfs($value, padding-top); |
|
} |
|
|
|
@mixin padding-right($value) { |
|
@include rfs($value, padding-right); |
|
} |
|
|
|
@mixin padding-bottom($value) { |
|
@include rfs($value, padding-bottom); |
|
} |
|
|
|
@mixin padding-left($value) { |
|
@include rfs($value, padding-left); |
|
} |
|
|
|
@mixin margin($value) { |
|
@include rfs($value, margin); |
|
} |
|
|
|
@mixin margin-top($value) { |
|
@include rfs($value, margin-top); |
|
} |
|
|
|
@mixin margin-right($value) { |
|
@include rfs($value, margin-right); |
|
} |
|
|
|
@mixin margin-bottom($value) { |
|
@include rfs($value, margin-bottom); |
|
} |
|
|
|
@mixin margin-left($value) { |
|
@include rfs($value, margin-left); |
|
} |
|
|