Deployed 878d1b09 to 6.0 with MkDocs 1.3.1 and mike 1.1.2
[GitHub/WoltLab/woltlab.github.io.git] / 6.0 / migration / wsc55 / javascript / index.html
CommitLineData
9aa5da67
WG
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 <link rel="canonical" href="https://docs.woltlab.com/6.0/migration/wsc55/javascript/">
12
13 <link rel="icon" href="../../../assets/default.favicon.ico">
14 <meta name="generator" content="mkdocs-1.3.1, mkdocs-material-8.3.9">
15
16
17
18 <title>TypeScript and JavaScript - WoltLab Suite Documentation</title>
19
20
21
22 <link rel="stylesheet" href="../../../assets/stylesheets/main.1d29e8d0.min.css">
23
24
25 <link rel="stylesheet" href="../../../assets/stylesheets/palette.cbb835fc.min.css">
26
27
28
29 <meta name="theme-color" content="#009485">
30
31
32
33
34
35
36
37
38
39 <link rel="stylesheet" href="../../../stylesheets/extra.css">
40
41 <script>__md_scope=new URL("../../..",location),__md_get=(e,_=localStorage,t=__md_scope)=>JSON.parse(_.getItem(t.pathname+"."+e)),__md_set=(e,_,t=localStorage,a=__md_scope)=>{try{t.setItem(a.pathname+"."+e,JSON.stringify(_))}catch(e){}}</script>
42
43
44
45
46
47 </head>
48
49
50
51
52
53
54
55 <body dir="ltr" data-md-color-scheme="" data-md-color-primary="teal" data-md-color-accent="">
56
57
58
59 <input class="md-toggle" data-md-toggle="drawer" type="checkbox" id="__drawer" autocomplete="off">
60 <input class="md-toggle" data-md-toggle="search" type="checkbox" id="__search" autocomplete="off">
61 <label class="md-overlay" for="__drawer"></label>
62 <div data-md-component="skip">
63
64
65 <a href="#migrating-from-woltlab-suite-55-typescript-and-javascript" class="md-skip">
66 Skip to content
67 </a>
68
69 </div>
70 <div data-md-component="announce">
71
72 <aside class="md-banner">
73 <div class="md-banner__inner md-grid md-typeset">
74
75 <a href="https://www.woltlab.com">Back to <strong>woltlab.com</strong></a>
76
77 </div>
78 </aside>
79
80 </div>
81
82 <div data-md-component="outdated" hidden>
83 <aside class="md-banner md-banner--warning">
84
85 </aside>
86 </div>
87
88
89
90
91<header class="md-header" data-md-component="header">
92 <nav class="md-header__inner md-grid" aria-label="Header">
93 <a href="../../.." title="WoltLab Suite Documentation" class="md-header__button md-logo" aria-label="WoltLab Suite Documentation" data-md-component="logo">
94
95 <img src="../../../assets/logo.png" alt="logo">
96
97 </a>
98 <label class="md-header__button md-icon" for="__drawer">
99 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M3 6h18v2H3V6m0 5h18v2H3v-2m0 5h18v2H3v-2Z"/></svg>
100 </label>
101 <div class="md-header__title" data-md-component="header-title">
102 <div class="md-header__ellipsis">
103 <div class="md-header__topic">
104 <span class="md-ellipsis">
105 WoltLab Suite Documentation
106 </span>
107 </div>
108 <div class="md-header__topic" data-md-component="header-topic">
109 <span class="md-ellipsis">
110
111 TypeScript and JavaScript
112
113 </span>
114 </div>
115 </div>
116 </div>
117
118
119
120 <label class="md-header__button md-icon" for="__search">
121 <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>
122 </label>
123 <div class="md-search" data-md-component="search" role="dialog">
124 <label class="md-search__overlay" for="__search"></label>
125 <div class="md-search__inner" role="search">
126 <form class="md-search__form" name="search">
127 <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" required>
128 <label class="md-search__icon md-icon" for="__search">
129 <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>
130 <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>
131 </label>
132 <nav class="md-search__options" aria-label="Search">
133
134 <button type="reset" class="md-search__icon md-icon" aria-label="Clear" tabindex="-1">
135 <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>
136 </button>
137 </nav>
138
139 </form>
140 <div class="md-search__output">
141 <div class="md-search__scrollwrap" data-md-scrollfix>
142 <div class="md-search-result" data-md-component="search-result">
143 <div class="md-search-result__meta">
144 Initializing search
145 </div>
146 <ol class="md-search-result__list"></ol>
147 </div>
148 </div>
149 </div>
150 </div>
151</div>
152
153
154 <div class="md-header__source">
155 <a href="https://github.com/WoltLab/docs.woltlab.com/" title="Go to repository" class="md-source" data-md-component="source">
156 <div class="md-source__icon md-icon">
157
158 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><!--! Font Awesome Free 6.1.1 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License) Copyright 2022 Fonticons, Inc.--><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>
159 </div>
160 <div class="md-source__repository">
161 GitHub
162 </div>
163</a>
164 </div>
165
166 </nav>
167
168</header>
169
170 <div class="md-container" data-md-component="container">
171
172
173
174
175
176
177 <main class="md-main" data-md-component="main">
178 <div class="md-main__inner md-grid">
179
180
181
182 <div class="md-sidebar md-sidebar--primary" data-md-component="sidebar" data-md-type="navigation" >
183 <div class="md-sidebar__scrollwrap">
184 <div class="md-sidebar__inner">
185
186
187
188<nav class="md-nav md-nav--primary" aria-label="Navigation" data-md-level="0">
189 <label class="md-nav__title" for="__drawer">
190 <a href="../../.." title="WoltLab Suite Documentation" class="md-nav__button md-logo" aria-label="WoltLab Suite Documentation" data-md-component="logo">
191
192 <img src="../../../assets/logo.png" alt="logo">
193
194 </a>
195 WoltLab Suite Documentation
196 </label>
197
198 <div class="md-nav__source">
199 <a href="https://github.com/WoltLab/docs.woltlab.com/" title="Go to repository" class="md-source" data-md-component="source">
200 <div class="md-source__icon md-icon">
201
202 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><!--! Font Awesome Free 6.1.1 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License) Copyright 2022 Fonticons, Inc.--><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>
203 </div>
204 <div class="md-source__repository">
205 GitHub
206 </div>
207</a>
208 </div>
209
210 <ul class="md-nav__list" data-md-scrollfix>
211
212
213
214
215
216
217
218
219 <li class="md-nav__item">
220 <a href="../../../getting-started/" class="md-nav__link">
221 Getting Started
222 </a>
223 </li>
224
225
226
227
228
229
230
231
232
233
234
235 <li class="md-nav__item md-nav__item--nested">
236
237
238 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_2" type="checkbox" id="__nav_2" >
239
240
241
242
243 <label class="md-nav__link" for="__nav_2">
244 PHP API
245 <span class="md-nav__icon md-icon"></span>
246 </label>
247
248 <nav class="md-nav" aria-label="PHP API" data-md-level="1">
249 <label class="md-nav__title" for="__nav_2">
250 <span class="md-nav__icon md-icon"></span>
251 PHP API
252 </label>
253 <ul class="md-nav__list" data-md-scrollfix>
254
255
256
257
258
259
260 <li class="md-nav__item">
261 <a href="../../../php/pages/" class="md-nav__link">
262 Pages
263 </a>
264 </li>
265
266
267
268
269
270
271
272
273
274 <li class="md-nav__item">
275 <a href="../../../php/database-objects/" class="md-nav__link">
276 Database Objects
277 </a>
278 </li>
279
280
281
282
283
284
285
286
287
288 <li class="md-nav__item">
289 <a href="../../../php/database-access/" class="md-nav__link">
290 Database Access
291 </a>
292 </li>
293
294
295
296
297
298
299
300
301
302 <li class="md-nav__item">
303 <a href="../../../php/exceptions/" class="md-nav__link">
304 Exceptions
305 </a>
306 </li>
307
308
309
310
311
312
313
314
315
316
317 <li class="md-nav__item md-nav__item--nested">
318
319
320 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_2_5" type="checkbox" id="__nav_2_5" >
321
322
323
324
325 <label class="md-nav__link" for="__nav_2_5">
326 API
327 <span class="md-nav__icon md-icon"></span>
328 </label>
329
330 <nav class="md-nav" aria-label="API" data-md-level="2">
331 <label class="md-nav__title" for="__nav_2_5">
332 <span class="md-nav__icon md-icon"></span>
333 API
334 </label>
335 <ul class="md-nav__list" data-md-scrollfix>
336
337
338
339
340
341
342
343 <li class="md-nav__item md-nav__item--nested">
344
345
346 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_2_5_1" type="checkbox" id="__nav_2_5_1" >
347
348
349
350
351 <label class="md-nav__link" for="__nav_2_5_1">
352 Caches
353 <span class="md-nav__icon md-icon"></span>
354 </label>
355
356 <nav class="md-nav" aria-label="Caches" data-md-level="3">
357 <label class="md-nav__title" for="__nav_2_5_1">
358 <span class="md-nav__icon md-icon"></span>
359 Caches
360 </label>
361 <ul class="md-nav__list" data-md-scrollfix>
362
363
364
365
366
367
368 <li class="md-nav__item">
369 <a href="../../../php/api/caches/" class="md-nav__link">
370 Overview
371 </a>
372 </li>
373
374
375
376
377
378
379
380
381
382 <li class="md-nav__item">
383 <a href="../../../php/api/caches_persistent-caches/" class="md-nav__link">
384 Persistent Caches
385 </a>
386 </li>
387
388
389
390
391
392
393
394
395
396 <li class="md-nav__item">
397 <a href="../../../php/api/caches_runtime-caches/" class="md-nav__link">
398 Runtime Caches
399 </a>
400 </li>
401
402
403
404
405 </ul>
406 </nav>
407 </li>
408
409
410
411
412
413
414
415
416
417 <li class="md-nav__item">
418 <a href="../../../php/api/comments/" class="md-nav__link">
419 Comments
420 </a>
421 </li>
422
423
424
425
426
427
428
429
430
431 <li class="md-nav__item">
432 <a href="../../../php/api/cronjobs/" class="md-nav__link">
433 Cronjobs
434 </a>
435 </li>
436
437
438
439
440
441
442
443
444
445 <li class="md-nav__item">
446 <a href="../../../php/api/events/" class="md-nav__link">
447 Events
448 </a>
449 </li>
450
451
452
453
454
455
456
457
458
459
460 <li class="md-nav__item md-nav__item--nested">
461
462
463 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_2_5_5" type="checkbox" id="__nav_2_5_5" >
464
465
466
467
468 <label class="md-nav__link" for="__nav_2_5_5">
469 Form Builder
470 <span class="md-nav__icon md-icon"></span>
471 </label>
472
473 <nav class="md-nav" aria-label="Form Builder" data-md-level="3">
474 <label class="md-nav__title" for="__nav_2_5_5">
475 <span class="md-nav__icon md-icon"></span>
476 Form Builder
477 </label>
478 <ul class="md-nav__list" data-md-scrollfix>
479
480
481
482
483
484
485 <li class="md-nav__item">
486 <a href="../../../php/api/form_builder/overview/" class="md-nav__link">
487 Overview
488 </a>
489 </li>
490
491
492
493
494
495
496
497
498
499 <li class="md-nav__item">
500 <a href="../../../php/api/form_builder/structure/" class="md-nav__link">
501 Structure
502 </a>
503 </li>
504
505
506
507
508
509
510
511
512
513 <li class="md-nav__item">
514 <a href="../../../php/api/form_builder/form_fields/" class="md-nav__link">
515 Fields
516 </a>
517 </li>
518
519
520
521
522
523
524
525
526
527 <li class="md-nav__item">
528 <a href="../../../php/api/form_builder/validation_data/" class="md-nav__link">
529 Validation and Data
530 </a>
531 </li>
532
533
534
535
536
537
538
539
540
541 <li class="md-nav__item">
542 <a href="../../../php/api/form_builder/dependencies/" class="md-nav__link">
543 Dependencies
544 </a>
545 </li>
546
547
548
549
550 </ul>
551 </nav>
552 </li>
553
554
555
556
557
558
559
560
561
562 <li class="md-nav__item">
563 <a href="../../../php/api/package_installation_plugins/" class="md-nav__link">
564 Package Installation Plugins
565 </a>
566 </li>
567
568
569
570
571
572
573
574
575
576 <li class="md-nav__item">
577 <a href="../../../php/api/user_activity_points/" class="md-nav__link">
578 User Activity Points
579 </a>
580 </li>
581
582
583
584
585
586
587
588
589
590 <li class="md-nav__item">
591 <a href="../../../php/api/user_notifications/" class="md-nav__link">
592 User Notifications
593 </a>
594 </li>
595
596
597
598
599
600
601
602
603
604 <li class="md-nav__item">
605 <a href="../../../php/api/sitemaps/" class="md-nav__link">
606 Sitemaps
607 </a>
608 </li>
609
610
611
612
613 </ul>
614 </nav>
615 </li>
616
617
618
619
620
621
622
623
624
625 <li class="md-nav__item">
626 <a href="../../../php/code-style/" class="md-nav__link">
627 Code Style
628 </a>
629 </li>
630
631
632
633
634
635
636
637
638
639 <li class="md-nav__item">
640 <a href="../../../php/apps/" class="md-nav__link">
641 Apps
642 </a>
643 </li>
644
645
646
647
648
649
650
651
652
653 <li class="md-nav__item">
654 <a href="../../../php/gdpr/" class="md-nav__link">
655 GDPR
656 </a>
657 </li>
658
659
660
661
662 </ul>
663 </nav>
664 </li>
665
666
667
668
669
670
671
672
673
674
675
676 <li class="md-nav__item md-nav__item--nested">
677
678
679 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_3" type="checkbox" id="__nav_3" >
680
681
682
683
684 <label class="md-nav__link" for="__nav_3">
685 Languages, Templates & CSS
686 <span class="md-nav__icon md-icon"></span>
687 </label>
688
689 <nav class="md-nav" aria-label="Languages, Templates & CSS" data-md-level="1">
690 <label class="md-nav__title" for="__nav_3">
691 <span class="md-nav__icon md-icon"></span>
692 Languages, Templates & CSS
693 </label>
694 <ul class="md-nav__list" data-md-scrollfix>
695
696
697
698
699
700
701 <li class="md-nav__item">
702 <a href="../../../view/languages/" class="md-nav__link">
703 Languages
704 </a>
705 </li>
706
707
708
709
710
711
712
713
714
715 <li class="md-nav__item">
716 <a href="../../../view/templates/" class="md-nav__link">
717 Templates
718 </a>
719 </li>
720
721
722
723
724
725
726
727
728
729 <li class="md-nav__item">
730 <a href="../../../view/template-plugins/" class="md-nav__link">
731 Template Plugins
732 </a>
733 </li>
734
735
736
737
738
739
740
741
742
743 <li class="md-nav__item">
744 <a href="../../../view/css/" class="md-nav__link">
745 CSS
746 </a>
747 </li>
748
749
750
751
752 </ul>
753 </nav>
754 </li>
755
756
757
758
759
760
761
762
763
764
765
766 <li class="md-nav__item md-nav__item--nested">
767
768
769 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_4" type="checkbox" id="__nav_4" >
770
771
772
773
774 <label class="md-nav__link" for="__nav_4">
775 TypeScript and JavaScript API
776 <span class="md-nav__icon md-icon"></span>
777 </label>
778
779 <nav class="md-nav" aria-label="TypeScript and JavaScript API" data-md-level="1">
780 <label class="md-nav__title" for="__nav_4">
781 <span class="md-nav__icon md-icon"></span>
782 TypeScript and JavaScript API
783 </label>
784 <ul class="md-nav__list" data-md-scrollfix>
785
786
787
788
789
790
791 <li class="md-nav__item">
792 <a href="../../../javascript/general-usage/" class="md-nav__link">
793 General Usage
794 </a>
795 </li>
796
797
798
799
800
801
802
803
804
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
817
818
819
820 <li class="md-nav__item md-nav__item--nested">
821
822
823 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_4_3" type="checkbox" id="__nav_4_3" >
824
825
826
827
828 <label class="md-nav__link" for="__nav_4_3">
829 New API
830 <span class="md-nav__icon md-icon"></span>
831 </label>
832
833 <nav class="md-nav" aria-label="New API" data-md-level="2">
834 <label class="md-nav__title" for="__nav_4_3">
835 <span class="md-nav__icon md-icon"></span>
836 New API
837 </label>
838 <ul class="md-nav__list" data-md-scrollfix>
839
840
841
842
843
844
845 <li class="md-nav__item">
846 <a href="../../../javascript/new-api_writing-a-module/" class="md-nav__link">
847 Writing a module
848 </a>
849 </li>
850
851
852
853
854
855
856
857
858
859 <li class="md-nav__item">
860 <a href="../../../javascript/new-api_data-structures/" class="md-nav__link">
861 Data Structures
862 </a>
863 </li>
864
865
866
867
868
869
870
871
872
873 <li class="md-nav__item">
874 <a href="../../../javascript/new-api_core/" class="md-nav__link">
875 Core Functions
876 </a>
877 </li>
878
879
880
881
882
883
884
885
886
887 <li class="md-nav__item">
888 <a href="../../../javascript/new-api_dom/" class="md-nav__link">
889 DOM
890 </a>
891 </li>
892
893
894
895
896
897
898
899
900
901 <li class="md-nav__item">
902 <a href="../../../javascript/new-api_events/" class="md-nav__link">
903 Event Handling
904 </a>
905 </li>
906
907
908
909
910
911
912
913
914
915 <li class="md-nav__item">
916 <a href="../../../javascript/new-api_ajax/" class="md-nav__link">
917 Ajax
918 </a>
919 </li>
920
921
922
923
924
925
926
927
928
929 <li class="md-nav__item">
930 <a href="../../../javascript/new-api_dialogs/" class="md-nav__link">
931 Dialogs
932 </a>
933 </li>
934
935
936
937
938
939
940
941
942
943 <li class="md-nav__item">
944 <a href="../../../javascript/new-api_browser/" class="md-nav__link">
945 Browser and Screen Sizes
946 </a>
947 </li>
948
949
950
951
952
953
954
955
956
957 <li class="md-nav__item">
958 <a href="../../../javascript/new-api_ui/" class="md-nav__link">
959 User Interface
960 </a>
961 </li>
962
963
964
965
966 </ul>
967 </nav>
968 </li>
969
970
971
972
973
974
975
976
977
978 <li class="md-nav__item">
979 <a href="../../../javascript/legacy-api/" class="md-nav__link">
980 Legacy API
981 </a>
982 </li>
983
984
985
986
987
988
989
990
991
992 <li class="md-nav__item">
993 <a href="../../../javascript/helper-functions/" class="md-nav__link">
994 Helper Functions
995 </a>
996 </li>
997
998
999
1000
1001
1002
1003
1004
1005
1006 <li class="md-nav__item">
1007 <a href="../../../javascript/code-snippets/" class="md-nav__link">
1008 Code Snippets
1009 </a>
1010 </li>
1011
1012
1013
1014
1015 </ul>
1016 </nav>
1017 </li>
1018
1019
1020
1021
1022
1023
1024
1025
1026
1027
1028
1029 <li class="md-nav__item md-nav__item--nested">
1030
1031
1032 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_5" type="checkbox" id="__nav_5" >
1033
1034
1035
1036
1037 <label class="md-nav__link" for="__nav_5">
1038 Package Components
1039 <span class="md-nav__icon md-icon"></span>
1040 </label>
1041
1042 <nav class="md-nav" aria-label="Package Components" data-md-level="1">
1043 <label class="md-nav__title" for="__nav_5">
1044 <span class="md-nav__icon md-icon"></span>
1045 Package Components
1046 </label>
1047 <ul class="md-nav__list" data-md-scrollfix>
1048
1049
1050
1051
1052
1053
1054 <li class="md-nav__item">
1055 <a href="../../../package/package-xml/" class="md-nav__link">
1056 package.xml
1057 </a>
1058 </li>
1059
1060
1061
1062
1063
1064
1065
1066
1067
1068
1069 <li class="md-nav__item md-nav__item--nested">
1070
1071
1072 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_5_2" type="checkbox" id="__nav_5_2" >
1073
1074
1075
1076
1077 <label class="md-nav__link" for="__nav_5_2">
1078 PIPs
1079 <span class="md-nav__icon md-icon"></span>
1080 </label>
1081
1082 <nav class="md-nav" aria-label="PIPs" data-md-level="2">
1083 <label class="md-nav__title" for="__nav_5_2">
1084 <span class="md-nav__icon md-icon"></span>
1085 PIPs
1086 </label>
1087 <ul class="md-nav__list" data-md-scrollfix>
1088
1089
1090
1091
1092
1093
1094 <li class="md-nav__item">
1095 <a href="../../../package/pip/" class="md-nav__link">
1096 Overview
1097 </a>
1098 </li>
1099
1100
1101
1102
1103
1104
1105
1106
1107
1108 <li class="md-nav__item">
1109 <a href="../../../package/pip/acl-option/" class="md-nav__link">
1110 aclOption
1111 </a>
1112 </li>
1113
1114
1115
1116
1117
1118
1119
1120
1121
1122 <li class="md-nav__item">
1123 <a href="../../../package/pip/acp-menu/" class="md-nav__link">
1124 acpMenu
1125 </a>
1126 </li>
1127
1128
1129
1130
1131
1132
1133
1134
1135
1136 <li class="md-nav__item">
1137 <a href="../../../package/pip/acp-search-provider/" class="md-nav__link">
1138 acpSearchProvider
1139 </a>
1140 </li>
1141
1142
1143
1144
1145
1146
1147
1148
1149
1150 <li class="md-nav__item">
1151 <a href="../../../package/pip/acp-template/" class="md-nav__link">
1152 acpTemplate
1153 </a>
1154 </li>
1155
1156
1157
1158
1159
1160
1161
1162
1163
1164 <li class="md-nav__item">
1165 <a href="../../../package/pip/acp-template-delete/" class="md-nav__link">
1166 acpTemplateDelete
1167 </a>
1168 </li>
1169
1170
1171
1172
1173
1174
1175
1176
1177
1178 <li class="md-nav__item">
1179 <a href="../../../package/pip/bbcode/" class="md-nav__link">
1180 bbcode
1181 </a>
1182 </li>
1183
1184
1185
1186
1187
1188
1189
1190
1191
1192 <li class="md-nav__item">
1193 <a href="../../../package/pip/box/" class="md-nav__link">
1194 box
1195 </a>
1196 </li>
1197
1198
1199
1200
1201
1202
1203
1204
1205
1206 <li class="md-nav__item">
1207 <a href="../../../package/pip/clipboard-action/" class="md-nav__link">
1208 clipboardAction
1209 </a>
1210 </li>
1211
1212
1213
1214
1215
1216
1217
1218
1219
1220 <li class="md-nav__item">
1221 <a href="../../../package/pip/core-object/" class="md-nav__link">
1222 coreObject
1223 </a>
1224 </li>
1225
1226
1227
1228
1229
1230
1231
1232
1233
1234 <li class="md-nav__item">
1235 <a href="../../../package/pip/cronjob/" class="md-nav__link">
1236 cronjob
1237 </a>
1238 </li>
1239
1240
1241
1242
1243
1244
1245
1246
1247
1248 <li class="md-nav__item">
1249 <a href="../../../package/pip/database/" class="md-nav__link">
1250 database
1251 </a>
1252 </li>
1253
1254
1255
1256
1257
1258
1259
1260
1261
1262 <li class="md-nav__item">
1263 <a href="../../../package/pip/event-listener/" class="md-nav__link">
1264 eventListener
1265 </a>
1266 </li>
1267
1268
1269
1270
1271
1272
1273
1274
1275
1276 <li class="md-nav__item">
1277 <a href="../../../package/pip/file/" class="md-nav__link">
1278 file
1279 </a>
1280 </li>
1281
1282
1283
1284
1285
1286
1287
1288
1289
1290 <li class="md-nav__item">
1291 <a href="../../../package/pip/file-delete/" class="md-nav__link">
1292 fileDelete
1293 </a>
1294 </li>
1295
1296
1297
1298
1299
1300
1301
1302
1303
1304 <li class="md-nav__item">
1305 <a href="../../../package/pip/language/" class="md-nav__link">
1306 language
1307 </a>
1308 </li>
1309
1310
1311
1312
1313
1314
1315
1316
1317
1318 <li class="md-nav__item">
1319 <a href="../../../package/pip/media-provider/" class="md-nav__link">
1320 mediaProvider
1321 </a>
1322 </li>
1323
1324
1325
1326
1327
1328
1329
1330
1331
1332 <li class="md-nav__item">
1333 <a href="../../../package/pip/menu/" class="md-nav__link">
1334 menu
1335 </a>
1336 </li>
1337
1338
1339
1340
1341
1342
1343
1344
1345
1346 <li class="md-nav__item">
1347 <a href="../../../package/pip/menu-item/" class="md-nav__link">
1348 menuItem
1349 </a>
1350 </li>
1351
1352
1353
1354
1355
1356
1357
1358
1359
1360 <li class="md-nav__item">
1361 <a href="../../../package/pip/object-type/" class="md-nav__link">
1362 objectType
1363 </a>
1364 </li>
1365
1366
1367
1368
1369
1370
1371
1372
1373
1374 <li class="md-nav__item">
1375 <a href="../../../package/pip/object-type-definition/" class="md-nav__link">
1376 objectTypeDefinition
1377 </a>
1378 </li>
1379
1380
1381
1382
1383
1384
1385
1386
1387
1388 <li class="md-nav__item">
1389 <a href="../../../package/pip/option/" class="md-nav__link">
1390 option
1391 </a>
1392 </li>
1393
1394
1395
1396
1397
1398
1399
1400
1401
1402 <li class="md-nav__item">
1403 <a href="../../../package/pip/page/" class="md-nav__link">
1404 page
1405 </a>
1406 </li>
1407
1408
1409
1410
1411
1412
1413
1414
1415
1416 <li class="md-nav__item">
1417 <a href="../../../package/pip/pip/" class="md-nav__link">
1418 pip
1419 </a>
1420 </li>
1421
1422
1423
1424
1425
1426
1427
1428
1429
1430 <li class="md-nav__item">
1431 <a href="../../../package/pip/script/" class="md-nav__link">
1432 script
1433 </a>
1434 </li>
1435
1436
1437
1438
1439
1440
1441
1442
1443
1444 <li class="md-nav__item">
1445 <a href="../../../package/pip/smiley/" class="md-nav__link">
1446 smiley
1447 </a>
1448 </li>
1449
1450
1451
1452
1453
1454
1455
1456
1457
1458 <li class="md-nav__item">
1459 <a href="../../../package/pip/sql/" class="md-nav__link">
1460 sql
1461 </a>
1462 </li>
1463
1464
1465
1466
1467
1468
1469
1470
1471
1472 <li class="md-nav__item">
1473 <a href="../../../package/pip/style/" class="md-nav__link">
1474 style
1475 </a>
1476 </li>
1477
1478
1479
1480
1481
1482
1483
1484
1485
1486 <li class="md-nav__item">
1487 <a href="../../../package/pip/template/" class="md-nav__link">
1488 template
1489 </a>
1490 </li>
1491
1492
1493
1494
1495
1496
1497
1498
1499
1500 <li class="md-nav__item">
1501 <a href="../../../package/pip/template-delete/" class="md-nav__link">
1502 templateDelete
1503 </a>
1504 </li>
1505
1506
1507
1508
1509
1510
1511
1512
1513
1514 <li class="md-nav__item">
1515 <a href="../../../package/pip/template-listener/" class="md-nav__link">
1516 templateListener
1517 </a>
1518 </li>
1519
1520
1521
1522
1523
1524
1525
1526
1527
1528 <li class="md-nav__item">
1529 <a href="../../../package/pip/user-group-option/" class="md-nav__link">
1530 userGroupOption
1531 </a>
1532 </li>
1533
1534
1535
1536
1537
1538
1539
1540
1541
1542 <li class="md-nav__item">
1543 <a href="../../../package/pip/user-menu/" class="md-nav__link">
1544 userMenu
1545 </a>
1546 </li>
1547
1548
1549
1550
1551
1552
1553
1554
1555
1556 <li class="md-nav__item">
1557 <a href="../../../package/pip/user-notification-event/" class="md-nav__link">
1558 userNotificationEvent
1559 </a>
1560 </li>
1561
1562
1563
1564
1565
1566
1567
1568
1569
1570 <li class="md-nav__item">
1571 <a href="../../../package/pip/user-option/" class="md-nav__link">
1572 userOption
1573 </a>
1574 </li>
1575
1576
1577
1578
1579
1580
1581
1582
1583
1584 <li class="md-nav__item">
1585 <a href="../../../package/pip/user-profile-menu/" class="md-nav__link">
1586 userProfileMenu
1587 </a>
1588 </li>
1589
1590
1591
1592
1593 </ul>
1594 </nav>
1595 </li>
1596
1597
1598
1599
1600
1601
1602
1603
1604
1605 <li class="md-nav__item">
1606 <a href="../../../package/database-php-api/" class="md-nav__link">
1607 Database PHP API
1608 </a>
1609 </li>
1610
1611
1612
1613
1614 </ul>
1615 </nav>
1616 </li>
1617
1618
1619
1620
1621
1622
1623
1624
1625
1626
1627
1628
1629
1630 <li class="md-nav__item md-nav__item--active md-nav__item--nested">
1631
1632
1633 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6" type="checkbox" id="__nav_6" checked>
1634
1635
1636
1637
1638 <label class="md-nav__link" for="__nav_6">
1639 Migration
1640 <span class="md-nav__icon md-icon"></span>
1641 </label>
1642
1643 <nav class="md-nav" aria-label="Migration" data-md-level="1">
1644 <label class="md-nav__title" for="__nav_6">
1645 <span class="md-nav__icon md-icon"></span>
1646 Migration
1647 </label>
1648 <ul class="md-nav__list" data-md-scrollfix>
1649
1650
1651
1652
1653
1654
1655
1656
1657
1658 <li class="md-nav__item md-nav__item--active md-nav__item--nested">
1659
1660
1661 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6_1" type="checkbox" id="__nav_6_1" checked>
1662
1663
1664
1665
1666 <label class="md-nav__link" for="__nav_6_1">
1667 From WoltLab Suite 5.5
1668 <span class="md-nav__icon md-icon"></span>
1669 </label>
1670
1671 <nav class="md-nav" aria-label="From WoltLab Suite 5.5" data-md-level="2">
1672 <label class="md-nav__title" for="__nav_6_1">
1673 <span class="md-nav__icon md-icon"></span>
1674 From WoltLab Suite 5.5
1675 </label>
1676 <ul class="md-nav__list" data-md-scrollfix>
1677
1678
1679
1680
1681
1682
1683 <li class="md-nav__item">
1684 <a href="../php/" class="md-nav__link">
1685 PHP API
1686 </a>
1687 </li>
1688
1689
1690
1691
1692
1693
1694
1695
1696
1697
1698
1699 <li class="md-nav__item md-nav__item--active">
1700
1701 <input class="md-nav__toggle md-toggle" data-md-toggle="toc" type="checkbox" id="__toc">
1702
1703
1704
1705
1706
1707 <label class="md-nav__link md-nav__link--active" for="__toc">
1708 TypeScript and JavaScript
1709 <span class="md-nav__icon md-icon"></span>
1710 </label>
1711
1712 <a href="./" class="md-nav__link md-nav__link--active">
1713 TypeScript and JavaScript
1714 </a>
1715
1716
1717
1718<nav class="md-nav md-nav--secondary" aria-label="Table of contents">
1719
1720
1721
1722
1723
1724
1725 <label class="md-nav__title" for="__toc">
1726 <span class="md-nav__icon md-icon"></span>
1727 Table of contents
1728 </label>
1729 <ul class="md-nav__list" data-md-component="toc" data-md-scrollfix>
1730
1731 <li class="md-nav__item">
1732 <a href="#minimum-requirements" class="md-nav__link">
1733 Minimum requirements
1734 </a>
1735
b2915b65
WG
1736</li>
1737
1738 <li class="md-nav__item">
1739 <a href="#subscribe-button-wcfuserobjectwatchsubscribe" class="md-nav__link">
1740 Subscribe Button (WCF.User.ObjectWatch.Subscribe)
1741 </a>
1742
9aa5da67
WG
1743</li>
1744
1745 </ul>
1746
1747</nav>
1748
1749 </li>
1750
1751
1752
1753
1754
1755
1756
1757
1758
1759 <li class="md-nav__item">
1760 <a href="../templates/" class="md-nav__link">
1761 Templates
1762 </a>
1763 </li>
1764
1765
1766
1767
1768
1769
1770
1771
1772
1773 <li class="md-nav__item">
1774 <a href="../libraries/" class="md-nav__link">
1775 Third Party Libraries
1776 </a>
1777 </li>
1778
1779
1780
1781
1782
1783
1784
1785
1786
1787 <li class="md-nav__item">
1788 <a href="../deprecations_removals/" class="md-nav__link">
1789 Deprecations and Removals
1790 </a>
1791 </li>
1792
1793
1794
1795
1796 </ul>
1797 </nav>
1798 </li>
1799
1800
1801
1802
1803
1804
1805
1806
1807
1808
1809 <li class="md-nav__item md-nav__item--nested">
1810
1811
1812 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6_2" type="checkbox" id="__nav_6_2" >
1813
1814
1815
1816
1817 <label class="md-nav__link" for="__nav_6_2">
1818 From WoltLab Suite 5.4
1819 <span class="md-nav__icon md-icon"></span>
1820 </label>
1821
1822 <nav class="md-nav" aria-label="From WoltLab Suite 5.4" data-md-level="2">
1823 <label class="md-nav__title" for="__nav_6_2">
1824 <span class="md-nav__icon md-icon"></span>
1825 From WoltLab Suite 5.4
1826 </label>
1827 <ul class="md-nav__list" data-md-scrollfix>
1828
1829
1830
1831
1832
1833
1834 <li class="md-nav__item">
1835 <a href="../../wsc54/php/" class="md-nav__link">
1836 PHP API
1837 </a>
1838 </li>
1839
1840
1841
1842
1843
1844
1845
1846
1847
1848 <li class="md-nav__item">
1849 <a href="../../wsc54/javascript/" class="md-nav__link">
1850 TypeScript and JavaScript
1851 </a>
1852 </li>
1853
1854
1855
1856
1857
1858
1859
1860
1861
1862 <li class="md-nav__item">
1863 <a href="../../wsc54/templates/" class="md-nav__link">
1864 Templates
1865 </a>
1866 </li>
1867
1868
1869
1870
1871
1872
1873
1874
1875
1876 <li class="md-nav__item">
1877 <a href="../../wsc54/libraries/" class="md-nav__link">
1878 Third Party Libraries
1879 </a>
1880 </li>
1881
1882
1883
1884
1885
1886
1887
1888
1889
1890 <li class="md-nav__item">
1891 <a href="../../wsc54/deprecations_removals/" class="md-nav__link">
1892 Deprecations and Removals
1893 </a>
1894 </li>
1895
1896
1897
1898
1899 </ul>
1900 </nav>
1901 </li>
1902
1903
1904
1905
1906
1907
1908
1909
1910
1911
1912 <li class="md-nav__item md-nav__item--nested">
1913
1914
1915 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6_3" type="checkbox" id="__nav_6_3" >
1916
1917
1918
1919
1920 <label class="md-nav__link" for="__nav_6_3">
1921 From WoltLab Suite 5.3
1922 <span class="md-nav__icon md-icon"></span>
1923 </label>
1924
1925 <nav class="md-nav" aria-label="From WoltLab Suite 5.3" data-md-level="2">
1926 <label class="md-nav__title" for="__nav_6_3">
1927 <span class="md-nav__icon md-icon"></span>
1928 From WoltLab Suite 5.3
1929 </label>
1930 <ul class="md-nav__list" data-md-scrollfix>
1931
1932
1933
1934
1935
1936
1937 <li class="md-nav__item">
1938 <a href="../../wsc53/php/" class="md-nav__link">
1939 PHP API
1940 </a>
1941 </li>
1942
1943
1944
1945
1946
1947
1948
1949
1950
1951 <li class="md-nav__item">
1952 <a href="../../wsc53/session/" class="md-nav__link">
1953 Session Handling and Authentication
1954 </a>
1955 </li>
1956
1957
1958
1959
1960
1961
1962
1963
1964
1965 <li class="md-nav__item">
1966 <a href="../../wsc53/javascript/" class="md-nav__link">
1967 TypeScript and JavaScript
1968 </a>
1969 </li>
1970
1971
1972
1973
1974
1975
1976
1977
1978
1979 <li class="md-nav__item">
1980 <a href="../../wsc53/templates/" class="md-nav__link">
1981 Templates
1982 </a>
1983 </li>
1984
1985
1986
1987
1988
1989
1990
1991
1992
1993 <li class="md-nav__item">
1994 <a href="../../wsc53/libraries/" class="md-nav__link">
1995 Third Party Libraries
1996 </a>
1997 </li>
1998
1999
2000
2001
2002 </ul>
2003 </nav>
2004 </li>
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015 <li class="md-nav__item md-nav__item--nested">
2016
2017
2018 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6_4" type="checkbox" id="__nav_6_4" >
2019
2020
2021
2022
2023 <label class="md-nav__link" for="__nav_6_4">
2024 From WoltLab Suite 5.2
2025 <span class="md-nav__icon md-icon"></span>
2026 </label>
2027
2028 <nav class="md-nav" aria-label="From WoltLab Suite 5.2" data-md-level="2">
2029 <label class="md-nav__title" for="__nav_6_4">
2030 <span class="md-nav__icon md-icon"></span>
2031 From WoltLab Suite 5.2
2032 </label>
2033 <ul class="md-nav__list" data-md-scrollfix>
2034
2035
2036
2037
2038
2039
2040 <li class="md-nav__item">
2041 <a href="../../wsc52/php/" class="md-nav__link">
2042 PHP API
2043 </a>
2044 </li>
2045
2046
2047
2048
2049
2050
2051
2052
2053
2054 <li class="md-nav__item">
2055 <a href="../../wsc52/templates/" class="md-nav__link">
2056 Templates and Languages
2057 </a>
2058 </li>
2059
2060
2061
2062
2063
2064
2065
2066
2067
2068 <li class="md-nav__item">
2069 <a href="../../wsc52/libraries/" class="md-nav__link">
2070 Third Party Libraries
2071 </a>
2072 </li>
2073
2074
2075
2076
2077 </ul>
2078 </nav>
2079 </li>
2080
2081
2082
2083
2084
2085
2086
2087
2088
2089
2090 <li class="md-nav__item md-nav__item--nested">
2091
2092
2093 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6_5" type="checkbox" id="__nav_6_5" >
2094
2095
2096
2097
2098 <label class="md-nav__link" for="__nav_6_5">
2099 From WoltLab Suite 3.1
2100 <span class="md-nav__icon md-icon"></span>
2101 </label>
2102
2103 <nav class="md-nav" aria-label="From WoltLab Suite 3.1" data-md-level="2">
2104 <label class="md-nav__title" for="__nav_6_5">
2105 <span class="md-nav__icon md-icon"></span>
2106 From WoltLab Suite 3.1
2107 </label>
2108 <ul class="md-nav__list" data-md-scrollfix>
2109
2110
2111
2112
2113
2114
2115 <li class="md-nav__item">
2116 <a href="../../wsc31/php/" class="md-nav__link">
2117 PHP API
2118 </a>
2119 </li>
2120
2121
2122
2123
2124 </ul>
2125 </nav>
2126 </li>
2127
2128
2129
2130
2131
2132
2133
2134
2135
2136
2137 <li class="md-nav__item md-nav__item--nested">
2138
2139
2140 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6_6" type="checkbox" id="__nav_6_6" >
2141
2142
2143
2144
2145 <label class="md-nav__link" for="__nav_6_6">
2146 From WoltLab Suite 3.0
2147 <span class="md-nav__icon md-icon"></span>
2148 </label>
2149
2150 <nav class="md-nav" aria-label="From WoltLab Suite 3.0" data-md-level="2">
2151 <label class="md-nav__title" for="__nav_6_6">
2152 <span class="md-nav__icon md-icon"></span>
2153 From WoltLab Suite 3.0
2154 </label>
2155 <ul class="md-nav__list" data-md-scrollfix>
2156
2157
2158
2159
2160
2161
2162 <li class="md-nav__item">
2163 <a href="../../wsc30/php/" class="md-nav__link">
2164 PHP API
2165 </a>
2166 </li>
2167
2168
2169
2170
2171
2172
2173
2174
2175
2176 <li class="md-nav__item">
2177 <a href="../../wsc30/javascript/" class="md-nav__link">
2178 JavaScript API
2179 </a>
2180 </li>
2181
2182
2183
2184
2185
2186
2187
2188
2189
2190 <li class="md-nav__item">
2191 <a href="../../wsc30/templates/" class="md-nav__link">
2192 Templates
2193 </a>
2194 </li>
2195
2196
2197
2198
2199
2200
2201
2202
2203
2204 <li class="md-nav__item">
2205 <a href="../../wsc30/css/" class="md-nav__link">
2206 CSS
2207 </a>
2208 </li>
2209
2210
2211
2212
2213
2214
2215
2216
2217
2218 <li class="md-nav__item">
2219 <a href="../../wsc30/package/" class="md-nav__link">
2220 Package Components
2221 </a>
2222 </li>
2223
2224
2225
2226
2227 </ul>
2228 </nav>
2229 </li>
2230
2231
2232
2233
2234
2235
2236
2237
2238
2239
2240 <li class="md-nav__item md-nav__item--nested">
2241
2242
2243 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6_7" type="checkbox" id="__nav_6_7" >
2244
2245
2246
2247
2248 <label class="md-nav__link" for="__nav_6_7">
2249 From WCF 2.1
2250 <span class="md-nav__icon md-icon"></span>
2251 </label>
2252
2253 <nav class="md-nav" aria-label="From WCF 2.1" data-md-level="2">
2254 <label class="md-nav__title" for="__nav_6_7">
2255 <span class="md-nav__icon md-icon"></span>
2256 From WCF 2.1
2257 </label>
2258 <ul class="md-nav__list" data-md-scrollfix>
2259
2260
2261
2262
2263
2264
2265 <li class="md-nav__item">
2266 <a href="../../wcf21/php/" class="md-nav__link">
2267 PHP API
2268 </a>
2269 </li>
2270
2271
2272
2273
2274
2275
2276
2277
2278
2279 <li class="md-nav__item">
2280 <a href="../../wcf21/templates/" class="md-nav__link">
2281 Templates
2282 </a>
2283 </li>
2284
2285
2286
2287
2288
2289
2290
2291
2292
2293 <li class="md-nav__item">
2294 <a href="../../wcf21/css/" class="md-nav__link">
2295 CSS
2296 </a>
2297 </li>
2298
2299
2300
2301
2302
2303
2304
2305
2306
2307 <li class="md-nav__item">
2308 <a href="../../wcf21/package/" class="md-nav__link">
2309 Package Components
2310 </a>
2311 </li>
2312
2313
2314
2315
2316 </ul>
2317 </nav>
2318 </li>
2319
2320
2321
2322
2323 </ul>
2324 </nav>
2325 </li>
2326
2327
2328
2329
2330
2331
2332
2333
2334
2335
2336
2337 <li class="md-nav__item md-nav__item--nested">
2338
2339
2340 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_7" type="checkbox" id="__nav_7" >
2341
2342
2343
2344
2345 <label class="md-nav__link" for="__nav_7">
2346 Tutorials
2347 <span class="md-nav__icon md-icon"></span>
2348 </label>
2349
2350 <nav class="md-nav" aria-label="Tutorials" data-md-level="1">
2351 <label class="md-nav__title" for="__nav_7">
2352 <span class="md-nav__icon md-icon"></span>
2353 Tutorials
2354 </label>
2355 <ul class="md-nav__list" data-md-scrollfix>
2356
2357
2358
2359
2360
2361
2362
2363 <li class="md-nav__item md-nav__item--nested">
2364
2365
2366 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_7_1" type="checkbox" id="__nav_7_1" >
2367
2368
2369
2370
2371 <label class="md-nav__link" for="__nav_7_1">
2372 Tutorial Series
2373 <span class="md-nav__icon md-icon"></span>
2374 </label>
2375
2376 <nav class="md-nav" aria-label="Tutorial Series" data-md-level="2">
2377 <label class="md-nav__title" for="__nav_7_1">
2378 <span class="md-nav__icon md-icon"></span>
2379 Tutorial Series
2380 </label>
2381 <ul class="md-nav__list" data-md-scrollfix>
2382
2383
2384
2385
2386
2387
2388 <li class="md-nav__item">
2389 <a href="../../../tutorial/series/overview/" class="md-nav__link">
2390 Overview
2391 </a>
2392 </li>
2393
2394
2395
2396
2397
2398
2399
2400
2401
2402 <li class="md-nav__item">
2403 <a href="../../../tutorial/series/part_1/" class="md-nav__link">
2404 Part 1
2405 </a>
2406 </li>
2407
2408
2409
2410
2411
2412
2413
2414
2415
2416 <li class="md-nav__item">
2417 <a href="../../../tutorial/series/part_2/" class="md-nav__link">
2418 Part 2
2419 </a>
2420 </li>
2421
2422
2423
2424
2425
2426
2427
2428
2429
2430 <li class="md-nav__item">
2431 <a href="../../../tutorial/series/part_3/" class="md-nav__link">
2432 Part 3
2433 </a>
2434 </li>
2435
2436
2437
2438
2439
2440
2441
2442
2443
2444 <li class="md-nav__item">
2445 <a href="../../../tutorial/series/part_4/" class="md-nav__link">
2446 Part 4
2447 </a>
2448 </li>
2449
2450
2451
2452
2453
2454
2455
2456
2457
2458 <li class="md-nav__item">
2459 <a href="../../../tutorial/series/part_5/" class="md-nav__link">
2460 Part 5
2461 </a>
2462 </li>
2463
2464
2465
2466
2467
2468
2469
2470
2471
2472 <li class="md-nav__item">
2473 <a href="../../../tutorial/series/part_6/" class="md-nav__link">
2474 Part 6
2475 </a>
2476 </li>
2477
2478
2479
2480
2481 </ul>
2482 </nav>
2483 </li>
2484
2485
2486
2487
2488 </ul>
2489 </nav>
2490 </li>
2491
2492
2493
2494 </ul>
2495</nav>
2496 </div>
2497 </div>
2498 </div>
2499
2500
2501
2502 <div class="md-sidebar md-sidebar--secondary" data-md-component="sidebar" data-md-type="toc" >
2503 <div class="md-sidebar__scrollwrap">
2504 <div class="md-sidebar__inner">
2505
2506
2507<nav class="md-nav md-nav--secondary" aria-label="Table of contents">
2508
2509
2510
2511
2512
2513
2514 <label class="md-nav__title" for="__toc">
2515 <span class="md-nav__icon md-icon"></span>
2516 Table of contents
2517 </label>
2518 <ul class="md-nav__list" data-md-component="toc" data-md-scrollfix>
2519
2520 <li class="md-nav__item">
2521 <a href="#minimum-requirements" class="md-nav__link">
2522 Minimum requirements
2523 </a>
2524
b2915b65
WG
2525</li>
2526
2527 <li class="md-nav__item">
2528 <a href="#subscribe-button-wcfuserobjectwatchsubscribe" class="md-nav__link">
2529 Subscribe Button (WCF.User.ObjectWatch.Subscribe)
2530 </a>
2531
9aa5da67
WG
2532</li>
2533
2534 </ul>
2535
2536</nav>
2537 </div>
2538 </div>
2539 </div>
2540
2541
2542 <div class="md-content" data-md-component="content">
2543 <article class="md-content__inner md-typeset">
2544
2545
2546 <a href="https://github.com/WoltLab/docs.woltlab.com/edit/6.0/docs/migration/wsc55/javascript.md" title="Edit this page" class="md-content__button md-icon">
2547 <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>
2548 </a>
2549
2550
2551
2552<h1 id="migrating-from-woltlab-suite-55-typescript-and-javascript">Migrating from WoltLab Suite 5.5 - TypeScript and JavaScript<a class="headerlink" href="#migrating-from-woltlab-suite-55-typescript-and-javascript" title="Permanent link">#</a></h1>
2553<h2 id="minimum-requirements">Minimum requirements<a class="headerlink" href="#minimum-requirements" title="Permanent link">#</a></h2>
2554<p>The ECMAScript target version has been increased to es2019 from es2017.</p>
b2915b65
WG
2555<h2 id="subscribe-button-wcfuserobjectwatchsubscribe">Subscribe Button (WCF.User.ObjectWatch.Subscribe)<a class="headerlink" href="#subscribe-button-wcfuserobjectwatchsubscribe" title="Permanent link">#</a></h2>
2556<p>We have replaced the old jQuery-based <code>WCF.User.ObjectWatch.Subscribe</code> with a more modern replacement <code>WoltLabSuite/Core/Ui/User/ObjectWatch</code>.</p>
2557<p>The new implementation comes with a ready-to-use template (<code>__userObjectWatchButton</code>) for use within <code>contentInteractionButtons</code>:
2558<div class="highlight"><table class="highlighttable"><tr><td class="linenos"><div class="linenodiv"><pre><span></span><span class="normal">1</span></pre></div></td><td class="code"><div><pre><span></span><code><span class="cp">{</span><span class="nf">include</span> <span class="na">file</span><span class="o">=</span><span class="s1">&#39;__userObjectWatchButton&#39;</span> <span class="na">isSubscribed</span><span class="o">=</span><span class="nv">$isSubscribed</span> <span class="na">objectType</span><span class="o">=</span><span class="s1">&#39;foo.bar&#39;</span> <span class="na">objectID</span><span class="o">=</span><span class="nv">$id</span><span class="cp">}</span><span class="x"></span>
2559</code></pre></div></td></tr></table></div></p>
2560<p>See <a href="https://github.com/WoltLab/WCF/pull/4962/">WoltLab/WCF#4962</a> for details.</p>
9aa5da67
WG
2561
2562 <hr>
2563<div class="md-source-file">
2564 <small>
2565
2566 Last update:
b2915b65 2567 2022-08-16
9aa5da67
WG
2568
2569 </small>
2570</div>
2571
2572
2573 </article>
2574
2575 </div>
2576 </div>
2577
2578 </main>
2579
2580 <footer class="md-footer">
2581
2582
2583 <nav class="md-footer__inner md-grid" aria-label="Footer" >
2584
2585
2586 <a href="../php/" class="md-footer__link md-footer__link--prev" aria-label="Previous: PHP API" rel="prev">
2587 <div class="md-footer__button md-icon">
2588 <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>
2589 </div>
2590 <div class="md-footer__title">
2591 <div class="md-ellipsis">
2592 <span class="md-footer__direction">
2593 Previous
2594 </span>
2595 PHP API
2596 </div>
2597 </div>
2598 </a>
2599
2600
2601
2602 <a href="../templates/" class="md-footer__link md-footer__link--next" aria-label="Next: Templates" rel="next">
2603 <div class="md-footer__title">
2604 <div class="md-ellipsis">
2605 <span class="md-footer__direction">
2606 Next
2607 </span>
2608 Templates
2609 </div>
2610 </div>
2611 <div class="md-footer__button md-icon">
2612 <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>
2613 </div>
2614 </a>
2615
2616 </nav>
2617
2618 <div class="md-footer-meta md-typeset">
2619 <div class="md-footer-meta__inner md-grid">
2620 <div class="md-copyright">
2621
2622 <div class="md-copyright__highlight">
2623 Copyright © 2020 WoltLab GmbH
2624 </div>
2625
2626
2627 Made with
2628 <a href="https://squidfunk.github.io/mkdocs-material/" target="_blank" rel="noopener">
2629 Material for MkDocs
2630 </a>
2631
2632</div>
2633
2634 <div class="md-copyright">
2635 <a href="https://www.woltlab.com/legal-notice/">Legal Notice</a>
2636 <a href="https://www.woltlab.com/privacy-policy/">Privacy Policy</a>
2637</div>
2638
2639 </div>
2640 </div>
2641</footer>
2642
2643 </div>
2644 <div class="md-dialog" data-md-component="dialog">
2645 <div class="md-dialog__inner md-typeset"></div>
2646 </div>
2647 <script id="__config" type="application/json">{"base": "../../..", "features": ["navigation.tracking"], "search": "../../../assets/javascripts/workers/search.b97dbffb.min.js", "translations": {"clipboard.copied": "Copied to clipboard", "clipboard.copy": "Copy to clipboard", "search.config.lang": "en", "search.config.pipeline": "trimmer, stopWordFilter", "search.config.separator": "[\\s\\-]+", "search.placeholder": "Search", "search.result.more.one": "1 more on this page", "search.result.more.other": "# more on this page", "search.result.none": "No matching documents", "search.result.one": "1 matching document", "search.result.other": "# matching documents", "search.result.placeholder": "Type to start searching", "search.result.term.missing": "Missing", "select.version.title": "Select version"}, "version": {"provider": "mike"}}</script>
2648
2649
2650 <script src="../../../assets/javascripts/bundle.6c7ad80a.min.js"></script>
2651
2652
2653 </body>
2654</html>