v1/web/modules/contrib/bootstrap_styles/scss/_mixins.scss

369 lines
12 KiB
SCSS

// 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%);
}
}
}