// Foundation by ZURB // foundation.zurb.com // Licensed under MIT Open Source @import "global"; @import "type"; // Off Canvas Tab Bar Variables $include-html-off-canvas-classes: $include-html-classes !default; $tabbar-bg: $oil !default; $tabbar-height: rem-calc(45) !default; $tabbar-icon-width: $tabbar-height !default; $tabbar-line-height: $tabbar-height !default; $tabbar-color: $white !default; $tabbar-middle-padding: 0 rem-calc(10) !default; // Off Canvas Divider Styles $tabbar-left-section-border: solid 1px scale-color($tabbar-bg, $lightness: -50%) !default; $tabbar-right-section-border: $tabbar-left-section-border; // Off Canvas Tab Bar Headers $tabbar-header-color: $white !default; $tabbar-header-weight: $font-weight-bold !default; $tabbar-header-line-height: $tabbar-height !default; $tabbar-header-margin: 0 !default; // Off Canvas Menu Variables $off-canvas-width: rem-calc(250) !default; $off-canvas-bg: $oil !default; $off-canvas-bg-hover: scale-color($tabbar-bg, $lightness: -30%) !default; // Off Canvas Menu List Variables $off-canvas-label-padding: 0.3rem rem-calc(15) !default; $off-canvas-label-color: $aluminum !default; $off-canvas-label-text-transform: uppercase !default; $off-canvas-label-font-size: rem-calc(12) !default; $off-canvas-label-font-weight: $font-weight-bold !default; $off-canvas-label-bg: $tuatara !default; $off-canvas-label-border-top: 1px solid scale-color($off-canvas-label-bg, $lightness: 14%) !default; $off-canvas-label-border-bottom: none !default; $off-canvas-label-margin:0 !default; $off-canvas-link-padding: rem-calc(10, 15) !default; $off-canvas-link-color: rgba($white, 0.7) !default; $off-canvas-link-border-bottom: 1px solid scale-color($off-canvas-bg, $lightness: -25%) !default; $off-canvas-back-bg: #444 !default; $off-canvas-back-border-top: $off-canvas-label-border-top !default; $off-canvas-back-border-bottom: $off-canvas-label-border-bottom !default; $off-canvas-back-hover-bg: scale-color($off-canvas-back-bg, $lightness: -30%) !default; $off-canvas-back-hover-border-top: 1px solid scale-color($off-canvas-label-bg, $lightness: 14%) !default; $off-canvas-back-hover-border-bottom: none !default; // Off Canvas Menu Icon Variables $tabbar-menu-icon-color: $white !default; $tabbar-menu-icon-hover: scale-color($tabbar-menu-icon-color, $lightness: -30%) !default; $tabbar-menu-icon-text-indent: rem-calc(35) !default; $tabbar-menu-icon-width: $tabbar-icon-width !default; $tabbar-menu-icon-height: $tabbar-height !default; $tabbar-menu-icon-padding: 0 !default; $tabbar-hamburger-icon-width: rem-calc(16) !default; $tabbar-hamburger-icon-left: false !default; $tabbar-hamburger-icon-top: false !default; $tabbar-hamburger-icon-thickness: 1px !default; $tabbar-hamburger-icon-gap: 6px !default; // Off Canvas Back-Link Overlay $off-canvas-overlay-transition: background 300ms ease !default; $off-canvas-overlay-cursor: pointer !default; $off-canvas-overlay-box-shadow: -4px 0 4px rgba($black, 0.5), 4px 0 4px rgba($black, 0.5) !default; $off-canvas-overlay-background: rgba($white, 0.2) !default; $off-canvas-overlay-background-hover: rgba($white, 0.05) !default; // Transition Variables $menu-slide: "transform 500ms ease" !default; // MIXINS // Remove transition flicker on phones @mixin kill-flicker { // -webkit-transform: translateZ(0x); -webkit-backface-visibility: hidden; } // Basic properties for the content wraps @mixin wrap-base { position: relative; width: 100%; } @mixin translate3d($tx,$ty,$tz) { -ms-transform: translate($tx,$ty); -webkit-transform: translate3d($tx,$ty,$tz); -moz-transform: translate3d($tx,$ty,$tz); -ms-transform: translate3d($tx,$ty,$tz); -o-transform: translate3d($tx,$ty,$tz); transform: translate3d($tx,$ty,$tz) } // basic styles for off-canvas menu container @mixin off-canvas-menu($position) { @include kill-flicker; * { @include kill-flicker; } width: $off-canvas-width; top: 0; bottom: 0; position: absolute; overflow-x: hidden; overflow-y: auto; background: $off-canvas-bg; z-index: 1001; box-sizing: content-box; transition: transform 500ms ease 0s; -webkit-overflow-scrolling: touch; -ms-overflow-style: -ms-autohiding-scrollbar; @if $position == left { @include translate3d(-100%,0,0); left: 0; } @if $position == right { @include translate3d(100%,0,0); right: 0; } } // OFF CANVAS WRAP // Wrap visible content and prevent scroll bars @mixin off-canvas-wrap { @include kill-flicker; @include wrap-base; overflow: hidden; &.move-right, &.move-left { min-height: 100%; -webkit-overflow-scrolling: touch; } } // INNER WRAP // Main content area that moves to reveal the off-canvas nav @mixin inner-wrap { // @include kill-flicker; // removed for now till chrome fixes backface issue @include wrap-base; @include clearfix; -webkit-transition: -webkit-#{$menu-slide}; -moz-transition: -moz-#{$menu-slide}; -ms-transition: -ms-#{$menu-slide}; -o-transition: -o-#{$menu-slide}; transition: #{$menu-slide}; } // TAB BAR // This is the tab bar base @mixin tab-bar-base { @include kill-flicker; // base styles background: $tabbar-bg; color: $tabbar-color; height: $tabbar-height; line-height: $tabbar-line-height; // make sure it's below the .exit-off-canvas link position: relative; // z-index: 999; // Typography h1,h2,h3,h4,h5,h6 { color: $tabbar-header-color; font-weight: $tabbar-header-weight; line-height: $tabbar-header-line-height; margin: $tabbar-header-margin; } h1,h2,h3,h4 { font-size: $h5-font-size; } } // SMALL SECTIONS // These are small sections on the left and right that contain the off-canvas toggle buttons; @mixin tabbar-small-section($position) { width: $tabbar-icon-width; height: $tabbar-height; position: absolute; top: 0; @if $position == left { border-right: $tabbar-left-section-border; // box-shadow: 1px 0 0 scale-color($tabbar-bg, $lightness: 13%); left: 0; } @if $position == right { border-left: $tabbar-right-section-border; // box-shadow: -1px 0 0 scale-color($tabbar-bg, $lightness: -50%); right:0; } } @mixin tab-bar-section { padding: $tabbar-middle-padding; position: absolute; text-align: center; height: $tabbar-height; top: 0; @media #{$medium-up} { &.left { text-align: left; } &.right { text-align: right; } } // still need to make these non-presentational &.left { left: 0; right: $tabbar-icon-width; } &.right { left: $tabbar-icon-width; right: 0; } &.middle { left: $tabbar-icon-width; right: $tabbar-icon-width; } } // OFF CANVAS LIST // This is the list of links in the off-canvas menu @mixin off-canvas-list { list-style-type: none; padding:0; margin:0; li { label { display: block; padding: $off-canvas-label-padding; color: $off-canvas-label-color; text-transform: $off-canvas-label-text-transform; font-size: $off-canvas-label-font-size; font-weight: $off-canvas-label-font-weight; background: $off-canvas-label-bg; border-top: $off-canvas-label-border-top; border-bottom: $off-canvas-label-border-bottom; margin: $off-canvas-label-margin; } a { display: block; padding: $off-canvas-link-padding; color: $off-canvas-link-color; border-bottom: $off-canvas-link-border-bottom; transition: background 300ms ease; &:hover { background: $off-canvas-bg-hover; } } } } // BACK LINK // This is an overlay that, when clicked, will toggle off the off canvas menu @mixin back-link { @include kill-flicker; transition: $off-canvas-overlay-transition; cursor: $off-canvas-overlay-cursor; box-shadow: $off-canvas-overlay-box-shadow; // fill the screen display: block; position: absolute; background: $off-canvas-overlay-background; top: 0; bottom: 0; left:0; right:0; z-index: 1002; -webkit-tap-highlight-color: rgba(0,0,0,0); @media #{$medium-up} { &:hover { background: $off-canvas-overlay-background-hover; } } } // // DEFAULT CLASSES // @include exports("offcanvas") { @if $include-html-off-canvas-classes { .off-canvas-wrap { @include off-canvas-wrap; } .inner-wrap { @include inner-wrap; } .tab-bar { @include tab-bar-base; } .left-small { @include tabbar-small-section($position: left); } .right-small { @include tabbar-small-section($position: right); } .tab-bar-section { @include tab-bar-section; } // MENU BUTTON // This is a little bonus. You don't need it for off canvas to work. Mixins to be written in the future. .tab-bar .menu-icon { text-indent: $tabbar-menu-icon-text-indent; width: $tabbar-menu-icon-width; height: $tabbar-menu-icon-height; display: block; padding: $tabbar-menu-icon-padding; color: $tabbar-menu-icon-color; position: relative; transform: translate3d(0,0,0); // @include for the hamburger menu-icon // // Arguments as follows: ($width, $left, $top, $thickness, $gap, $color, $hover-color) // $width - Width of hamburger icon in rem Default: $tabbar-hamburger-icon-width. // $left - If false, icon will be centered horizontally || explicitly set value in rem Default: $tabbar-hamburger-icon-left= False // $top - If false, icon will be centered vertically || explicitly set value in rem Default: = False // $thickness - thickness of lines in hamburger icon, set value in px Default: $tabbar-hamburger-icon-thickness = 1px // $gap - spacing between the lines in hamburger icon, set value in px Default: $tabbar-hamburger-icon-gap = 6px // $color - icon color Default: $tabbar-menu-icon-color // $hover-color - icon color when hovered Default: $tabbar-menu-icon-hover // $offcanvas - Set to true @include hamburger($tabbar-hamburger-icon-width, $tabbar-hamburger-icon-left, $tabbar-hamburger-icon-top, $tabbar-hamburger-icon-thickness, $tabbar-hamburger-icon-gap, $tabbar-menu-icon-color, $tabbar-menu-icon-hover, true) } .left-off-canvas-menu { @include off-canvas-menu($position: left); } .right-off-canvas-menu { @include off-canvas-menu($position: right); } ul.off-canvas-list { @include off-canvas-list; } // ANIMATION CLASSES // These classes are added with JS and trigger the actual animation. .move-right { > .inner-wrap { @include translate3d($off-canvas-width,0,0); } .exit-off-canvas { @include back-link;} } .move-left { > .inner-wrap { @include translate3d(-($off-canvas-width),0,0); } .exit-off-canvas { @include back-link; } } .offcanvas-overlap { .left-off-canvas-menu, .right-off-canvas-menu { -ms-transform: none; -webkit-transform: none; -moz-transform: none; -o-transform: none; transform: none; z-index: 1003; } .exit-off-canvas { @include back-link; } } .offcanvas-overlap-left { .right-off-canvas-menu { -ms-transform: none; -webkit-transform: none; -moz-transform: none; -o-transform: none; transform: none; z-index: 1003; } .exit-off-canvas { @include back-link; } } .offcanvas-overlap-right { .left-off-canvas-menu { -ms-transform: none; -webkit-transform: none; -moz-transform: none; -o-transform: none; transform: none; z-index: 1003; } .exit-off-canvas { @include back-link; } } // Older browsers .no-csstransforms { .left-off-canvas-menu { left: -($off-canvas-width); } .right-off-canvas-menu { right: -($off-canvas-width); } .move-left > .inner-wrap { right: $off-canvas-width; } .move-right > .inner-wrap { left: $off-canvas-width; } } } } // // Off-Canvas Submenu Classes // @mixin off-canvas-submenu($position) { @include kill-flicker; * { @include kill-flicker; } width: $off-canvas-width; top: 0; bottom: 0; position: absolute; margin: 0; overflow-x: hidden; overflow-y: auto; background: $off-canvas-bg; z-index: 1002; box-sizing: content-box; -webkit-overflow-scrolling: touch; @if $position == left { @include translate3d(-100%,0,0); left: 0; } @if $position == right { @include translate3d(100%,0,0); right: 0; } -webkit-transition: -webkit-#{$menu-slide}; -moz-transition: -moz-#{$menu-slide}; -ms-transition: -ms-#{$menu-slide}; -o-transition: -o-#{$menu-slide}; transition: #{$menu-slide}; //back button style like label .back > a { padding: $off-canvas-label-padding; color: $off-canvas-label-color; text-transform: $off-canvas-label-text-transform; font-weight: $off-canvas-label-font-weight; background: $off-canvas-back-bg; border-top: $off-canvas-back-border-top; border-bottom: $off-canvas-back-border-bottom; &:hover { background: $off-canvas-back-hover-bg; border-top: $off-canvas-back-hover-border-top; border-bottom: $off-canvas-back-hover-border-bottom; } margin: $off-canvas-label-margin; @if $position == right { @if $text-direction == rtl { &:before { @include icon-double-arrows($position: left); } } @else { &:after { @include icon-double-arrows($position: right); } } } @if $position == left { @if $text-direction == rtl { &:after { @include icon-double-arrows($position: right); } } @else { &:before { @include icon-double-arrows($position: left); } } } } } //Left double angle quote or Right double angle quote chars @mixin icon-double-arrows ($position){ @if $position == left { content: "\AB"; @if $text-direction == rtl { margin-left: 0.5rem; } @else { margin-right: 0.5rem; } } @if $position == right { content: "\BB"; @if $text-direction == rtl { margin-right: 0.5rem; } @else { margin-left: 0.5rem; } } display: inline; } @if $include-html-off-canvas-classes { .left-submenu { @include off-canvas-submenu($position: left); &.move-right, &.offcanvas-overlap-right, &.offcanvas-overlap { @include translate3d(0%,0,0); } } .right-submenu { @include off-canvas-submenu($position: right); &.move-left, &.offcanvas-overlap-left, &.offcanvas-overlap { @include translate3d(0%,0,0); } } @if $text-direction == rtl { .left-off-canvas-menu ul.off-canvas-list li.has-submenu > a:before { @include icon-double-arrows($position: left); } .right-off-canvas-menu ul.off-canvas-list li.has-submenu > a:after { @include icon-double-arrows($position: right); } } @else { .left-off-canvas-menu ul.off-canvas-list li.has-submenu > a:after { @include icon-double-arrows($position: right); } .right-off-canvas-menu ul.off-canvas-list li.has-submenu > a:before { @include icon-double-arrows($position: left); } } }