mirror of
https://github.com/squidfunk/mkdocs-material.git
synced 2025-01-11 13:42:14 +01:00
395 lines
10 KiB
SCSS
395 lines
10 KiB
SCSS
////
|
|
/// Copyright (c) 2016-2020 Martin Donath <martin.donath@squidfunk.com>
|
|
///
|
|
/// Permission is hereby granted, free of charge, to any person obtaining a
|
|
/// copy of this software and associated documentation files (the "Software"),
|
|
/// to deal in the Software without restriction, including without limitation
|
|
/// the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
|
/// and/or sell copies of the Software, and to permit persons to whom the
|
|
/// Software is furnished to do so, subject to the following conditions:
|
|
///
|
|
/// The above copyright notice and this permission notice shall be included in
|
|
/// all copies or substantial portions of the Software.
|
|
///
|
|
/// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
/// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
/// FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO EVENT SHALL
|
|
/// THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
/// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
|
/// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
|
/// DEALINGS
|
|
////
|
|
|
|
// ----------------------------------------------------------------------------
|
|
// Dependencies
|
|
// ----------------------------------------------------------------------------
|
|
|
|
@import "modularscale";
|
|
@import "material-color";
|
|
@import "material-shadows";
|
|
|
|
// ----------------------------------------------------------------------------
|
|
// Local imports
|
|
// ----------------------------------------------------------------------------
|
|
|
|
@import "utilities/break";
|
|
@import "utilities/px2em";
|
|
|
|
@import "config";
|
|
|
|
// ----------------------------------------------------------------------------
|
|
// Rules: button styles
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// Color tile for presentation in theme documentation
|
|
button[data-md-color-primary],
|
|
button[data-md-color-accent] {
|
|
width: px2rem(130px);
|
|
margin-bottom: px2rem(4px);
|
|
padding: px2rem(24px) px2rem(8px) px2rem(4px);
|
|
transition:
|
|
background-color 0.25s,
|
|
opacity 0.25s;
|
|
border-radius: px2rem(2px);
|
|
color: $md-color-white;
|
|
font-size: ms(-1);
|
|
text-align: left;
|
|
cursor: pointer;
|
|
|
|
// Hovered color tile
|
|
&:hover {
|
|
opacity: 0.75;
|
|
}
|
|
}
|
|
|
|
// ----------------------------------------------------------------------------
|
|
// Rules: primary colors
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// Build primary colors
|
|
@each $name, $color in (
|
|
"red": $clr-red-400,
|
|
"pink": $clr-pink-500,
|
|
"purple": $clr-purple-400,
|
|
"deep-purple": $clr-deep-purple-400,
|
|
"indigo": $clr-indigo-500,
|
|
"blue": $clr-blue-500,
|
|
"light-blue": $clr-light-blue-500,
|
|
"cyan": $clr-cyan-500,
|
|
"teal": $clr-teal-500,
|
|
"green": $clr-green-500,
|
|
"light-green": $clr-light-green-600,
|
|
"lime": $clr-lime-600,
|
|
"yellow": $clr-yellow-800,
|
|
"amber": $clr-amber-700,
|
|
"orange": $clr-orange-600,
|
|
"deep-orange": $clr-deep-orange-400,
|
|
"brown": $clr-brown-500,
|
|
"grey": $clr-grey-600,
|
|
"blue-grey": $clr-blue-grey-600
|
|
) {
|
|
|
|
// Color tile for presentation in theme documentation
|
|
button[data-md-color-primary="#{$name}"] {
|
|
background-color: $color;
|
|
}
|
|
|
|
// Color palette
|
|
[data-md-color-primary="#{$name}"] {
|
|
|
|
// Links in typesetted content
|
|
.md-typeset a {
|
|
color: $color;
|
|
}
|
|
|
|
// Application header (stays always on top)
|
|
.md-header {
|
|
background-color: $color;
|
|
}
|
|
|
|
// Hero teaser
|
|
.md-hero {
|
|
background-color: $color;
|
|
}
|
|
|
|
// Current or active link
|
|
.md-nav__link:active,
|
|
.md-nav__link--active {
|
|
color: $color;
|
|
}
|
|
|
|
// Reset active color for nested list titles
|
|
.md-nav__item--nested > .md-nav__link {
|
|
color: inherit;
|
|
}
|
|
|
|
// [tablet portrait -]: Layered navigation
|
|
@include break-to-device(tablet portrait) {
|
|
|
|
// Repository containing source
|
|
.md-nav__source {
|
|
background-color: mix($color, $md-color-black, 75%);
|
|
}
|
|
}
|
|
|
|
// [tablet -]: Layered navigation
|
|
@include break-to-device(tablet) {
|
|
|
|
// Site title in main navigation
|
|
html & .md-nav--primary .md-nav__title--site {
|
|
background-color: $color;
|
|
}
|
|
}
|
|
|
|
// [screen +]: Set background color for tabs
|
|
@include break-from-device(screen) {
|
|
|
|
// Tabs with outline
|
|
.md-tabs {
|
|
background-color: $color;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
// ----------------------------------------------------------------------------
|
|
// Rules: white
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// Color tile for presentation in theme documentation
|
|
button[data-md-color-primary="white"] {
|
|
background-color: $md-color-white;
|
|
color: $md-color-black;
|
|
box-shadow: 0 0 px2rem(1px) $md-color-black--light inset;
|
|
}
|
|
|
|
// Overrides for black color
|
|
[data-md-color-primary="white"] {
|
|
|
|
// Application header (stays always on top)
|
|
.md-header {
|
|
background-color: $md-color-white;
|
|
color: $md-color-black;
|
|
}
|
|
|
|
// Hero teaser
|
|
.md-hero {
|
|
background-color: $md-color-white;
|
|
color: $md-color-black;
|
|
|
|
// Add a border if there are no tabs
|
|
&--expand {
|
|
border-bottom: px2rem(1px) solid $md-color-black--lightest;
|
|
}
|
|
}
|
|
|
|
// [tablet portrait -]: Layered navigation
|
|
@include break-to-device(tablet portrait) {
|
|
|
|
// Repository containing source
|
|
.md-nav__source {
|
|
background-color: $md-color-black--lightest;
|
|
color: $md-color-black;
|
|
}
|
|
}
|
|
|
|
// [tablet portrait +]: Change color of search input
|
|
@include break-from-device(tablet landscape) {
|
|
|
|
// Search input
|
|
.md-search__input {
|
|
background-color: $md-color-black--lightest;
|
|
|
|
// Search input placeholder
|
|
&::placeholder {
|
|
color: $md-color-black--light;
|
|
}
|
|
}
|
|
}
|
|
|
|
// [tablet -]: Layered navigation
|
|
@include break-to-device(tablet) {
|
|
|
|
// Site title in main navigation
|
|
html & .md-nav--primary .md-nav__title--site {
|
|
background-color: $md-color-white;
|
|
color: $md-color-black;
|
|
}
|
|
|
|
// Hero teaser
|
|
.md-hero {
|
|
border-bottom: px2rem(1px) solid $md-color-black--lightest;
|
|
}
|
|
}
|
|
|
|
// [screen +]: Set background color for tabs
|
|
@include break-from-device(screen) {
|
|
|
|
// Tabs with outline
|
|
.md-tabs {
|
|
border-bottom: px2rem(1px) solid $md-color-black--lightest;
|
|
background-color: $md-color-white;
|
|
color: $md-color-black;
|
|
}
|
|
}
|
|
}
|
|
|
|
// ----------------------------------------------------------------------------
|
|
// Rules: black
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// Color tile for presentation in theme documentation
|
|
button[data-md-color-primary="black"] {
|
|
background-color: $clr-black;
|
|
}
|
|
|
|
// Color palette
|
|
[data-md-color-primary="black"] {
|
|
|
|
// Application header (stays always on top)
|
|
.md-header {
|
|
background-color: $clr-black;
|
|
}
|
|
|
|
// Hero teaser
|
|
.md-hero {
|
|
background-color: $clr-black;
|
|
}
|
|
|
|
// [tablet portrait -]: Layered navigation
|
|
@include break-to-device(tablet portrait) {
|
|
|
|
// Repository containing source
|
|
.md-nav__source {
|
|
background-color: mix($clr-black, $md-color-white, 75%);
|
|
}
|
|
}
|
|
|
|
// [tablet landscape +]: Header-embedded search
|
|
@include break-from-device(tablet landscape) {
|
|
|
|
// Search input
|
|
.md-search__input {
|
|
background-color: $md-color-white--lighter;
|
|
}
|
|
}
|
|
|
|
// [tablet -]: Layered navigation
|
|
@include break-to-device(tablet) {
|
|
|
|
// Site title in main navigation
|
|
html & .md-nav--primary .md-nav__title--site {
|
|
background-color: $clr-black;
|
|
}
|
|
}
|
|
|
|
// [screen +]: Set background color for tabs
|
|
@include break-from-device(screen) {
|
|
|
|
// Tabs with outline
|
|
.md-tabs {
|
|
background-color: $clr-black;
|
|
}
|
|
}
|
|
}
|
|
|
|
// ----------------------------------------------------------------------------
|
|
// Rules: accent colors
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// Build accent colors
|
|
@each $name, $color in (
|
|
"red": $clr-red-a400,
|
|
"pink": $clr-pink-a400,
|
|
"purple": $clr-purple-a200,
|
|
"deep-purple": $clr-deep-purple-a200,
|
|
"indigo": $clr-indigo-a200,
|
|
"blue": $clr-blue-a200,
|
|
"light-blue": $clr-light-blue-a700,
|
|
"cyan": $clr-cyan-a700,
|
|
"teal": $clr-teal-a700,
|
|
"green": $clr-green-a700,
|
|
"light-green": $clr-light-green-a700,
|
|
"lime": $clr-lime-a700,
|
|
"yellow": $clr-yellow-a700,
|
|
"amber": $clr-amber-a700,
|
|
"orange": $clr-orange-a400,
|
|
"deep-orange": $clr-deep-orange-a200
|
|
) {
|
|
|
|
// Color tile for presentation in theme documentation
|
|
button[data-md-color-accent="#{$name}"] {
|
|
background-color: $color;
|
|
}
|
|
|
|
// Color palette
|
|
[data-md-color-accent="#{$name}"] {
|
|
|
|
// Typesetted content
|
|
.md-typeset {
|
|
|
|
// Hovered and active links
|
|
a:hover,
|
|
a:active {
|
|
color: $color;
|
|
}
|
|
|
|
// Hovered scrollbar thumb
|
|
pre code::-webkit-scrollbar-thumb:hover,
|
|
.codehilite pre::-webkit-scrollbar-thumb:hover {
|
|
background-color: $color;
|
|
}
|
|
|
|
// Copy to clipboard active icon
|
|
.md-clipboard:hover::before,
|
|
.md-clipboard:active::before {
|
|
color: $color;
|
|
}
|
|
|
|
// Active or targeted back reference
|
|
.footnote li:hover .footnote-backref:hover,
|
|
.footnote li:target .footnote-backref {
|
|
color: $color;
|
|
}
|
|
|
|
// Active, targeted or focused permalink
|
|
[id]:hover .headerlink:hover,
|
|
[id]:target .headerlink,
|
|
[id] .headerlink:focus {
|
|
color: $color;
|
|
}
|
|
}
|
|
|
|
// Focused or hovered link
|
|
.md-nav__link:focus,
|
|
.md-nav__link:hover {
|
|
color: $color;
|
|
}
|
|
|
|
// Search container scrollbar thumb
|
|
.md-search__scrollwrap::-webkit-scrollbar-thumb:hover {
|
|
background-color: $color;
|
|
}
|
|
|
|
// Search result link
|
|
.md-search-result__link {
|
|
|
|
// Active or hovered link
|
|
&[data-md-state="active"],
|
|
&:hover {
|
|
background-color: transparentize($color, 0.9);
|
|
}
|
|
}
|
|
|
|
// Wrapper for scrolling on overflow
|
|
.md-sidebar__scrollwrap::-webkit-scrollbar-thumb:hover {
|
|
background-color: $color;
|
|
}
|
|
|
|
// Source file icon
|
|
.md-source-file:hover::before {
|
|
background-color: $color;
|
|
}
|
|
}
|
|
}
|