/** * Minerva CSS Custom properties * ---------------------------- * Please be aware that these properties are accessible via *any* client-side code. * These variables should mirror Codex design token names and values: * https://doc.wikimedia.org/codex/latest/design-tokens * Only include properties that are required for client-side modification. * * @private - Currently, these variables are only intended for use by Minerva, * however, they are designed to mimic the naming convention in Codex tokens * in order to facilitate an eventual migration to a centralized source. * @experimental * @since February 2024 (MediaWiki 1.43) */ @import 'mediawiki.skin.variables.less'; @import 'mediawiki.skin.codex-design-tokens/theme-wikimedia-ui-mixin-dark.less'; @import 'mediawiki.skin.codex-design-tokens/theme-wikimedia-ui-reset.less'; /** * Placeholder Night mode color palette. * NOTE: These values are temporarily hard coded. */ .mixin-night-mode-palette() { .cdx-mode-dark(); } /** * == Night-mode helpers == * The following classes are provided to help third-parties deal with night mode when using the * CSS color variables is not feasible. * * .skin-invert - This class implements an inverted night-mode effect on applied elements using * a CSS filter instead of CSS custom properties. For this effect to work, the light mode palette * has to be applied to avoid inverting night-mode colors. * * .notheme - This class prevents night mode from being applied to a specific element. It needs the * the light mode color palette, and includes an opinionated color: @color-base; rule * since the main assumption underlying the light theme is black text. */ /** * Light mode * * Applies the light mode color palette by default * or with the .skin-invert, or .notheme classes */ :root, .skin-invert, .notheme { .cdx-mode-reset(); } .skin-invert, .notheme { color-scheme: light; color: @color-base; } /** * == Forced night mode == * Applies the night mode color palette per the users explicit preference, * regardless of system settings. */ @media screen { html.skin-theme-clientpref-night { color-scheme: dark; .mixin-night-mode-palette(); .skin-invert, .skin-invert-image img, /* Special treatment of inverted OOUI icons, see T365764 */ .oo-ui-iconElement-icon:not( .oo-ui-image-progressive ):not( .oo-ui-image-destructive ):not( .oo-ui-checkboxInputWidget-checkIcon ):not( .oo-ui-image-invert ):not( .mw-no-invert ), .oo-ui-indicatorElement-indicator { filter: invert( 1 ) hue-rotate( 180deg ); } /* Do not apply invert to elements that are inside a notheme or a skin-invert class to avoid inversion in light theme or double inversion in an already inverted element */ .skin-invert, .notheme { .oo-ui-iconElement-icon:not( .oo-ui-image-progressive ):not( .oo-ui-image-destructive ):not( .oo-ui-checkboxInputWidget-checkIcon ):not( .oo-ui-image-invert ):not( .mw-no-invert ), .oo-ui-indicatorElement-indicator { filter: none !important; } } } } /** * == Auto night mode == * Applies the night mode color palette only in response to system settings. */ @media screen and ( prefers-color-scheme: dark ) { html.skin-theme-clientpref-os { color-scheme: light dark; .mixin-night-mode-palette(); .skin-invert, .skin-invert-image img, .oo-ui-iconElement-icon:not( .oo-ui-image-progressive ):not( .oo-ui-image-destructive ):not( .oo-ui-checkboxInputWidget-checkIcon ), .oo-ui-indicatorElement-indicator { filter: invert( 1 ) hue-rotate( 180deg ); } /* Do not apply invert to elements that are inside a notheme or a skin-invert class to avoid inversion in light theme or double inversion in an already inverted element */ .skin-invert, .notheme { .oo-ui-iconElement-icon:not( .oo-ui-image-progressive ):not( .oo-ui-image-destructive ):not( .oo-ui-checkboxInputWidget-checkIcon ), .oo-ui-indicatorElement-indicator { filter: none !important; } } } }