]>
Commit | Line | Data |
---|---|---|
1 | $icon-font-path: '~@neos21/bootstrap3-glyphicons/assets/fonts/'; | |
2 | ||
3 | @use '_variables' as *; | |
4 | @use '_mixins' as *; | |
5 | ||
6 | @import './_bootstrap-variables'; | |
7 | ||
8 | @import '~bootstrap/scss/functions'; | |
9 | @import '~bootstrap/scss/variables'; | |
10 | ||
11 | @import '~bootstrap/scss/mixins'; | |
12 | @import '~bootstrap/scss/root'; | |
13 | @import '~bootstrap/scss/reboot'; | |
14 | @import '~bootstrap/scss/type'; | |
15 | @import '~bootstrap/scss/grid'; | |
16 | @import '~bootstrap/scss/tables'; | |
17 | @import '~bootstrap/scss/forms'; | |
18 | @import '~bootstrap/scss/buttons'; | |
19 | @import '~bootstrap/scss/dropdown'; | |
20 | @import '~bootstrap/scss/button-group'; | |
21 | @import '~bootstrap/scss/input-group'; | |
22 | @import '~bootstrap/scss/nav'; | |
23 | @import '~bootstrap/scss/card'; | |
24 | @import '~bootstrap/scss/badge'; | |
25 | @import '~bootstrap/scss/alert'; | |
26 | @import '~bootstrap/scss/close'; | |
27 | @import '~bootstrap/scss/modal'; | |
28 | @import '~bootstrap/scss/tooltip'; | |
29 | @import '~bootstrap/scss/popover'; | |
30 | @import '~bootstrap/scss/utilities'; | |
31 | ||
32 | @import '~@neos21/bootstrap3-glyphicons/assets/stylesheets/bootstrap3-glyphicons'; | |
33 | ||
34 | // Thanks https://gist.github.com/alexandrevicenzi/680147013e902a4eaa5d | |
35 | .glyphicon-refresh-animate { | |
36 | animation: spin 0.7s infinite linear; | |
37 | } | |
38 | ||
39 | .glyphicon-duplicate { | |
40 | font-size: 70%; | |
41 | } | |
42 | ||
43 | .flex-auto { | |
44 | flex: auto; | |
45 | } | |
46 | ||
47 | .c-hand { | |
48 | cursor: pointer; | |
49 | } | |
50 | ||
51 | @keyframes spin { | |
52 | from { | |
53 | transform: scale(1) rotate(0deg); | |
54 | } | |
55 | ||
56 | to { | |
57 | transform: scale(1) rotate(360deg); | |
58 | } | |
59 | } | |
60 | ||
61 | /* rules for dropdowns excepts when in button group, to avoid impacting the dropdown-toggle */ | |
62 | .dropdown, | |
63 | .dropup { | |
64 | z-index: z(dropdown) !important; | |
65 | } | |
66 | ||
67 | .list-overflow-menu, | |
68 | .parent-entry { | |
69 | z-index: z(menu) - 1 !important; | |
70 | } | |
71 | ||
72 | .btn-group, | |
73 | .dropdown-root, | |
74 | .action-dropdown, | |
75 | .input-group-prepend, | |
76 | .column-toggle { | |
77 | z-index: inherit !important; | |
78 | } | |
79 | ||
80 | .btn-group > .btn:not(:first-child) { | |
81 | border-top-left-radius: 0 !important; | |
82 | border-bottom-left-radius: 0 !important; | |
83 | } | |
84 | ||
85 | .dropdown-menu { | |
86 | z-index: z(dropdown) + 1 !important; | |
87 | ||
88 | border-radius: 3px; | |
89 | box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12), 0 3px 1px -2px rgba(0, 0, 0, 0.2); | |
90 | font-size: 15px; | |
91 | ||
92 | .dropdown-header { | |
93 | @include padding-left(1rem); | |
94 | } | |
95 | ||
96 | .dropdown-item { | |
97 | padding: 3px 15px; | |
98 | ||
99 | &.active { | |
100 | color: pvar(--mainBackgroundColor) !important; | |
101 | background-color: pvar(--mainHoverColor); | |
102 | opacity: 0.9; | |
103 | } | |
104 | ||
105 | &:active { | |
106 | color: pvar(--mainForegroundColor) !important; | |
107 | } | |
108 | ||
109 | &::after { | |
110 | display: none; | |
111 | } | |
112 | } | |
113 | ||
114 | button { | |
115 | @include disable-default-a-behaviour; | |
116 | } | |
117 | ||
118 | a { | |
119 | @include disable-default-a-behaviour; | |
120 | color: #000 !important; | |
121 | } | |
122 | } | |
123 | ||
124 | .badge { | |
125 | line-height: 1.1; | |
126 | } | |
127 | ||
128 | @media screen and (min-width: #{breakpoint(md)}) { | |
129 | .modal::before { | |
130 | vertical-align: middle; | |
131 | content: ' '; | |
132 | height: 100%; | |
133 | } | |
134 | ||
135 | .modal-dialog { | |
136 | text-align: start; | |
137 | ||
138 | &:not(.modal-lg):not(.modal-xl) { | |
139 | min-width: 500px; | |
140 | width: 40vw; | |
141 | max-width: 900px; | |
142 | } | |
143 | } | |
144 | } | |
145 | ||
146 | .modal { | |
147 | text-align: center; | |
148 | ||
149 | .modal-content { | |
150 | background-color: pvar(--mainBackgroundColor); | |
151 | word-break: break-word; | |
152 | } | |
153 | ||
154 | .modal-header { | |
155 | border-bottom: 0; | |
156 | margin-bottom: 5px; | |
157 | ||
158 | .modal-title { | |
159 | font-size: 20px; | |
160 | font-weight: $font-semibold; | |
161 | } | |
162 | ||
163 | my-global-icon { | |
164 | @include icon(22px); | |
165 | ||
166 | position: relative; | |
167 | top: 5px; | |
168 | float: right; | |
169 | ||
170 | margin: 0; | |
171 | padding: 0; | |
172 | opacity: 0.5; | |
173 | ||
174 | &[iconName=cross] { /* stylelint-disable-line selector-max-compound-selectors */ | |
175 | @include icon(16px); | |
176 | ||
177 | top: -3px; | |
178 | } | |
179 | } | |
180 | } | |
181 | ||
182 | .inputs { | |
183 | margin-bottom: 0; | |
184 | text-align: end; | |
185 | ||
186 | > .peertube-button:not(:first-child) { | |
187 | @include margin-left(10px); | |
188 | } | |
189 | } | |
190 | } | |
191 | ||
192 | ||
193 | // On desktop browsers, make the content and header horizontally sticked to right not move when modal open and close | |
194 | .modal-open { | |
195 | overflow-y: scroll !important; // Make sure vertical scroll bar is always visible on desktop browsers to get disabled scrollbar effect | |
196 | width: 100vw; // Make sure the content fits all the available width | |
197 | } | |
198 | ||
199 | // On touchscreen devices, simply overflow: hidden to avoid detached overlay on scroll | |
200 | @media (hover: none) and (pointer: coarse) { | |
201 | .modal-open, | |
202 | .menu-open { | |
203 | overflow: hidden !important; | |
204 | } | |
205 | ||
206 | // On touchscreen devices display content overlay when opened menu | |
207 | .menu-open { | |
208 | .main-col { | |
209 | &::before { | |
210 | background-color: #000; | |
211 | width: 100vw; | |
212 | height: 100vh; | |
213 | opacity: 0.75; | |
214 | content: ''; | |
215 | display: block; | |
216 | position: fixed; | |
217 | z-index: z(overlay); | |
218 | } | |
219 | } | |
220 | } | |
221 | } | |
222 | ||
223 | // Nav customizations | |
224 | .nav .nav-link { | |
225 | display: flex !important; | |
226 | align-items: center; | |
227 | height: 30px !important; | |
228 | padding: 10px 15px !important; | |
229 | } | |
230 | ||
231 | .nav.nav-pills { | |
232 | font-size: 16px !important; | |
233 | font-weight: $font-semibold !important; | |
234 | ||
235 | .nav-link { | |
236 | opacity: 0.6 !important; | |
237 | ||
238 | &.active, | |
239 | &:hover, | |
240 | &:active, | |
241 | &:focus { | |
242 | opacity: 1 !important; | |
243 | } | |
244 | } | |
245 | ||
246 | a { | |
247 | @include disable-default-a-behaviour; | |
248 | ||
249 | color: pvar(--mainForegroundColor); | |
250 | } | |
251 | } | |
252 | ||
253 | .nav-tabs .nav-link { | |
254 | @include disable-default-a-behaviour; | |
255 | ||
256 | color: pvar(--mainForegroundColor); | |
257 | font-weight: $font-semibold; | |
258 | border: 0; | |
259 | border-bottom: 2px solid transparent; | |
260 | opacity: 0.6; | |
261 | ||
262 | &.active { | |
263 | color: pvar(--mainForegroundColor); | |
264 | background-color: pvar(--mainBackgroundColor) !important; | |
265 | border-bottom-color: pvar(--mainColor); | |
266 | } | |
267 | ||
268 | &.active, | |
269 | &:hover, | |
270 | &:active, | |
271 | &:focus { | |
272 | opacity: 1; | |
273 | } | |
274 | } | |
275 | ||
276 | .card { | |
277 | background-color: pvar(--mainBackgroundColor); | |
278 | border-color: #dee2e6; | |
279 | } | |
280 | ||
281 | .collapse-transition { | |
282 | // Animation when we show/hide the filters | |
283 | transition: max-height 0.3s; | |
284 | display: block !important; | |
285 | overflow: hidden !important; | |
286 | max-height: 0; | |
287 | ||
288 | &.show { | |
289 | max-height: 1500px; | |
290 | } | |
291 | } | |
292 | ||
293 | .dropdown-divider { | |
294 | margin: 0.3rem 0; | |
295 | } | |
296 | ||
297 | ngb-modal-backdrop { | |
298 | z-index: z(modal) - 1 !important; | |
299 | } | |
300 | ||
301 | ngb-modal-window { | |
302 | z-index: z(modal) !important; | |
303 | } | |
304 | ||
305 | ngb-popover-window { | |
306 | z-index: z(popover) !important; | |
307 | } | |
308 | ||
309 | ngb-tooltip-window { | |
310 | z-index: z(tooltip) !important; | |
311 | } | |
312 | ||
313 | .btn-outline-secondary { | |
314 | border-color: $input-border-color; | |
315 | ||
316 | &:focus-within, | |
317 | &:focus, | |
318 | &:hover { | |
319 | color: #fff; | |
320 | background-color: #6c757d; | |
321 | } | |
322 | } | |
323 | ||
324 | .btn-outline-tertiary { | |
325 | color: pvar(--secondaryColor); | |
326 | border-color: pvar(--secondaryColor); | |
327 | ||
328 | &:focus-within, | |
329 | &:focus, | |
330 | &:hover { | |
331 | color: pvar(--mainBackgroundColor); | |
332 | background-color: pvar(--secondaryColor); | |
333 | } | |
334 | } | |
335 | ||
336 | // input box-shadow on focus | |
337 | .form-control { | |
338 | font-size: 15px; | |
339 | color: pvar(--mainForegroundColor); | |
340 | background-color: pvar(--inputBackgroundColor); | |
341 | outline: none; | |
342 | ||
343 | &:focus-within, | |
344 | &:focus { | |
345 | box-shadow: #{$focus-box-shadow-form} pvar(--mainColorLightest); | |
346 | ||
347 | &.input-error { | |
348 | box-shadow: #{$focus-box-shadow-form} #{scale-color($red, $alpha: -75%)}; | |
349 | } | |
350 | } | |
351 | } | |
352 | ||
353 | .input-group { | |
354 | > .form-control { | |
355 | flex: initial; | |
356 | } | |
357 | ||
358 | input.form-control { | |
359 | width: unset !important; | |
360 | flex-grow: 1; | |
361 | } | |
362 | ||
363 | .input-group-prepend + input { | |
364 | border-top-left-radius: 0 !important; | |
365 | border-bottom-left-radius: 0 !important; | |
366 | } | |
367 | } | |
368 | ||
369 | .has-feedback.has-clear { | |
370 | position: relative; | |
371 | ||
372 | input { | |
373 | @include padding-right(1.5rem !important); | |
374 | } | |
375 | ||
376 | .form-control-clear { | |
377 | color: rgba(0, 0, 0, 0.4); | |
378 | /* | |
379 | * Enable pointer events as they have been disabled since Bootstrap 3.3 | |
380 | * See https://github.com/twbs/bootstrap/pull/14104 | |
381 | */ | |
382 | pointer-events: all; | |
383 | display: flex; | |
384 | justify-content: center; | |
385 | align-items: center; | |
386 | position: absolute; | |
387 | right: .5rem; | |
388 | height: 95%; | |
389 | font-size: 14px; | |
390 | ||
391 | &:hover { | |
392 | color: rgba(0, 0, 0, 0.7); | |
393 | cursor: pointer; | |
394 | } | |
395 | } | |
396 | ||
397 | input:placeholder-shown + .form-control-clear { | |
398 | display: none; | |
399 | } | |
400 | } | |
401 | ||
402 | .callout { | |
403 | padding: 1.25rem; | |
404 | border: 1px solid #eee; | |
405 | border-radius: .25rem; | |
406 | ||
407 | > label { | |
408 | position: relative; | |
409 | top: -5px; | |
410 | left: -10px; | |
411 | color: #6c757d !important; | |
412 | } | |
413 | ||
414 | &:not(.callout-light) { | |
415 | border-left-width: .25rem; | |
416 | } | |
417 | ||
418 | &.callout-info { | |
419 | border-color: pvar(--mainColorLightest); | |
420 | border-left-color: pvar(--mainColor); | |
421 | } | |
422 | } | |
423 | ||
424 | // Override these properties for Bidi support | |
425 | @each $size, $length in $spacers { | |
426 | .ml-#{$size} { | |
427 | @include margin-left($length); | |
428 | } | |
429 | ||
430 | .mr-#{$size} { | |
431 | @include margin-right($length); | |
432 | } | |
433 | ||
434 | .pl-#{$size} { | |
435 | @include padding-left($length); | |
436 | } | |
437 | ||
438 | .pr-#{$size} { | |
439 | @include padding-right($length); | |
440 | } | |
441 | } |