// Mixins @mixin sr-only() { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0; } @mixin smooth-all-transition() { transition: all .3s ease-in-out; } // Buttons @mixin button-variant($background, $border, $hover-background: darken($background, 7.5%), $hover-border: darken($border, 10%), $active-background: darken($background, 10%), $active-border: darken($border, 12.5%)) { color: color-yiq($background); @include gradient-bg($background); border-color: $border; @include box-shadow($btn-box-shadow); @include hover() { color: color-yiq($hover-background); @include gradient-bg($hover-background); border-color: $hover-border; } &:focus, &.focus { color: color-yiq($hover-background); @include gradient-bg($hover-background); border-color: $hover-border; @if $enable-shadows { @include box-shadow($btn-box-shadow, 0 0 0 $btn-focus-width rgba(mix(color-yiq($background), $border, 15%), .5)); } @else { // Avoid using mixin so we can pass custom focus shadow properly box-shadow: 0 0 0 $btn-focus-width rgba(mix(color-yiq($background), $border, 15%), .5); } } } @mixin button-outline-variant($color, $color-hover: color-yiq($color), $active-background: $color, $active-border: $color) { color: $color; border-color: $color; @include hover() { color: $color-hover; background-color: $active-background; border-color: $active-border; } &:focus, &.focus { box-shadow: 0 0 0 $btn-focus-width rgba($color, .5); } } // Rounded input style toggles (container & background type) @mixin blb_box_inputs($width: 100%, $rounded: false, $height: 40px, $border-color: $box_input_bg_checked) { position: relative; flex: $width; width: $width; margin: 0; padding: 0; @if $rounded { &:first-child input + label { border-right: 0; border-radius: 8px 0 0 8px; } &:last-child input + label { border-left: 0; border-radius: 0 8px 8px 0; } } input { @include sr-only; + label { @include smooth-all-transition; font-size: .875rem; border: 1px solid $border-color; padding: 10px; height: $height; width: 100%; display: flex; align-items: center; justify-content: center; text-align: center; cursor: pointer; margin: 0; &:hover { background-color: rgba($panel_text_color, .1); } svg { height: 18px; width: 18px; } } // Active state. &:checked + label { color: $white; background-color: $box_input_bg_checked; svg, svg * { color: $white; } } } } // Squared input style (spacing/borders inputs) @mixin bs_boxed_inputs($width: 100%, $max-width: 100%, $height: 35px, $bg: $box_input_bg, $active_color: inherit, $active_bg: $box_input_bg_checked) { position: relative; flex: $width; max-width: $max-width; width: $width; margin: 0; padding: 0; input { @include sr-only; + label { @include smooth-all-transition; padding: 8px; height: $height; width: 100%; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; cursor: pointer; background-color: $box_input_bg; &:hover { background-color: $box_input_bg_hover; &:after { border-color: $box_input_hover_border; } } } // Active state. &:checked + label { color: $active_color; background-color: $active_bg; svg, svg * { color: $active_color; } &:after { border-color: $box_input_checked_border; } } } } // Card input styles (box shadow, scroll effects) @mixin bs_boxed_inputs_cards($height: 80px) { input { + label { font-size: 10px; font-weight: normal; padding: 8px; margin: 2px; width: calc(100% - 4px); display: flex; align-items: center; justify-content: center; text-align: center; cursor: pointer; border-radius: 0; background-color: $icon_box_input_bg; min-height: $height; flex-direction: column; &:hover { background-color: $icon_box_input_bg_hover; } // Hide our default tooltip. .bs_tooltip { display: none; } } // Active state. @include bs_invert_icon_color_when_checked; // Custom fix for Bootstrap 3 Drupal theme. label { width: 100%; display: flex; align-items: center; justify-content: center; text-align: center; cursor: pointer; flex-direction: column; height: $height; + input { opacity: 0; position: absolute; } // Active state. &.active { color: $panel_bg_color; background-color: $panel_text_color; } } } } @mixin bs_invert_icon_color_when_checked { &:checked + label { font-weight: bold; color: $panel_link_color; background-color: $icon_box_input_bg_checked; .input-icon { filter: invert(46%) sepia(100%) saturate(313%) hue-rotate(169deg) brightness(91%) contrast(94%); } } } @mixin bs_circle_inputs($width: 100%) { > div { display: flex; flex-wrap: wrap; } input { @include sr-only(); &:checked + label.option { border-color: $panel_link_color; &:after { @include smooth-all-transition; width: 20px; height: 20px; top: 50%; left: 50%; margin: -10px 0 0 -10px; content: ''; position: absolute; background: url("") center center no-repeat; background-size: contain; } &.bs_yiq-dark:after { background: url("") center center no-repeat; background-size: contain; } } // Red "X" &[value="_none"] { + label:after { @include smooth-all-transition; width: 20px; height: 20px; top: 50%; left: 50%; margin: -10px 0 0 -10px; content: ''; position: absolute; background: url("") center center no-repeat; background-size: contain; } &:checked + label.option { &:before { display: none; } &:after { background: url("") center center no-repeat; background-size: contain; } } } } &.style-selected input:not(:checked) + label { opacity: 0.3; &:hover { opacity: 1; } } label { @include smooth-all-transition; cursor: pointer !important; border: 2px solid $panel_text_color; border-radius: 40px; font-size: 0.00001px; position: relative; display: inline-block; width: 40px; height: 40px; float: left; margin: 0 5px 5px 0; padding: 0; white-space: nowrap; box-shadow: 2px 2px 3px 1px rgba($panel_bg_color, 0.15); &:after { display: table; position: absolute; top: 3px; left: 0; right: 0; bottom: 0; z-index: 1; font-size: 20px; text-align: center; vertical-align: middle; width: 100%; height: 100%; } } } // Override input slider colours (padding/margin) @mixin bs_range_sliders($track_color: $panel_link_color) { &::-webkit-slider-runnable-track { background: $track_color; } &::-moz-range-track { background: $track_color; } &::-ms-fill-lower { background: $track_color; } &:focus { &::-webkit-slider-runnable-track { background: lighten($track_color, 10%); } &::-ms-fill-lower { background: lighten($track_color, 10%); } &::-ms-fill-upper { background: lighten($track_color, 10%); } } }