mediawiki-skins-Vector/resources/skins.vector.styles/components/TableOfContentsUnpinned.less
2023-01-12 11:45:13 -06:00

162 lines
4.6 KiB
Plaintext

@import '../../common/variables.less';
@import '../../common/mixins.less';
@selector-nojs-collapsed-toc-open: ~'#vector-toc-collapsed-checkbox:checked';
.vector-feature-page-tools-enabled .vector-unpinned-container .vector-toc {
// Adjust TOC spacing when unpinned
.vector-pinnable-header {
padding-left: @padding-horizontal-dropdown-menu-item + @spacing-subsection-toggle;
}
.vector-toc-contents {
padding-right: @padding-horizontal-dropdown-menu-item;
padding-left: @padding-horizontal-dropdown-menu-item + @spacing-subsection-toggle;
}
}
// TOC dropdown/button styles
#vector-toc-collapsed-button,
.vector-sticky-header-toc,
.vector-page-titlebar-toc {
display: none;
margin-right: 8px;
}
// TOC styles when unpinned
.mixin-toc-unpinned() {
display: block;
> .vector-menu-content {
// Override default dropdown max width
max-width: none;
}
// Shared unpinned TOC styles, applies across all unpinned cases (page titlebar, sticky header, floating)
// FIXME: Remove all .sidebar-toc selectors after I5b9228380f5c4674ef424d33127a5cb4010822da is in prod for 5 days
.sidebar-toc,
.vector-toc {
// T316056 Remove TOC menu fixed width and apply min/max-width
width: max-content;
min-width: 200px;
// Collapsed TOC should be smaller than 85% of the content container (51em) and 75vw
max-width: ~'min( 0.85 * @{max-width-content-container}, 75vw )'; // min( 51em, 75vw )
}
}
.vector-feature-page-tools-disabled .vector-unpinned-container .vector-toc {
box-sizing: content-box;
}
.client-js {
@media ( max-width: @max-width-tablet ) {
// Prevent layout shift from the TOC being in the sidebar before JS loads and
// moves the TOC into the page titlebar on small screens
// FIXME: Remove all .sidebar-toc selectors after I5b9228380f5c4674ef424d33127a5cb4010822da is in prod for 5 days
#vector-toc-pinned-container .sidebar-toc,
#vector-toc-pinned-container .vector-toc {
display: none;
}
// Hide pin ToC toggles on smaller resolution
// FIXME: Remove all .sidebar-toc selectors after I5b9228380f5c4674ef424d33127a5cb4010822da is in prod for 5 days
.sidebar-toc .vector-pinnable-header-toggle-button,
.vector-toc .vector-pinnable-header-toggle-button {
display: none;
}
//
// TOC in page titlebar on narrow screens
//
.vector-page-titlebar-toc {
.mixin-toc-unpinned();
}
//
// TOC floating on narrow screens when below page title
//
.vector-below-page-title {
.vector-page-titlebar-toc {
position: fixed;
top: 0;
left: 0;
margin: 0;
// Override background color for when the TOC button overlaps content
// as a fixed element when the page is scrolled down.
background-color: @background-color-base;
z-index: @z-index-menu;
}
}
}
@media ( min-width: @min-width-desktop ) {
//
// TOC in page titlebar
//
.vector-toc-unpinned:not( .vector-sticky-header-visible ) {
.vector-page-titlebar-toc {
.mixin-toc-unpinned();
}
}
//
// TOC in sticky header
//
.vector-toc-unpinned.vector-sticky-header-visible {
.vector-sticky-header-toc {
.mixin-toc-unpinned();
}
}
}
}
//
// No-js TOC
//
@media ( max-width: @max-width-tablet ) {
.client-nojs {
#vector-toc-collapsed-button {
display: block;
// Override the default button styles so the ToC button is slightly shorter when collapsed into the page title
padding: 7px 12px;
&:hover,
&:active {
background-color: @colorGray15;
}
}
#vector-toc-pinned-container {
// Override TOC container's sticky positioning
position: relative;
.mixin-toc-unpinned();
}
// FIXME: Remove all .sidebar-toc selectors after I5b9228380f5c4674ef424d33127a5cb4010822da is in prod for 5 days
.sidebar-toc,
.vector-toc {
display: none;
position: absolute;
top: 36px; // TOC button height
// FIXME: Don't use a magic number. This used to be tied to the private variable in core
// @icon-padding-md so perhaps this needs to make use of the flush classes?
left: -12px;
margin-top: @padding-top-content; // Account for padding-top from .mw-body
// FIXME: Collapsed TOC styles are not consistent with other vector dropdowns
border: @border-width-base @border-style-base @border-color-base;
z-index: @z-index-menu;
}
.vector-feature-page-tools-enabled .vector-toc {
padding-left: @padding-horizontal-dropdown-menu-item;
}
// FIXME: Remove all .sidebar-toc selectors after I5b9228380f5c4674ef424d33127a5cb4010822da is in prod for 5 days
@{selector-nojs-collapsed-toc-open} ~ .mw-table-of-contents-container .sidebar-toc,
@{selector-nojs-collapsed-toc-open} ~ .mw-table-of-contents-container .vector-toc {
// Hide the TOC when the button is not checked
display: block;
}
}
}