Files
2015-07-26 00:21:41 -05:00

231 lines
4.5 KiB
SCSS

// Core Button Variables
// --------------------------------------------------
$button-font-size: 1.6rem !default;
$button-margin: 0.4rem 0 !default;
$button-padding: 0 2rem !default;
$button-height: 4.4rem !default;
$button-border-width: 1px !default;
$button-border-radius: 4px !default;
$button-large-font-size: 2rem !default;
$button-large-height: 5.4rem !default;
$button-large-padding: 1.4rem !default;
$button-small-font-size: 1.3rem !default;
$button-small-height: 2.8rem !default;
$button-small-padding: 1.1rem !default;
$button-round-border-radius: 64px !default;
$button-round-padding: 0 2.6rem !default;
// Core Button
// --------------------------------------------------
button,
[button] {
position: relative;
display: inline-flex;
flex-shrink: 0;
flex-flow: row nowrap;
align-items: center;
justify-content: center;
will-change: transform;
margin: $button-margin;
line-height: 1;
@include appearance(none);
vertical-align: top; // the better option for most scenarios
vertical-align: -webkit-baseline-middle; // the best for those that support it
font-family: inherit;
font-variant: inherit;
font-style: inherit;
white-space: nowrap;
text-overflow: ellipsis;
overflow: hidden;
cursor: pointer;
user-select: none;
border: 1px solid #ccc;
padding: $button-padding;
min-height: $button-height;
background: transparent;
text-align: center;
font-size: $button-font-size;
border: transparent;
border-radius: $button-border-radius;
&[large] {
padding: 0 $button-large-padding;
min-width: ($button-large-padding * 4);
min-height: $button-large-height;
font-size: $button-large-font-size;
}
&[small] {
padding: 0 $button-small-padding;
min-width: ($button-small-padding * 3);
min-height: $button-small-height;
font-size: $button-small-font-size;
}
// Core Button Types
// --------------------------------------------------
&[clear] {
border-color: transparent;
background: none;
}
&[outline] {
background: none;
&.activated {
opacity: 0.3 !important;
}
&[full] {
border-radius: 0;
border-right-width: 0;
border-left-width: 0;
}
}
&[block] {
display: flex;
clear: both;
margin-right: 0;
margin-left: 0;
width: 100%;
&:after {
clear: both;
}
}
&[full] {
width: 100%;
margin-right: 0;
margin-left: 0;
border-radius: 0;
border-right-width: 0;
border-left-width: 0;
}
&.disabled,
&[disabled] {
opacity: .4;
cursor: default !important;
pointer-events: none;
}
&[round] {
border-radius: $button-round-border-radius;
padding: $button-round-padding;
}
}
.padding > button[block]:first-child,
.padding > [button][block]:first-child {
margin-top: 0;
}
// Button Misc
// --------------------------------------------------
a[button] {
color: inherit;
text-decoration: none;
}
// Core Button Mixins
// --------------------------------------------------
@mixin button-default($bg-color, $fg-color) {
background-color: $bg-color;
color: $fg-color;
transition: background-color,opacity 100ms linear;
&[full][outline] {
border-radius: 0;
border-right-width: 0;
border-left-width: 0;
}
&:hover,
&.hover {
opacity: 0.88;
color: $fg-color;
text-decoration: none;
}
&.activated {
opacity: 1;
background-color: darken($bg-color, 12%);
}
}
@mixin button-clear($fg-color) {
&[clear] {
color: $fg-color;
background: none;
&.activated {
opacity: 0.4;
}
}
}
@mixin button-outline($fg-color) {
&[outline] {
border: 1px solid $fg-color;
background: transparent;
color: $fg-color;
&.activated {
color: white;
background-color: rgb(red($fg-color), green($fg-color), blue($fg-color));//, 0.15);
}
}
}
// Core Button Color Generation
// --------------------------------------------------
@each $color, $value in $colors {
button[#{$color}],
[button][#{$color}] {
@if lightness(get-color($color, base)) > 90 {
$fg-color: get-color($color, inverse);
} @else {
$fg-color: get-color($color, base);
}
@include button-default(get-color($color, base),
get-color($color, inverse));
@include button-clear($fg-color);
@include button-outline(get-color($color, light));
}
}