]> BookStack Code Mirror - bookstack/blob - resources/sass/_layout.scss
Add footer element, styles, and associated settings
[bookstack] / resources / sass / _layout.scss
1
2 /**
3  * Generic content container
4  */
5 .container {
6   max-width: $xxl;
7   margin-left: auto;
8   margin-right: auto;
9   padding-left: $-m;
10   padding-right: $-m;
11   &.small {
12     max-width: 840px;
13   }
14   &.very-small {
15     max-width: 480px;
16   }
17 }
18
19 /**
20  * Core grid layout system
21  */
22 .grid {
23   display: grid;
24   grid-column-gap: $-l;
25   grid-row-gap: $-l;
26   &.half {
27     grid-template-columns: 1fr 1fr;
28   }
29   &.third {
30     grid-template-columns: 1fr 1fr 1fr;
31   }
32   &.left-focus {
33     grid-template-columns: 2fr 1fr;
34   }
35   &.right-focus {
36     grid-template-columns: 1fr 3fr;
37   }
38   &.gap-y-xs {
39     grid-row-gap: $-xs;
40   }
41   &.gap-xl {
42     grid-column-gap: $-xl;
43     grid-row-gap: $-xl;
44   }
45   &.gap-xxl {
46     grid-column-gap: $-xxl;
47     grid-row-gap: $-xxl;
48   }
49   &.v-center {
50     align-items: center;
51   }
52   &.no-gap {
53     grid-row-gap: 0;
54     grid-column-gap: 0;
55   }
56   &.no-row-gap {
57     grid-row-gap: 0;
58   }
59 }
60
61 @include smaller-than($m) {
62   .grid.third:not(.no-break) {
63     grid-template-columns: 1fr 1fr;
64   }
65   .grid.half:not(.no-break), .grid.left-focus:not(.no-break), .grid.right-focus:not(.no-break) {
66     grid-template-columns: 1fr;
67   }
68   .grid.half.collapse-xs {
69     grid-template-columns: 1fr 1fr;
70   }
71   .grid.gap-xl {
72     grid-column-gap: $-m;
73     grid-row-gap: $-m;
74   }
75   .grid.right-focus.reverse-collapse > *:nth-child(2) {
76     order: 0;
77   }
78   .grid.right-focus.reverse-collapse > *:nth-child(1) {
79     order: 1;
80   }
81 }
82
83 @include smaller-than($s) {
84   .grid.third:not(.no-break) {
85     grid-template-columns: 1fr;
86   }
87 }
88
89 @include smaller-than($xs) {
90   .grid.half.collapse-xs {
91     grid-template-columns: 1fr;
92   }
93 }
94
95 #content {
96   flex: 1 0 auto;
97 }
98
99 /**
100  * Flexbox layout system
101  */
102 body.flexbox {
103   display: flex;
104   flex-direction: column;
105   align-items: stretch;
106   height: 100%;
107   min-height: 100%;
108   max-height: 100%;
109   overflow: hidden;
110   #content {
111     flex: 1;
112     display: flex;
113     min-height: 0;
114   }
115 }
116
117 .flex-fill {
118   display: flex;
119   align-items: stretch;
120   min-height: 0;
121   max-width: 100%;
122   position: relative;
123 }
124
125 .flex {
126   min-height: 0;
127   flex: 1;
128 }
129
130
131 /**
132  * Display and float utilities
133  */
134 .block {
135   display: block;
136   position: relative;
137 }
138
139 .inline {
140   display: inline;
141 }
142
143 .block.inline {
144   display: inline-block;
145 }
146
147 .hidden {
148   display: none;
149 }
150
151 .float {
152   float: left;
153   &.right {
154     float: right;
155   }
156 }
157
158 /**
159  * Visibility
160  */
161 @each $sizeLetter, $size in $screen-sizes {
162   @include smaller-than($size) {
163     .hide-under-#{$sizeLetter} {
164       display: none !important;
165     }
166   }
167   @include larger-than($size) {
168     .hide-over-#{$sizeLetter} {
169       display: none !important;
170     }
171   }
172 }
173
174 /**
175  * Inline content columns
176  */
177 .dual-column-content {
178   columns: 2;
179 }
180
181 @include smaller-than($m) {
182   .dual-column-content {
183     columns: 1;
184   }
185 }
186
187
188 /**
189  * Fixes
190  */
191 .clearfix:before,
192 .clearfix:after {
193   content: " ";
194   display: table;
195 }
196 .clearfix:after {
197   clear: both;
198 }
199
200 /**
201  * View Layouts
202  */
203 .tri-layout-container {
204   display: grid;
205   margin-left: $-xl;
206   margin-right: $-xl;
207   grid-template-columns: 1fr 4fr 1fr;
208   grid-template-areas: "a b c";
209   grid-column-gap: $-xxl;
210   .tri-layout-right {
211     grid-area: c;
212     min-width: 0;
213   }
214   .tri-layout-left {
215     grid-area: a;
216     min-width: 0;
217   }
218   .tri-layout-middle {
219     grid-area: b;
220     padding-top: $-m;
221   }
222 }
223 @include smaller-than($xxl) {
224   .tri-layout-container {
225     grid-template-areas:  "c b b"
226     "a b b"
227     ". b b";
228     grid-template-columns: 1fr 3fr;
229     grid-template-rows: min-content min-content 1fr;
230     padding-right: $-l;
231   }
232 }
233 @include between($l, $xxl) {
234   .tri-layout-left {
235     position: sticky;
236     top: $-m;
237   }
238 }
239 @include larger-than($xxl) {
240   .tri-layout-left-contents, .tri-layout-right-contents {
241     padding: $-m;
242     position: sticky;
243     top: $-m;
244     max-height: 100vh;
245     min-height: 50vh;
246     overflow-y: scroll;
247     overflow-x: hidden;
248     scrollbar-width: none;
249     -ms-overflow-style: none;
250     &::-webkit-scrollbar {
251       display: none;
252     }
253   }
254   .tri-layout-middle-contents {
255     max-width: 940px;
256     margin: 0 auto;
257   }
258 }
259
260 @include smaller-than($l) {
261   .tri-layout-container {
262     grid-template-areas:  none;
263     grid-template-columns: 1fr;
264     grid-column-gap: 0;
265     padding-right: $-xs;
266     padding-left: $-xs;
267     .tri-layout-left-contents, .tri-layout-right-contents {
268       padding-left: $-m;
269       padding-right: $-m;
270     }
271     .tri-layout-left > *, .tri-layout-right > * {
272       display: none;
273       pointer-events: none;
274     }
275     .tri-layout-left, .tri-layout-right {
276       grid-area: none;
277       grid-column: 1/1;
278       grid-row: 1;
279       padding-top: 0 !important;
280     }
281     .tri-layout-middle {
282       grid-area: none;
283       grid-row: 3;
284       grid-column: 1/1;
285       z-index: 1;
286       overflow: hidden;
287       transition: transform ease-in-out 240ms;
288     }
289     .tri-layout-left {
290       grid-row: 2;
291     }
292     &.show-info {
293       overflow: hidden;
294       .tri-layout-middle {
295         display: none;
296       }
297       .tri-layout-right  > *, .tri-layout-left > * {
298         display: block;
299         pointer-events: auto;
300       }
301     }
302   }
303 }
304 @include larger-than($l) {
305   .tri-layout-mobile-tabs {
306     display: none;
307   }
308   .tri-layout-left-contents > *, .tri-layout-right-contents > * {
309     opacity: 0.6;
310     transition: opacity ease-in-out 120ms;
311     &:hover {
312       opacity: 1;
313     }
314     &:focus-within {
315       opacity: 1;
316     }
317   }
318
319 }
320
321 @include smaller-than($m) {
322   .tri-layout-container {
323     margin-left: 0;
324     margin-right: 0;
325   }
326 }