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