3 <html lang=
"en" class=
"no-js">
7 <meta name=
"viewport" content=
"width=device-width,initial-scale=1">
11 <link rel=
"canonical" href=
"https://docs.woltlab.com/6.0/migration/wsc30/templates/">
13 <link rel=
"icon" href=
"../../../assets/default.favicon.ico">
14 <meta name=
"generator" content=
"mkdocs-1.3.1, mkdocs-material-8.5.0">
18 <title>Templates - WoltLab Suite Documentation
</title>
22 <link rel=
"stylesheet" href=
"../../../assets/stylesheets/main.2e8b5541.min.css">
25 <link rel=
"stylesheet" href=
"../../../assets/stylesheets/palette.cbb835fc.min.css">
29 <meta name=
"theme-color" content=
"#009485">
40 <link rel=
"stylesheet" href=
"../../../stylesheets/extra.css">
42 <script>__md_scope=new URL(
"../../..",location),__md_hash=e=
>[...e].reduce((e,_)=
>(e<
<5)-e+_.charCodeAt(
0),
0),__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>
57 <body dir=
"ltr" data-md-color-scheme=
"" data-md-color-primary=
"teal" data-md-color-accent=
"">
61 <input class=
"md-toggle" data-md-toggle=
"drawer" type=
"checkbox" id=
"__drawer" autocomplete=
"off">
62 <input class=
"md-toggle" data-md-toggle=
"search" type=
"checkbox" id=
"__search" autocomplete=
"off">
63 <label class=
"md-overlay" for=
"__drawer"></label>
64 <div data-md-component=
"skip">
67 <a href=
"#migrating-from-wsc-30-templates" class=
"md-skip">
72 <div data-md-component=
"announce">
74 <aside class=
"md-banner">
75 <div class=
"md-banner__inner md-grid md-typeset">
78 <a href=
"https://www.woltlab.com">Back to
<strong>woltlab.com
</strong></a>
86 <div data-md-component=
"outdated" hidden
>
93 <header class=
"md-header" data-md-component=
"header">
94 <nav class=
"md-header__inner md-grid" aria-label=
"Header">
95 <a href=
"../../.." title=
"WoltLab Suite Documentation" class=
"md-header__button md-logo" aria-label=
"WoltLab Suite Documentation" data-md-component=
"logo">
97 <img src=
"../../../assets/logo.png" alt=
"logo">
100 <label class=
"md-header__button md-icon" for=
"__drawer">
101 <svg xmlns=
"http://www.w3.org/2000/svg" viewBox=
"0 0 24 24"><path d=
"M3 6h18v2H3V6m0 5h18v2H3v-2m0 5h18v2H3v-2Z"/></svg>
103 <div class=
"md-header__title" data-md-component=
"header-title">
104 <div class=
"md-header__ellipsis">
105 <div class=
"md-header__topic">
106 <span class=
"md-ellipsis">
107 WoltLab Suite Documentation
110 <div class=
"md-header__topic" data-md-component=
"header-topic">
111 <span class=
"md-ellipsis">
122 <label class=
"md-header__button md-icon" for=
"__search">
123 <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>
125 <div class=
"md-search" data-md-component=
"search" role=
"dialog">
126 <label class=
"md-search__overlay" for=
"__search"></label>
127 <div class=
"md-search__inner" role=
"search">
128 <form class=
"md-search__form" name=
"search">
129 <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
>
130 <label class=
"md-search__icon md-icon" for=
"__search">
131 <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>
132 <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>
134 <nav class=
"md-search__options" aria-label=
"Search">
136 <button type=
"reset" class=
"md-search__icon md-icon" title=
"Clear" aria-label=
"Clear" tabindex=
"-1">
137 <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>
142 <div class=
"md-search__output">
143 <div class=
"md-search__scrollwrap" data-md-scrollfix
>
144 <div class=
"md-search-result" data-md-component=
"search-result">
145 <div class=
"md-search-result__meta">
148 <ol class=
"md-search-result__list"></ol>
156 <div class=
"md-header__source">
157 <a href=
"https://github.com/WoltLab/docs.woltlab.com/" title=
"Go to repository" class=
"md-source" data-md-component=
"source">
158 <div class=
"md-source__icon md-icon">
160 <svg xmlns=
"http://www.w3.org/2000/svg" viewBox=
"0 0 448 512"><!--! Font Awesome Free 6.2.0 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>
162 <div class=
"md-source__repository">
172 <div class=
"md-container" data-md-component=
"container">
179 <main class=
"md-main" data-md-component=
"main">
180 <div class=
"md-main__inner md-grid">
184 <div class=
"md-sidebar md-sidebar--primary" data-md-component=
"sidebar" data-md-type=
"navigation" >
185 <div class=
"md-sidebar__scrollwrap">
186 <div class=
"md-sidebar__inner">
190 <nav class=
"md-nav md-nav--primary" aria-label=
"Navigation" data-md-level=
"0">
191 <label class=
"md-nav__title" for=
"__drawer">
192 <a href=
"../../.." title=
"WoltLab Suite Documentation" class=
"md-nav__button md-logo" aria-label=
"WoltLab Suite Documentation" data-md-component=
"logo">
194 <img src=
"../../../assets/logo.png" alt=
"logo">
197 WoltLab Suite Documentation
200 <div class=
"md-nav__source">
201 <a href=
"https://github.com/WoltLab/docs.woltlab.com/" title=
"Go to repository" class=
"md-source" data-md-component=
"source">
202 <div class=
"md-source__icon md-icon">
204 <svg xmlns=
"http://www.w3.org/2000/svg" viewBox=
"0 0 448 512"><!--! Font Awesome Free 6.2.0 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>
206 <div class=
"md-source__repository">
212 <ul class=
"md-nav__list" data-md-scrollfix
>
221 <li class=
"md-nav__item">
222 <a href=
"../../../getting-started/" class=
"md-nav__link">
237 <li class=
"md-nav__item md-nav__item--nested">
240 <input class=
"md-nav__toggle md-toggle" data-md-toggle=
"__nav_2" type=
"checkbox" id=
"__nav_2" >
245 <label class=
"md-nav__link" for=
"__nav_2">
247 <span class=
"md-nav__icon md-icon"></span>
250 <nav class=
"md-nav" aria-label=
"PHP API" data-md-level=
"1">
251 <label class=
"md-nav__title" for=
"__nav_2">
252 <span class=
"md-nav__icon md-icon"></span>
255 <ul class=
"md-nav__list" data-md-scrollfix
>
262 <li class=
"md-nav__item">
263 <a href=
"../../../php/pages/" class=
"md-nav__link">
276 <li class=
"md-nav__item">
277 <a href=
"../../../php/database-objects/" class=
"md-nav__link">
290 <li class=
"md-nav__item">
291 <a href=
"../../../php/database-access/" class=
"md-nav__link">
304 <li class=
"md-nav__item">
305 <a href=
"../../../php/exceptions/" class=
"md-nav__link">
319 <li class=
"md-nav__item md-nav__item--nested">
322 <input class=
"md-nav__toggle md-toggle" data-md-toggle=
"__nav_2_5" type=
"checkbox" id=
"__nav_2_5" >
327 <label class=
"md-nav__link" for=
"__nav_2_5">
329 <span class=
"md-nav__icon md-icon"></span>
332 <nav class=
"md-nav" aria-label=
"API" data-md-level=
"2">
333 <label class=
"md-nav__title" for=
"__nav_2_5">
334 <span class=
"md-nav__icon md-icon"></span>
337 <ul class=
"md-nav__list" data-md-scrollfix
>
345 <li class=
"md-nav__item md-nav__item--nested">
348 <input class=
"md-nav__toggle md-toggle" data-md-toggle=
"__nav_2_5_1" type=
"checkbox" id=
"__nav_2_5_1" >
353 <label class=
"md-nav__link" for=
"__nav_2_5_1">
355 <span class=
"md-nav__icon md-icon"></span>
358 <nav class=
"md-nav" aria-label=
"Caches" data-md-level=
"3">
359 <label class=
"md-nav__title" for=
"__nav_2_5_1">
360 <span class=
"md-nav__icon md-icon"></span>
363 <ul class=
"md-nav__list" data-md-scrollfix
>
370 <li class=
"md-nav__item">
371 <a href=
"../../../php/api/caches/" class=
"md-nav__link">
384 <li class=
"md-nav__item">
385 <a href=
"../../../php/api/caches_persistent-caches/" class=
"md-nav__link">
398 <li class=
"md-nav__item">
399 <a href=
"../../../php/api/caches_runtime-caches/" class=
"md-nav__link">
419 <li class=
"md-nav__item">
420 <a href=
"../../../php/api/comments/" class=
"md-nav__link">
433 <li class=
"md-nav__item">
434 <a href=
"../../../php/api/cronjobs/" class=
"md-nav__link">
447 <li class=
"md-nav__item">
448 <a href=
"../../../php/api/events/" class=
"md-nav__link">
462 <li class=
"md-nav__item md-nav__item--nested">
465 <input class=
"md-nav__toggle md-toggle" data-md-toggle=
"__nav_2_5_5" type=
"checkbox" id=
"__nav_2_5_5" >
470 <label class=
"md-nav__link" for=
"__nav_2_5_5">
472 <span class=
"md-nav__icon md-icon"></span>
475 <nav class=
"md-nav" aria-label=
"Form Builder" data-md-level=
"3">
476 <label class=
"md-nav__title" for=
"__nav_2_5_5">
477 <span class=
"md-nav__icon md-icon"></span>
480 <ul class=
"md-nav__list" data-md-scrollfix
>
487 <li class=
"md-nav__item">
488 <a href=
"../../../php/api/form_builder/overview/" class=
"md-nav__link">
501 <li class=
"md-nav__item">
502 <a href=
"../../../php/api/form_builder/structure/" class=
"md-nav__link">
515 <li class=
"md-nav__item">
516 <a href=
"../../../php/api/form_builder/form_fields/" class=
"md-nav__link">
529 <li class=
"md-nav__item">
530 <a href=
"../../../php/api/form_builder/validation_data/" class=
"md-nav__link">
543 <li class=
"md-nav__item">
544 <a href=
"../../../php/api/form_builder/dependencies/" class=
"md-nav__link">
564 <li class=
"md-nav__item">
565 <a href=
"../../../php/api/package_installation_plugins/" class=
"md-nav__link">
566 Package Installation Plugins
578 <li class=
"md-nav__item">
579 <a href=
"../../../php/api/user_activity_points/" class=
"md-nav__link">
592 <li class=
"md-nav__item">
593 <a href=
"../../../php/api/user_notifications/" class=
"md-nav__link">
606 <li class=
"md-nav__item">
607 <a href=
"../../../php/api/sitemaps/" class=
"md-nav__link">
627 <li class=
"md-nav__item">
628 <a href=
"../../../php/code-style/" class=
"md-nav__link">
641 <li class=
"md-nav__item">
642 <a href=
"../../../php/apps/" class=
"md-nav__link">
655 <li class=
"md-nav__item">
656 <a href=
"../../../php/gdpr/" class=
"md-nav__link">
678 <li class=
"md-nav__item md-nav__item--nested">
681 <input class=
"md-nav__toggle md-toggle" data-md-toggle=
"__nav_3" type=
"checkbox" id=
"__nav_3" >
686 <label class=
"md-nav__link" for=
"__nav_3">
687 Languages, Templates & CSS
688 <span class=
"md-nav__icon md-icon"></span>
691 <nav class=
"md-nav" aria-label=
"Languages, Templates & CSS" data-md-level=
"1">
692 <label class=
"md-nav__title" for=
"__nav_3">
693 <span class=
"md-nav__icon md-icon"></span>
694 Languages, Templates & CSS
696 <ul class=
"md-nav__list" data-md-scrollfix
>
703 <li class=
"md-nav__item">
704 <a href=
"../../../view/languages/" class=
"md-nav__link">
717 <li class=
"md-nav__item">
718 <a href=
"../../../view/templates/" class=
"md-nav__link">
731 <li class=
"md-nav__item">
732 <a href=
"../../../view/template-plugins/" class=
"md-nav__link">
745 <li class=
"md-nav__item">
746 <a href=
"../../../view/css/" class=
"md-nav__link">
768 <li class=
"md-nav__item md-nav__item--nested">
771 <input class=
"md-nav__toggle md-toggle" data-md-toggle=
"__nav_4" type=
"checkbox" id=
"__nav_4" >
776 <label class=
"md-nav__link" for=
"__nav_4">
777 TypeScript and JavaScript API
778 <span class=
"md-nav__icon md-icon"></span>
781 <nav class=
"md-nav" aria-label=
"TypeScript and JavaScript API" data-md-level=
"1">
782 <label class=
"md-nav__title" for=
"__nav_4">
783 <span class=
"md-nav__icon md-icon"></span>
784 TypeScript and JavaScript API
786 <ul class=
"md-nav__list" data-md-scrollfix
>
793 <li class=
"md-nav__item">
794 <a href=
"../../../javascript/general-usage/" class=
"md-nav__link">
807 <li class=
"md-nav__item">
808 <a href=
"../../../javascript/typescript/" class=
"md-nav__link">
822 <li class=
"md-nav__item md-nav__item--nested">
825 <input class=
"md-nav__toggle md-toggle" data-md-toggle=
"__nav_4_3" type=
"checkbox" id=
"__nav_4_3" >
830 <label class=
"md-nav__link" for=
"__nav_4_3">
832 <span class=
"md-nav__icon md-icon"></span>
835 <nav class=
"md-nav" aria-label=
"New API" data-md-level=
"2">
836 <label class=
"md-nav__title" for=
"__nav_4_3">
837 <span class=
"md-nav__icon md-icon"></span>
840 <ul class=
"md-nav__list" data-md-scrollfix
>
847 <li class=
"md-nav__item">
848 <a href=
"../../../javascript/new-api_writing-a-module/" class=
"md-nav__link">
861 <li class=
"md-nav__item">
862 <a href=
"../../../javascript/new-api_data-structures/" class=
"md-nav__link">
875 <li class=
"md-nav__item">
876 <a href=
"../../../javascript/new-api_core/" class=
"md-nav__link">
889 <li class=
"md-nav__item">
890 <a href=
"../../../javascript/new-api_dom/" class=
"md-nav__link">
903 <li class=
"md-nav__item">
904 <a href=
"../../../javascript/new-api_events/" class=
"md-nav__link">
917 <li class=
"md-nav__item">
918 <a href=
"../../../javascript/new-api_ajax/" class=
"md-nav__link">
931 <li class=
"md-nav__item">
932 <a href=
"../../../javascript/new-api_dialogs/" class=
"md-nav__link">
945 <li class=
"md-nav__item">
946 <a href=
"../../../javascript/new-api_browser/" class=
"md-nav__link">
947 Browser and Screen Sizes
959 <li class=
"md-nav__item">
960 <a href=
"../../../javascript/new-api_ui/" class=
"md-nav__link">
980 <li class=
"md-nav__item">
981 <a href=
"../../../javascript/legacy-api/" class=
"md-nav__link">
994 <li class=
"md-nav__item">
995 <a href=
"../../../javascript/helper-functions/" class=
"md-nav__link">
1008 <li class=
"md-nav__item">
1009 <a href=
"../../../javascript/code-snippets/" class=
"md-nav__link">
1031 <li class=
"md-nav__item md-nav__item--nested">
1034 <input class=
"md-nav__toggle md-toggle" data-md-toggle=
"__nav_5" type=
"checkbox" id=
"__nav_5" >
1039 <label class=
"md-nav__link" for=
"__nav_5">
1041 <span class=
"md-nav__icon md-icon"></span>
1044 <nav class=
"md-nav" aria-label=
"Package Components" data-md-level=
"1">
1045 <label class=
"md-nav__title" for=
"__nav_5">
1046 <span class=
"md-nav__icon md-icon"></span>
1049 <ul class=
"md-nav__list" data-md-scrollfix
>
1056 <li class=
"md-nav__item">
1057 <a href=
"../../../package/package-xml/" class=
"md-nav__link">
1071 <li class=
"md-nav__item md-nav__item--nested">
1074 <input class=
"md-nav__toggle md-toggle" data-md-toggle=
"__nav_5_2" type=
"checkbox" id=
"__nav_5_2" >
1079 <label class=
"md-nav__link" for=
"__nav_5_2">
1081 <span class=
"md-nav__icon md-icon"></span>
1084 <nav class=
"md-nav" aria-label=
"PIPs" data-md-level=
"2">
1085 <label class=
"md-nav__title" for=
"__nav_5_2">
1086 <span class=
"md-nav__icon md-icon"></span>
1089 <ul class=
"md-nav__list" data-md-scrollfix
>
1096 <li class=
"md-nav__item">
1097 <a href=
"../../../package/pip/" class=
"md-nav__link">
1110 <li class=
"md-nav__item">
1111 <a href=
"../../../package/pip/acl-option/" class=
"md-nav__link">
1124 <li class=
"md-nav__item">
1125 <a href=
"../../../package/pip/acp-menu/" class=
"md-nav__link">
1138 <li class=
"md-nav__item">
1139 <a href=
"../../../package/pip/acp-search-provider/" class=
"md-nav__link">
1152 <li class=
"md-nav__item">
1153 <a href=
"../../../package/pip/acp-template/" class=
"md-nav__link">
1166 <li class=
"md-nav__item">
1167 <a href=
"../../../package/pip/acp-template-delete/" class=
"md-nav__link">
1180 <li class=
"md-nav__item">
1181 <a href=
"../../../package/pip/bbcode/" class=
"md-nav__link">
1194 <li class=
"md-nav__item">
1195 <a href=
"../../../package/pip/box/" class=
"md-nav__link">
1208 <li class=
"md-nav__item">
1209 <a href=
"../../../package/pip/clipboard-action/" class=
"md-nav__link">
1222 <li class=
"md-nav__item">
1223 <a href=
"../../../package/pip/core-object/" class=
"md-nav__link">
1236 <li class=
"md-nav__item">
1237 <a href=
"../../../package/pip/cronjob/" class=
"md-nav__link">
1250 <li class=
"md-nav__item">
1251 <a href=
"../../../package/pip/database/" class=
"md-nav__link">
1264 <li class=
"md-nav__item">
1265 <a href=
"../../../package/pip/event-listener/" class=
"md-nav__link">
1278 <li class=
"md-nav__item">
1279 <a href=
"../../../package/pip/file/" class=
"md-nav__link">
1292 <li class=
"md-nav__item">
1293 <a href=
"../../../package/pip/file-delete/" class=
"md-nav__link">
1306 <li class=
"md-nav__item">
1307 <a href=
"../../../package/pip/language/" class=
"md-nav__link">
1320 <li class=
"md-nav__item">
1321 <a href=
"../../../package/pip/media-provider/" class=
"md-nav__link">
1334 <li class=
"md-nav__item">
1335 <a href=
"../../../package/pip/menu/" class=
"md-nav__link">
1348 <li class=
"md-nav__item">
1349 <a href=
"../../../package/pip/menu-item/" class=
"md-nav__link">
1362 <li class=
"md-nav__item">
1363 <a href=
"../../../package/pip/object-type/" class=
"md-nav__link">
1376 <li class=
"md-nav__item">
1377 <a href=
"../../../package/pip/object-type-definition/" class=
"md-nav__link">
1378 objectTypeDefinition
1390 <li class=
"md-nav__item">
1391 <a href=
"../../../package/pip/option/" class=
"md-nav__link">
1404 <li class=
"md-nav__item">
1405 <a href=
"../../../package/pip/page/" class=
"md-nav__link">
1418 <li class=
"md-nav__item">
1419 <a href=
"../../../package/pip/pip/" class=
"md-nav__link">
1432 <li class=
"md-nav__item">
1433 <a href=
"../../../package/pip/script/" class=
"md-nav__link">
1446 <li class=
"md-nav__item">
1447 <a href=
"../../../package/pip/smiley/" class=
"md-nav__link">
1460 <li class=
"md-nav__item">
1461 <a href=
"../../../package/pip/sql/" class=
"md-nav__link">
1474 <li class=
"md-nav__item">
1475 <a href=
"../../../package/pip/style/" class=
"md-nav__link">
1488 <li class=
"md-nav__item">
1489 <a href=
"../../../package/pip/template/" class=
"md-nav__link">
1502 <li class=
"md-nav__item">
1503 <a href=
"../../../package/pip/template-delete/" class=
"md-nav__link">
1516 <li class=
"md-nav__item">
1517 <a href=
"../../../package/pip/template-listener/" class=
"md-nav__link">
1530 <li class=
"md-nav__item">
1531 <a href=
"../../../package/pip/user-group-option/" class=
"md-nav__link">
1544 <li class=
"md-nav__item">
1545 <a href=
"../../../package/pip/user-menu/" class=
"md-nav__link">
1558 <li class=
"md-nav__item">
1559 <a href=
"../../../package/pip/user-notification-event/" class=
"md-nav__link">
1560 userNotificationEvent
1572 <li class=
"md-nav__item">
1573 <a href=
"../../../package/pip/user-option/" class=
"md-nav__link">
1586 <li class=
"md-nav__item">
1587 <a href=
"../../../package/pip/user-profile-menu/" class=
"md-nav__link">
1607 <li class=
"md-nav__item">
1608 <a href=
"../../../package/database-php-api/" class=
"md-nav__link">
1632 <li class=
"md-nav__item md-nav__item--active md-nav__item--nested">
1635 <input class=
"md-nav__toggle md-toggle" data-md-toggle=
"__nav_6" type=
"checkbox" id=
"__nav_6" checked
>
1640 <label class=
"md-nav__link" for=
"__nav_6">
1642 <span class=
"md-nav__icon md-icon"></span>
1645 <nav class=
"md-nav" aria-label=
"Migration" data-md-level=
"1">
1646 <label class=
"md-nav__title" for=
"__nav_6">
1647 <span class=
"md-nav__icon md-icon"></span>
1650 <ul class=
"md-nav__list" data-md-scrollfix
>
1658 <li class=
"md-nav__item md-nav__item--nested">
1661 <input class=
"md-nav__toggle md-toggle" data-md-toggle=
"__nav_6_1" type=
"checkbox" id=
"__nav_6_1" >
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>
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
1676 <ul class=
"md-nav__list" data-md-scrollfix
>
1683 <li class=
"md-nav__item">
1684 <a href=
"../../wsc55/php/" class=
"md-nav__link">
1697 <li class=
"md-nav__item">
1698 <a href=
"../../wsc55/javascript/" class=
"md-nav__link">
1699 TypeScript and JavaScript
1711 <li class=
"md-nav__item">
1712 <a href=
"../../wsc55/templates/" class=
"md-nav__link">
1725 <li class=
"md-nav__item">
1726 <a href=
"../../wsc55/libraries/" class=
"md-nav__link">
1727 Third Party Libraries
1739 <li class=
"md-nav__item">
1740 <a href=
"../../wsc55/deprecations_removals/" class=
"md-nav__link">
1741 Deprecations and Removals
1761 <li class=
"md-nav__item md-nav__item--nested">
1764 <input class=
"md-nav__toggle md-toggle" data-md-toggle=
"__nav_6_2" type=
"checkbox" id=
"__nav_6_2" >
1769 <label class=
"md-nav__link" for=
"__nav_6_2">
1770 From WoltLab Suite
5.4
1771 <span class=
"md-nav__icon md-icon"></span>
1774 <nav class=
"md-nav" aria-label=
"From WoltLab Suite 5.4" data-md-level=
"2">
1775 <label class=
"md-nav__title" for=
"__nav_6_2">
1776 <span class=
"md-nav__icon md-icon"></span>
1777 From WoltLab Suite
5.4
1779 <ul class=
"md-nav__list" data-md-scrollfix
>
1786 <li class=
"md-nav__item">
1787 <a href=
"../../wsc54/php/" class=
"md-nav__link">
1800 <li class=
"md-nav__item">
1801 <a href=
"../../wsc54/javascript/" class=
"md-nav__link">
1802 TypeScript and JavaScript
1814 <li class=
"md-nav__item">
1815 <a href=
"../../wsc54/templates/" class=
"md-nav__link">
1828 <li class=
"md-nav__item">
1829 <a href=
"../../wsc54/libraries/" class=
"md-nav__link">
1830 Third Party Libraries
1842 <li class=
"md-nav__item">
1843 <a href=
"../../wsc54/deprecations_removals/" class=
"md-nav__link">
1844 Deprecations and Removals
1864 <li class=
"md-nav__item md-nav__item--nested">
1867 <input class=
"md-nav__toggle md-toggle" data-md-toggle=
"__nav_6_3" type=
"checkbox" id=
"__nav_6_3" >
1872 <label class=
"md-nav__link" for=
"__nav_6_3">
1873 From WoltLab Suite
5.3
1874 <span class=
"md-nav__icon md-icon"></span>
1877 <nav class=
"md-nav" aria-label=
"From WoltLab Suite 5.3" data-md-level=
"2">
1878 <label class=
"md-nav__title" for=
"__nav_6_3">
1879 <span class=
"md-nav__icon md-icon"></span>
1880 From WoltLab Suite
5.3
1882 <ul class=
"md-nav__list" data-md-scrollfix
>
1889 <li class=
"md-nav__item">
1890 <a href=
"../../wsc53/php/" class=
"md-nav__link">
1903 <li class=
"md-nav__item">
1904 <a href=
"../../wsc53/session/" class=
"md-nav__link">
1905 Session Handling and Authentication
1917 <li class=
"md-nav__item">
1918 <a href=
"../../wsc53/javascript/" class=
"md-nav__link">
1919 TypeScript and JavaScript
1931 <li class=
"md-nav__item">
1932 <a href=
"../../wsc53/templates/" class=
"md-nav__link">
1945 <li class=
"md-nav__item">
1946 <a href=
"../../wsc53/libraries/" class=
"md-nav__link">
1947 Third Party Libraries
1967 <li class=
"md-nav__item md-nav__item--nested">
1970 <input class=
"md-nav__toggle md-toggle" data-md-toggle=
"__nav_6_4" type=
"checkbox" id=
"__nav_6_4" >
1975 <label class=
"md-nav__link" for=
"__nav_6_4">
1976 From WoltLab Suite
5.2
1977 <span class=
"md-nav__icon md-icon"></span>
1980 <nav class=
"md-nav" aria-label=
"From WoltLab Suite 5.2" data-md-level=
"2">
1981 <label class=
"md-nav__title" for=
"__nav_6_4">
1982 <span class=
"md-nav__icon md-icon"></span>
1983 From WoltLab Suite
5.2
1985 <ul class=
"md-nav__list" data-md-scrollfix
>
1992 <li class=
"md-nav__item">
1993 <a href=
"../../wsc52/php/" class=
"md-nav__link">
2006 <li class=
"md-nav__item">
2007 <a href=
"../../wsc52/templates/" class=
"md-nav__link">
2008 Templates and Languages
2020 <li class=
"md-nav__item">
2021 <a href=
"../../wsc52/libraries/" class=
"md-nav__link">
2022 Third Party Libraries
2042 <li class=
"md-nav__item md-nav__item--nested">
2045 <input class=
"md-nav__toggle md-toggle" data-md-toggle=
"__nav_6_5" type=
"checkbox" id=
"__nav_6_5" >
2050 <label class=
"md-nav__link" for=
"__nav_6_5">
2051 From WoltLab Suite
3.1
2052 <span class=
"md-nav__icon md-icon"></span>
2055 <nav class=
"md-nav" aria-label=
"From WoltLab Suite 3.1" data-md-level=
"2">
2056 <label class=
"md-nav__title" for=
"__nav_6_5">
2057 <span class=
"md-nav__icon md-icon"></span>
2058 From WoltLab Suite
3.1
2060 <ul class=
"md-nav__list" data-md-scrollfix
>
2067 <li class=
"md-nav__item">
2068 <a href=
"../../wsc31/php/" class=
"md-nav__link">
2091 <li class=
"md-nav__item md-nav__item--active md-nav__item--nested">
2094 <input class=
"md-nav__toggle md-toggle" data-md-toggle=
"__nav_6_6" type=
"checkbox" id=
"__nav_6_6" checked
>
2099 <label class=
"md-nav__link" for=
"__nav_6_6">
2100 From WoltLab Suite
3.0
2101 <span class=
"md-nav__icon md-icon"></span>
2104 <nav class=
"md-nav" aria-label=
"From WoltLab Suite 3.0" data-md-level=
"2">
2105 <label class=
"md-nav__title" for=
"__nav_6_6">
2106 <span class=
"md-nav__icon md-icon"></span>
2107 From WoltLab Suite
3.0
2109 <ul class=
"md-nav__list" data-md-scrollfix
>
2116 <li class=
"md-nav__item">
2117 <a href=
"../php/" class=
"md-nav__link">
2130 <li class=
"md-nav__item">
2131 <a href=
"../javascript/" class=
"md-nav__link">
2146 <li class=
"md-nav__item md-nav__item--active">
2148 <input class=
"md-nav__toggle md-toggle" data-md-toggle=
"toc" type=
"checkbox" id=
"__toc">
2154 <label class=
"md-nav__link md-nav__link--active" for=
"__toc">
2156 <span class=
"md-nav__icon md-icon"></span>
2159 <a href=
"./" class=
"md-nav__link md-nav__link--active">
2165 <nav class=
"md-nav md-nav--secondary" aria-label=
"Table of contents">
2172 <label class=
"md-nav__title" for=
"__toc">
2173 <span class=
"md-nav__icon md-icon"></span>
2176 <ul class=
"md-nav__list" data-md-component=
"toc" data-md-scrollfix
>
2178 <li class=
"md-nav__item">
2179 <a href=
"#comment-system-overhaul" class=
"md-nav__link">
2180 Comment-System Overhaul
2183 <nav class=
"md-nav" aria-label=
"Comment-System Overhaul">
2184 <ul class=
"md-nav__list">
2186 <li class=
"md-nav__item">
2187 <a href=
"#adding-comments" class=
"md-nav__link">
2198 <li class=
"md-nav__item">
2199 <a href=
"#redesigned-acp-user-list" class=
"md-nav__link">
2200 Redesigned ACP User List
2205 <li class=
"md-nav__item">
2206 <a href=
"#sidebar-toogle-buttons-on-mobile-device" class=
"md-nav__link">
2207 Sidebar Toogle-Buttons on Mobile Device
2226 <li class=
"md-nav__item">
2227 <a href=
"../css/" class=
"md-nav__link">
2240 <li class=
"md-nav__item">
2241 <a href=
"../package/" class=
"md-nav__link">
2262 <li class=
"md-nav__item md-nav__item--nested">
2265 <input class=
"md-nav__toggle md-toggle" data-md-toggle=
"__nav_6_7" type=
"checkbox" id=
"__nav_6_7" >
2270 <label class=
"md-nav__link" for=
"__nav_6_7">
2272 <span class=
"md-nav__icon md-icon"></span>
2275 <nav class=
"md-nav" aria-label=
"From WCF 2.1" data-md-level=
"2">
2276 <label class=
"md-nav__title" for=
"__nav_6_7">
2277 <span class=
"md-nav__icon md-icon"></span>
2280 <ul class=
"md-nav__list" data-md-scrollfix
>
2287 <li class=
"md-nav__item">
2288 <a href=
"../../wcf21/php/" class=
"md-nav__link">
2301 <li class=
"md-nav__item">
2302 <a href=
"../../wcf21/templates/" class=
"md-nav__link">
2315 <li class=
"md-nav__item">
2316 <a href=
"../../wcf21/css/" class=
"md-nav__link">
2329 <li class=
"md-nav__item">
2330 <a href=
"../../wcf21/package/" class=
"md-nav__link">
2359 <li class=
"md-nav__item md-nav__item--nested">
2362 <input class=
"md-nav__toggle md-toggle" data-md-toggle=
"__nav_7" type=
"checkbox" id=
"__nav_7" >
2367 <label class=
"md-nav__link" for=
"__nav_7">
2369 <span class=
"md-nav__icon md-icon"></span>
2372 <nav class=
"md-nav" aria-label=
"Tutorials" data-md-level=
"1">
2373 <label class=
"md-nav__title" for=
"__nav_7">
2374 <span class=
"md-nav__icon md-icon"></span>
2377 <ul class=
"md-nav__list" data-md-scrollfix
>
2385 <li class=
"md-nav__item md-nav__item--nested">
2388 <input class=
"md-nav__toggle md-toggle" data-md-toggle=
"__nav_7_1" type=
"checkbox" id=
"__nav_7_1" >
2393 <label class=
"md-nav__link" for=
"__nav_7_1">
2395 <span class=
"md-nav__icon md-icon"></span>
2398 <nav class=
"md-nav" aria-label=
"Tutorial Series" data-md-level=
"2">
2399 <label class=
"md-nav__title" for=
"__nav_7_1">
2400 <span class=
"md-nav__icon md-icon"></span>
2403 <ul class=
"md-nav__list" data-md-scrollfix
>
2410 <li class=
"md-nav__item">
2411 <a href=
"../../../tutorial/series/overview/" class=
"md-nav__link">
2424 <li class=
"md-nav__item">
2425 <a href=
"../../../tutorial/series/part_1/" class=
"md-nav__link">
2438 <li class=
"md-nav__item">
2439 <a href=
"../../../tutorial/series/part_2/" class=
"md-nav__link">
2452 <li class=
"md-nav__item">
2453 <a href=
"../../../tutorial/series/part_3/" class=
"md-nav__link">
2466 <li class=
"md-nav__item">
2467 <a href=
"../../../tutorial/series/part_4/" class=
"md-nav__link">
2480 <li class=
"md-nav__item">
2481 <a href=
"../../../tutorial/series/part_5/" class=
"md-nav__link">
2494 <li class=
"md-nav__item">
2495 <a href=
"../../../tutorial/series/part_6/" class=
"md-nav__link">
2524 <div class=
"md-sidebar md-sidebar--secondary" data-md-component=
"sidebar" data-md-type=
"toc" >
2525 <div class=
"md-sidebar__scrollwrap">
2526 <div class=
"md-sidebar__inner">
2529 <nav class=
"md-nav md-nav--secondary" aria-label=
"Table of contents">
2536 <label class=
"md-nav__title" for=
"__toc">
2537 <span class=
"md-nav__icon md-icon"></span>
2540 <ul class=
"md-nav__list" data-md-component=
"toc" data-md-scrollfix
>
2542 <li class=
"md-nav__item">
2543 <a href=
"#comment-system-overhaul" class=
"md-nav__link">
2544 Comment-System Overhaul
2547 <nav class=
"md-nav" aria-label=
"Comment-System Overhaul">
2548 <ul class=
"md-nav__list">
2550 <li class=
"md-nav__item">
2551 <a href=
"#adding-comments" class=
"md-nav__link">
2562 <li class=
"md-nav__item">
2563 <a href=
"#redesigned-acp-user-list" class=
"md-nav__link">
2564 Redesigned ACP User List
2569 <li class=
"md-nav__item">
2570 <a href=
"#sidebar-toogle-buttons-on-mobile-device" class=
"md-nav__link">
2571 Sidebar Toogle-Buttons on Mobile Device
2585 <div class=
"md-content" data-md-component=
"content">
2586 <article class=
"md-content__inner md-typeset">
2590 <a href=
"https://github.com/WoltLab/docs.woltlab.com/edit/6.0/docs/migration/wsc30/templates.md" title=
"Edit this page" class=
"md-content__button md-icon">
2592 <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>
2596 <h1 id=
"migrating-from-wsc-30-templates">Migrating from WSC
3.0 - Templates
<a class=
"headerlink" href=
"#migrating-from-wsc-30-templates" title=
"Permanent link">#
</a></h1>
2597 <h2 id=
"comment-system-overhaul">Comment-System Overhaul
<a class=
"headerlink" href=
"#comment-system-overhaul" title=
"Permanent link">#
</a></h2>
2598 <div class=
"admonition danger">
2599 <p class=
"admonition-title">Unfortunately, there has been a breaking change related to the creation of comments. You need to apply the changes below before being able to create new comments.
</p>
2601 <h3 id=
"adding-comments">Adding Comments
<a class=
"headerlink" href=
"#adding-comments" title=
"Permanent link">#
</a></h3>
2602 <p>Existing implementations need to include a new template right before including the generic
<code>commentList
</code> template.
</p>
2603 <div class=
"highlight"><table class=
"highlighttable"><tr><td class=
"linenos"><div class=
"linenodiv"><pre><span></span><span class=
"normal">1</span>
2604 <span class=
"normal">2</span>
2605 <span class=
"normal">3</span>
2606 <span class=
"normal">4</span></pre></div></td><td class=
"code"><div><pre><span></span><code><span class=
"p"><</span><span class=
"nt">ul
</span> <span class=
"na">id
</span><span class=
"o">=
</span><span class=
"s">"exampleCommentList
"</span> <span class=
"na">class
</span><span class=
"o">=
</span><span class=
"s">"commentList containerList
"</span> <span class=
"na">data-
</span><span class=
"err">...
</span><span class=
"p">></span>
2607 {include file=
'commentListAddComment
' wysiwygSelector=
'exampleCommentListAddComment
'}
2608 {include file=
'commentList
'}
2609 <span class=
"p"></
</span><span class=
"nt">ul
</span><span class=
"p">></span>
2610 </code></pre></div></td></tr></table></div>
2611 <h2 id=
"redesigned-acp-user-list">Redesigned ACP User List
<a class=
"headerlink" href=
"#redesigned-acp-user-list" title=
"Permanent link">#
</a></h2>
2612 <p>Custom interaction buttons were previously added through the template event
<code>rowButtons
</code> and were merely a link-like element with an icon inside. This is still valid and supported for backwards-compatibility, but it is recommend to adapt to the new drop-down-style options using the new template event
<code>dropdownItems
</code>.
</p>
2613 <div class=
"highlight"><table class=
"highlighttable"><tr><td class=
"linenos"><div class=
"linenodiv"><pre><span></span><span class=
"normal">1</span>
2614 <span class=
"normal">2</span>
2615 <span class=
"normal">3</span>
2616 <span class=
"normal">4</span>
2617 <span class=
"normal">5</span></pre></div></td><td class=
"code"><div><pre><span></span><code><span class=
"cm"><!-- button for usage with the `rowButtons` event --
></span>
2618 <span class=
"p"><</span><span class=
"nt">span
</span> <span class=
"na">class
</span><span class=
"o">=
</span><span class=
"s">"icon icon16 fa-list jsTooltip
"</span> <span class=
"na">title
</span><span class=
"o">=
</span><span class=
"s">"Button Title
"</span><span class=
"p">></
</span><span class=
"nt">span
</span><span class=
"p">></span>
2620 <span class=
"cm"><!-- new drop-down item for the `dropdownItems` event --
></span>
2621 <span class=
"p"><</span><span class=
"nt">li
</span><span class=
"p">><</span><span class=
"nt">a
</span> <span class=
"na">href
</span><span class=
"o">=
</span><span class=
"s">"#
"</span> <span class=
"na">class
</span><span class=
"o">=
</span><span class=
"s">"jsMyButton
"</span><span class=
"p">></span>Button Title
<span class=
"p"></
</span><span class=
"nt">a
</span><span class=
"p">></
</span><span class=
"nt">li
</span><span class=
"p">></span>
2622 </code></pre></div></td></tr></table></div>
2623 <h2 id=
"sidebar-toogle-buttons-on-mobile-device">Sidebar Toogle-Buttons on Mobile Device
<a class=
"headerlink" href=
"#sidebar-toogle-buttons-on-mobile-device" title=
"Permanent link">#
</a></h2>
2624 <div class=
"admonition info">
2625 <p class=
"admonition-title">You cannot override the button label for sidebars containing navigation menus.
</p>
2627 <p>The page sidebars are automatically collapsed and presented as one or, when both sidebar are present, two condensed buttons. They use generic sidebar-related labels when open or closed, with the exception of embedded menus which will change the button label to read
"Show/Hide Navigation".
</p>
2628 <p>You can provide a custom label before including the sidebars by assigning the new labels to a few special variables:
</p>
2629 <div class=
"highlight"><table class=
"highlighttable"><tr><td class=
"linenos"><div class=
"linenodiv"><pre><span></span><span class=
"normal">1</span>
2630 <span class=
"normal">2</span>
2631 <span class=
"normal">3</span>
2632 <span class=
"normal">4</span></pre></div></td><td class=
"code"><div><pre><span></span><code>{assign var=
'__sidebarLeftShow
' value=
'Show Left Sidebar
'}
2633 {assign var=
'__sidebarLeftHide
' value=
'Hide Left Sidebar
'}
2634 {assign var=
'__sidebarRightShow
' value=
'Show Right Sidebar
'}
2635 {assign var=
'__sidebarRightHide
' value=
'Hide Right Sidebar
'}
2636 </code></pre></div></td></tr></table></div>
2639 <div class=
"md-source-file">
2661 <footer class=
"md-footer">
2664 <nav class=
"md-footer__inner md-grid" aria-label=
"Footer" >
2667 <a href=
"../javascript/" class=
"md-footer__link md-footer__link--prev" aria-label=
"Previous: JavaScript API" rel=
"prev">
2668 <div class=
"md-footer__button md-icon">
2669 <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>
2671 <div class=
"md-footer__title">
2672 <div class=
"md-ellipsis">
2673 <span class=
"md-footer__direction">
2683 <a href=
"../css/" class=
"md-footer__link md-footer__link--next" aria-label=
"Next: CSS" rel=
"next">
2684 <div class=
"md-footer__title">
2685 <div class=
"md-ellipsis">
2686 <span class=
"md-footer__direction">
2692 <div class=
"md-footer__button md-icon">
2693 <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>
2699 <div class=
"md-footer-meta md-typeset">
2700 <div class=
"md-footer-meta__inner md-grid">
2701 <div class=
"md-copyright">
2703 <div class=
"md-copyright__highlight">
2704 Copyright ©
2020 WoltLab GmbH
2709 <a href=
"https://squidfunk.github.io/mkdocs-material/" target=
"_blank" rel=
"noopener">
2715 <div class=
"md-copyright">
2716 <a href=
"https://www.woltlab.com/legal-notice/">Legal Notice
</a>
2717 <a href=
"https://www.woltlab.com/privacy-policy/">Privacy Policy
</a>
2725 <div class=
"md-dialog" data-md-component=
"dialog">
2726 <div class=
"md-dialog__inner md-typeset"></div>
2729 <script id=
"__config" type=
"application/json">{
"base":
"../../..",
"features": [
"navigation.tracking"],
"search":
"../../../assets/javascripts/workers/search.ecf98df9.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>
2732 <script src=
"../../../assets/javascripts/bundle.48f2be22.min.js"></script>