mediawiki-skins-MinervaNeue/skinStyles/mediawiki.ui.icon/mediawiki.ui.icon.less

154 lines
3.6 KiB
Plaintext
Raw Normal View History

/**
* Redefinition of the mw-ui-icon class from MediaWiki-core.
*
* This module attempts to maintain compatibility with the
* core mw-ui-icon module, while adding more mobile-friendly
* features like increased touch-area sizes and highlights.
*
* - mw-ui-icon = base class. 20px square with icon.
* - mw-ui-icon + mw-ui-icon-element = icon with padding & pseudo-states.
* - mw-ui-icon + mw-ui-icon-small = small icon with padding & pseudo-states.
* - mw-ui-icon + mw-ui-icon-flush-left = negative right-margin.
* - mw-ui-icon + mw-ui-icon-flush-right = negative left-margin.
* - mw-ui-icon + mw-ui-icon-before = *deprecated*, icon with text.
* Labels should be placed in a separate element beside the icon.
*
*/
@import '../../minerva.less/minerva.variables.less';
/**
* Mixin for a pseudo-element with a background image.
*/
.mixin-background-square() {
// sizing
content: '';
display: block;
width: 100%;
height: 100%;
// background
background-repeat: no-repeat;
background-size: contain;
background-position: center;
}
/**
* A standalone 20px square with screen-reader text. Contains a :before element
* to house the icon as a background image. Total size is increased with padding via
* `box-sizing: content-box`. This separates control over size of icon vs the size of
* the touch-area.
*/
.mw-ui-icon {
// reset font-size so the "em" value is relative to the more
// predictable rem font size ...and no rems because we can't have nice things.
font-size: initial;
// sizing
position: relative;
display: inline-block;
// this is important for increasing the size via padding. Overrides `.view-border-box *`.
box-sizing: content-box !important;
width: @icon-size-md;
height: @icon-size-md;
// alignment
vertical-align: middle;
line-height: 0;
overflow: hidden;
// resetting styles for <button> elements
-moz-appearance: none;
-webkit-appearance: none;
background-color: transparent;
border: 0;
margin: 0;
padding: 0;
&:before {
.mixin-background-square();
}
}
/**
* When aligning a series of similar icons (e.g. list items)
* prefer using a `:first-child` or `:last-child` selector.
* The flush-left/right classes are appropriate when that's unavailable.
*/
.mw-ui-icon-flush-top {
margin-top: -@icon-padding-md;
}
.mw-ui-icon-flush-left {
margin-left: -@icon-padding-md;
}
.mw-ui-icon-flush-right {
margin-right: -@icon-padding-md;
}
.mw-ui-icon-element {
padding: @icon-padding-md;
border-radius: @borderRadius;
// screen-reader text. Not using `text-indent: -999px` because
// the inner :before element is `display: block` so text-indent has no effect.
line-height: 999px;
color: transparent;
&:focus, &:active, &:visited {
color: transparent;
}
&:hover {
background-color: rgba( 0, 0, 0, 0.03 );
}
}
.mw-ui-icon-small {
width: @icon-size-sm;
height: @icon-size-sm;
line-height: @icon-size-sm;
}
.mw-ui-icon-small.mw-ui-icon-element {
padding: @icon-padding-sm;
}
.mw-ui-icon-small.mw-ui-icon-flush-left {
margin-left: -@icon-padding-sm;
}
.mw-ui-icon-small.mw-ui-icon-flush-right {
margin-right: -@icon-padding-sm;
}
.mw-ui-icon-small.mw-ui-icon-before:before {
min-width: @icon-size-sm;
min-height: @icon-size-sm;
margin-right: @icon-padding-sm;
}
.mw-ui-icon-before {
width: auto;
max-width: 100%;
&:before {
.mixin-background-square();
// sizing
display: inline-block;
font-size: initial;
width: auto;
min-width: @icon-size-md;
min-height: @icon-size-md;
// alignment. Margin is added to separate accompanying text.
margin-right: @icon-padding-md;
vertical-align: middle;
}
span {
vertical-align: middle;
}
}