material-design-lite/src/layout/_layout.scss

653 lines
15 KiB
SCSS

/**
* Copyright 2015 Google Inc. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
@import "../variables";
@import "../mixins";
// Navigation classes. Only used here for now, but we may at some point move
// this to its own component.
.mdl-navigation {
display: flex;
flex-wrap: nowrap;
box-sizing: border-box;
}
.mdl-navigation__link {
color: $layout-text-color;
text-decoration: none;
font-weight: 500;
font-size: $layout-nav-link-font-size;
margin: 0;
// Align icons inside link with text
& .material-icons {
vertical-align: middle;
}
}
// Main layout class.
.mdl-layout {
width: 100%;
height: 100%;
display: flex;
flex-direction: column;
overflow-y: auto;
overflow-x: hidden;
position: relative;
-webkit-overflow-scrolling: touch;
}
// Utility classes for screen sizes.
.mdl-layout.is-small-screen .mdl-layout--large-screen-only {
display: none;
}
.mdl-layout:not(.is-small-screen) .mdl-layout--small-screen-only {
display: none;
}
.mdl-layout__container {
position: absolute;
width: 100%;
height: 100%;
}
// Optional utility classes for formatting special blocks in this component.
.mdl-layout__title,
.mdl-layout-title {
display: block;
position: relative;
@include typo-title();
font-weight: 400;
box-sizing: border-box;
}
.mdl-layout-spacer {
flex-grow: 1;
}
// Drawer.
.mdl-layout__drawer {
display: flex;
flex-direction: column;
flex-wrap: nowrap;
width: $layout-drawer-width;
height: 100%;
max-height: 100%;
position: absolute;
top: 0;
left: 0;
@include shadow-2dp();
box-sizing: border-box;
border-right: 1px solid $layout-drawer-border-color;
background: $layout-drawer-bg-color;
// Transform offscreen.
transform: translateX(-$layout-drawer-width - 10px);
transform-style: preserve-3d;
will-change: transform;
@include material-animation-default();
transition-property: transform;
color: $layout-text-color;
overflow: visible;
overflow-y: auto;
z-index: 5;
&.is-visible {
transform: translateX(0);
& ~ .mdl-layout__content.mdl-layout__content {
overflow: hidden;
}
}
& > * {
flex-shrink: 0;
}
& > .mdl-layout__title,
& > .mdl-layout-title {
line-height: $layout-desktop-header-height;
padding-left: $layout-header-desktop-indent;
@media screen and (max-width: $layout-screen-size-threshold) {
line-height: $layout-mobile-header-height;
padding-left: $layout-header-mobile-indent;
}
}
& .mdl-navigation {
flex-direction: column;
align-items: stretch;
padding-top: 16px;
& .mdl-navigation__link {
display: block;
flex-shrink: 0;
padding: 16px $layout-header-desktop-indent;
margin: 0;
color: $layout-drawer-navigation-color;
@media screen and (max-width: $layout-screen-size-threshold) {
padding: 16px $layout-header-mobile-indent;
}
&:hover {
background-color: $layout-nav-color;
}
&--current {
background-color: $layout-drawer-navigation-link-active-background;
color: $layout-drawer-navigation-link-active-color;
}
}
}
@media screen and (min-width: $layout-screen-size-threshold + 1px) {
.mdl-layout--fixed-drawer > & {
transform: translateX(0);
}
}
}
// Drawer button.
// TODO(sgomes): Replace with an icon button when we have that component.
.mdl-layout__drawer-button {
display: block;
position: absolute;
height: $layout-drawer-button-desktop-size;
width: $layout-drawer-button-desktop-size;
border: 0;
flex-shrink: 0;
overflow: hidden;
text-align: center;
cursor: pointer;
font-size: 26px;
line-height: $layout-drawer-button-desktop-size + 2;
font-family: Helvetica, Arial, sans-serif;
margin: 10px 12px;
top: 0;
left: 0;
color: $layout-header-text-color;
z-index: 4;
.mdl-layout__header & {
position: absolute;
color: $layout-header-text-color;
background-color: inherit;
@media screen and (max-width: $layout-screen-size-threshold) {
margin: 4px;
}
}
@media screen and (max-width: $layout-screen-size-threshold) {
margin: 4px;
color: rgba(0, 0, 0, 0.5);
}
@media screen and (min-width: $layout-screen-size-threshold + 1px) {
.mdl-layout--fixed-drawer > & {
display: none;
}
.mdl-layout--no-desktop-drawer-button & {
display: none;
}
}
.mdl-layout--no-drawer-button & {
display: none;
}
}
.mdl-layout__header {
display: flex;
flex-direction: column;
flex-wrap: nowrap;
justify-content: flex-start;
box-sizing: border-box;
flex-shrink: 0;
width: 100%;
margin: 0;
padding: 0;
border: none;
min-height: $layout-desktop-header-height;
max-height: 1000px;
z-index: 3;
background-color: $layout-header-bg-color;
color: $layout-header-text-color;
@include shadow-2dp();
@include material-animation-default();
transition-property: max-height, box-shadow;
@media screen and (max-width: $layout-screen-size-threshold) {
min-height: $layout-mobile-header-height;
}
.mdl-layout--fixed-drawer.is-upgraded:not(.is-small-screen) > & {
margin-left: $layout-drawer-width;
width: calc(100% - #{$layout-drawer-width});
}
@media screen and (min-width: $layout-screen-size-threshold + 1px) {
.mdl-layout--fixed-drawer > & {
.mdl-layout__header-row {
padding-left: 40px;
}
}
}
& > .mdl-layout-icon {
position: absolute;
left: $layout-header-desktop-indent;
top: ($layout-desktop-header-height - $layout-header-icon-size) / 2;
height: $layout-header-icon-size;
width: $layout-header-icon-size;
overflow: hidden;
z-index: 3;
display: block;
@media screen and (max-width: $layout-screen-size-threshold) {
left: $layout-header-mobile-indent;
top: ($layout-mobile-header-height - $layout-header-icon-size) / 2;
}
}
.mdl-layout.has-drawer & > .mdl-layout-icon {
display: none;
}
&.is-compact {
max-height: $layout-desktop-header-height;
@media screen and (max-width: $layout-screen-size-threshold) {
max-height: $layout-mobile-header-height;
}
}
&.is-compact.has-tabs {
height: $layout-desktop-header-height + $layout-tab-bar-height;
@media screen and (max-width: $layout-screen-size-threshold) {
min-height: $layout-mobile-header-height + $layout-tab-bar-height;
}
}
@media screen and (max-width: $layout-screen-size-threshold) {
& {
display: none;
}
.mdl-layout--fixed-header > & {
display: flex;
}
}
}
.mdl-layout__header--transparent.mdl-layout__header--transparent {
background-color: transparent;
box-shadow: none;
}
.mdl-layout__header--seamed {
box-shadow: none;
}
.mdl-layout__header--scroll {
box-shadow: none;
}
.mdl-layout__header--waterfall {
box-shadow: none;
overflow: hidden;
&.is-casting-shadow {
@include shadow-2dp();
}
}
.mdl-layout__header-row {
display: flex;
flex-direction: row;
flex-wrap: nowrap;
flex-shrink: 0;
box-sizing: border-box;
align-self: stretch;
align-items: center;
height: $layout-header-desktop-row-height;
margin: 0;
padding: 0 $layout-header-desktop-indent 0 $layout-header-desktop-baseline;
.mdl-layout--no-drawer-button & {
padding-left: $layout-header-desktop-indent;
}
@media screen and (min-width: $layout-screen-size-threshold + 1px) {
.mdl-layout--no-desktop-drawer-button & {
padding-left: $layout-header-desktop-indent;
}
}
@media screen and (max-width: $layout-screen-size-threshold) {
height: $layout-header-mobile-row-height;
padding: 0 $layout-header-mobile-indent 0 $layout-header-mobile-baseline;
.mdl-layout--no-drawer-button & {
padding-left: $layout-header-mobile-indent;
}
}
& > * {
flex-shrink: 0;
}
.mdl-layout__header--scroll & {
width: 100%;
}
& .mdl-navigation {
margin: 0;
padding: 0;
height: $layout-header-desktop-row-height;
flex-direction: row;
align-items: center;
@media screen and (max-width: $layout-screen-size-threshold) {
height: $layout-header-mobile-row-height;
}
}
& .mdl-navigation__link {
display: block;
color: $layout-header-text-color;
line-height: $layout-header-desktop-row-height;
padding: 0 24px;
@media screen and (max-width: $layout-screen-size-threshold) {
line-height: $layout-header-mobile-row-height;
padding: 0 $layout-header-mobile-indent;
}
}
}
// Obfuscator.
.mdl-layout__obfuscator {
background-color: transparent;
position: absolute;
top: 0;
left: 0;
height: 100%;
width: 100%;
z-index: 4;
visibility: hidden;
transition-property: background-color;
@include material-animation-default();
&.is-visible {
background-color: rgba(0, 0, 0, 0.5);
visibility: visible;
}
}
// Content.
.mdl-layout__content {
// Fix IE10 bug.
-ms-flex: 0 1 auto;
position: relative;
display: inline-block;
overflow-y: auto;
overflow-x: hidden;
flex-grow: 1;
z-index: 1;
-webkit-overflow-scrolling: touch;
.mdl-layout--fixed-drawer > & {
margin-left: $layout-drawer-width;
}
.mdl-layout__container.has-scrolling-header & {
overflow: visible;
}
@media screen and (max-width: $layout-screen-size-threshold) {
.mdl-layout--fixed-drawer > & {
margin-left: 0;
}
.mdl-layout__container.has-scrolling-header & {
overflow-y: auto;
overflow-x: hidden;
}
}
}
// Tabs.
.mdl-layout__tab-bar {
height: $layout-tab-bar-height * 2;
margin: 0;
width: calc(100% -
#{(($layout-header-desktop-baseline - $layout-tab-desktop-padding) * 2)});
padding: 0 0 0
($layout-header-desktop-baseline - $layout-tab-desktop-padding);
display: flex;
background-color: $layout-header-bg-color;
overflow-y: hidden;
overflow-x: scroll;
&::-webkit-scrollbar {
display: none;
}
.mdl-layout--no-drawer-button & {
padding-left: $layout-header-desktop-indent - $layout-tab-desktop-padding;
width: calc(100% -
#{(($layout-header-desktop-indent - $layout-tab-desktop-padding) * 2)});
}
@media screen and (min-width: $layout-screen-size-threshold + 1px) {
.mdl-layout--no-desktop-drawer-button & {
padding-left: $layout-header-desktop-indent - $layout-tab-desktop-padding;
width: calc(100% -
#{(($layout-header-desktop-indent - $layout-tab-desktop-padding) * 2)});
}
}
@media screen and (max-width: $layout-screen-size-threshold) {
width: calc(100% -
#{($layout-header-mobile-baseline - $layout-tab-mobile-padding)});
padding: 0 0 0
($layout-header-mobile-baseline - $layout-tab-mobile-padding);
.mdl-layout--no-drawer-button & {
width: calc(100% -
#{(($layout-header-mobile-indent - $layout-tab-mobile-padding) * 2)});
padding-left: $layout-header-mobile-indent - $layout-tab-mobile-padding;
}
}
.mdl-layout--fixed-tabs & {
padding: 0;
overflow: hidden;
width: 100%;
}
}
.mdl-layout__tab-bar-container {
position: relative;
height: $layout-tab-bar-height;
width: 100%;
border: none;
margin: 0;
z-index: 2;
flex-grow: 0;
flex-shrink: 0;
overflow: hidden;
.mdl-layout__container > & {
position: absolute;
top: 0;
left: 0;
}
}
.mdl-layout__tab-bar-button {
display: inline-block;
position: absolute;
top: 0;
height: $layout-tab-bar-height;
width: $layout-header-desktop-baseline - $layout-tab-desktop-padding;
z-index: 4;
text-align: center;
background-color: $layout-header-bg-color;
color: transparent;
cursor: pointer;
user-select: none;
.mdl-layout--no-desktop-drawer-button &,
.mdl-layout--no-drawer-button & {
width: $layout-header-desktop-indent - $layout-tab-desktop-padding;
& .material-icons {
position: relative;
left: ($layout-header-desktop-indent - $layout-tab-desktop-padding - 24px) / 2;
}
}
@media screen and (max-width: $layout-screen-size-threshold) {
display: none;
width: $layout-header-mobile-baseline - $layout-tab-mobile-padding;
}
.mdl-layout--fixed-tabs & {
display: none;
}
& .material-icons {
line-height: $layout-tab-bar-height;
}
&.is-active {
color: $layout-header-text-color;
}
}
.mdl-layout__tab-bar-left-button {
left: 0;
}
.mdl-layout__tab-bar-right-button {
right: 0;
}
.mdl-layout__tab {
margin: 0;
border: none;
padding: 0 $layout-tab-desktop-padding 0 $layout-tab-desktop-padding;
float: left;
position: relative;
display: block;
flex-grow: 0;
flex-shrink: 0;
text-decoration: none;
height: $layout-tab-bar-height;
line-height: $layout-tab-bar-height;
text-align: center;
font-weight: 500;
font-size: $layout-tab-font-size;
text-transform: uppercase;
color: $layout-header-tab-text-color;
overflow: hidden;
@media screen and (max-width: $layout-screen-size-threshold) {
padding: 0 $layout-tab-mobile-padding 0 $layout-tab-mobile-padding;
}
.mdl-layout--fixed-tabs & {
float: none;
flex-grow: 1;
padding: 0;
}
.mdl-layout.is-upgraded &.is-active {
color: $layout-header-text-color;
}
.mdl-layout.is-upgraded &.is-active::after {
height: $layout-tab-highlight-thickness;
width: 100%;
display: block;
content: " ";
bottom: 0;
left: 0;
position: absolute;
background: $layout-header-tab-highlight;
animation: border-expand 0.2s cubic-bezier(0.4, 0.0, 0.4, 1) 0.01s alternate forwards;
transition: all 1s cubic-bezier(0.4, 0.0, 1, 1);
}
& .mdl-layout__tab-ripple-container {
display: block;
position: absolute;
height: 100%;
width: 100%;
left: 0;
top: 0;
z-index: 1;
overflow: hidden;
& .mdl-ripple {
background-color: $layout-header-text-color;
}
}
}
.mdl-layout__tab-panel {
display: block;
.mdl-layout.is-upgraded & {
display: none;
}
.mdl-layout.is-upgraded &.is-active {
display: block;
}
}