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