144 lines
2.9 KiB
SCSS
144 lines
2.9 KiB
SCSS
@use "shared";
|
|
@use "../utilities/controls";
|
|
@use "../utilities/css-variables" as cv;
|
|
@use "../utilities/initial-variables" as iv;
|
|
@use "../utilities/extends";
|
|
|
|
$select-colors: shared.$form-colors !default;
|
|
|
|
.#{iv.$class-prefix}select {
|
|
@include cv.register-vars(
|
|
(
|
|
"input-h": #{cv.getVar("scheme-h")},
|
|
"input-s": #{cv.getVar("scheme-s")},
|
|
"input-border-style": solid,
|
|
"input-border-width": 1px,
|
|
"input-border-l": #{cv.getVar("border-l")},
|
|
)
|
|
);
|
|
|
|
display: inline-block;
|
|
max-width: 100%;
|
|
position: relative;
|
|
vertical-align: top;
|
|
|
|
&:not(.#{iv.$class-prefix}is-multiple) {
|
|
height: shared.$input-height;
|
|
}
|
|
|
|
&:not(.#{iv.$class-prefix}is-multiple):not(.#{iv.$class-prefix}is-loading) {
|
|
&::after {
|
|
@extend %arrow;
|
|
inset-inline-end: 1.125em;
|
|
z-index: 4;
|
|
}
|
|
}
|
|
|
|
&.#{iv.$class-prefix}is-rounded {
|
|
select {
|
|
border-radius: cv.getVar("radius-rounded");
|
|
padding-inline-start: 1em;
|
|
}
|
|
}
|
|
|
|
select {
|
|
@extend %input;
|
|
cursor: pointer;
|
|
display: block;
|
|
font-size: 1em;
|
|
max-width: 100%;
|
|
outline: none;
|
|
|
|
&::-ms-expand {
|
|
display: none;
|
|
}
|
|
|
|
&[disabled]:hover,
|
|
fieldset[disabled] &:hover {
|
|
border-color: shared.$input-disabled-border-color;
|
|
}
|
|
|
|
&:not([multiple]) {
|
|
padding-inline-end: 2.5em;
|
|
}
|
|
|
|
&[multiple] {
|
|
height: auto;
|
|
padding: 0;
|
|
|
|
option {
|
|
padding: 0.5em 1em;
|
|
}
|
|
}
|
|
}
|
|
|
|
// Colors
|
|
@each $name, $pair in $select-colors {
|
|
&.#{iv.$class-prefix}is-#{$name} {
|
|
@include cv.register-vars(
|
|
(
|
|
"input-h": #{cv.getVar($name, "", "-h")},
|
|
"input-s": #{cv.getVar($name, "", "-s")},
|
|
"input-l": #{cv.getVar($name, "", "-l")},
|
|
"input-focus-h": #{cv.getVar($name, "", "-h")},
|
|
"input-focus-s": #{cv.getVar($name, "", "-s")},
|
|
"input-focus-l": #{cv.getVar($name, "", "-l")},
|
|
"input-border-l": #{cv.getVar($name, "", "-l")},
|
|
)
|
|
);
|
|
}
|
|
}
|
|
|
|
// Sizes
|
|
&.#{iv.$class-prefix}is-small {
|
|
@include controls.control-small;
|
|
}
|
|
|
|
&.#{iv.$class-prefix}is-medium {
|
|
@include controls.control-medium;
|
|
}
|
|
|
|
&.#{iv.$class-prefix}is-large {
|
|
@include controls.control-large;
|
|
}
|
|
|
|
// Modifiers
|
|
&.#{iv.$class-prefix}is-disabled {
|
|
&::after {
|
|
border-color: shared.$input-disabled-color !important;
|
|
opacity: 0.5;
|
|
}
|
|
}
|
|
|
|
&.#{iv.$class-prefix}is-fullwidth {
|
|
width: 100%;
|
|
|
|
select {
|
|
width: 100%;
|
|
}
|
|
}
|
|
|
|
&.#{iv.$class-prefix}is-loading {
|
|
&::after {
|
|
@extend %loader;
|
|
inset-inline-end: 0.625em;
|
|
margin-top: 0;
|
|
position: absolute;
|
|
top: 0.625em;
|
|
transform: none;
|
|
}
|
|
|
|
&.#{iv.$class-prefix}is-small:after {
|
|
font-size: cv.getVar("size-small");
|
|
}
|
|
|
|
&.#{iv.$class-prefix}is-medium:after {
|
|
font-size: cv.getVar("size-medium");
|
|
}
|
|
|
|
&.#{iv.$class-prefix}is-large:after {
|
|
font-size: cv.getVar("size-large");
|
|
}
|
|
}
|
|
}
|