mirror of
https://github.com/StarCitizenTools/mediawiki-skins-Citizen.git
synced 2025-01-22 10:34:36 +00:00
76a39eafdf
Dropdown + Menu component are already doing the same thing. We can just extend those and drop all the custom handling
156 lines
3.7 KiB
Plaintext
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;
|
|
}
|
|
}
|