2019-11-04 13:09:44 +00:00
@mixin themify ( $themes ) {
@each $theme , $map in $themes {
. theme__ #{ $theme } & {
$theme-map : () !global ;
@each $key , $submap in $map {
$value : map-get ( map-get ( $themes , $theme ) , " #{ $key } " ) ;
$theme-map : map-merge (
$ theme-map ,
(
$key : $value
)
) ! global ;
}
@content ;
$theme-map : null !global ;
}
}
}
@mixin pseudo ( $display : block , $pos : absolute , $content : " " ) {
content : $content ;
display : $display ;
position : $pos ;
}
@mixin responsive-ratio ( $x , $y , $pseudo : false ) {
$padding : unquote (( $y / $x ) * 100 + " % " ) ;
@if $pseudo {
& : before {
@include pseudo ( $pos : relative ) ;
width : 100 % ;
padding-top : $padding ;
}
} @else {
padding-top : $padding ;
}
}
@mixin css-triangle ( $color , $direction , $size : 6 px , $position : absolute , $round : false ) {
@include pseudo ( $pos : $position ) ;
width : 0 ;
height : 0 ;
@if $round {
border-radius : 3 px ;
}
@if $direction == down {
border-left : $size solid transparent ;
border-right : $size solid transparent ;
border-top : $size solid $color ;
margin-top : 0 - round ( $size / 2 .5 ) ;
} @else if $direction == up {
border-left : $size solid transparent ;
border-right : $size solid transparent ;
border-bottom : $size solid $color ;
margin-bottom : 0 - round ( $size / 2 .5 ) ;
} @else if $direction == right {
border-top : $size solid transparent ;
border-bottom : $size solid transparent ;
border-left : $size solid $color ;
margin-right : - $size ;
} @else if $direction == left {
border-top : $size solid transparent ;
border-bottom : $size solid transparent ;
border-right : $size solid $color ;
margin-left : - $size ;
}
}
@mixin font-source-sans ( $size : false , $colour : false , $weight : false , $lh : false ) {
font-family : " Source Sans Pro " , Helvetica , Arial , sans-serif ;
@if $size {
font-size : $size ;
}
@if $colour {
color : $colour ;
}
@if $weight {
font-weight : $weight ;
}
@if $lh {
line-height : $lh ;
}
}
@mixin input-placeholder {
& . placeholder {
@content ;
}
& : -moz-placeholder {
@content ;
}
& : : -moz-placeholder {
@content ;
}
& : -ms-input-placeholder {
@content ;
}
& : : -webkit-input-placeholder {
@content ;
}
}
@mixin truncate ( $truncation-boundary ) {
white-space : nowrap ;
overflow : hidden ;
text-overflow : ellipsis ;
2019-12-31 02:26:57 +00:00
width : $truncation-boundary ;
2019-11-04 13:09:44 +00:00
}
@mixin box-shadow ( $top , $left , $blur , $size , $color , $inset : false ) {
@if $inset {
-webkit-box-shadow : inset $top $left $blur $size $color ;
-moz-box-shadow : inset $top $left $blur $size $color ;
box-shadow : inset $top $left $blur $size $color ;
} @else {
-webkit-box-shadow : $top $left $blur $size $color ;
-moz-box-shadow : $top $left $blur $size $color ;
box-shadow : $top $left $blur $size $color ;
}
}
@mixin on-event ( $self : false ) {
@if $self {
& ,
& : hover ,
& : active ,
& : focus {
@content ;
}
} @else {
& : hover ,
& : active ,
& : focus {
@content ;
}
}
}
@mixin transition ( $what : all , $time : 0 .2 s , $how : ease-in-out ) {
-webkit-transition : $what $time $how ;
-moz-transition : $what $time $how ;
-ms-transition : $what $time $how ;
-o-transition : $what $time $how ;
transition : $what $time $how ;
}
// Browser Prefixes
@mixin transform ( $transforms ) {
-webkit-transform : $transforms ;
-moz-transform : $transforms ;
-ms-transform : $transforms ;
transform : $transforms ;
}
// Rotate
@mixin rotate ( $deg ) {
@include transform ( rotate ( #{ $deg } deg )) ;
}
// Scale
@mixin scale ( $scale ) {
@include transform ( scale ( $scale )) ;
}
@mixin scaleX ( $scale ) {
@include transform ( scaleX ( $scale )) ;
}
@mixin scaleY ( $scale ) {
@include transform ( scaleY ( $scale )) ;
}
// Translate
@mixin translate ( $x , $y ) {
@include transform ( translate ( $x , $y )) ;
}
@mixin translateX ( $x ) {
@include transform ( translateX ( $x )) ;
}
@mixin translateY ( $y ) {
@include transform ( translateY ( $y )) ;
}
// Skew
@mixin skew ( $x , $y ) {
@include transform ( skew ( #{ $x } deg , #{ $y } deg )) ;
}
// Transform Origin
@mixin transform-origin ( $origin ) {
-webkit-transform-origin : $origin ;
-moz-transform-origin : $origin ;
-ms-transform-origin : $origin ;
transform-origin : $origin ;
}
2019-11-12 11:24:17 +00:00
2019-11-20 17:45:46 +00:00
@mixin keyframes ( $animation-name ) {
@-webkit-keyframes #{ $animation-name } {
@content ;
}
@-moz-keyframes #{ $animation-name } {
@content ;
}
@-ms-keyframes #{ $animation-name } {
@content ;
}
@-o-keyframes #{ $animation-name } {
@content ;
}
@keyframes #{ $animation-name } {
@content ;
}
}
@mixin animation ( $str ) {
-webkit-animation : #{ $str } ;
-moz-animation : #{ $str } ;
-ms-animation : #{ $str } ;
-o-animation : #{ $str } ;
animation : #{ $str } ;
}
2019-11-22 03:43:10 +00:00
@mixin no-select {
-webkit-touch-callout : none ;
-webkit-user-select : none ;
-khtml-user-select : none ;
-moz-user-select : none ;
-ms-user-select : none ;
user-select : none ;
}
2019-11-12 11:24:17 +00:00
@mixin clippy () {
background-image : url( 'data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="24pt" height="24pt" viewBox="0 0 24 24" version="1.1">
< path style = " stroke:none;fill-rule:nonzero;fill:rgb(100,100,100);fill-opacity:1; " d = " M 4 2 C 2.894531 2 2 2.894531 2 4 L 2 17 C 2 17.550781 2.449219 18 3 18 C 3.550781 18 4 17.550781 4 17 L 4 4 L 17 4 C 17.550781 4 18 3.550781 18 3 C 18 2.449219 17.550781 2 17 2 Z M 8 6 C 6.894531 6 6 6.894531 6 8 L 6 20 C 6 21.105469 6.894531 22 8 22 L 20 22 C 21.105469 22 22 21.105469 22 20 L 22 8 C 22 6.894531 21.105469 6 20 6 Z M 8 8 L 20 8 L 20 20 L 8 20 Z M 8 8 " / > < / svg > ' );
2019-11-20 06:55:05 +00:00
}