5 A generic container that stays fixed to the left, top, right, or bottom of the screen, and is summoned when needed. When an off-canvas panel is open, the app frame shifts over to reveal the menu.
8 /// @Foundation.settings
10 $offcanvas-size-horizontal: 250px !default;
11 $offcanvas-size-vertical: 250px !default;
13 $offcanvas-background: #fff !default;
14 $offcanvas-color: isitlight($offcanvas-background) !default;
15 $offcanvas-padding: 0 !default;
16 $offcanvas-shadow: 3px 0 10px rgba(black, 0.25) !default;
17 $offcanvas-animation-speed: 0.25s !default;
19 $offcanvas-frame-selector: '.grid-frame' !default;
25 -webkit-overflow-scrolling: touch;
26 transition: transform $offcanvas-animation-speed ease-out;
31 transform: translate(0,0) !important;
35 & ~ #{$offcanvas-frame-selector} {
36 transform: translate(0,0,0);
37 transition: transform 0.25s ease-out;
38 backface-visibility: hidden;
42 @mixin off-canvas-detached {
50 & ~ #{$offcanvas-frame-selector} {
52 box-shadow: 0 0 15px rgba(0,0,0,0.5);
56 @mixin off-canvas-layout(
59 $shadow: $offcanvas-shadow
62 Get shadow values for later use
67 @if hasvalue($shadow) {
68 $shadow-length: get-shadow-value($shadow, x);
69 $shadow-size: get-shadow-value($shadow, size);
70 $shadow-color: get-shadow-value($shadow, color);
76 @if $position == left or $position == right {
77 @if $size == default {
78 $size: $offcanvas-size-horizontal;
84 @if $size == default {
85 $size: $offcanvas-size-vertical;
94 @if $position == left {
97 @if hasvalue($shadow) { box-shadow: inset (-$shadow-length) 0 $shadow-size $shadow-color; }
98 transform: translateX(-100%);
100 & ~ #{$offcanvas-frame-selector} { transform: translateX($size) !important; }
103 @else if $position == right {
107 @if hasvalue($shadow) { box-shadow: inset $shadow-length 0 $shadow-size $shadow-color; }
108 transform: translateX(100%);
110 & ~ #{$offcanvas-frame-selector} { transform: translateX(-$size) !important; }
113 @else if $position == top {
116 transform: translateY(-100%);
117 @if hasvalue($shadow) { box-shadow: inset 0 (-$shadow-length) $shadow-size $shadow-color; }
119 & ~ #{$offcanvas-frame-selector} { transform: translateY($size) !important; }
122 @else if $position == bottom {
126 transform: translateY(100%);
127 @if hasvalue($shadow) { box-shadow: inset 0 $shadow-length $shadow-size $shadow-color; }
129 & ~ #{$offcanvas-frame-selector} { transform: translateY(-$size) !important; }
134 @mixin off-canvas-style(
135 $background: $offcanvas-background,
136 $color: $offcanvas-color,
137 $padding: $offcanvas-padding
139 background: $background;
142 color: isitlight($background, #000, #fff);
148 @if hasvalue($padding) {
153 @include exports(off-canvas) {
156 @include off-canvas-layout;
157 @include off-canvas-style;
159 &.top { @include off-canvas-layout(top); }
160 &.right { @include off-canvas-layout(right); }
161 &.bottom { @include off-canvas-layout(bottom); }
162 &.left { @include off-canvas-layout(left); }
164 &.detached { @include off-canvas-detached; }
166 &.primary { @include off-canvas-style($primary-color, auto); }
167 &.dark { @include off-canvas-style($dark-color, auto); }