mediawiki-skins-Citizen/skinStyles/lib/leaflet/leaflet.less

252 lines
5.6 KiB
Plaintext
Raw Normal View History

/*
* Citizen
*
* SkinStyles for Leaflet
* Shared by Extension:DataMaps, Extension:Kartographer, Extension:Maps, Extension:SemanticResultFormats
*
* Date: 2024-07-09
*/
/*
* Backported fixes
* @see https://github.com/Leaflet/Leaflet/blob/main/dist/leaflet.css
*/
.leaflet-container img.leaflet-tile {
/* See: https://bugs.chromium.org/p/chromium/issues/detail?id=600120 */
mix-blend-mode: plus-lighter;
}
/*
* Citizen modifications
*/
.leaflet-top .leaflet-control {
margin-top: var( --space-xs );
}
.leaflet-bottom .leaflet-control {
margin-bottom: var( --space-xs );
}
.leaflet-left .leaflet-control {
margin-left: var( --space-xs );
}
.leaflet-right .leaflet-control {
margin-right: var( --space-xs );
}
.leaflet-container {
font-family: var( --font-family-base );
font-size: var( --font-size-x-small );
line-height: var( --line-height );
background: var( --color-surface-3 ) !important; // Override inline styles
border-radius: var( --border-radius-medium );
a {
color: var( --color-link );
}
&.leaflet-active {
outline: var( --border-width-thick ) solid var( --color-progressive );
}
}
.leaflet-zoom-box {
border: 2px dotted var( --color-progressive );
// background: rgba(255,255,255,0.5);
}
.leaflet-bar {
// Give the bar background color and make buttons quiet
// We can't apply background styles directly to buttons because we need to invert the icon
background-color: var( --color-surface-1 );
border-radius: var( --border-radius-base );
a,
button {
// Increase button size to 32px to align with Codex
width: 32px;
height: 32px;
line-height: 32px;
color: var( --color-emphasized );
background-color: transparent;
border-bottom-color: var( --border-color-interactive );
&:hover {
color: var( --color-emphasized );
background-color: var( --background-color-quiet--hover );
border-bottom-color: var( --border-color-interactive );
}
&:active {
color: var( --color-emphasized );
background-color: var( --background-color-quiet--active );
}
&.leaflet-disabled {
color: var( --color-disabled );
background-color: var( --background-color-disabled );
}
}
}
.leaflet-control-layers {
background: var( --color-surface-1 );
border-radius: var( --border-radius-base );
/* Make layers easier to click */
label {
display: flex;
min-height: 32px;
padding: 0 var( --space-xs );
cursor: pointer;
user-select: none;
border-radius: var( --border-radius-base );
&:hover {
background: var( --background-color-quiet--hover );
}
&:has( input:checked ) {
background: var( --background-color-quiet--active );
}
/* Align leaflet controls */
>div {
display: flex;
gap: var( --space-xs );
align-items: center;
}
}
}
.leaflet-control-layers-expanded {
padding: var( --space-xs );
color: var( --color-base );
background: var( --color-surface-1 );
}
/* Already aligned with the flex rules above */
.leaflet-control-layers-selector {
position: static;
margin-top: 0;
}
.leaflet-control-layers-separator {
border-top-color: var( --border-color-base );
}
.leaflet-container .leaflet-control-attribution {
margin: 0;
background: var( --background-color-backdrop-light );
-webkit-backdrop-filter: saturate( 50% ) blur( 16px );
backdrop-filter: saturate( 50% ) blur( 16px );
border-top-left-radius: var( --border-radius-base );
}
.leaflet-control-attribution,
.leaflet-control-scale-line {
color: var( --color-subtle );
}
.leaflet-control-scale-line {
background: var( --background-color-backdrop-dark );
border-color: var( --border-color-interactive );
}
.leaflet-control-scale-line:not( :first-child ) {
border-top-color: var( --border-color-interactive );
}
.leaflet-control-scale-line:not( :first-child ):not( :last-child ) {
border-bottom-color: var( --border-color-interactive );
}
.leaflet-touch .leaflet-control-layers,
.leaflet-touch .leaflet-bar {
border: 0;
box-shadow: 0 1px 5px rgba( 0, 0, 0, 0.65 );
}
.leaflet-popup-content {
padding: var( --space-md );
margin: 0; // Switch to use padding instead like DataMaps does
font-size: var( --font-size-small );
line-height: var( --line-height-xx-small );
}
.leaflet-popup-content > b {
font-size: var( --font-size-medium );
color: var( --color-emphasized );
}
.leaflet-popup-content p {
margin: var( --space-md ) 0;
}
.leaflet-popup-content-wrapper {
border-radius: var( --border-radius-medium );
}
.leaflet-popup-content-wrapper,
.leaflet-popup-tip {
color: var( --color-base );
background: var( --color-surface-1 );
}
/* Make close button easier to click */
.leaflet-container a.leaflet-popup-close-button {
display: grid;
place-content: center;
width: 24px;
height: 24px;
padding: 0;
color: var( --color-base );
border-radius: var( --border-radius-medium );
&:hover {
color: var( --color-emphasized );
background-color: var( --background-color-quiet--hover );
}
}
.leaflet-popup-scrolled {
border-top-color: var( --border-color-base );
border-bottom-color: var( --border-color-base );
}
.leaflet-div-icon {
background: var( --color-surface-1 );
border-color: var( --border-color-base );
}
.leaflet-tooltip {
position: absolute;
padding: var( --space-xs );
color: var( --color-base );
background-color: var( --color-surface-1 );
border-color: var( --color-surface-1 );
border-radius: var( --border-radius-base );
}
.leaflet-tooltip-top::before {
border-top-color: var( --color-surface-1 );
}
.leaflet-tooltip-bottom::before {
border-bottom-color: var( --color-surface-1 );
}
.leaflet-tooltip-left::before {
border-left-color: var( --color-surface-1 );
}
.leaflet-tooltip-right::before {
border-right-color: var( --color-surface-1 );
}
/* Invert icons for dark mode */
.fullscreen-icon {
filter: var( --filter-invert );
}