Files
webawesome/source/css/dropdowns.css

118 lines
3.1 KiB
CSS
Raw Normal View History

2017-08-04 10:06:03 -04:00
/*! Dropdowns */
2017-08-13 15:41:38 -04:00
: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);
2017-08-22 16:53:35 -04:00
--dropdown-box-shadow: var(--component-box-shadow-outer);
2017-08-17 10:49:56 -04:00
--dropdown-divider-color: var(--component-border-color);
--dropdown-divider-width: var(--component-border-width);
2017-08-13 16:51:58 -04:00
--dropdown-padding-x: 1rem;
--dropdown-padding-y: .25rem;
2017-08-17 10:49:56 -04:00
--dropdown-offset-x: 0;
--dropdown-offset-y: 1px;
2017-08-13 15:41:38 -04:00
--dropdown-z-index: 100;
}
2017-08-04 10:06:03 -04:00
.dropdown {
position: relative;
display: inline-block;
2017-08-17 10:49:56 -04:00
/* 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;
}
2017-08-04 10:06:03 -04:00
2017-08-17 10:49:56 -04:00
&.dropdown-top .dropdown-trigger::after {
transform: scaleY(.75) rotate(180deg);
}
2017-08-04 10:06:03 -04:00
2017-08-17 10:49:56 -04:00
/* 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);
2017-08-04 10:06:03 -04:00
2017-08-17 10:49:56 -04:00
& 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;
2017-08-04 10:06:03 -04:00
2017-08-17 10:55:29 -04:00
&:focus:not(.disabled) {
outline: none;
color: var(--dropdown-color);
background-color: color(var(--dropdown-bg-color) shade(5%));
}
2017-08-17 10:49:56 -04:00
&:hover:not(.disabled) {
color: var(--dropdown-color-hover);
background-color: var(--dropdown-bg-color-hover);
}
2017-08-04 10:06:03 -04:00
2017-08-17 10:49:56 -04:00
&.disabled {
2017-08-17 10:55:29 -04:00
outline: none;
2017-08-17 10:49:56 -04:00
cursor: not-allowed;
opacity: .5;
}
2017-08-04 10:06:03 -04:00
2017-08-17 10:49:56 -04:00
&.checked::before {
position: absolute;
left: calc(var(--dropdown-padding-x) / 2 - .1em);
content: '✓';
font-family: var(--font-system);
font-weight: 600;
}
}
2017-08-04 10:06:03 -04:00
2017-08-17 10:49:56 -04:00
& hr {
width: 100%;
border-top: solid var(--dropdown-divider-width) var(--dropdown-divider-color);
margin: var(--dropdown-padding-y) 0;
}
}
2017-08-04 10:06:03 -04:00
2017-08-17 10:49:56 -04:00
&.dropdown-top .dropdown-menu {
top: auto;
bottom: calc(100% + var(--dropdown-offset-y));
}
2017-08-04 10:06:03 -04:00
2017-08-17 10:49:56 -04:00
&.dropdown-left .dropdown-menu {
left: auto;
right: var(--dropdown-offset-x);
}
2017-08-04 10:06:03 -04:00
2017-08-17 10:49:56 -04:00
&.dropdown.active .dropdown-menu {
display: block;
}
2017-08-04 10:06:03 -04:00
}