mediawiki-skins-Citizen/resources/skins.citizen.styles/components/Dropdown.less
alistair3149 76a39eafdf
perf(preferences): ️ rewrite to use dropdown component
Dropdown + Menu component are already doing the same thing.
We can just extend those and drop all the custom handling
2024-11-12 20:13:47 -05:00

156 lines
3.7 KiB
Plaintext

.citizen-dropdown {
.citizen-menu__card {
z-index: @z-index-dropdown;
content-visibility: hidden;
min-width: 16rem;
max-width: 80vw;
transition-timing-function: var( --transition-timing-function-ease-in );
transition-duration: var( --transition-duration-base );
transition-property: transform, content-visibility;
transition-behavior: allow-discrete;
> * {
opacity: 0;
transition-timing-function: var( --transition-timing-function-ease-in );
transition-duration: var( --transition-duration-base );
transition-property: opacity;
}
&:empty {
display: none;
}
.citizen-ui-icon {
content-visibility: hidden;
}
}
&-summary {
cursor: pointer;
// Icons have to use span inside label elements
> span:not( .citizen-ui-icon ) {
.sr-only;
}
&:hover {
background-color: var( --background-color-button-quiet--hover );
> .citizen-ui-icon::before {
opacity: var( --opacity-icon-base--hover );
}
}
&:active {
background-color: var( --background-color-button-quiet--active );
> .citizen-ui-icon::before {
opacity: var( --opacity-icon-base--selected );
}
}
// Remove Safari summary marker
&::-webkit-details-marker {
display: none;
}
// Reset hover styles if it is a touch device
// This is dumb but hover:hover overrides active states
@media ( hover: none ) {
&:hover {
background-color: transparent;
.citizen-ui-icon::before {
opacity: var( --opacity-icon-base );
}
}
}
}
&-details {
&[ open ] {
+ .citizen-menu__card {
content-visibility: visible;
transition-timing-function: var( --transition-timing-function-ease-out );
transition-duration: var( --transition-duration-medium );
transform: none;
> * {
opacity: 1;
transition-delay: var( --transition-delay-menu );
transition-timing-function: var( --transition-timing-function-ease-out );
transition-duration: var( --transition-duration-medium );
}
.citizen-ui-icon {
content-visibility: visible;
}
}
> .citizen-dropdown-summary {
background-color: var( --background-color-button-quiet--active );
&:hover {
background-color: var( --background-color-button-quiet--hover );
}
}
}
}
.citizen-header__end & .citizen-menu__card {
.citizen-header-card( end );
transform-origin: var( --transform-origin-offset-end ) var( --transform-origin-offset-end );
@media ( min-width: @min-width-breakpoint-desktop ) {
transform-origin: var( --transform-origin-offset-start ) var( --transform-origin-offset-end );
}
}
@media ( max-width: @max-width-breakpoint-tablet ) {
.citizen-menu__card {
max-width: ~'calc( 100vw - var( --space-xs ) * 2 )';
}
// Add dismiss affordnance backdrop
&-details {
&::before {
content: '';
background: var( --background-color-backdrop-light );
-webkit-backdrop-filter: blur( 2px );
backdrop-filter: blur( 2px );
opacity: 0;
transition-timing-function: var( --transition-timing-function-ease );
transition-duration: var( --transition-duration-base );
transition-property: opacity;
}
&[ open ] {
&::before {
position: fixed;
inset: 0;
z-index: @z-index-off-canvas-backdrop;
opacity: 1;
transition-duration: var( --transition-duration-medium );
}
> .citizen-dropdown-summary {
position: relative;
// Slightly higher than the menu so it is not covered by the box shadow
z-index: @z-index-off-canvas + @z-index-stacking-1;
}
+ .citizen-menu__card {
z-index: @z-index-off-canvas;
}
}
}
}
}
@media ( max-width: @max-width-breakpoint-tablet ) {
/* HACK: Disable page from scolling when a dropdown menu is opened */
body:has( .citizen-dropdown-details[ open ] ) {
overflow: hidden;
}
}