// Shorthand mixin. Supports multiple parentheses-deliminated values for each variable. // Example: @include transition (all, 2.0s, ease-in-out); // @include transition ((opacity, width), (1.0s, 2.0s), ease-in, (0, 2s)); // @include transition ($property:(opacity, width), $delay: (1.5s, 2.5s)); @mixin transition ($property: all, $duration: 0.15s, $timing-function: ease-out, $delay: 0) { // Detect # of args passed into each variable $length-of-property: length($property); $length-of-duration: length($duration); $length-of-timing-function: length($timing-function); $length-of-delay: length($delay); @if $length-of-property > 1 { @include transition-property(zip($property)); } @else { @include transition-property( $property); } @if $length-of-duration > 1 { @include transition-duration(zip($duration)); } @else { @include transition-duration( $duration); } @if $length-of-timing-function > 1 { @include transition-timing-function(zip($timing-function)); } @else { @include transition-timing-function( $timing-function); } @if $length-of-delay > 1 { @include transition-delay(zip($delay)); } @else { @include transition-delay( $delay); } } @mixin transition-property ($prop-1: all, $prop-2: false, $prop-3: false, $prop-4: false, $prop-5: false, $prop-6: false, $prop-7: false, $prop-8: false, $prop-9: false) { $full: compact($prop-1, $prop-2, $prop-3, $prop-4, $prop-5, $prop-6, $prop-7, $prop-8, $prop-9); -webkit-transition-property: $full; -moz-transition-property: $full; -ms-transition-property: $full; -o-transition-property: $full; transition-property: $full; } @mixin transition-duration ($time-1: 0, $time-2: false, $time-3: false, $time-4: false, $time-5: false, $time-6: false, $time-7: false, $time-8: false, $time-9: false) { $full: compact($time-1, $time-2, $time-3, $time-4, $time-5, $time-6, $time-7, $time-8, $time-9); -webkit-transition-duration: $full; -moz-transition-duration: $full; -ms-transition-duration: $full; -o-transition-duration: $full; transition-duration: $full; } @mixin transition-timing-function ($motion-1: ease, $motion-2: false, $motion-3: false, $motion-4: false, $motion-5: false, $motion-6: false, $motion-7: false, $motion-8: false, $motion-9: false) { $full: compact($motion-1, $motion-2, $motion-3, $motion-4, $motion-5, $motion-6, $motion-7, $motion-8, $motion-9); // ease | linear | ease-in | ease-out | ease-in-out | cubic-bezier() -webkit-transition-timing-function: $full; -moz-transition-timing-function: $full; -ms-transition-timing-function: $full; -o-transition-timing-function: $full; transition-timing-function: $full; } @mixin transition-delay ($time-1: 0, $time-2: false, $time-3: false, $time-4: false, $time-5: false, $time-6: false, $time-7: false, $time-8: false, $time-9: false) { $full: compact($time-1, $time-2, $time-3, $time-4, $time-5, $time-6, $time-7, $time-8, $time-9); -webkit-transition-delay: $full; -moz-transition-delay: $full; -ms-transition-delay: $full; -o-transition-delay: $full; transition-delay: $full; }