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