mirror of
https://github.com/StarCitizenTools/mediawiki-skins-Citizen.git
synced 2025-01-10 04:04:58 +00:00
6de95d4fec
Change header into vertical header for large screen and bottom header for small screen.
160 lines
3.1 KiB
Plaintext
160 lines
3.1 KiB
Plaintext
.citizen-header {
|
|
--header-icon-size: ~'calc( var( --header-button-size ) / 2 )';
|
|
--header-button-size: ~'calc( var( --header-size ) - var( --space-sm ) * 2 )';
|
|
--header-direction: row;
|
|
position: fixed;
|
|
z-index: @z-index-site-header;
|
|
right: 0;
|
|
bottom: 0;
|
|
left: 0;
|
|
display: flex;
|
|
flex-direction: var( --header-direction );
|
|
padding: var( --space-sm );
|
|
border-top: 1px solid var( --border-color-base );
|
|
background-color: var( --color-surface-0 );
|
|
gap: var( --space-xs );
|
|
|
|
&__item {
|
|
display: flex;
|
|
align-items: center;
|
|
}
|
|
|
|
&__button {
|
|
display: grid;
|
|
width: var( --header-button-size );
|
|
height: var( --header-button-size );
|
|
border-radius: var( --border-radius--small );
|
|
place-items: center;
|
|
|
|
// Used in checkbox hack
|
|
&Checkbox {
|
|
position: absolute;
|
|
display: block;
|
|
width: inherit;
|
|
height: inherit;
|
|
}
|
|
|
|
// Pure CSS icons
|
|
&Icon {
|
|
overflow: hidden; // Sometimes CSS animation can clip
|
|
width: var( --header-icon-size );
|
|
height: var( --header-icon-size );
|
|
}
|
|
|
|
// Background image icons
|
|
&--icon:after {
|
|
width: var( --header-icon-size );
|
|
height: var( --header-icon-size );
|
|
background-position: center;
|
|
background-repeat: no-repeat;
|
|
background-size: contain;
|
|
content: '';
|
|
}
|
|
|
|
&Icon,
|
|
&--icon:after {
|
|
opacity: var( --opacity-icon-base );
|
|
transition: @transition-transform, @transition-opacity;
|
|
}
|
|
|
|
&:hover {
|
|
background-color: var( --background-color-quiet--hover );
|
|
|
|
.citizen-header__buttonIcon,
|
|
&.citizen-header__button--icon:after {
|
|
opacity: var( --opacity-icon-base--hover );
|
|
}
|
|
}
|
|
|
|
&:active {
|
|
background-color: var( --background-color-quiet--active );
|
|
|
|
.citizen-header__buttonIcon,
|
|
&.citizen-header__button--icon:after {
|
|
opacity: var( --opacity-icon-base--active );
|
|
}
|
|
}
|
|
}
|
|
|
|
&__inner {
|
|
z-index: -1; // Inner element should be behind menu and search
|
|
display: flex;
|
|
min-width: 0;
|
|
flex-direction: var( --header-direction );
|
|
flex-grow: 1;
|
|
justify-content: space-between;
|
|
gap: var( --space-xs );
|
|
|
|
.mw-checkbox-hack-checkbox:checked {
|
|
~ .citizen-header__button {
|
|
background-color: var( --background-color-primary--active );
|
|
}
|
|
}
|
|
}
|
|
|
|
&__start,
|
|
&__end {
|
|
display: flex;
|
|
flex-direction: var( --header-direction );
|
|
gap: var( --space-xs );
|
|
}
|
|
|
|
&__start {
|
|
min-width: 0;
|
|
align-items: center;
|
|
}
|
|
|
|
// Reset
|
|
ul {
|
|
margin: 0;
|
|
list-style: none;
|
|
}
|
|
}
|
|
|
|
.skin-citizen-dark {
|
|
.citizen-header__button {
|
|
&Icon,
|
|
&--icon:after {
|
|
filter: invert( 1 );
|
|
}
|
|
}
|
|
}
|
|
|
|
// Notifications
|
|
#p-notifications {
|
|
ul {
|
|
display: flex;
|
|
flex-direction: var( --header-direction );
|
|
align-items: center;
|
|
gap: var( --space-xs );
|
|
}
|
|
}
|
|
|
|
// Reset hover styles if it is a touch device
|
|
// This is dumb but hover:hover overrides active states
|
|
@media ( hover: none ) {
|
|
.citizen-header {
|
|
&__button {
|
|
&:hover {
|
|
background-color: none;
|
|
|
|
.citizen-header__buttonIcon,
|
|
&.citizen-header__button--icon:after {
|
|
opacity: var( --opacity-icon-base );
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
@media ( min-width: @width-breakpoint-desktop ) {
|
|
.citizen-header {
|
|
--header-direction: column;
|
|
top: 0;
|
|
right: unset;
|
|
left: 0;
|
|
border-top: 0;
|
|
border-right: 1px solid var( --border-color-base );
|
|
}
|
|
}
|