Deployed 59ff7f1 to 5.4 with MkDocs 1.1.2 and mike 0.5.5
[GitHub/WoltLab/woltlab.github.io.git] / latest / view / css / index.html
CommitLineData
0c5338dd
TD
1
2<!doctype html>
3<html lang="en" class="no-js">
4 <head>
5
6 <meta charset="utf-8">
7 <meta name="viewport" content="width=device-width,initial-scale=1">
8
9
10
11
fb962f09
WG
12 <link rel="icon" href="../../assets/default.favicon.ico">
13 <meta name="generator" content="mkdocs-1.1.2, mkdocs-material-7.1.0">
0c5338dd
TD
14
15
16
17 <title>CSS - WoltLab Suite Documentation</title>
18
19
20
fb962f09 21 <link rel="stylesheet" href="../../assets/stylesheets/main.33e2939f.min.css">
0c5338dd
TD
22
23
fb962f09 24 <link rel="stylesheet" href="../../assets/stylesheets/palette.ef6f36e2.min.css">
0c5338dd
TD
25
26
27
28 <meta name="theme-color" content="#009485">
29
30
31
32
33
fd8430cb
WG
34
35
0c5338dd
TD
36
37
38 <link rel="stylesheet" href="../../stylesheets/extra.css">
39
40
41
42
43
44 </head>
45
46
47
48
49
50
51
52 <body dir="ltr" data-md-color-scheme="" data-md-color-primary="teal" data-md-color-accent="">
0c5338dd
TD
53
54
fb962f09
WG
55 <script>function __prefix(e){return new URL("../..",location).pathname+"."+e}function __get(e,t=localStorage){return JSON.parse(t.getItem(__prefix(e)))}</script>
56
0c5338dd
TD
57 <input class="md-toggle" data-md-toggle="drawer" type="checkbox" id="__drawer" autocomplete="off">
58 <input class="md-toggle" data-md-toggle="search" type="checkbox" id="__search" autocomplete="off">
59 <label class="md-overlay" for="__drawer"></label>
60 <div data-md-component="skip">
61
62
63 <a href="#css" class="md-skip">
64 Skip to content
65 </a>
66
67 </div>
68 <div data-md-component="announce">
69
70 <aside class="md-announce">
71 <div class="md-announce__inner md-grid md-typeset">
72
73 <a href="https://www.woltlab.com">Back to <strong>woltlab.com</strong></a>
74
75 </div>
76 </aside>
77
78 </div>
79
fb962f09 80 <header class="md-header" data-md-component="header">
0c5338dd 81 <nav class="md-header__inner md-grid" aria-label="Header">
fb962f09 82 <a href="../.." title="WoltLab Suite Documentation" class="md-header__button md-logo" aria-label="WoltLab Suite Documentation" data-md-component="logo">
0c5338dd
TD
83
84 <img src="../../assets/logo.png" alt="logo">
85
86 </a>
87 <label class="md-header__button md-icon" for="__drawer">
88 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M3 6h18v2H3V6m0 5h18v2H3v-2m0 5h18v2H3v-2z"/></svg>
89 </label>
90 <div class="md-header__title" data-md-component="header-title">
91 <div class="md-header__ellipsis">
92 <div class="md-header__topic">
93 <span class="md-ellipsis">
94 WoltLab Suite Documentation
95 </span>
96 </div>
97 <div class="md-header__topic" data-md-component="header-topic">
98 <span class="md-ellipsis">
99
100 CSS
101
102 </span>
103 </div>
104 </div>
0c5338dd
TD
105 </div>
106
fb962f09
WG
107
108
a3639e76
WG
109 <label class="md-header__button md-icon" for="__search">
110 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.5 3A6.5 6.5 0 0 1 16 9.5c0 1.61-.59 3.09-1.56 4.23l.27.27h.79l5 5-1.5 1.5-5-5v-.79l-.27-.27A6.516 6.516 0 0 1 9.5 16 6.5 6.5 0 0 1 3 9.5 6.5 6.5 0 0 1 9.5 3m0 2C7 5 5 7 5 9.5S7 14 9.5 14 14 12 14 9.5 12 5 9.5 5z"/></svg>
111 </label>
112
113<div class="md-search" data-md-component="search" role="dialog">
114 <label class="md-search__overlay" for="__search"></label>
115 <div class="md-search__inner" role="search">
116 <form class="md-search__form" name="search">
117 <input type="text" class="md-search__input" name="query" aria-label="Search" placeholder="Search" autocapitalize="off" autocorrect="off" autocomplete="off" spellcheck="false" data-md-component="search-query" data-md-state="active" required>
118 <label class="md-search__icon md-icon" for="__search">
119 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.5 3A6.5 6.5 0 0 1 16 9.5c0 1.61-.59 3.09-1.56 4.23l.27.27h.79l5 5-1.5 1.5-5-5v-.79l-.27-.27A6.516 6.516 0 0 1 9.5 16 6.5 6.5 0 0 1 3 9.5 6.5 6.5 0 0 1 9.5 3m0 2C7 5 5 7 5 9.5S7 14 9.5 14 14 12 14 9.5 12 5 9.5 5z"/></svg>
120 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20 11v2H8l5.5 5.5-1.42 1.42L4.16 12l7.92-7.92L13.5 5.5 8 11h12z"/></svg>
121 </label>
122 <button type="reset" class="md-search__icon md-icon" aria-label="Clear" tabindex="-1">
fb962f09 123 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M19 6.41 17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12 19 6.41z"/></svg>
a3639e76
WG
124 </button>
125 </form>
126 <div class="md-search__output">
127 <div class="md-search__scrollwrap" data-md-scrollfix>
128 <div class="md-search-result" data-md-component="search-result">
129 <div class="md-search-result__meta">
130 Initializing search
131 </div>
132 <ol class="md-search-result__list"></ol>
133 </div>
134 </div>
135 </div>
136 </div>
137</div>
138
0c5338dd 139
7124f4cb
WG
140 <div class="md-header__source">
141
142<a href="https://github.com/WoltLab/docs.woltlab.com/" title="Go to repository" class="md-source" data-md-component="source">
143 <div class="md-source__icon md-icon">
144
fb962f09 145 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><path d="M439.55 236.05 244 40.45a28.87 28.87 0 0 0-40.81 0l-40.66 40.63 51.52 51.52c27.06-9.14 52.68 16.77 43.39 43.68l49.66 49.66c34.23-11.8 61.18 31 35.47 56.69-26.49 26.49-70.21-2.87-56-37.34L240.22 199v121.85c25.3 12.54 22.26 41.85 9.08 55a34.34 34.34 0 0 1-48.55 0c-17.57-17.6-11.07-46.91 11.25-56v-123c-20.8-8.51-24.6-30.74-18.64-45L142.57 101 8.45 235.14a28.86 28.86 0 0 0 0 40.81l195.61 195.6a28.86 28.86 0 0 0 40.8 0l194.69-194.69a28.86 28.86 0 0 0 0-40.81z"/></svg>
7124f4cb
WG
146 </div>
147 <div class="md-source__repository">
148 GitHub
149 </div>
150</a>
151 </div>
152
0c5338dd
TD
153 </nav>
154</header>
155
156 <div class="md-container" data-md-component="container">
157
158
159
160
161 <main class="md-main" data-md-component="main">
162 <div class="md-main__inner md-grid">
163
164
165
166 <div class="md-sidebar md-sidebar--primary" data-md-component="sidebar" data-md-type="navigation" >
167 <div class="md-sidebar__scrollwrap">
168 <div class="md-sidebar__inner">
169
170
171
0c5338dd
TD
172<nav class="md-nav md-nav--primary" aria-label="Navigation" data-md-level="0">
173 <label class="md-nav__title" for="__drawer">
fb962f09 174 <a href="../.." title="WoltLab Suite Documentation" class="md-nav__button md-logo" aria-label="WoltLab Suite Documentation" data-md-component="logo">
0c5338dd
TD
175
176 <img src="../../assets/logo.png" alt="logo">
177
178 </a>
179 WoltLab Suite Documentation
180 </label>
181
7124f4cb
WG
182 <div class="md-nav__source">
183
184<a href="https://github.com/WoltLab/docs.woltlab.com/" title="Go to repository" class="md-source" data-md-component="source">
185 <div class="md-source__icon md-icon">
186
fb962f09 187 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><path d="M439.55 236.05 244 40.45a28.87 28.87 0 0 0-40.81 0l-40.66 40.63 51.52 51.52c27.06-9.14 52.68 16.77 43.39 43.68l49.66 49.66c34.23-11.8 61.18 31 35.47 56.69-26.49 26.49-70.21-2.87-56-37.34L240.22 199v121.85c25.3 12.54 22.26 41.85 9.08 55a34.34 34.34 0 0 1-48.55 0c-17.57-17.6-11.07-46.91 11.25-56v-123c-20.8-8.51-24.6-30.74-18.64-45L142.57 101 8.45 235.14a28.86 28.86 0 0 0 0 40.81l195.61 195.6a28.86 28.86 0 0 0 40.8 0l194.69-194.69a28.86 28.86 0 0 0 0-40.81z"/></svg>
7124f4cb
WG
188 </div>
189 <div class="md-source__repository">
190 GitHub
191 </div>
192</a>
193 </div>
194
0c5338dd
TD
195 <ul class="md-nav__list" data-md-scrollfix>
196
197
198
199
200
201
202
203
204 <li class="md-nav__item">
205 <a href="../../getting-started/" class="md-nav__link">
206 Getting Started
207 </a>
208 </li>
209
210
211
212
213
214
215
216
217
218
219
220 <li class="md-nav__item md-nav__item--nested">
221
222
223 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_2" type="checkbox" id="__nav_2" >
224
225 <label class="md-nav__link" for="__nav_2">
226 PHP API
227 <span class="md-nav__icon md-icon"></span>
228 </label>
229 <nav class="md-nav" aria-label="PHP API" data-md-level="1">
230 <label class="md-nav__title" for="__nav_2">
231 <span class="md-nav__icon md-icon"></span>
232 PHP API
233 </label>
234 <ul class="md-nav__list" data-md-scrollfix>
235
236
237
238
239
240 <li class="md-nav__item">
241 <a href="../../php/pages/" class="md-nav__link">
242 Pages
243 </a>
244 </li>
245
246
247
248
249
250
251
252 <li class="md-nav__item">
253 <a href="../../php/database-objects/" class="md-nav__link">
254 Database Objects
255 </a>
256 </li>
257
258
259
260
261
262
263
264 <li class="md-nav__item">
265 <a href="../../php/database-access/" class="md-nav__link">
266 Database Access
267 </a>
268 </li>
269
270
271
272
273
274
275
276 <li class="md-nav__item">
277 <a href="../../php/exceptions/" class="md-nav__link">
278 Exceptions
279 </a>
280 </li>
281
282
283
284
285
286
287
288
289 <li class="md-nav__item md-nav__item--nested">
290
291
292 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_2_5" type="checkbox" id="__nav_2_5" >
293
294 <label class="md-nav__link" for="__nav_2_5">
295 API
296 <span class="md-nav__icon md-icon"></span>
297 </label>
298 <nav class="md-nav" aria-label="API" data-md-level="2">
299 <label class="md-nav__title" for="__nav_2_5">
300 <span class="md-nav__icon md-icon"></span>
301 API
302 </label>
303 <ul class="md-nav__list" data-md-scrollfix>
304
305
306
307
308
6923e968
WG
309
310 <li class="md-nav__item md-nav__item--nested">
311
312
313 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_2_5_1" type="checkbox" id="__nav_2_5_1" >
314
315 <label class="md-nav__link" for="__nav_2_5_1">
316 Caches
317 <span class="md-nav__icon md-icon"></span>
318 </label>
319 <nav class="md-nav" aria-label="Caches" data-md-level="3">
320 <label class="md-nav__title" for="__nav_2_5_1">
321 <span class="md-nav__icon md-icon"></span>
322 Caches
323 </label>
324 <ul class="md-nav__list" data-md-scrollfix>
325
326
327
328
329
0c5338dd
TD
330 <li class="md-nav__item">
331 <a href="../../php/api/caches/" class="md-nav__link">
6923e968
WG
332 Overview
333 </a>
334 </li>
335
336
337
338
339
340
341
342 <li class="md-nav__item">
343 <a href="../../php/api/caches_persistent-caches/" class="md-nav__link">
344 Persistent Caches
345 </a>
346 </li>
347
348
349
350
351
352
353
354 <li class="md-nav__item">
355 <a href="../../php/api/caches_runtime-caches/" class="md-nav__link">
356 Runtime Caches
0c5338dd
TD
357 </a>
358 </li>
359
360
361
6923e968
WG
362 </ul>
363 </nav>
364 </li>
365
366
367
0c5338dd
TD
368
369
370
371
372 <li class="md-nav__item">
373 <a href="../../php/api/comments/" class="md-nav__link">
374 Comments
375 </a>
376 </li>
377
378
379
380
381
382
383
384 <li class="md-nav__item">
385 <a href="../../php/api/cronjobs/" class="md-nav__link">
386 Cronjobs
387 </a>
388 </li>
389
390
391
392
393
394
395
396 <li class="md-nav__item">
397 <a href="../../php/api/events/" class="md-nav__link">
398 Events
399 </a>
400 </li>
401
402
403
404
405
406
407
408
409 <li class="md-nav__item md-nav__item--nested">
410
411
412 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_2_5_5" type="checkbox" id="__nav_2_5_5" >
413
414 <label class="md-nav__link" for="__nav_2_5_5">
415 Form Builder
416 <span class="md-nav__icon md-icon"></span>
417 </label>
418 <nav class="md-nav" aria-label="Form Builder" data-md-level="3">
419 <label class="md-nav__title" for="__nav_2_5_5">
420 <span class="md-nav__icon md-icon"></span>
421 Form Builder
422 </label>
423 <ul class="md-nav__list" data-md-scrollfix>
424
425
426
427
428
429 <li class="md-nav__item">
430 <a href="../../php/api/form_builder/overview/" class="md-nav__link">
431 Overview
432 </a>
433 </li>
434
435
436
437
438
439
440
441 <li class="md-nav__item">
442 <a href="../../php/api/form_builder/structure/" class="md-nav__link">
443 Structure
444 </a>
445 </li>
446
447
448
449
450
451
452
453 <li class="md-nav__item">
454 <a href="../../php/api/form_builder/form_fields/" class="md-nav__link">
455 Fields
456 </a>
457 </li>
458
459
460
461
462
463
464
465 <li class="md-nav__item">
466 <a href="../../php/api/form_builder/validation_data/" class="md-nav__link">
467 Validation and Data
468 </a>
469 </li>
470
471
472
473
474
475
476
477 <li class="md-nav__item">
478 <a href="../../php/api/form_builder/dependencies/" class="md-nav__link">
479 Dependencies
480 </a>
481 </li>
482
483
484
485 </ul>
486 </nav>
487 </li>
488
489
490
491
492
493
494
495 <li class="md-nav__item">
496 <a href="../../php/api/package_installation_plugins/" class="md-nav__link">
497 Package Installation Plugins
498 </a>
499 </li>
500
501
502
503
504
505
506
507 <li class="md-nav__item">
508 <a href="../../php/api/user_activity_points/" class="md-nav__link">
509 User Activity Points
510 </a>
511 </li>
512
513
514
515
516
517
518
519 <li class="md-nav__item">
520 <a href="../../php/api/user_notifications/" class="md-nav__link">
521 User Notifications
522 </a>
523 </li>
524
525
526
527
528
529
530
531 <li class="md-nav__item">
532 <a href="../../php/api/sitemaps/" class="md-nav__link">
533 Sitemaps
534 </a>
535 </li>
536
537
538
539 </ul>
540 </nav>
541 </li>
542
543
544
545
546
547
548
549 <li class="md-nav__item">
550 <a href="../../php/code-style/" class="md-nav__link">
551 Code Style
552 </a>
553 </li>
554
555
556
557
558
559
560
561 <li class="md-nav__item">
562 <a href="../../php/apps/" class="md-nav__link">
563 Apps
564 </a>
565 </li>
566
567
568
569
570
571
572
573 <li class="md-nav__item">
574 <a href="../../php/gdpr/" class="md-nav__link">
575 GDPR
576 </a>
577 </li>
578
579
580
581 </ul>
582 </nav>
583 </li>
584
585
586
587
588
589
590
591
592
593
594
595
596
597 <li class="md-nav__item md-nav__item--active md-nav__item--nested">
598
599
600 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_3" type="checkbox" id="__nav_3" checked>
601
602 <label class="md-nav__link" for="__nav_3">
603 Languages, Templates & CSS
604 <span class="md-nav__icon md-icon"></span>
605 </label>
606 <nav class="md-nav" aria-label="Languages, Templates & CSS" data-md-level="1">
607 <label class="md-nav__title" for="__nav_3">
608 <span class="md-nav__icon md-icon"></span>
609 Languages, Templates & CSS
610 </label>
611 <ul class="md-nav__list" data-md-scrollfix>
612
613
614
615
616
617 <li class="md-nav__item">
618 <a href="../languages/" class="md-nav__link">
619 Languages
620 </a>
621 </li>
622
623
624
625
626
627
628
629 <li class="md-nav__item">
630 <a href="../templates/" class="md-nav__link">
631 Templates
632 </a>
633 </li>
634
635
636
637
638
639
6923e968
WG
640
641 <li class="md-nav__item">
642 <a href="../template-plugins/" class="md-nav__link">
643 Template Plugins
644 </a>
645 </li>
646
647
648
649
650
651
0c5338dd
TD
652
653
654
655 <li class="md-nav__item md-nav__item--active">
656
657 <input class="md-nav__toggle md-toggle" data-md-toggle="toc" type="checkbox" id="__toc">
658
659
660
661
662 <label class="md-nav__link md-nav__link--active" for="__toc">
663 CSS
664 <span class="md-nav__icon md-icon"></span>
665 </label>
666
667 <a href="./" class="md-nav__link md-nav__link--active">
668 CSS
669 </a>
670
671
672<nav class="md-nav md-nav--secondary" aria-label="Table of contents">
673
674
675
676
677
678 <label class="md-nav__title" for="__toc">
679 <span class="md-nav__icon md-icon"></span>
680 Table of contents
681 </label>
682 <ul class="md-nav__list" data-md-component="toc" data-md-scrollfix>
683
684 <li class="md-nav__item">
685 <a href="#scss-and-css" class="md-nav__link">
686 SCSS and CSS
687 </a>
688
689 <nav class="md-nav" aria-label="SCSS and CSS">
690 <ul class="md-nav__list">
691
692 <li class="md-nav__item">
693 <a href="#file-location" class="md-nav__link">
694 File Location
695 </a>
696
697</li>
698
699 <li class="md-nav__item">
700 <a href="#variables" class="md-nav__link">
701 Variables
702 </a>
703
704 <nav class="md-nav" aria-label="Variables">
705 <ul class="md-nav__list">
706
707 <li class="md-nav__item">
708 <a href="#linking-images" class="md-nav__link">
709 Linking images
710 </a>
711
712</li>
713
714 </ul>
715 </nav>
716
717</li>
718
719 </ul>
720 </nav>
721
722</li>
723
724 <li class="md-nav__item">
725 <a href="#media-breakpoints" class="md-nav__link">
726 Media Breakpoints
727 </a>
728
729 <nav class="md-nav" aria-label="Media Breakpoints">
730 <ul class="md-nav__list">
731
732 <li class="md-nav__item">
733 <a href="#available-breakpoints" class="md-nav__link">
734 Available Breakpoints
735 </a>
736
737</li>
738
739 </ul>
740 </nav>
741
f8622c01
WG
742</li>
743
744 <li class="md-nav__item">
745 <a href="#asset-preloading" class="md-nav__link">
746 Asset Preloading
747 </a>
748
0c5338dd
TD
749</li>
750
751 </ul>
752
753</nav>
754
755 </li>
756
757
758
759 </ul>
760 </nav>
761 </li>
762
763
764
765
766
767
768
769
770
771
772
773 <li class="md-nav__item md-nav__item--nested">
774
775
776 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_4" type="checkbox" id="__nav_4" >
777
778 <label class="md-nav__link" for="__nav_4">
77efcd46 779 TypeScript and JavaScript API
0c5338dd
TD
780 <span class="md-nav__icon md-icon"></span>
781 </label>
77efcd46 782 <nav class="md-nav" aria-label="TypeScript and JavaScript API" data-md-level="1">
0c5338dd
TD
783 <label class="md-nav__title" for="__nav_4">
784 <span class="md-nav__icon md-icon"></span>
77efcd46 785 TypeScript and JavaScript API
0c5338dd
TD
786 </label>
787 <ul class="md-nav__list" data-md-scrollfix>
788
789
790
791
792
793 <li class="md-nav__item">
794 <a href="../../javascript/general-usage/" class="md-nav__link">
795 General Usage
796 </a>
797 </li>
798
799
800
801
802
803
804
77efcd46
WG
805 <li class="md-nav__item">
806 <a href="../../javascript/typescript/" class="md-nav__link">
807 TypeScript
808 </a>
809 </li>
810
811
812
813
814
815
816
0c5338dd
TD
817
818 <li class="md-nav__item md-nav__item--nested">
819
820
77efcd46 821 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_4_3" type="checkbox" id="__nav_4_3" >
0c5338dd 822
77efcd46 823 <label class="md-nav__link" for="__nav_4_3">
0c5338dd
TD
824 New API
825 <span class="md-nav__icon md-icon"></span>
826 </label>
827 <nav class="md-nav" aria-label="New API" data-md-level="2">
77efcd46 828 <label class="md-nav__title" for="__nav_4_3">
0c5338dd
TD
829 <span class="md-nav__icon md-icon"></span>
830 New API
831 </label>
832 <ul class="md-nav__list" data-md-scrollfix>
833
834
835
836
837
838 <li class="md-nav__item">
839 <a href="../../javascript/new-api_writing-a-module/" class="md-nav__link">
840 Writing a module
841 </a>
842 </li>
843
844
845
846
847
848
849
850 <li class="md-nav__item">
851 <a href="../../javascript/new-api_data-structures/" class="md-nav__link">
852 Data Structures
853 </a>
854 </li>
855
856
857
858
859
860
861
862 <li class="md-nav__item">
863 <a href="../../javascript/new-api_core/" class="md-nav__link">
864 Core Functions
865 </a>
866 </li>
867
868
869
870
871
872
873
874 <li class="md-nav__item">
875 <a href="../../javascript/new-api_dom/" class="md-nav__link">
876 DOM
877 </a>
878 </li>
879
880
881
882
883
884
885
886 <li class="md-nav__item">
887 <a href="../../javascript/new-api_events/" class="md-nav__link">
888 Event Handling
889 </a>
890 </li>
891
892
893
894
895
896
897
898 <li class="md-nav__item">
899 <a href="../../javascript/new-api_ajax/" class="md-nav__link">
900 Ajax
901 </a>
902 </li>
903
904
905
906
907
908
909
910 <li class="md-nav__item">
911 <a href="../../javascript/new-api_dialogs/" class="md-nav__link">
912 Dialogs
913 </a>
914 </li>
915
916
917
918
919
920
921
922 <li class="md-nav__item">
923 <a href="../../javascript/new-api_browser/" class="md-nav__link">
924 Browser and Screen Sizes
925 </a>
926 </li>
927
928
929
930
931
932
933
934 <li class="md-nav__item">
935 <a href="../../javascript/new-api_ui/" class="md-nav__link">
936 User Interface
937 </a>
938 </li>
939
940
941
942 </ul>
943 </nav>
944 </li>
945
946
947
948
949
950
951
952 <li class="md-nav__item">
953 <a href="../../javascript/legacy-api/" class="md-nav__link">
954 Legacy API
955 </a>
956 </li>
957
958
959
960
961
962
963
964 <li class="md-nav__item">
965 <a href="../../javascript/helper-functions/" class="md-nav__link">
966 Helper Functions
967 </a>
968 </li>
969
970
971
972
973
974
975
976 <li class="md-nav__item">
977 <a href="../../javascript/code-snippets/" class="md-nav__link">
978 Code Snippets
979 </a>
980 </li>
981
982
983
984 </ul>
985 </nav>
986 </li>
987
988
989
990
991
992
993
994
995
996
997
998 <li class="md-nav__item md-nav__item--nested">
999
1000
1001 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_5" type="checkbox" id="__nav_5" >
1002
1003 <label class="md-nav__link" for="__nav_5">
1004 Package Components
1005 <span class="md-nav__icon md-icon"></span>
1006 </label>
1007 <nav class="md-nav" aria-label="Package Components" data-md-level="1">
1008 <label class="md-nav__title" for="__nav_5">
1009 <span class="md-nav__icon md-icon"></span>
1010 Package Components
1011 </label>
1012 <ul class="md-nav__list" data-md-scrollfix>
1013
1014
1015
1016
1017
1018 <li class="md-nav__item">
1019 <a href="../../package/package-xml/" class="md-nav__link">
1020 package.xml
1021 </a>
1022 </li>
1023
1024
1025
1026
1027
1028
1029
1030
1031 <li class="md-nav__item md-nav__item--nested">
1032
1033
1034 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_5_2" type="checkbox" id="__nav_5_2" >
1035
1036 <label class="md-nav__link" for="__nav_5_2">
1037 PIPs
1038 <span class="md-nav__icon md-icon"></span>
1039 </label>
1040 <nav class="md-nav" aria-label="PIPs" data-md-level="2">
1041 <label class="md-nav__title" for="__nav_5_2">
1042 <span class="md-nav__icon md-icon"></span>
1043 PIPs
1044 </label>
1045 <ul class="md-nav__list" data-md-scrollfix>
1046
1047
1048
1049
1050
1051 <li class="md-nav__item">
1052 <a href="../../package/pip/" class="md-nav__link">
1053 Overview
1054 </a>
1055 </li>
1056
1057
1058
1059
1060
1061
1062
1063 <li class="md-nav__item">
1064 <a href="../../package/pip/acl-option/" class="md-nav__link">
1065 aclOption
1066 </a>
1067 </li>
1068
1069
1070
1071
1072
1073
1074
1075 <li class="md-nav__item">
1076 <a href="../../package/pip/acp-menu/" class="md-nav__link">
1077 acpMenu
1078 </a>
1079 </li>
1080
1081
1082
1083
1084
1085
1086
1087 <li class="md-nav__item">
1088 <a href="../../package/pip/acp-search-provider/" class="md-nav__link">
1089 acpSearchProvider
1090 </a>
1091 </li>
1092
1093
1094
1095
1096
1097
1098
1099 <li class="md-nav__item">
1100 <a href="../../package/pip/acp-template/" class="md-nav__link">
1101 acpTemplate
1102 </a>
1103 </li>
1104
1105
1106
1107
1108
1109
1110
1111 <li class="md-nav__item">
1112 <a href="../../package/pip/bbcode/" class="md-nav__link">
1113 bbcode
1114 </a>
1115 </li>
1116
1117
1118
1119
1120
1121
1122
1123 <li class="md-nav__item">
1124 <a href="../../package/pip/box/" class="md-nav__link">
1125 box
1126 </a>
1127 </li>
1128
1129
1130
1131
1132
1133
1134
1135 <li class="md-nav__item">
1136 <a href="../../package/pip/clipboard-action/" class="md-nav__link">
1137 clipboardAction
1138 </a>
1139 </li>
1140
1141
1142
1143
1144
1145
1146
1147 <li class="md-nav__item">
1148 <a href="../../package/pip/core-object/" class="md-nav__link">
1149 coreObject
1150 </a>
1151 </li>
1152
1153
1154
1155
1156
1157
1158
1159 <li class="md-nav__item">
1160 <a href="../../package/pip/cronjob/" class="md-nav__link">
1161 cronjob
1162 </a>
1163 </li>
1164
1165
1166
1167
1168
1169
1170
6923e968
WG
1171 <li class="md-nav__item">
1172 <a href="../../package/pip/database/" class="md-nav__link">
1173 database
1174 </a>
1175 </li>
1176
1177
1178
1179
1180
1181
1182
0c5338dd
TD
1183 <li class="md-nav__item">
1184 <a href="../../package/pip/event-listener/" class="md-nav__link">
1185 eventListener
1186 </a>
1187 </li>
1188
1189
1190
1191
1192
1193
1194
1195 <li class="md-nav__item">
1196 <a href="../../package/pip/file/" class="md-nav__link">
1197 file
1198 </a>
1199 </li>
1200
1201
1202
1203
1204
1205
1206
1207 <li class="md-nav__item">
1208 <a href="../../package/pip/language/" class="md-nav__link">
1209 language
1210 </a>
1211 </li>
1212
1213
1214
1215
1216
1217
1218
1219 <li class="md-nav__item">
1220 <a href="../../package/pip/media-provider/" class="md-nav__link">
1221 mediaProvider
1222 </a>
1223 </li>
1224
1225
1226
1227
1228
1229
1230
1231 <li class="md-nav__item">
1232 <a href="../../package/pip/menu/" class="md-nav__link">
1233 menu
1234 </a>
1235 </li>
1236
1237
1238
1239
1240
1241
1242
1243 <li class="md-nav__item">
1244 <a href="../../package/pip/menu-item/" class="md-nav__link">
1245 menuItem
1246 </a>
1247 </li>
1248
1249
1250
1251
1252
1253
1254
1255 <li class="md-nav__item">
1256 <a href="../../package/pip/object-type/" class="md-nav__link">
1257 objectType
1258 </a>
1259 </li>
1260
1261
1262
1263
1264
1265
1266
1267 <li class="md-nav__item">
1268 <a href="../../package/pip/object-type-definition/" class="md-nav__link">
1269 objectTypeDefinition
1270 </a>
1271 </li>
1272
1273
1274
1275
1276
1277
1278
1279 <li class="md-nav__item">
1280 <a href="../../package/pip/option/" class="md-nav__link">
1281 option
1282 </a>
1283 </li>
1284
1285
1286
1287
1288
1289
1290
1291 <li class="md-nav__item">
1292 <a href="../../package/pip/page/" class="md-nav__link">
1293 page
1294 </a>
1295 </li>
1296
1297
1298
1299
1300
1301
1302
1303 <li class="md-nav__item">
1304 <a href="../../package/pip/pip/" class="md-nav__link">
1305 pip
1306 </a>
1307 </li>
1308
1309
1310
1311
1312
1313
1314
1315 <li class="md-nav__item">
1316 <a href="../../package/pip/script/" class="md-nav__link">
1317 script
1318 </a>
1319 </li>
1320
1321
1322
1323
1324
1325
1326
1327 <li class="md-nav__item">
1328 <a href="../../package/pip/smiley/" class="md-nav__link">
1329 smiley
1330 </a>
1331 </li>
1332
1333
1334
1335
1336
1337
1338
1339 <li class="md-nav__item">
1340 <a href="../../package/pip/sql/" class="md-nav__link">
1341 sql
1342 </a>
1343 </li>
1344
1345
1346
1347
1348
1349
1350
1351 <li class="md-nav__item">
1352 <a href="../../package/pip/style/" class="md-nav__link">
1353 style
1354 </a>
1355 </li>
1356
1357
1358
1359
1360
1361
1362
1363 <li class="md-nav__item">
1364 <a href="../../package/pip/template/" class="md-nav__link">
1365 template
1366 </a>
1367 </li>
1368
1369
1370
1371
1372
1373
1374
1375 <li class="md-nav__item">
1376 <a href="../../package/pip/template-listener/" class="md-nav__link">
1377 templateListener
1378 </a>
1379 </li>
1380
1381
1382
1383
1384
1385
1386
1387 <li class="md-nav__item">
1388 <a href="../../package/pip/user-group-option/" class="md-nav__link">
1389 userGroupOption
1390 </a>
1391 </li>
1392
1393
1394
1395
1396
1397
1398
1399 <li class="md-nav__item">
1400 <a href="../../package/pip/user-menu/" class="md-nav__link">
1401 userMenu
1402 </a>
1403 </li>
1404
1405
1406
1407
1408
1409
1410
1411 <li class="md-nav__item">
1412 <a href="../../package/pip/user-notification-event/" class="md-nav__link">
1413 userNotificationEvent
1414 </a>
1415 </li>
1416
1417
1418
1419
1420
1421
1422
1423 <li class="md-nav__item">
1424 <a href="../../package/pip/user-option/" class="md-nav__link">
1425 userOption
1426 </a>
1427 </li>
1428
1429
1430
1431
1432
1433
1434
1435 <li class="md-nav__item">
1436 <a href="../../package/pip/user-profile-menu/" class="md-nav__link">
1437 userProfileMenu
1438 </a>
1439 </li>
1440
1441
1442
1443 </ul>
1444 </nav>
1445 </li>
1446
1447
1448
1449
1450
1451
1452
1453 <li class="md-nav__item">
1454 <a href="../../package/database-php-api/" class="md-nav__link">
1455 Database PHP API
1456 </a>
1457 </li>
1458
1459
1460
1461 </ul>
1462 </nav>
1463 </li>
1464
1465
1466
1467
1468
1469
1470
1471
1472
1473
1474
1475 <li class="md-nav__item md-nav__item--nested">
1476
1477
1478 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6" type="checkbox" id="__nav_6" >
1479
1480 <label class="md-nav__link" for="__nav_6">
1481 Migration
1482 <span class="md-nav__icon md-icon"></span>
1483 </label>
1484 <nav class="md-nav" aria-label="Migration" data-md-level="1">
1485 <label class="md-nav__title" for="__nav_6">
1486 <span class="md-nav__icon md-icon"></span>
1487 Migration
1488 </label>
1489 <ul class="md-nav__list" data-md-scrollfix>
1490
1491
1492
1493
1494
1495
1496 <li class="md-nav__item md-nav__item--nested">
1497
1498
1499 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6_1" type="checkbox" id="__nav_6_1" >
1500
1501 <label class="md-nav__link" for="__nav_6_1">
1502 Migrating from WSC 5.3
1503 <span class="md-nav__icon md-icon"></span>
1504 </label>
1505 <nav class="md-nav" aria-label="Migrating from WSC 5.3" data-md-level="2">
1506 <label class="md-nav__title" for="__nav_6_1">
1507 <span class="md-nav__icon md-icon"></span>
1508 Migrating from WSC 5.3
1509 </label>
1510 <ul class="md-nav__list" data-md-scrollfix>
1511
1512
1513
1514
1515
1516 <li class="md-nav__item">
1517 <a href="../../migration/wsc53/php/" class="md-nav__link">
1518 PHP API
1519 </a>
1520 </li>
1521
1522
1523
1524
1525
1526
1527
1528 <li class="md-nav__item">
1529 <a href="../../migration/wsc53/session/" class="md-nav__link">
1530 Session Handling and Authentication
1531 </a>
1532 </li>
1533
1534
1535
1536
1537
1538
1539
1540 <li class="md-nav__item">
1541 <a href="../../migration/wsc53/javascript/" class="md-nav__link">
77efcd46 1542 TypeScript and JavaScript
0c5338dd
TD
1543 </a>
1544 </li>
1545
1546
1547
1548
1549
1550
1551
1552 <li class="md-nav__item">
1553 <a href="../../migration/wsc53/templates/" class="md-nav__link">
1554 Templates
1555 </a>
1556 </li>
1557
1558
1559
1560
1561
1562
1563
1564 <li class="md-nav__item">
1565 <a href="../../migration/wsc53/libraries/" class="md-nav__link">
1566 Third Party Libraries
1567 </a>
1568 </li>
1569
1570
1571
1572 </ul>
1573 </nav>
1574 </li>
1575
1576
1577
1578
1579
1580
1581
1582
1583 <li class="md-nav__item md-nav__item--nested">
1584
1585
1586 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6_2" type="checkbox" id="__nav_6_2" >
1587
1588 <label class="md-nav__link" for="__nav_6_2">
1589 Migrating from WSC 5.2
1590 <span class="md-nav__icon md-icon"></span>
1591 </label>
1592 <nav class="md-nav" aria-label="Migrating from WSC 5.2" data-md-level="2">
1593 <label class="md-nav__title" for="__nav_6_2">
1594 <span class="md-nav__icon md-icon"></span>
1595 Migrating from WSC 5.2
1596 </label>
1597 <ul class="md-nav__list" data-md-scrollfix>
1598
1599
1600
1601
1602
1603 <li class="md-nav__item">
1604 <a href="../../migration/wsc52/php/" class="md-nav__link">
1605 PHP API
1606 </a>
1607 </li>
1608
1609
1610
1611
1612
1613
1614
1615 <li class="md-nav__item">
1616 <a href="../../migration/wsc52/templates/" class="md-nav__link">
1617 Templates and Languages
1618 </a>
1619 </li>
1620
1621
1622
1623
1624
1625
1626
1627 <li class="md-nav__item">
1628 <a href="../../migration/wsc52/libraries/" class="md-nav__link">
1629 Third Party Libraries
1630 </a>
1631 </li>
1632
1633
1634
1635 </ul>
1636 </nav>
1637 </li>
1638
1639
1640
1641
1642
1643
1644
1645
1646 <li class="md-nav__item md-nav__item--nested">
1647
1648
1649 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6_3" type="checkbox" id="__nav_6_3" >
1650
1651 <label class="md-nav__link" for="__nav_6_3">
1652 Migrating from WSC 3.1
1653 <span class="md-nav__icon md-icon"></span>
1654 </label>
1655 <nav class="md-nav" aria-label="Migrating from WSC 3.1" data-md-level="2">
1656 <label class="md-nav__title" for="__nav_6_3">
1657 <span class="md-nav__icon md-icon"></span>
1658 Migrating from WSC 3.1
1659 </label>
1660 <ul class="md-nav__list" data-md-scrollfix>
1661
1662
1663
1664
1665
1666 <li class="md-nav__item">
1667 <a href="../../migration/wsc31/php/" class="md-nav__link">
1668 PHP API
1669 </a>
1670 </li>
1671
1672
1673
1674 </ul>
1675 </nav>
1676 </li>
1677
1678
1679
1680
1681
1682
1683
1684
1685 <li class="md-nav__item md-nav__item--nested">
1686
1687
1688 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6_4" type="checkbox" id="__nav_6_4" >
1689
1690 <label class="md-nav__link" for="__nav_6_4">
1691 Migrating from WSC 3.0
1692 <span class="md-nav__icon md-icon"></span>
1693 </label>
1694 <nav class="md-nav" aria-label="Migrating from WSC 3.0" data-md-level="2">
1695 <label class="md-nav__title" for="__nav_6_4">
1696 <span class="md-nav__icon md-icon"></span>
1697 Migrating from WSC 3.0
1698 </label>
1699 <ul class="md-nav__list" data-md-scrollfix>
1700
1701
1702
1703
1704
1705 <li class="md-nav__item">
1706 <a href="../../migration/wsc30/php/" class="md-nav__link">
1707 PHP API
1708 </a>
1709 </li>
1710
1711
1712
1713
1714
1715
1716
1717 <li class="md-nav__item">
1718 <a href="../../migration/wsc30/javascript/" class="md-nav__link">
1719 JavaScript API
1720 </a>
1721 </li>
1722
1723
1724
1725
1726
1727
1728
1729 <li class="md-nav__item">
1730 <a href="../../migration/wsc30/templates/" class="md-nav__link">
1731 Templates
1732 </a>
1733 </li>
1734
1735
1736
1737
1738
1739
1740
1741 <li class="md-nav__item">
1742 <a href="../../migration/wsc30/css/" class="md-nav__link">
1743 CSS
1744 </a>
1745 </li>
1746
1747
1748
1749
1750
1751
1752
1753 <li class="md-nav__item">
1754 <a href="../../migration/wsc30/package/" class="md-nav__link">
1755 Package Components
1756 </a>
1757 </li>
1758
1759
1760
1761 </ul>
1762 </nav>
1763 </li>
1764
1765
1766
1767
1768
1769
1770
1771
1772 <li class="md-nav__item md-nav__item--nested">
1773
1774
1775 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6_5" type="checkbox" id="__nav_6_5" >
1776
1777 <label class="md-nav__link" for="__nav_6_5">
1778 Migrating from WCF 2.1
1779 <span class="md-nav__icon md-icon"></span>
1780 </label>
1781 <nav class="md-nav" aria-label="Migrating from WCF 2.1" data-md-level="2">
1782 <label class="md-nav__title" for="__nav_6_5">
1783 <span class="md-nav__icon md-icon"></span>
1784 Migrating from WCF 2.1
1785 </label>
1786 <ul class="md-nav__list" data-md-scrollfix>
1787
1788
1789
1790
1791
1792 <li class="md-nav__item">
1793 <a href="../../migration/wcf21/php/" class="md-nav__link">
1794 PHP API
1795 </a>
1796 </li>
1797
1798
1799
1800
1801
1802
1803
1804 <li class="md-nav__item">
1805 <a href="../../migration/wcf21/templates/" class="md-nav__link">
1806 Templates
1807 </a>
1808 </li>
1809
1810
1811
1812
1813
1814
1815
1816 <li class="md-nav__item">
1817 <a href="../../migration/wcf21/css/" class="md-nav__link">
1818 CSS
1819 </a>
1820 </li>
1821
1822
1823
1824
1825
1826
1827
1828 <li class="md-nav__item">
1829 <a href="../../migration/wcf21/package/" class="md-nav__link">
1830 Package Components
1831 </a>
1832 </li>
1833
1834
1835
1836 </ul>
1837 </nav>
1838 </li>
1839
1840
1841
1842 </ul>
1843 </nav>
1844 </li>
1845
1846
1847
1848
1849
1850
1851
1852
1853
1854
1855
1856 <li class="md-nav__item md-nav__item--nested">
1857
1858
1859 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_7" type="checkbox" id="__nav_7" >
1860
1861 <label class="md-nav__link" for="__nav_7">
1862 Tutorials
1863 <span class="md-nav__icon md-icon"></span>
1864 </label>
1865 <nav class="md-nav" aria-label="Tutorials" data-md-level="1">
1866 <label class="md-nav__title" for="__nav_7">
1867 <span class="md-nav__icon md-icon"></span>
1868 Tutorials
1869 </label>
1870 <ul class="md-nav__list" data-md-scrollfix>
1871
1872
1873
1874
1875
1876
1877 <li class="md-nav__item md-nav__item--nested">
1878
1879
1880 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_7_1" type="checkbox" id="__nav_7_1" >
1881
1882 <label class="md-nav__link" for="__nav_7_1">
1883 Tutorial Series
1884 <span class="md-nav__icon md-icon"></span>
1885 </label>
1886 <nav class="md-nav" aria-label="Tutorial Series" data-md-level="2">
1887 <label class="md-nav__title" for="__nav_7_1">
1888 <span class="md-nav__icon md-icon"></span>
1889 Tutorial Series
1890 </label>
1891 <ul class="md-nav__list" data-md-scrollfix>
1892
1893
1894
1895
1896
1897 <li class="md-nav__item">
1898 <a href="../../tutorial/series/overview/" class="md-nav__link">
1899 Overview
1900 </a>
1901 </li>
1902
1903
1904
1905
1906
1907
1908
1909 <li class="md-nav__item">
1910 <a href="../../tutorial/series/part_1/" class="md-nav__link">
1911 Part 1
1912 </a>
1913 </li>
1914
1915
1916
1917
1918
1919
1920
1921 <li class="md-nav__item">
1922 <a href="../../tutorial/series/part_2/" class="md-nav__link">
1923 Part 2
1924 </a>
1925 </li>
1926
1927
1928
1929
1930
1931
1932
1933 <li class="md-nav__item">
1934 <a href="../../tutorial/series/part_3/" class="md-nav__link">
1935 Part 3
1936 </a>
1937 </li>
1938
1939
1940
1941 </ul>
1942 </nav>
1943 </li>
1944
1945
1946
1947 </ul>
1948 </nav>
1949 </li>
1950
1951
1952
1953 </ul>
1954</nav>
1955 </div>
1956 </div>
1957 </div>
1958
1959
1960
1961 <div class="md-sidebar md-sidebar--secondary" data-md-component="sidebar" data-md-type="toc" >
1962 <div class="md-sidebar__scrollwrap">
1963 <div class="md-sidebar__inner">
1964
1965<nav class="md-nav md-nav--secondary" aria-label="Table of contents">
1966
1967
1968
1969
1970
1971 <label class="md-nav__title" for="__toc">
1972 <span class="md-nav__icon md-icon"></span>
1973 Table of contents
1974 </label>
1975 <ul class="md-nav__list" data-md-component="toc" data-md-scrollfix>
1976
1977 <li class="md-nav__item">
1978 <a href="#scss-and-css" class="md-nav__link">
1979 SCSS and CSS
1980 </a>
1981
1982 <nav class="md-nav" aria-label="SCSS and CSS">
1983 <ul class="md-nav__list">
1984
1985 <li class="md-nav__item">
1986 <a href="#file-location" class="md-nav__link">
1987 File Location
1988 </a>
1989
1990</li>
1991
1992 <li class="md-nav__item">
1993 <a href="#variables" class="md-nav__link">
1994 Variables
1995 </a>
1996
1997 <nav class="md-nav" aria-label="Variables">
1998 <ul class="md-nav__list">
1999
2000 <li class="md-nav__item">
2001 <a href="#linking-images" class="md-nav__link">
2002 Linking images
2003 </a>
2004
2005</li>
2006
2007 </ul>
2008 </nav>
2009
2010</li>
2011
2012 </ul>
2013 </nav>
2014
2015</li>
2016
2017 <li class="md-nav__item">
2018 <a href="#media-breakpoints" class="md-nav__link">
2019 Media Breakpoints
2020 </a>
2021
2022 <nav class="md-nav" aria-label="Media Breakpoints">
2023 <ul class="md-nav__list">
2024
2025 <li class="md-nav__item">
2026 <a href="#available-breakpoints" class="md-nav__link">
2027 Available Breakpoints
2028 </a>
2029
2030</li>
2031
2032 </ul>
2033 </nav>
2034
f8622c01
WG
2035</li>
2036
2037 <li class="md-nav__item">
2038 <a href="#asset-preloading" class="md-nav__link">
2039 Asset Preloading
2040 </a>
2041
0c5338dd
TD
2042</li>
2043
2044 </ul>
2045
2046</nav>
2047 </div>
2048 </div>
2049 </div>
2050
2051
2052 <div class="md-content" data-md-component="content">
2053 <article class="md-content__inner md-typeset">
2054
2055
9b8bddda 2056 <a href="https://github.com/WoltLab/docs.woltlab.com/edit/5.4/docs/view/css.md" title="Edit this page" class="md-content__button md-icon">
7124f4cb
WG
2057 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20.71 7.04c.39-.39.39-1.04 0-1.41l-2.34-2.34c-.37-.39-1.02-.39-1.41 0l-1.84 1.83 3.75 3.75M3 17.25V21h3.75L17.81 9.93l-3.75-3.75L3 17.25z"/></svg>
2058 </a>
2059
0c5338dd
TD
2060
2061 <h1 id="css">CSS<a class="headerlink" href="#css" title="Permanent link">#</a></h1>
2062<h2 id="scss-and-css">SCSS and CSS<a class="headerlink" href="#scss-and-css" title="Permanent link">#</a></h2>
2063<p>SCSS is a scripting language that features a syntax similar to CSS and compiles into native CSS at runtime. It provides many great additions to CSS such as declaration nesting and variables, it is recommended to read the <a href="http://sass-lang.com/guide">official guide</a> to learn more.</p>
2064<p>You can create <code>.scss</code> files containing only pure CSS code and it will work just fine, you are at no point required to write actual SCSS code.</p>
2065<h3 id="file-location">File Location<a class="headerlink" href="#file-location" title="Permanent link">#</a></h3>
2066<p>Please place your style files in a subdirectory of the <code>style/</code> directory of the target application or the Core's style directory, for example <code>style/layout/pageHeader.scss</code>.</p>
2067<h3 id="variables">Variables<a class="headerlink" href="#variables" title="Permanent link">#</a></h3>
2068<p>You can access variables with <code>$myVariable</code>, variable interpolation (variables inside strings) is accomplished with <code>#{$myVariable}</code>.</p>
2069<h4 id="linking-images">Linking images<a class="headerlink" href="#linking-images" title="Permanent link">#</a></h4>
2070<p>Images used within a style must be located in the style's image folder. To get the folder name within the CSS the SCSS variable <code>#{$style_image_path}</code> can be used. The value will contain a trailing slash.</p>
2071<h2 id="media-breakpoints">Media Breakpoints<a class="headerlink" href="#media-breakpoints" title="Permanent link">#</a></h2>
2072<p>Media breakpoints instruct the browser to apply different CSS depending on the viewport dimensions, e.g. serving a desktop PC a different view than when viewed on a smartphone.</p>
2073<div class="highlight"><pre><span></span><code><span class="cm">/* red background color for desktop pc */</span>
2074<span class="k">@include</span><span class="nd"> screen-lg</span> <span class="p">{</span>
2075 <span class="nt">body</span> <span class="p">{</span>
2076 <span class="nt">background-color</span><span class="nd">:</span> <span class="nt">red</span><span class="o">;</span>
2077 <span class="p">}</span>
2078<span class="p">}</span>
2079
2080<span class="cm">/* green background color on smartphones and tablets */</span>
2081<span class="k">@include</span><span class="nd"> screen-md-down</span> <span class="p">{</span>
2082 <span class="nt">body</span> <span class="p">{</span>
2083 <span class="nt">background-color</span><span class="nd">:</span> <span class="nt">green</span><span class="o">;</span>
2084 <span class="p">}</span>
2085<span class="p">}</span>
2086</code></pre></div>
0c5338dd
TD
2087<h3 id="available-breakpoints">Available Breakpoints<a class="headerlink" href="#available-breakpoints" title="Permanent link">#</a></h3>
2088<div class="admonition info">
2089<p class="admonition-title">Some very large smartphones, for example the Apple iPhone 7 Plus, do match the media query for <code>Tablets (portrait)</code> when viewed in landscape mode.</p>
2090</div>
2091<table>
2092<thead>
2093<tr>
2094<th>Name</th>
2095<th>Devices</th>
2096<th><code>@media</code> equivalent</th>
2097</tr>
2098</thead>
2099<tbody>
2100<tr>
2101<td><code>screen-xs</code></td>
2102<td>Smartphones only</td>
2103<td><code>(max-width: 544px)</code></td>
2104</tr>
2105<tr>
2106<td><code>screen-sm</code></td>
2107<td>Tablets (portrait)</td>
2108<td><code>(min-width: 545px) and (max-width: 768px)</code></td>
2109</tr>
2110<tr>
2111<td><code>screen-sm-down</code></td>
2112<td>Tablets (portrait) and smartphones</td>
2113<td><code>(max-width: 768px)</code></td>
2114</tr>
2115<tr>
2116<td><code>screen-sm-up</code></td>
2117<td>Tablets and desktop PC</td>
2118<td><code>(min-width: 545px)</code></td>
2119</tr>
2120<tr>
2121<td><code>screen-sm-md</code></td>
2122<td>Tablets only</td>
2123<td><code>(min-width: 545px) and (max-width: 1024px)</code></td>
2124</tr>
2125<tr>
2126<td><code>screen-md</code></td>
2127<td>Tablets (landscape)</td>
2128<td><code>(min-width: 769px) and (max-width: 1024px)</code></td>
2129</tr>
2130<tr>
2131<td><code>screen-md-down</code></td>
2132<td>Smartphones and Tablets</td>
2133<td><code>(max-width: 1024px)</code></td>
2134</tr>
2135<tr>
2136<td><code>screen-md-up</code></td>
2137<td>Tablets (landscape) and desktop PC</td>
2138<td><code>(min-width: 769px)</code></td>
2139</tr>
2140<tr>
2141<td><code>screen-lg</code></td>
2142<td>Desktop PC</td>
2143<td><code>(min-width: 1025px)</code></td>
2144</tr>
2145</tbody>
2146</table>
f8622c01
WG
2147<h2 id="asset-preloading">Asset Preloading<a class="headerlink" href="#asset-preloading" title="Permanent link">#</a></h2>
2148<p>WoltLab Suite’s SCSS compiler supports adding <a href="https://developer.mozilla.org/en-US/docs/Web/HTML/Preloading_content">preloading</a> metadata to the CSS.
2149To communicate the preloading intent to the compiler, the <code>--woltlab-suite-preload</code> CSS variable is set to the result of the <code>preload()</code> function:</p>
2150<div class="highlight"><pre><span></span><code><span class="nc">.fooBar</span> <span class="p">{</span>
2151 <span class="nt">--woltlab-suite-preload</span><span class="nd">:</span> <span class="nn">#</span><span class="p">{</span><span class="nt">preload</span><span class="o">(</span>
2152 <span class="s1">&#39;</span><span class="si">#{</span><span class="nv">$style_image_path</span><span class="si">}</span><span class="s1">custom/background.png&#39;</span><span class="o">,</span>
2153 <span class="err">$</span><span class="nt">as</span><span class="nd">:</span> <span class="s2">&quot;image&quot;</span><span class="o">,</span>
2154 <span class="err">$</span><span class="nt">crossorigin</span><span class="nd">:</span> <span class="nt">false</span><span class="o">,</span>
2155 <span class="err">$</span><span class="nt">type</span><span class="nd">:</span> <span class="s2">&quot;image/png&quot;</span>
2156 <span class="o">)</span><span class="p">}</span><span class="o">;</span>
2157
2158 <span class="nt">background</span><span class="nd">:</span> <span class="nt">url</span><span class="o">(</span><span class="s1">&#39;</span><span class="si">#{</span><span class="nv">$style_image_path</span><span class="si">}</span><span class="s1">custom/background.png&#39;</span><span class="o">);</span>
2159<span class="p">}</span>
2160</code></pre></div>
2161<p>The parameters of the <code>preload()</code> function map directly to the preloading properties that are used within the <code>&lt;link&gt;</code> tag and the <code>link:</code> HTTP response header.</p>
2162<p>The above example will result in a <code>&lt;link&gt;</code> similar to the following being added to the generated HTML:</p>
2163<div class="highlight"><pre><span></span><code>&lt;link rel=&quot;preload&quot; href=&quot;https://example.com/images/style-1/custom/background.png&quot; as=&quot;image&quot; type=&quot;image/png&quot;&gt;
2164</code></pre></div>
2165<div class="admonition info">
2166<p class="admonition-title">Use preloading sparingly for the most important resources where you can be certain that the browser will need them. Unused preloaded resources will unnecessarily waste bandwidth.</p>
2167</div>
0c5338dd 2168
4a5c32e1
WG
2169
2170
2171
2172<hr>
2173<div class="md-source-date">
2174 <small>
2175
2176 Last update: 2021-03-08
2177
2178 </small>
2179</div>
2180
2181
0c5338dd
TD
2182
2183
2184
2185
2186
2187
2188 </article>
2189 </div>
2190 </div>
fb962f09 2191
0c5338dd
TD
2192 </main>
2193
2194
2195<footer class="md-footer">
2196
2197 <nav class="md-footer__inner md-grid" aria-label="Footer">
2198
6923e968 2199 <a href="../template-plugins/" class="md-footer__link md-footer__link--prev" rel="prev">
0c5338dd
TD
2200 <div class="md-footer__button md-icon">
2201 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20 11v2H8l5.5 5.5-1.42 1.42L4.16 12l7.92-7.92L13.5 5.5 8 11h12z"/></svg>
2202 </div>
2203 <div class="md-footer__title">
2204 <div class="md-ellipsis">
2205 <span class="md-footer__direction">
2206 Previous
2207 </span>
6923e968 2208 Template Plugins
0c5338dd
TD
2209 </div>
2210 </div>
2211 </a>
2212
2213
2214 <a href="../../javascript/general-usage/" class="md-footer__link md-footer__link--next" rel="next">
2215 <div class="md-footer__title">
2216 <div class="md-ellipsis">
2217 <span class="md-footer__direction">
2218 Next
2219 </span>
2220 General Usage
2221 </div>
2222 </div>
2223 <div class="md-footer__button md-icon">
2224 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M4 11v2h12l-5.5 5.5 1.42 1.42L19.84 12l-7.92-7.92L10.5 5.5 16 11H4z"/></svg>
2225 </div>
2226 </a>
2227
2228 </nav>
2229
2230 <div class="md-footer-meta md-typeset">
2231 <div class="md-footer-meta__inner md-grid">
2232 <div class="md-footer-copyright">
2233
2234 <div class="md-footer-copyright__highlight">
2235 Copyright © 2020 WoltLab GmbH
2236 </div>
2237
2238 Made with
2239 <a href="https://squidfunk.github.io/mkdocs-material/" target="_blank" rel="noopener">
2240 Material for MkDocs
2241 </a>
fb88dc6e 2242
0c5338dd
TD
2243 </div>
2244 <div class="md-footer-copyright">
2245 <a href="https://www.woltlab.com/legal-notice/">Legal Notice</a>
2246 <a href="https://www.woltlab.com/privacy-policy/">Privacy Policy</a>
2247</div>
2248 </div>
2249 </div>
2250</footer>
2251
2252 </div>
2253 <div class="md-dialog" data-md-component="dialog">
2254 <div class="md-dialog__inner md-typeset"></div>
2255 </div>
fb962f09 2256 <script id="__config" type="application/json">{"base": "../..", "features": [], "translations": {"clipboard.copy": "Copy to clipboard", "clipboard.copied": "Copied to clipboard", "search.config.lang": "en", "search.config.pipeline": "trimmer, stopWordFilter", "search.config.separator": "[\\s\\-]+", "search.placeholder": "Search", "search.result.placeholder": "Type to start searching", "search.result.none": "No matching documents", "search.result.one": "1 matching document", "search.result.other": "# matching documents", "search.result.more.one": "1 more on this page", "search.result.more.other": "# more on this page", "search.result.term.missing": "Missing"}, "search": "../../assets/javascripts/workers/search.fe42c31b.min.js", "version": {"provider": "mike"}}</script>
0c5338dd
TD
2257
2258
fb962f09 2259 <script src="../../assets/javascripts/bundle.d892486b.min.js"></script>
0c5338dd
TD
2260
2261
2262 </body>
2263</html>