Files
webawesome/source/css/dropdowns.css
2017-08-22 16:53:35 -04:00

118 lines
3.1 KiB
CSS

/*! Dropdowns */
:root {
--dropdown-min-width: 10rem;
--dropdown-max-width: 25rem;
--dropdown-max-height: none;
--dropdown-border-color: var(--component-border-color);
--dropdown-border-radius: var(--component-border-radius);
--dropdown-border-width: var(--component-border-width);
--dropdown-color: var(--body-color);
--dropdown-color-hover: var(--color-white);
--dropdown-bg-color: var(--color-white);
--dropdown-bg-color-hover: var(--state-primary);
--dropdown-box-shadow: var(--component-box-shadow-outer);
--dropdown-divider-color: var(--component-border-color);
--dropdown-divider-width: var(--component-border-width);
--dropdown-padding-x: 1rem;
--dropdown-padding-y: .25rem;
--dropdown-offset-x: 0;
--dropdown-offset-y: 1px;
--dropdown-z-index: 100;
}
.dropdown {
position: relative;
display: inline-block;
/* Trigger */
& .dropdown-trigger::after {
content: '▼';
font-family: var(--font-system);
font-size: .6em;
vertical-align: middle;
margin-left: .5em;
display: inline-block;
transform: scaleY(.75);
margin-top: -.2em;
}
&.dropdown-top .dropdown-trigger::after {
transform: scaleY(.75) rotate(180deg);
}
/* Menu */
& .dropdown-menu {
position: absolute;
top: calc(100% + var(--dropdown-offset-y));
left: var(--dropdown-offset-x);
z-index: var(--dropdown-z-index);
min-width: var(--dropdown-min-width);
max-width: var(--dropdown-max-width);
max-height: var(--dropdown-max-height);
background-color: var(--dropdown-bg-color);
border: solid var(--dropdown-border-width) var(--dropdown-border-color);
border-radius: var(--dropdown-border-radius);
box-shadow: var(--dropdown-box-shadow);
display: none;
padding: var(--dropdown-padding-y) 0;
overflow-y: auto;
transform: translateZ(0);
& a {
position: relative;
color: var(--dropdown-color);
text-decoration: none;
padding: var(--dropdown-padding-y) calc(var(--dropdown-padding-x) + .5em);
display: block;
white-space: nowrap;
overflow-x: hidden;
text-overflow: ellipsis;
&:focus:not(.disabled) {
outline: none;
color: var(--dropdown-color);
background-color: color(var(--dropdown-bg-color) shade(5%));
}
&:hover:not(.disabled) {
color: var(--dropdown-color-hover);
background-color: var(--dropdown-bg-color-hover);
}
&.disabled {
outline: none;
cursor: not-allowed;
opacity: .5;
}
&.checked::before {
position: absolute;
left: calc(var(--dropdown-padding-x) / 2 - .1em);
content: '✓';
font-family: var(--font-system);
font-weight: 600;
}
}
& hr {
width: 100%;
border-top: solid var(--dropdown-divider-width) var(--dropdown-divider-color);
margin: var(--dropdown-padding-y) 0;
}
}
&.dropdown-top .dropdown-menu {
top: auto;
bottom: calc(100% + var(--dropdown-offset-y));
}
&.dropdown-left .dropdown-menu {
left: auto;
right: var(--dropdown-offset-x);
}
&.dropdown.active .dropdown-menu {
display: block;
}
}