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