Navigation Menu

Skip to content

Instantly share code, notes, and snippets.

@allanwhite
Created January 2, 2019 20:46
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save allanwhite/81d70af0856ce16b127e5d3ff9d4332f to your computer and use it in GitHub Desktop.
Save allanwhite/81d70af0856ce16b127e5d3ff9d4332f to your computer and use it in GitHub Desktop.
// functions includes mixins for now
/// Return black or white with alpha
/// @access public
/// @param {Opacity} $opacity, 0-1
/// @return - black or white with alpha, like rgba(0,0,0,0.4);
@function black($opacity) {
@return rgba(0,0,0,$opacity);
}
@function white($opacity) {
@return rgba(255,255,255,$opacity);
}
/// Map deep get
/// @author Hugo Giraudel
/// @access public
/// @param {Map} $map - Map
/// @param {Arglist} $keys - Key chain
/// @return {*} - Desired value
@function map-deep-get($map, $keys...) {
@each $key in $keys {
$map: map-get($map, $key);
}
@return $map;
}
// === mixins ====
$link-color-default: #fff !default;
$underline: false !default;
@mixin link-colors($color: $link-color-default, $hover-color: $color_yellow-glow, $has-underline: $underline ) {
color: $color !important;
&:hover {
color: $hover-color !important;
@if $has-underline == true {
border-bottom: 1px solid $hover-color;
}
}
}
@mixin spaced-out {
text-transform: uppercase;
letter-spacing: 0.2em;
}
@mixin border-radius($r){
-webkit-border-radius: ($r);
-moz-border-radius: ($r);
border-radius: ($r);
}
@mixin easing($s){ // keeping this for legacy uses for now. Should use the one below, with transform3D
-moz-transition: all $s ease;
-webkit-transition: all $s ease;
-o-transition: all $s ease;
transition: all $s ease;
}
@mixin transition($args...){
-moz-transition: $args;
-webkit-transition: $args;
-o-transition: $args;
transition: $args;
}
@mixin transform($args...){
// -ms-transform: $t;
-moz-transform: $args;
-webkit-transform: $args;
-o-transform: $args;
transform: $args;
}
@mixin vertical-center-text(){
justify-content: center;
align-content: center;
flex-direction: column;
}
@mixin animation($arg){
-webkit-animation: $arg;
-moz-animation: $arg;
-o-animation: $arg;
animation: $arg;
}
// this mixin sets up animations. Still need to call the newly created keyframed animation with the above
// eg. @include animation (dotpulse 1s infinite); - AW
@mixin keyframes($animationName) {
@-webkit-keyframes #{$animationName} {
@content;
}
@-moz-keyframes #{$animationName} {
@content;
}
@-o-keyframes #{$animationName} {
@content;
}
@keyframes #{$animationName} {
@content;
}
}
@mixin shadow($offset, $blur, $color, $opacity) {
// ex: shadow(0, 20px, $black, 0.4);
-moz-box-shadow: $offset $offset $blur transparentize($color, $opacity);
-webkit-box-shadow: $offset $offset $blur transparentize($color, $opacity);
box-shadow: $offset $offset $blur transparentize($color, $opacity);
}
@mixin shadow-anarchy($s...){ // no more kings! let chaos reign
-moz-box-shadow: $s;
-webkit-box-shadow: $s;
box-shadow: $s;
}
@mixin blur($r){ // covers most browsers...FF needs JS for this I think. http://codepen.io/ebellempire/pen/rnvEK
// $r: $radius * 1px;
filter: blur($r); /* Someday, sigh ... */
-webkit-filter: blur($r); /* Prefixed CSS3 blur filters */
-moz-filter: blur($r);
-o-filter: blur($r);
-ms-filter: blur($r);
// filter: url(#blur); /* Firefox needs SVG */
// filter:progid:DXImageTransform.Microsoft.Blur(PixelRadius='$radius'); /* IE lte 9 */
}
@mixin opacity($alpha){
opacity: $alpha;
}
@mixin container-pad() {
// padding: 5.5vw 4vw;
padding: 2rem 1rem; // any rows & cols should handle padding at small viewports. - AW
}
// centered bg images
@mixin background-fill ($align...) { // center center
background:{
repeat: no-repeat !important;
position: $align !important;
size: cover;
}
}
/// Adds basic styles for a callout, including padding and margin. Forked from Foundation's callout mixin
@mixin seldon-callout-base() {
margin: $callout-margin;
padding: $callout-padding;
border: $callout-border;
border-radius: $callout-radius;
position: relative;
// color: $callout-font-color;
// Respect the padding, fool.
> :first-child {
margin-top: 0;
}
> :last-child {
margin-bottom: 0;
}
}
// Mobile faux callout - this allows us to add the mixin to any class on mobile and -->
// turn that into something that looks like a callout. This works best for blocks -->
// of text that look nice without a callout on desktop, but fall apart on mobile
@mixin mobile-callout(){
margin: 0 0 2.5rem 0;
padding: 1.2rem 1.5rem;
position: relative;
overflow: hidden;
@include border-radius(rem-calc(6px));
}
@mixin button-hollow($color){
$button-border-width: 1px;
background-color: transparent;
background-image: none !important;
border: $button-border-width solid $color;
color: $color;
&:hover,
&:focus {
border: $button-border-width solid adjust-color($color, $lightness: 20%);
background-color: transparent;
color: adjust-color($color, $lightness: 20%);
}
}
// pass any arguments to a flex: statement
@mixin flex-it ($set...){
-webkit-box-flex: 0;
-webkit-flex: $set;
-ms-flex: $set;
flex: $set;
}
@mixin fx-hover-nudge {
transition: transform $timing-default * 0.8 ease, color $timing-default * 0.8 linear, background-color $timing-default * 0.8 linear;
&:focus,
&:hover {
transform: translate3d(3px, 0, 0);
}
}
@mixin no-nudge {
&:focus,
&:hover {
transform: translate3d(0, 0, 0);
}
}
// Gradient mixins
@mixin gradient($args...){ // pass whatever you want, as long as it's a valid gradient
background-image: -webkit-linear-gradient($args);
background-image: -o-linear-gradient($args);
background-image: linear-gradient($args);
}
// @function gradient-prefixes($args...){
// @return -webkit-linear-gradient($args), -o-linear-gradient($args), linear-gradient($args);
// }
@mixin clip-path($a, $b, $c, $d){
-webkit-clip-path: polygon($a, $b, $c, $d);
clip-path: polygon($a, $b, $c, $d);
}
// Angled bottom -- right now this only works with solid colors :(
@mixin angle($pseudo, $flip: false, $angle: 5.5deg){
@if $pseudo == 'before' or $pseudo == 'after' or $pseudo == 'both'{
position: relative;
z-index: 1;
$selector: if($pseudo == 'both', '&:before,&:after', '&:#{$pseudo}');
#{$selector}{
background: inherit;
content: '';
display: block;
height: 50%;
left: 0;
position: absolute;
right: 0;
z-index: -1;
-webkit-backface-visibility: hidden;
}
@if $pseudo == 'before'{
#{$selector}{
top: 0;
@if $flip{
transform: skewY($angle * -1);
transform-origin: 0 0;
}@else{
transform: skewY($angle);
transform-origin: 100% 0;
}
}
}
@if $pseudo == 'after'{
#{$selector}{
bottom: 0;
@if $flip{
transform: skewY($angle);
transform-origin: 0 100%;
}@else{
transform: skewY($angle * -1);
transform-origin: 100%;
}
}
}
@if $pseudo == 'both'{
&:before{
top: 0;
@if $flip{
transform: skewY($angle * -1);
transform-origin: 0 0;
}@else{
transform: skewY($angle);
transform-origin: 100% 0;
}
}
&:after{
bottom: 0;
@if $flip{
transform: skewY($angle);
transform-origin: 0 0;
}@else{
transform: skewY($angle * -1);
transform-origin: 100%;
}
}
}
}
}
// for the .status-dot classes in _icons. Pass a color and one of the $thing-[size] vars for nice defaults.
@mixin status-dot($color, $size) {
@include border-radius(50%);
background-color: $color;
display: inline-block;
height: $size;
width: $size;
// vertical-align: middle;
}
// Border radius only on right side
@mixin border-radius-right($r){
-webkit-border-top-right-radius: $r;
-webkit-border-bottom-right-radius: $r;
-moz-border-radius-topright: $r;
-moz-border-radius-bottomright: $r;
border-top-right-radius: $r;
border-bottom-right-radius: $r;
}
// Border radius only on left side
@mixin border-radius-left($r){
-webkit-border-top-left-radius: $r;
-webkit-border-bottom-left-radius: $r;
-moz-border-radius-topleft: $r;
-moz-border-radius-bottomleft: $r;
border-top-left-radius: $r;
border-bottom-left-radius: $r;
}
// Border radius only on bottom side
@mixin border-radius-bottom($r){
-webkit-border-bottom-left-radius: $r;
-moz-border-radius-bottomleft: $r;
border-bottom-left-radius: $r;
-webkit-border-bottom-right-radius: $r;
-moz-border-radius-bottomright: $r;
border-bottom-right-radius: $r;
}
// Border radius only on TOP right side
@mixin border-radius-top-right($r){
-webkit-border-top-right-radius: $r;
-moz-border-radius-topright: $r;
border-top-right-radius: $r;
}
// Border radius only on TOP left side
@mixin border-radius-top-left($r){
-webkit-border-top-left-radius: $r;
-moz-border-radius-topleft: $r;
border-top-left-radius: $r;
}
// Border radius only on BOTTOM right side
@mixin border-radius-bottom-right($r){
-webkit-border-bottom-right-radius: $r;
-moz-border-radius-bottomright: $r;
border-bottom-right-radius: $r;
}
// Border radius only on BOTTOm left side
@mixin border-radius-bottom-left($r){
-webkit-border-bottom-left-radius: $r;
-moz-border-radius-bottomleft: $r;
border-bottom-left-radius: $r;
}
@mixin bg-noise {
background-image: url();
}
// animation moved to modules/animation.scss. only functions & mixins here - because this file is @included by other files.
@mixin textarea-selectable {
min-height: 9em;
font: {
family: $font-family-monospace;
size: 0.9rem;
}
background-color: transparent;
color: inherit; // from parent container
&:focus {
background-color: transparentize($color_prime-alt, 0.9);
color: inherit;
}
border: 1px solid transparentize($gray-7, 0.5);
}
@mixin hyphens ($args...){
-webkit-hyphens: $args;
-ms-hyphens: $args;
hyphens: $args;
}
// @ columns: 1 15em; column-gap: 2rem;
@mixin multicolumns ($cols, $height, $gap: 1.5rem){
-webkit-columns: $cols $height;
-moz-columns: $cols $height;
columns: $cols $height;
-webkit-column-gap: $gap;
-moz-column-gap: $gap;
column-gap: $gap;
}
@mixin break-inside { // use in children of multicolumns such as .masonry-group--item
-webkit-column-break-inside: avoid;
page-break-inside: avoid;
break-inside: avoid;
}
@mixin break-before {
-webkit-column-break-before: always;
// -moz-column-break-before: column;
column-break-before: always;
break-before: column;
}
@mixin hover-border($color: $color_prime-alt, $border-width: 6px) {
// a .avatar {
transition: box-shadow 150ms ease;
// transition-delay: 0;
&:hover {
box-shadow: 0 0 0 $border-width $color;
// transition-delay: 100ms;
}
// }
}
@mixin input-placeholder { // mixin to properly target placeholder text styling; just pass css rules into include.
&::placeholder {@content};
&::-webkit-input-placeholder {@content};
&:-moz-placeholder {@content};
&::-moz-placeholder {@content};
&:-ms-input-placeholder {@content};
}
@mixin percentage-widths {
&-half {
max-width: 50%;
}
&-two-thirds {
max-width: 66%;
}
&-third {
max-width: 33%;
}
}
@mixin blend-multiply {
@supports (background-blend-mode: multiply) {
background-blend-mode: multiply;
}
}
@mixin blend-overlay {
@supports (background-blend-mode: overlay) {
background-blend-mode: overlay;
}
}
@mixin gradient-cks($dir: to right) {
/* blue to blue-purple */
background: linear-gradient($dir, #4CC0F1 6.72%, #6929D1 96.96%);
color: white;
}
@mixin gradient-cpaas($dir: to right) {
/* blue-green */
background: linear-gradient($dir, #008FDF -5.71%, #00E3BA 82.93%);
color: white;
}
@mixin gradient-ccms($dir: to right) {
/* blue-purple */
background: linear-gradient($dir, #4C66F1 2.29%, #D129C3 98.71%);
color: white;
}
@mixin gradient-cmi($dir: to right) {
/* orange-red */
background: linear-gradient($dir, #E85C86 16.59%, #EC7474 59.68%, #FFC177 99.57%);
/* red-purple - orange */
// background: linear-gradient($dir, #DD48AA 16.59%, #FFE177 99.57%);
color: white;
}
@mixin gradient-services($dir: to right) {
/* red - pale green */
background: linear-gradient($dir, #E6699E 13.96%, #7AB2E9 57.53%, #08E1D4 96.11%);
color: white;
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment