]> BookStack Code Mirror - bookstack/blob - resources/assets/sass/_layout.scss
Update settings.php
[bookstack] / resources / assets / 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 {
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 {
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 /**
96  * Flexbox layout system
97  */
98 body.flexbox {
99   display: flex;
100   flex-direction: column;
101   align-items: stretch;
102   height: 100%;
103   min-height: 100%;
104   max-height: 100%;
105   overflow: hidden;
106   #content {
107     flex: 1;
108     display: flex;
109     min-height: 0;
110   }
111 }
112
113 .flex-fill {
114   display: flex;
115   align-items: stretch;
116   min-height: 0;
117   max-width: 100%;
118   position: relative;
119 }
120
121 .flex {
122   min-height: 0;
123   flex: 1;
124 }
125
126
127 /**
128  * Display and float utilities
129  */
130 .block {
131   display: block;
132   position: relative;
133 }
134
135 .inline {
136   display: inline;
137 }
138
139 .block.inline {
140   display: inline-block;
141 }
142
143 .hidden {
144   display: none;
145 }
146
147 .float {
148   float: left;
149   &.right {
150     float: right;
151   }
152 }
153
154 /**
155  * Visibility
156  */
157 @each $sizeLetter, $size in $screen-sizes {
158   @include smaller-than($size) {
159     .hide-under-#{$sizeLetter} {
160       display: none !important;
161     }
162   }
163   @include larger-than($size) {
164     .hide-over-#{$sizeLetter} {
165       display: none !important;
166     }
167   }
168 }
169
170 /**
171  * Inline content columns
172  */
173 .dual-column-content {
174   columns: 2;
175 }
176
177 @include smaller-than($m) {
178   .dual-column-content {
179     columns: 1;
180   }
181 }
182
183
184 /**
185  * Fixes
186  */
187 .clearfix:before,
188 .clearfix:after {
189   content: " ";
190   display: table;
191 }
192 .clearfix:after {
193   clear: both;
194 }
195
196 /**
197  * View Layouts
198  */
199 .tri-layout-container {
200   display: grid;
201   margin-left: $-xl;
202   margin-right: $-xl;
203   grid-template-columns: 1fr 4fr 1fr;
204   grid-template-areas: "a b c";
205   grid-column-gap: $-xxl;
206   .tri-layout-right {
207     grid-area: c;
208     min-width: 0;
209   }
210   .tri-layout-left {
211     grid-area: a;
212     min-width: 0;
213   }
214   .tri-layout-middle {
215     grid-area: b;
216     padding-top: $-m;
217   }
218 }
219 @include smaller-than($xxl) {
220   .tri-layout-container {
221     grid-template-areas:  "c b b"
222     "a b b";
223     grid-template-columns: 1fr 3fr;
224     grid-template-rows: max-content min-content;
225     padding-right: $-l;
226   }
227 }
228 @include larger-than($xxl) {
229   .tri-layout-left-contents, .tri-layout-right-contents {
230     padding: $-m;
231     position: sticky;
232     top: $-m;
233     max-height: 100vh;
234     min-height: 50vh;
235     overflow-y: scroll;
236     overflow-x: hidden;
237     scrollbar-width: none;
238     -ms-overflow-style: none;
239     &::-webkit-scrollbar {
240       display: none;
241     }
242   }
243   .tri-layout-middle-contents {
244     max-width: 940px;
245     margin: 0 auto;
246   }
247 }
248
249 @include smaller-than($l) {
250   .tri-layout-container {
251     grid-template-areas:  none;
252     grid-template-columns: 1fr;
253     grid-column-gap: 0;
254     padding-right: $-xs;
255     padding-left: $-xs;
256     .tri-layout-left-contents, .tri-layout-right-contents {
257       padding-left: $-m;
258       padding-right: $-m;
259     }
260     .tri-layout-right-contents > div, .tri-layout-left-contents > div {
261       opacity: 0.6;
262       z-index: 0;
263     }
264     .tri-layout-left > *, .tri-layout-right > * {
265       display: none;
266       pointer-events: none;
267     }
268     .tri-layout-left, .tri-layout-right {
269       grid-area: none;
270       grid-column: 1/1;
271       grid-row: 1;
272       padding-top: 0 !important;
273     }
274     .tri-layout-middle {
275       grid-area: none;
276       grid-row: 3;
277       grid-column: 1/1;
278       z-index: 1;
279       overflow: hidden;
280       transition: transform ease-in-out 240ms;
281     }
282     .tri-layout-left {
283       grid-row: 2;
284     }
285     &.show-info {
286       overflow: hidden;
287       .tri-layout-middle {
288         display: none;
289       }
290       .tri-layout-right  > *, .tri-layout-left > * {
291         display: block;
292         pointer-events: auto;
293       }
294     }
295   }
296 }
297 @include larger-than($l) {
298   .tri-layout-mobile-tabs {
299     display: none;
300   }
301 }
302
303 @include smaller-than($m) {
304   .tri-layout-container {
305     margin-left: 0;
306     margin-right: 0;
307   }
308 }
309
310 .tri-layout-left-contents > div, .tri-layout-right-contents > div {
311   opacity: 0.6;
312   transition: opacity ease-in-out 120ms;
313   &:hover {
314     opacity: 1;
315   }
316 }