]> BookStack Code Mirror - bookstack/blob - resources/sass/_layout.scss
Add prev and next button to navigate through different pages
[bookstack] / resources / sass / _layout.scss
1
2 /**
3  * Generic content container
4  */
5 .container {
6   max-width: $xxl;
7   margin-inline-start: auto;
8   margin-inline-end: auto;
9   padding-inline-start: $-m;
10   padding-inline-end: $-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   &.v-end {
53     align-items: end;
54   }
55   &.no-gap {
56     grid-row-gap: 0;
57     grid-column-gap: 0;
58   }
59   &.no-row-gap {
60     grid-row-gap: 0;
61   }
62 }
63
64 @include smaller-than($m) {
65   .grid.third.prev-next:not(.no-break) {
66     grid-template-columns: 1fr 1fr 1fr;
67   }
68   .grid.third:not(.no-break) {
69     grid-template-columns: 1fr 1fr;
70   }
71   .grid.half:not(.no-break), .grid.left-focus:not(.no-break), .grid.right-focus:not(.no-break) {
72     grid-template-columns: 1fr;
73   }
74   .grid.half.collapse-xs {
75     grid-template-columns: 1fr 1fr;
76   }
77   .grid.gap-xl {
78     grid-column-gap: $-m;
79     grid-row-gap: $-m;
80   }
81   .grid.right-focus.reverse-collapse > *:nth-child(2) {
82     order: 0;
83   }
84   .grid.right-focus.reverse-collapse > *:nth-child(1) {
85     order: 1;
86   }
87   .grid.third:not(.no-break) .text-m-left {
88     margin-left: 20%;
89   }
90   .grid.third:not(.no-break) .text-m-right {
91     margin-left: 45%;
92   }
93 }
94
95 @include smaller-than($s) {
96   .grid.third:not(.no-break) {
97     grid-template-columns: 1fr;
98   }
99   .grid.third:not(.no-break) .text-m-left {
100     margin-left: 18%;
101   }
102   .grid.third:not(.no-break) .text-m-right {
103     margin-left: 20%;
104   }
105 }
106
107 @include smaller-than($xs) {
108   .grid.half.collapse-xs {
109     grid-template-columns: 1fr;
110   }
111 }
112
113 /**
114  * Flexbox layout system
115  */
116 body.flexbox {
117   display: flex;
118   flex-direction: column;
119   align-items: stretch;
120   height: 100%;
121   min-height: 100%;
122   max-height: 100%;
123   overflow: hidden;
124   #content {
125     flex: 1;
126     display: flex;
127     min-height: 0;
128   }
129 }
130
131 .flex-fill {
132   display: flex;
133   align-items: stretch;
134   min-height: 0;
135   max-width: 100%;
136   position: relative;
137 }
138
139 .flex-container-row {
140   display: flex;
141   flex-direction: row;
142   &.v-center {
143     align-items: center;
144   }
145 }
146
147 .flex-container-column {
148   display: flex;
149   flex-direction: column;
150 }
151
152 .flex-container-column.wrap, .flex-container-row.wrap {
153   flex-wrap: wrap;
154 }
155
156 .flex {
157   min-height: 0;
158   flex: 1;
159   &.fit-content {
160     flex-basis: auto;
161     flex-grow: 0;
162   }
163 }
164
165 .justify-flex-end {
166   justify-content: flex-end;
167 }
168 .justify-center {
169   justify-content: center;
170 }
171 .items-center {
172   align-items: center;
173 }
174
175
176 /**
177  * Display and float utilities
178  */
179 .block {
180   display: block !important;
181   position: relative;
182 }
183
184 .inline {
185   display: inline !important;
186 }
187
188 .block.inline {
189   display: inline-block !important;
190 }
191
192 .hidden {
193   display: none !important;
194 }
195
196 .fill-height {
197   height: 100%;
198 }
199
200 .float {
201   float: left;
202   &.right {
203     float: right;
204   }
205 }
206
207 /**
208  * Visibility
209  */
210 @each $sizeLetter, $size in $screen-sizes {
211   @include smaller-than($size) {
212     .hide-under-#{$sizeLetter} {
213       display: none !important;
214     }
215   }
216   @include larger-than($size) {
217     .hide-over-#{$sizeLetter} {
218       display: none !important;
219     }
220   }
221 }
222
223 /**
224  * Inline content columns
225  */
226 .dual-column-content {
227   columns: 2;
228 }
229
230 @include smaller-than($m) {
231   .dual-column-content {
232     columns: 1;
233   }
234 }
235
236
237 /**
238  * Fixes
239  */
240 .clearfix::before,
241 .clearfix::after {
242   content: " ";
243   display: table;
244 }
245 .clearfix::after {
246   clear: both;
247 }
248
249 /**
250  * View Layouts
251  */
252 .tri-layout-container {
253   display: grid;
254   margin-inline-start: $-xl;
255   margin-inline-end: $-xl;
256   grid-template-columns: 1fr 4fr 1fr;
257   grid-template-areas: "a b c";
258   grid-column-gap: $-xxl;
259   .tri-layout-right {
260     grid-area: c;
261     min-width: 0;
262   }
263   .tri-layout-left {
264     grid-area: a;
265     min-width: 0;
266   }
267   .tri-layout-middle {
268     grid-area: b;
269     padding-top: $-m;
270   }
271 }
272 @include smaller-than($xxl) {
273   .tri-layout-container {
274     grid-template-areas:  "c b b"
275     "a b b"
276     ". b b";
277     grid-template-columns: 1fr 3fr;
278     grid-template-rows: min-content min-content 1fr;
279     padding-inline-end: $-l;
280   }
281 }
282 @include between($l, $xxl) {
283   .tri-layout-left {
284     position: sticky;
285     top: $-m;
286   }
287 }
288 @include larger-than($xxl) {
289   .tri-layout-left-contents, .tri-layout-right-contents {
290     padding: $-m;
291     position: sticky;
292     top: $-m;
293     max-height: 100vh;
294     min-height: 50vh;
295     overflow-y: scroll;
296     overflow-x: hidden;
297     height: 100%;
298     scrollbar-width: none;
299     -ms-overflow-style: none;
300     &::-webkit-scrollbar {
301       display: none;
302     }
303   }
304   .tri-layout-middle-contents {
305     max-width: 940px;
306     margin: 0 auto;
307   }
308 }
309
310 @include smaller-than($l) {
311   .tri-layout-container {
312     grid-template-areas:  none;
313     grid-template-columns: 1fr;
314     grid-column-gap: 0;
315     padding-inline-end: $-xs;
316     padding-inline-start: $-xs;
317     .tri-layout-left-contents, .tri-layout-right-contents {
318       padding-inline-start: $-m;
319       padding-inline-end: $-m;
320     }
321     .tri-layout-left > *, .tri-layout-right > * {
322       display: none;
323       pointer-events: none;
324     }
325     .tri-layout-left, .tri-layout-right {
326       grid-area: none;
327       grid-column: 1/1;
328       grid-row: 1;
329       padding-top: 0 !important;
330     }
331     .tri-layout-middle {
332       grid-area: none;
333       grid-row: 3;
334       grid-column: 1/1;
335       z-index: 1;
336       overflow: hidden;
337       transition: transform ease-in-out 240ms;
338     }
339     .tri-layout-left {
340       grid-row: 2;
341     }
342     &.show-info {
343       overflow: hidden;
344       .tri-layout-middle {
345         display: none;
346       }
347       .tri-layout-right  > *, .tri-layout-left > * {
348         display: block;
349         pointer-events: auto;
350       }
351     }
352   }
353 }
354 @include larger-than($l) {
355   .tri-layout-mobile-tabs {
356     display: none;
357   }
358   .tri-layout-left-contents > *, .tri-layout-right-contents > * {
359     opacity: 0.6;
360     transition: opacity ease-in-out 120ms;
361     &:hover {
362       opacity: 1;
363     }
364     &:focus-within {
365       opacity: 1;
366     }
367   }
368
369 }
370
371 @include smaller-than($m) {
372   .tri-layout-container {
373     margin-inline-start: 0;
374     margin-inline-end: 0;
375   }
376 }
377
378 .prev-next-btn {
379   height: 50px;
380 }
Morty Proxy This is a proxified and sanitized view of the page, visit original site.