shoelace/src/components/select/select.styles.ts

311 wiersze
7.3 KiB
TypeScript
Czysty Zwykły widok Historia

2021-07-10 00:45:44 +00:00
import { css } from 'lit';
import componentStyles from '../../styles/component.styles';
import formControlStyles from '../../styles/form-control.styles';
export default css`
${componentStyles}
${formControlStyles}
:host {
display: block;
}
.select {
display: block;
}
2021-09-24 12:48:01 +00:00
.select__control {
2021-07-10 00:45:44 +00:00
display: inline-flex;
align-items: center;
justify-content: start;
position: relative;
width: 100%;
font-family: var(--sl-input-font-family);
font-weight: var(--sl-input-font-weight);
letter-spacing: var(--sl-input-letter-spacing);
vertical-align: middle;
overflow: hidden;
transition: var(--sl-transition-fast) color, var(--sl-transition-fast) border, var(--sl-transition-fast) box-shadow;
cursor: pointer;
}
2021-09-25 02:28:14 +00:00
/* Standard selects */
.select--standard .select__control {
background-color: rgb(var(--sl-input-background-color));
border: solid var(--sl-input-border-width) rgb(var(--sl-input-border-color));
color: rgb(var(--sl-input-color));
}
.select--standard:not(.select--disabled) .select__control:hover {
background-color: rgb(var(--sl-input-background-color-hover));
border-color: rgb(var(--sl-input-border-color-hover));
color: rgb(var(--sl-input-color-hover));
2021-07-10 00:45:44 +00:00
}
2021-09-25 02:28:14 +00:00
.select--standard.select--focused:not(.select--disabled) .select__control {
background-color: rgb(var(--sl-input-background-color-focus));
border-color: rgb(var(--sl-input-border-color-focus));
2021-08-27 13:07:42 +00:00
box-shadow: var(--sl-focus-ring);
2021-07-10 00:45:44 +00:00
outline: none;
color: rgb(var(--sl-input-color-focus));
2021-07-10 00:45:44 +00:00
}
2021-09-25 02:28:14 +00:00
.select--standard.select--disabled .select__control {
background-color: rgb(var(--sl-input-background-color-disabled));
border-color: rgb(var(--sl-input-border-color-disabled));
color: rgb(var(--sl-input-color-disabled));
2021-07-10 00:45:44 +00:00
opacity: 0.5;
cursor: not-allowed;
outline: none;
}
2021-09-25 02:28:14 +00:00
/* Filled selects */
.select--filled .select__control {
background-color: rgb(var(--sl-color-neutral-100));
border: solid 1px rgb(var(--sl-color-neutral-100));
color: rgb(var(--sl-input-color));
}
.select--filled.select--focused:not(.select--disabled) .select__control {
2021-09-25 02:38:08 +00:00
background-color: rgb(var(--sl-color-surface-base));
2021-09-25 02:28:14 +00:00
border-color: rgb(var(--sl-color-primary-500));
box-shadow: var(--sl-focus-ring);
outline: none;
}
.select--filled.select--disabled .select__control {
opacity: 0.5;
cursor: not-allowed;
outline: none;
}
2021-07-10 00:45:44 +00:00
.select--disabled .select__tags,
.select--disabled .select__clear {
pointer-events: none;
}
.select__prefix {
display: inline-flex;
align-items: center;
color: rgb(var(--sl-input-placeholder-color));
}
2021-07-10 00:45:44 +00:00
.select__label {
flex: 1 1 auto;
display: flex;
align-items: center;
user-select: none;
overflow-x: auto;
overflow-y: hidden;
white-space: nowrap;
/* Hide scrollbar in Firefox */
scrollbar-width: none;
}
/* Hide scrollbar in Chrome/Safari */
.select__label::-webkit-scrollbar {
width: 0;
height: 0;
}
.select__clear {
flex: 0 0 auto;
2021-08-27 13:03:10 +00:00
width: 1.25em;
2021-07-10 00:45:44 +00:00
}
.select__suffix {
display: inline-flex;
align-items: center;
color: rgb(var(--sl-input-placeholder-color));
}
2021-07-10 00:45:44 +00:00
.select__icon {
flex: 0 0 auto;
display: inline-flex;
transition: var(--sl-transition-medium) transform ease;
}
.select--open .select__icon {
transform: rotate(-180deg);
}
/* Placeholder */
.select--placeholder-visible .select__label {
color: rgb(var(--sl-input-placeholder-color));
2021-07-10 00:45:44 +00:00
}
.select--disabled.select--placeholder-visible .select__label {
color: rgb(var(--sl-input-placeholder-color-disabled));
2021-07-10 00:45:44 +00:00
}
/* Tags */
.select__tags {
display: inline-flex;
align-items: center;
flex-wrap: wrap;
justify-content: left;
2021-09-08 13:51:31 +00:00
margin-left: var(--sl-spacing-2x-small);
2021-07-10 00:45:44 +00:00
}
/* Hidden input (for form control validation to show) */
.select__hidden-select {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
clip: rect(0 0 0 0);
clip-path: inset(50%);
overflow: hidden;
white-space: nowrap;
}
/*
* Size modifiers
*/
/* Small */
2021-09-24 12:48:01 +00:00
.select--small .select__control {
2021-07-10 00:45:44 +00:00
border-radius: var(--sl-input-border-radius-small);
font-size: var(--sl-input-font-size-small);
min-height: var(--sl-input-height-small);
}
.select--small .select__prefix ::slotted(*) {
margin-left: var(--sl-input-spacing-small);
}
2021-07-10 00:45:44 +00:00
.select--small .select__label {
margin: 0 var(--sl-input-spacing-small);
}
.select--small .select__clear {
margin-right: var(--sl-input-spacing-small);
}
.select--small .select__suffix ::slotted(*) {
margin-right: var(--sl-input-spacing-small);
}
2021-07-10 00:45:44 +00:00
.select--small .select__icon {
margin-right: var(--sl-input-spacing-small);
}
.select--small .select__tags {
padding-bottom: 2px;
}
.select--small .select__tags sl-tag {
padding-top: 2px;
}
.select--small .select__tags sl-tag:not(:last-of-type) {
2021-09-08 13:51:31 +00:00
margin-right: var(--sl-spacing-2x-small);
2021-07-10 00:45:44 +00:00
}
.select--small.select--has-tags .select__label {
margin-left: 0;
}
/* Medium */
2021-09-24 12:48:01 +00:00
.select--medium .select__control {
2021-07-10 00:45:44 +00:00
border-radius: var(--sl-input-border-radius-medium);
font-size: var(--sl-input-font-size-medium);
min-height: var(--sl-input-height-medium);
}
.select--medium .select__prefix ::slotted(*) {
margin-left: var(--sl-input-spacing-medium);
}
2021-07-10 00:45:44 +00:00
.select--medium .select__label {
margin: 0 var(--sl-input-spacing-medium);
}
.select--medium .select__clear {
margin-right: var(--sl-input-spacing-medium);
}
.select--medium .select__suffix ::slotted(*) {
margin-right: var(--sl-input-spacing-medium);
}
2021-07-10 00:45:44 +00:00
.select--medium .select__icon {
margin-right: var(--sl-input-spacing-medium);
}
.select--medium .select__tags {
padding-bottom: 3px;
}
.select--medium .select__tags sl-tag {
padding-top: 3px;
}
.select--medium .select__tags sl-tag:not(:last-of-type) {
2021-09-08 13:51:31 +00:00
margin-right: var(--sl-spacing-2x-small);
2021-07-10 00:45:44 +00:00
}
.select--medium.select--has-tags .select__label {
margin-left: 0;
}
/* Large */
2021-09-24 12:48:01 +00:00
.select--large .select__control {
2021-07-10 00:45:44 +00:00
border-radius: var(--sl-input-border-radius-large);
font-size: var(--sl-input-font-size-large);
min-height: var(--sl-input-height-large);
}
.select--large .select__prefix ::slotted(*) {
margin-left: var(--sl-input-spacing-large);
}
2021-07-10 00:45:44 +00:00
.select--large .select__label {
margin: 0 var(--sl-input-spacing-large);
}
.select--large .select__clear {
margin-right: var(--sl-input-spacing-large);
}
.select--large .select__suffix ::slotted(*) {
margin-right: var(--sl-input-spacing-large);
}
2021-07-10 00:45:44 +00:00
.select--large .select__icon {
margin-right: var(--sl-input-spacing-large);
}
.select--large .select__tags {
padding-bottom: 4px;
}
.select--large .select__tags sl-tag {
padding-top: 4px;
}
.select--large .select__tags sl-tag:not(:last-of-type) {
2021-09-08 13:51:31 +00:00
margin-right: var(--sl-spacing-2x-small);
2021-07-10 00:45:44 +00:00
}
.select--large.select--has-tags .select__label {
margin-left: 0;
}
/*
* Pill modifier
*/
2021-09-24 12:48:01 +00:00
.select--pill.select--small .select__control {
2021-07-10 00:45:44 +00:00
border-radius: var(--sl-input-height-small);
}
2021-09-24 12:48:01 +00:00
.select--pill.select--medium .select__control {
2021-07-10 00:45:44 +00:00
border-radius: var(--sl-input-height-medium);
}
2021-09-24 12:48:01 +00:00
.select--pill.select--large .select__control {
2021-07-10 00:45:44 +00:00
border-radius: var(--sl-input-height-large);
}
`;