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/tutorial/series/part_4/">
14 <link rel=
"prev" href=
"../part_3/">
17 <link rel=
"next" href=
"../part_5/">
19 <link rel=
"icon" href=
"../../../assets/default.favicon.ico">
20 <meta name=
"generator" content=
"mkdocs-1.4.3, mkdocs-material-9.1.15">
24 <title>Part
4 - WoltLab Suite Documentation
</title>
28 <link rel=
"stylesheet" href=
"../../../assets/stylesheets/main.26e3688c.min.css">
31 <link rel=
"stylesheet" href=
"../../../assets/stylesheets/palette.ecc896b0.min.css">
41 <link rel=
"stylesheet" href=
"../../../stylesheets/extra.css">
43 <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>
58 <body dir=
"ltr" data-md-color-scheme=
"default" data-md-color-primary=
"teal" data-md-color-accent=
"indigo">
62 <input class=
"md-toggle" data-md-toggle=
"drawer" type=
"checkbox" id=
"__drawer" autocomplete=
"off">
63 <input class=
"md-toggle" data-md-toggle=
"search" type=
"checkbox" id=
"__search" autocomplete=
"off">
64 <label class=
"md-overlay" for=
"__drawer"></label>
65 <div data-md-component=
"skip">
68 <a href=
"#part-4-box-and-box-conditions" class=
"md-skip">
73 <div data-md-component=
"announce">
75 <aside class=
"md-banner">
76 <div class=
"md-banner__inner md-grid md-typeset">
79 <a href=
"https://www.woltlab.com">Back to
<strong>woltlab.com
</strong></a>
87 <div data-md-color-scheme=
"default" data-md-component=
"outdated" hidden
>
96 <header class=
"md-header md-header--shadow" data-md-component=
"header">
97 <nav class=
"md-header__inner md-grid" aria-label=
"Header">
98 <a href=
"../../.." title=
"WoltLab Suite Documentation" class=
"md-header__button md-logo" aria-label=
"WoltLab Suite Documentation" data-md-component=
"logo">
100 <img src=
"../../../assets/logo.png" alt=
"logo">
103 <label class=
"md-header__button md-icon" for=
"__drawer">
104 <svg xmlns=
"http://www.w3.org/2000/svg" viewBox=
"0 0 24 24"><path d=
"M3 6h18v2H3V6m0 5h18v2H3v-2m0 5h18v2H3v-2Z"/></svg>
106 <div class=
"md-header__title" data-md-component=
"header-title">
107 <div class=
"md-header__ellipsis">
108 <div class=
"md-header__topic">
109 <span class=
"md-ellipsis">
110 WoltLab Suite Documentation
113 <div class=
"md-header__topic" data-md-component=
"header-topic">
114 <span class=
"md-ellipsis">
127 <label class=
"md-header__button md-icon" for=
"__search">
128 <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 <div class=
"md-search" data-md-component=
"search" role=
"dialog">
131 <label class=
"md-search__overlay" for=
"__search"></label>
132 <div class=
"md-search__inner" role=
"search">
133 <form class=
"md-search__form" name=
"search">
134 <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
>
135 <label class=
"md-search__icon md-icon" for=
"__search">
136 <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>
137 <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>
139 <nav class=
"md-search__options" aria-label=
"Search">
141 <button type=
"reset" class=
"md-search__icon md-icon" title=
"Clear" aria-label=
"Clear" tabindex=
"-1">
142 <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>
147 <div class=
"md-search__output">
148 <div class=
"md-search__scrollwrap" data-md-scrollfix
>
149 <div class=
"md-search-result" data-md-component=
"search-result">
150 <div class=
"md-search-result__meta">
153 <ol class=
"md-search-result__list" role=
"presentation"></ol>
161 <div class=
"md-header__source">
162 <a href=
"https://github.com/WoltLab/docs.woltlab.com/" title=
"Go to repository" class=
"md-source" data-md-component=
"source">
163 <div class=
"md-source__icon md-icon">
165 <svg xmlns=
"http://www.w3.org/2000/svg" viewBox=
"0 0 448 512"><!--! Font Awesome Free 6.4.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 2023 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>
167 <div class=
"md-source__repository">
177 <div class=
"md-container" data-md-component=
"container">
184 <main class=
"md-main" data-md-component=
"main">
185 <div class=
"md-main__inner md-grid">
189 <div class=
"md-sidebar md-sidebar--primary" data-md-component=
"sidebar" data-md-type=
"navigation" >
190 <div class=
"md-sidebar__scrollwrap">
191 <div class=
"md-sidebar__inner">
195 <nav class=
"md-nav md-nav--primary" aria-label=
"Navigation" data-md-level=
"0">
196 <label class=
"md-nav__title" for=
"__drawer">
197 <a href=
"../../.." title=
"WoltLab Suite Documentation" class=
"md-nav__button md-logo" aria-label=
"WoltLab Suite Documentation" data-md-component=
"logo">
199 <img src=
"../../../assets/logo.png" alt=
"logo">
202 WoltLab Suite Documentation
205 <div class=
"md-nav__source">
206 <a href=
"https://github.com/WoltLab/docs.woltlab.com/" title=
"Go to repository" class=
"md-source" data-md-component=
"source">
207 <div class=
"md-source__icon md-icon">
209 <svg xmlns=
"http://www.w3.org/2000/svg" viewBox=
"0 0 448 512"><!--! Font Awesome Free 6.4.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 2023 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>
211 <div class=
"md-source__repository">
217 <ul class=
"md-nav__list" data-md-scrollfix
>
226 <li class=
"md-nav__item">
227 <a href=
"../../../getting-started/" class=
"md-nav__link">
242 <li class=
"md-nav__item md-nav__item--nested">
247 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_2" >
251 <label class=
"md-nav__link" for=
"__nav_2" id=
"__nav_2_label" tabindex=
"0">
253 <span class=
"md-nav__icon md-icon"></span>
256 <nav class=
"md-nav" data-md-level=
"1" aria-labelledby=
"__nav_2_label" aria-expanded=
"false">
257 <label class=
"md-nav__title" for=
"__nav_2">
258 <span class=
"md-nav__icon md-icon"></span>
261 <ul class=
"md-nav__list" data-md-scrollfix
>
268 <li class=
"md-nav__item">
269 <a href=
"../../../php/pages/" class=
"md-nav__link">
282 <li class=
"md-nav__item">
283 <a href=
"../../../php/database-objects/" class=
"md-nav__link">
296 <li class=
"md-nav__item">
297 <a href=
"../../../php/database-access/" class=
"md-nav__link">
310 <li class=
"md-nav__item">
311 <a href=
"../../../php/exceptions/" class=
"md-nav__link">
325 <li class=
"md-nav__item md-nav__item--nested">
330 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_2_5" >
334 <label class=
"md-nav__link" for=
"__nav_2_5" id=
"__nav_2_5_label" tabindex=
"0">
336 <span class=
"md-nav__icon md-icon"></span>
339 <nav class=
"md-nav" data-md-level=
"2" aria-labelledby=
"__nav_2_5_label" aria-expanded=
"false">
340 <label class=
"md-nav__title" for=
"__nav_2_5">
341 <span class=
"md-nav__icon md-icon"></span>
344 <ul class=
"md-nav__list" data-md-scrollfix
>
352 <li class=
"md-nav__item md-nav__item--nested">
357 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_2_5_1" >
361 <label class=
"md-nav__link" for=
"__nav_2_5_1" id=
"__nav_2_5_1_label" tabindex=
"0">
363 <span class=
"md-nav__icon md-icon"></span>
366 <nav class=
"md-nav" data-md-level=
"3" aria-labelledby=
"__nav_2_5_1_label" aria-expanded=
"false">
367 <label class=
"md-nav__title" for=
"__nav_2_5_1">
368 <span class=
"md-nav__icon md-icon"></span>
371 <ul class=
"md-nav__list" data-md-scrollfix
>
378 <li class=
"md-nav__item">
379 <a href=
"../../../php/api/caches/" class=
"md-nav__link">
392 <li class=
"md-nav__item">
393 <a href=
"../../../php/api/caches_persistent-caches/" class=
"md-nav__link">
406 <li class=
"md-nav__item">
407 <a href=
"../../../php/api/caches_runtime-caches/" class=
"md-nav__link">
427 <li class=
"md-nav__item">
428 <a href=
"../../../php/api/comments/" class=
"md-nav__link">
441 <li class=
"md-nav__item">
442 <a href=
"../../../php/api/cronjobs/" class=
"md-nav__link">
455 <li class=
"md-nav__item">
456 <a href=
"../../../php/api/events/" class=
"md-nav__link">
470 <li class=
"md-nav__item md-nav__item--nested">
475 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_2_5_5" >
479 <label class=
"md-nav__link" for=
"__nav_2_5_5" id=
"__nav_2_5_5_label" tabindex=
"0">
481 <span class=
"md-nav__icon md-icon"></span>
484 <nav class=
"md-nav" data-md-level=
"3" aria-labelledby=
"__nav_2_5_5_label" aria-expanded=
"false">
485 <label class=
"md-nav__title" for=
"__nav_2_5_5">
486 <span class=
"md-nav__icon md-icon"></span>
489 <ul class=
"md-nav__list" data-md-scrollfix
>
496 <li class=
"md-nav__item">
497 <a href=
"../../../php/api/form_builder/overview/" class=
"md-nav__link">
510 <li class=
"md-nav__item">
511 <a href=
"../../../php/api/form_builder/structure/" class=
"md-nav__link">
524 <li class=
"md-nav__item">
525 <a href=
"../../../php/api/form_builder/form_fields/" class=
"md-nav__link">
538 <li class=
"md-nav__item">
539 <a href=
"../../../php/api/form_builder/validation_data/" class=
"md-nav__link">
552 <li class=
"md-nav__item">
553 <a href=
"../../../php/api/form_builder/dependencies/" class=
"md-nav__link">
573 <li class=
"md-nav__item">
574 <a href=
"../../../php/api/package_installation_plugins/" class=
"md-nav__link">
575 Package Installation Plugins
587 <li class=
"md-nav__item">
588 <a href=
"../../../php/api/user_activity_points/" class=
"md-nav__link">
601 <li class=
"md-nav__item">
602 <a href=
"../../../php/api/user_notifications/" class=
"md-nav__link">
615 <li class=
"md-nav__item">
616 <a href=
"../../../php/api/sitemaps/" class=
"md-nav__link">
636 <li class=
"md-nav__item">
637 <a href=
"../../../php/code-style/" class=
"md-nav__link">
650 <li class=
"md-nav__item">
651 <a href=
"../../../php/apps/" class=
"md-nav__link">
664 <li class=
"md-nav__item">
665 <a href=
"../../../php/gdpr/" class=
"md-nav__link">
687 <li class=
"md-nav__item md-nav__item--nested">
692 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_3" >
696 <label class=
"md-nav__link" for=
"__nav_3" id=
"__nav_3_label" tabindex=
"0">
697 Languages, Templates & CSS
698 <span class=
"md-nav__icon md-icon"></span>
701 <nav class=
"md-nav" data-md-level=
"1" aria-labelledby=
"__nav_3_label" aria-expanded=
"false">
702 <label class=
"md-nav__title" for=
"__nav_3">
703 <span class=
"md-nav__icon md-icon"></span>
704 Languages, Templates & CSS
706 <ul class=
"md-nav__list" data-md-scrollfix
>
713 <li class=
"md-nav__item">
714 <a href=
"../../../view/languages/" class=
"md-nav__link">
727 <li class=
"md-nav__item">
728 <a href=
"../../../view/templates/" class=
"md-nav__link">
741 <li class=
"md-nav__item">
742 <a href=
"../../../view/template-modifiers/" class=
"md-nav__link">
755 <li class=
"md-nav__item">
756 <a href=
"../../../view/template-plugins/" class=
"md-nav__link">
769 <li class=
"md-nav__item">
770 <a href=
"../../../view/css/" class=
"md-nav__link">
792 <li class=
"md-nav__item md-nav__item--nested">
797 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_4" >
801 <label class=
"md-nav__link" for=
"__nav_4" id=
"__nav_4_label" tabindex=
"0">
802 TypeScript and JavaScript API
803 <span class=
"md-nav__icon md-icon"></span>
806 <nav class=
"md-nav" data-md-level=
"1" aria-labelledby=
"__nav_4_label" aria-expanded=
"false">
807 <label class=
"md-nav__title" for=
"__nav_4">
808 <span class=
"md-nav__icon md-icon"></span>
809 TypeScript and JavaScript API
811 <ul class=
"md-nav__list" data-md-scrollfix
>
818 <li class=
"md-nav__item">
819 <a href=
"../../../javascript/general-usage/" class=
"md-nav__link">
832 <li class=
"md-nav__item">
833 <a href=
"../../../javascript/typescript/" class=
"md-nav__link">
847 <li class=
"md-nav__item md-nav__item--nested">
852 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_4_3" >
856 <label class=
"md-nav__link" for=
"__nav_4_3" id=
"__nav_4_3_label" tabindex=
"0">
858 <span class=
"md-nav__icon md-icon"></span>
861 <nav class=
"md-nav" data-md-level=
"2" aria-labelledby=
"__nav_4_3_label" aria-expanded=
"false">
862 <label class=
"md-nav__title" for=
"__nav_4_3">
863 <span class=
"md-nav__icon md-icon"></span>
866 <ul class=
"md-nav__list" data-md-scrollfix
>
873 <li class=
"md-nav__item">
874 <a href=
"../../../javascript/components_confirmation/" class=
"md-nav__link">
887 <li class=
"md-nav__item">
888 <a href=
"../../../javascript/components_dialog/" class=
"md-nav__link">
901 <li class=
"md-nav__item">
902 <a href=
"../../../javascript/components_google_maps/" class=
"md-nav__link">
915 <li class=
"md-nav__item">
916 <a href=
"../../../javascript/components_pagination/" class=
"md-nav__link">
937 <li class=
"md-nav__item md-nav__item--nested">
942 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_4_4" >
946 <label class=
"md-nav__link" for=
"__nav_4_4" id=
"__nav_4_4_label" tabindex=
"0">
948 <span class=
"md-nav__icon md-icon"></span>
951 <nav class=
"md-nav" data-md-level=
"2" aria-labelledby=
"__nav_4_4_label" aria-expanded=
"false">
952 <label class=
"md-nav__title" for=
"__nav_4_4">
953 <span class=
"md-nav__icon md-icon"></span>
956 <ul class=
"md-nav__list" data-md-scrollfix
>
963 <li class=
"md-nav__item">
964 <a href=
"../../../javascript/new-api_writing-a-module/" class=
"md-nav__link">
977 <li class=
"md-nav__item">
978 <a href=
"../../../javascript/new-api_core/" class=
"md-nav__link">
991 <li class=
"md-nav__item">
992 <a href=
"../../../javascript/new-api_dom/" class=
"md-nav__link">
1005 <li class=
"md-nav__item">
1006 <a href=
"../../../javascript/new-api_events/" class=
"md-nav__link">
1019 <li class=
"md-nav__item">
1020 <a href=
"../../../javascript/new-api_ajax/" class=
"md-nav__link">
1033 <li class=
"md-nav__item">
1034 <a href=
"../../../javascript/new-api_dialogs/" class=
"md-nav__link">
1047 <li class=
"md-nav__item">
1048 <a href=
"../../../javascript/new-api_browser/" class=
"md-nav__link">
1049 Browser and Screen Sizes
1061 <li class=
"md-nav__item">
1062 <a href=
"../../../javascript/new-api_ui/" class=
"md-nav__link">
1082 <li class=
"md-nav__item">
1083 <a href=
"../../../javascript/legacy-api/" class=
"md-nav__link">
1096 <li class=
"md-nav__item">
1097 <a href=
"../../../javascript/code-snippets/" class=
"md-nav__link">
1119 <li class=
"md-nav__item md-nav__item--nested">
1124 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_5" >
1128 <label class=
"md-nav__link" for=
"__nav_5" id=
"__nav_5_label" tabindex=
"0">
1130 <span class=
"md-nav__icon md-icon"></span>
1133 <nav class=
"md-nav" data-md-level=
"1" aria-labelledby=
"__nav_5_label" aria-expanded=
"false">
1134 <label class=
"md-nav__title" for=
"__nav_5">
1135 <span class=
"md-nav__icon md-icon"></span>
1138 <ul class=
"md-nav__list" data-md-scrollfix
>
1145 <li class=
"md-nav__item">
1146 <a href=
"../../../package/package-xml/" class=
"md-nav__link">
1160 <li class=
"md-nav__item md-nav__item--nested">
1165 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_5_2" >
1169 <label class=
"md-nav__link" for=
"__nav_5_2" id=
"__nav_5_2_label" tabindex=
"0">
1171 <span class=
"md-nav__icon md-icon"></span>
1174 <nav class=
"md-nav" data-md-level=
"2" aria-labelledby=
"__nav_5_2_label" aria-expanded=
"false">
1175 <label class=
"md-nav__title" for=
"__nav_5_2">
1176 <span class=
"md-nav__icon md-icon"></span>
1179 <ul class=
"md-nav__list" data-md-scrollfix
>
1186 <li class=
"md-nav__item">
1187 <a href=
"../../../package/pip/" class=
"md-nav__link">
1200 <li class=
"md-nav__item">
1201 <a href=
"../../../package/pip/acl-option/" class=
"md-nav__link">
1214 <li class=
"md-nav__item">
1215 <a href=
"../../../package/pip/acp-menu/" class=
"md-nav__link">
1228 <li class=
"md-nav__item">
1229 <a href=
"../../../package/pip/acp-search-provider/" class=
"md-nav__link">
1242 <li class=
"md-nav__item">
1243 <a href=
"../../../package/pip/acp-template/" class=
"md-nav__link">
1256 <li class=
"md-nav__item">
1257 <a href=
"../../../package/pip/acp-template-delete/" class=
"md-nav__link">
1270 <li class=
"md-nav__item">
1271 <a href=
"../../../package/pip/bbcode/" class=
"md-nav__link">
1284 <li class=
"md-nav__item">
1285 <a href=
"../../../package/pip/box/" class=
"md-nav__link">
1298 <li class=
"md-nav__item">
1299 <a href=
"../../../package/pip/clipboard-action/" class=
"md-nav__link">
1312 <li class=
"md-nav__item">
1313 <a href=
"../../../package/pip/core-object/" class=
"md-nav__link">
1326 <li class=
"md-nav__item">
1327 <a href=
"../../../package/pip/cronjob/" class=
"md-nav__link">
1340 <li class=
"md-nav__item">
1341 <a href=
"../../../package/pip/database/" class=
"md-nav__link">
1354 <li class=
"md-nav__item">
1355 <a href=
"../../../package/pip/event-listener/" class=
"md-nav__link">
1368 <li class=
"md-nav__item">
1369 <a href=
"../../../package/pip/file/" class=
"md-nav__link">
1382 <li class=
"md-nav__item">
1383 <a href=
"../../../package/pip/file-delete/" class=
"md-nav__link">
1396 <li class=
"md-nav__item">
1397 <a href=
"../../../package/pip/language/" class=
"md-nav__link">
1410 <li class=
"md-nav__item">
1411 <a href=
"../../../package/pip/media-provider/" class=
"md-nav__link">
1424 <li class=
"md-nav__item">
1425 <a href=
"../../../package/pip/menu/" class=
"md-nav__link">
1438 <li class=
"md-nav__item">
1439 <a href=
"../../../package/pip/menu-item/" class=
"md-nav__link">
1452 <li class=
"md-nav__item">
1453 <a href=
"../../../package/pip/object-type/" class=
"md-nav__link">
1466 <li class=
"md-nav__item">
1467 <a href=
"../../../package/pip/object-type-definition/" class=
"md-nav__link">
1468 objectTypeDefinition
1480 <li class=
"md-nav__item">
1481 <a href=
"../../../package/pip/option/" class=
"md-nav__link">
1494 <li class=
"md-nav__item">
1495 <a href=
"../../../package/pip/page/" class=
"md-nav__link">
1508 <li class=
"md-nav__item">
1509 <a href=
"../../../package/pip/pip/" class=
"md-nav__link">
1522 <li class=
"md-nav__item">
1523 <a href=
"../../../package/pip/script/" class=
"md-nav__link">
1536 <li class=
"md-nav__item">
1537 <a href=
"../../../package/pip/smiley/" class=
"md-nav__link">
1550 <li class=
"md-nav__item">
1551 <a href=
"../../../package/pip/sql/" class=
"md-nav__link">
1564 <li class=
"md-nav__item">
1565 <a href=
"../../../package/pip/style/" class=
"md-nav__link">
1578 <li class=
"md-nav__item">
1579 <a href=
"../../../package/pip/template/" class=
"md-nav__link">
1592 <li class=
"md-nav__item">
1593 <a href=
"../../../package/pip/template-delete/" class=
"md-nav__link">
1606 <li class=
"md-nav__item">
1607 <a href=
"../../../package/pip/template-listener/" class=
"md-nav__link">
1620 <li class=
"md-nav__item">
1621 <a href=
"../../../package/pip/user-group-option/" class=
"md-nav__link">
1634 <li class=
"md-nav__item">
1635 <a href=
"../../../package/pip/user-menu/" class=
"md-nav__link">
1648 <li class=
"md-nav__item">
1649 <a href=
"../../../package/pip/user-notification-event/" class=
"md-nav__link">
1650 userNotificationEvent
1662 <li class=
"md-nav__item">
1663 <a href=
"../../../package/pip/user-option/" class=
"md-nav__link">
1676 <li class=
"md-nav__item">
1677 <a href=
"../../../package/pip/user-profile-menu/" class=
"md-nav__link">
1697 <li class=
"md-nav__item">
1698 <a href=
"../../../package/database-php-api/" class=
"md-nav__link">
1720 <li class=
"md-nav__item md-nav__item--nested">
1725 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_6" >
1729 <label class=
"md-nav__link" for=
"__nav_6" id=
"__nav_6_label" tabindex=
"0">
1731 <span class=
"md-nav__icon md-icon"></span>
1734 <nav class=
"md-nav" data-md-level=
"1" aria-labelledby=
"__nav_6_label" aria-expanded=
"false">
1735 <label class=
"md-nav__title" for=
"__nav_6">
1736 <span class=
"md-nav__icon md-icon"></span>
1739 <ul class=
"md-nav__list" data-md-scrollfix
>
1747 <li class=
"md-nav__item md-nav__item--nested">
1752 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_6_1" >
1756 <label class=
"md-nav__link" for=
"__nav_6_1" id=
"__nav_6_1_label" tabindex=
"0">
1757 From WoltLab Suite
5.5
1758 <span class=
"md-nav__icon md-icon"></span>
1761 <nav class=
"md-nav" data-md-level=
"2" aria-labelledby=
"__nav_6_1_label" aria-expanded=
"false">
1762 <label class=
"md-nav__title" for=
"__nav_6_1">
1763 <span class=
"md-nav__icon md-icon"></span>
1764 From WoltLab Suite
5.5
1766 <ul class=
"md-nav__list" data-md-scrollfix
>
1773 <li class=
"md-nav__item">
1774 <a href=
"../../../migration/wsc55/php/" class=
"md-nav__link">
1787 <li class=
"md-nav__item">
1788 <a href=
"../../../migration/wsc55/javascript/" class=
"md-nav__link">
1789 TypeScript and JavaScript
1801 <li class=
"md-nav__item">
1802 <a href=
"../../../migration/wsc55/templates/" class=
"md-nav__link">
1815 <li class=
"md-nav__item">
1816 <a href=
"../../../migration/wsc55/icons/" class=
"md-nav__link">
1829 <li class=
"md-nav__item">
1830 <a href=
"../../../migration/wsc55/dialogs/" class=
"md-nav__link">
1843 <li class=
"md-nav__item">
1844 <a href=
"../../../migration/wsc55/libraries/" class=
"md-nav__link">
1845 Third Party Libraries
1857 <li class=
"md-nav__item">
1858 <a href=
"../../../migration/wsc55/deprecations_removals/" class=
"md-nav__link">
1859 Deprecations and Removals
1879 <li class=
"md-nav__item md-nav__item--nested">
1884 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_6_2" >
1888 <label class=
"md-nav__link" for=
"__nav_6_2" id=
"__nav_6_2_label" tabindex=
"0">
1889 From WoltLab Suite
5.4
1890 <span class=
"md-nav__icon md-icon"></span>
1893 <nav class=
"md-nav" data-md-level=
"2" aria-labelledby=
"__nav_6_2_label" aria-expanded=
"false">
1894 <label class=
"md-nav__title" for=
"__nav_6_2">
1895 <span class=
"md-nav__icon md-icon"></span>
1896 From WoltLab Suite
5.4
1898 <ul class=
"md-nav__list" data-md-scrollfix
>
1905 <li class=
"md-nav__item">
1906 <a href=
"../../../migration/wsc54/php/" class=
"md-nav__link">
1919 <li class=
"md-nav__item">
1920 <a href=
"../../../migration/wsc54/javascript/" class=
"md-nav__link">
1921 TypeScript and JavaScript
1933 <li class=
"md-nav__item">
1934 <a href=
"../../../migration/wsc54/templates/" class=
"md-nav__link">
1947 <li class=
"md-nav__item">
1948 <a href=
"../../../migration/wsc54/libraries/" class=
"md-nav__link">
1949 Third Party Libraries
1961 <li class=
"md-nav__item">
1962 <a href=
"../../../migration/wsc54/deprecations_removals/" class=
"md-nav__link">
1963 Deprecations and Removals
1983 <li class=
"md-nav__item md-nav__item--nested">
1988 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_6_3" >
1992 <label class=
"md-nav__link" for=
"__nav_6_3" id=
"__nav_6_3_label" tabindex=
"0">
1993 From WoltLab Suite
5.3
1994 <span class=
"md-nav__icon md-icon"></span>
1997 <nav class=
"md-nav" data-md-level=
"2" aria-labelledby=
"__nav_6_3_label" aria-expanded=
"false">
1998 <label class=
"md-nav__title" for=
"__nav_6_3">
1999 <span class=
"md-nav__icon md-icon"></span>
2000 From WoltLab Suite
5.3
2002 <ul class=
"md-nav__list" data-md-scrollfix
>
2009 <li class=
"md-nav__item">
2010 <a href=
"../../../migration/wsc53/php/" class=
"md-nav__link">
2023 <li class=
"md-nav__item">
2024 <a href=
"../../../migration/wsc53/session/" class=
"md-nav__link">
2025 Session Handling and Authentication
2037 <li class=
"md-nav__item">
2038 <a href=
"../../../migration/wsc53/javascript/" class=
"md-nav__link">
2039 TypeScript and JavaScript
2051 <li class=
"md-nav__item">
2052 <a href=
"../../../migration/wsc53/templates/" class=
"md-nav__link">
2065 <li class=
"md-nav__item">
2066 <a href=
"../../../migration/wsc53/libraries/" class=
"md-nav__link">
2067 Third Party Libraries
2087 <li class=
"md-nav__item md-nav__item--nested">
2092 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_6_4" >
2096 <label class=
"md-nav__link" for=
"__nav_6_4" id=
"__nav_6_4_label" tabindex=
"0">
2097 From WoltLab Suite
5.2
2098 <span class=
"md-nav__icon md-icon"></span>
2101 <nav class=
"md-nav" data-md-level=
"2" aria-labelledby=
"__nav_6_4_label" aria-expanded=
"false">
2102 <label class=
"md-nav__title" for=
"__nav_6_4">
2103 <span class=
"md-nav__icon md-icon"></span>
2104 From WoltLab Suite
5.2
2106 <ul class=
"md-nav__list" data-md-scrollfix
>
2113 <li class=
"md-nav__item">
2114 <a href=
"../../../migration/wsc52/php/" class=
"md-nav__link">
2127 <li class=
"md-nav__item">
2128 <a href=
"../../../migration/wsc52/templates/" class=
"md-nav__link">
2129 Templates and Languages
2141 <li class=
"md-nav__item">
2142 <a href=
"../../../migration/wsc52/libraries/" class=
"md-nav__link">
2143 Third Party Libraries
2163 <li class=
"md-nav__item md-nav__item--nested">
2168 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_6_5" >
2172 <label class=
"md-nav__link" for=
"__nav_6_5" id=
"__nav_6_5_label" tabindex=
"0">
2173 From WoltLab Suite
3.1
2174 <span class=
"md-nav__icon md-icon"></span>
2177 <nav class=
"md-nav" data-md-level=
"2" aria-labelledby=
"__nav_6_5_label" aria-expanded=
"false">
2178 <label class=
"md-nav__title" for=
"__nav_6_5">
2179 <span class=
"md-nav__icon md-icon"></span>
2180 From WoltLab Suite
3.1
2182 <ul class=
"md-nav__list" data-md-scrollfix
>
2189 <li class=
"md-nav__item">
2190 <a href=
"../../../migration/wsc31/php/" class=
"md-nav__link">
2211 <li class=
"md-nav__item md-nav__item--nested">
2216 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_6_6" >
2220 <label class=
"md-nav__link" for=
"__nav_6_6" id=
"__nav_6_6_label" tabindex=
"0">
2221 From WoltLab Suite
3.0
2222 <span class=
"md-nav__icon md-icon"></span>
2225 <nav class=
"md-nav" data-md-level=
"2" aria-labelledby=
"__nav_6_6_label" aria-expanded=
"false">
2226 <label class=
"md-nav__title" for=
"__nav_6_6">
2227 <span class=
"md-nav__icon md-icon"></span>
2228 From WoltLab Suite
3.0
2230 <ul class=
"md-nav__list" data-md-scrollfix
>
2237 <li class=
"md-nav__item">
2238 <a href=
"../../../migration/wsc30/php/" class=
"md-nav__link">
2251 <li class=
"md-nav__item">
2252 <a href=
"../../../migration/wsc30/javascript/" class=
"md-nav__link">
2265 <li class=
"md-nav__item">
2266 <a href=
"../../../migration/wsc30/templates/" class=
"md-nav__link">
2279 <li class=
"md-nav__item">
2280 <a href=
"../../../migration/wsc30/css/" class=
"md-nav__link">
2293 <li class=
"md-nav__item">
2294 <a href=
"../../../migration/wsc30/package/" class=
"md-nav__link">
2315 <li class=
"md-nav__item md-nav__item--nested">
2320 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_6_7" >
2324 <label class=
"md-nav__link" for=
"__nav_6_7" id=
"__nav_6_7_label" tabindex=
"0">
2326 <span class=
"md-nav__icon md-icon"></span>
2329 <nav class=
"md-nav" data-md-level=
"2" aria-labelledby=
"__nav_6_7_label" aria-expanded=
"false">
2330 <label class=
"md-nav__title" for=
"__nav_6_7">
2331 <span class=
"md-nav__icon md-icon"></span>
2334 <ul class=
"md-nav__list" data-md-scrollfix
>
2341 <li class=
"md-nav__item">
2342 <a href=
"../../../migration/wcf21/php/" class=
"md-nav__link">
2355 <li class=
"md-nav__item">
2356 <a href=
"../../../migration/wcf21/templates/" class=
"md-nav__link">
2369 <li class=
"md-nav__item">
2370 <a href=
"../../../migration/wcf21/css/" class=
"md-nav__link">
2383 <li class=
"md-nav__item">
2384 <a href=
"../../../migration/wcf21/package/" class=
"md-nav__link">
2415 <li class=
"md-nav__item md-nav__item--active md-nav__item--nested">
2420 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_7" checked
>
2424 <label class=
"md-nav__link" for=
"__nav_7" id=
"__nav_7_label" tabindex=
"0">
2426 <span class=
"md-nav__icon md-icon"></span>
2429 <nav class=
"md-nav" data-md-level=
"1" aria-labelledby=
"__nav_7_label" aria-expanded=
"true">
2430 <label class=
"md-nav__title" for=
"__nav_7">
2431 <span class=
"md-nav__icon md-icon"></span>
2434 <ul class=
"md-nav__list" data-md-scrollfix
>
2444 <li class=
"md-nav__item md-nav__item--active md-nav__item--nested">
2449 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_7_1" checked
>
2453 <label class=
"md-nav__link" for=
"__nav_7_1" id=
"__nav_7_1_label" tabindex=
"0">
2455 <span class=
"md-nav__icon md-icon"></span>
2458 <nav class=
"md-nav" data-md-level=
"2" aria-labelledby=
"__nav_7_1_label" aria-expanded=
"true">
2459 <label class=
"md-nav__title" for=
"__nav_7_1">
2460 <span class=
"md-nav__icon md-icon"></span>
2463 <ul class=
"md-nav__list" data-md-scrollfix
>
2470 <li class=
"md-nav__item">
2471 <a href=
"../overview/" class=
"md-nav__link">
2484 <li class=
"md-nav__item">
2485 <a href=
"../part_1/" class=
"md-nav__link">
2498 <li class=
"md-nav__item">
2499 <a href=
"../part_2/" class=
"md-nav__link">
2512 <li class=
"md-nav__item">
2513 <a href=
"../part_3/" class=
"md-nav__link">
2528 <li class=
"md-nav__item md-nav__item--active">
2530 <input class=
"md-nav__toggle md-toggle" type=
"checkbox" id=
"__toc">
2536 <label class=
"md-nav__link md-nav__link--active" for=
"__toc">
2538 <span class=
"md-nav__icon md-icon"></span>
2541 <a href=
"./" class=
"md-nav__link md-nav__link--active">
2547 <nav class=
"md-nav md-nav--secondary" aria-label=
"Table of contents">
2554 <label class=
"md-nav__title" for=
"__toc">
2555 <span class=
"md-nav__icon md-icon"></span>
2558 <ul class=
"md-nav__list" data-md-component=
"toc" data-md-scrollfix
>
2560 <li class=
"md-nav__item">
2561 <a href=
"#package-functionality" class=
"md-nav__link">
2562 Package Functionality
2567 <li class=
"md-nav__item">
2568 <a href=
"#used-components" class=
"md-nav__link">
2574 <li class=
"md-nav__item">
2575 <a href=
"#package-structure" class=
"md-nav__link">
2581 <li class=
"md-nav__item">
2582 <a href=
"#box-controller" class=
"md-nav__link">
2588 <li class=
"md-nav__item">
2589 <a href=
"#conditions" class=
"md-nav__link">
2609 <li class=
"md-nav__item">
2610 <a href=
"../part_5/" class=
"md-nav__link">
2623 <li class=
"md-nav__item">
2624 <a href=
"../part_6/" class=
"md-nav__link">
2653 <div class=
"md-sidebar md-sidebar--secondary" data-md-component=
"sidebar" data-md-type=
"toc" >
2654 <div class=
"md-sidebar__scrollwrap">
2655 <div class=
"md-sidebar__inner">
2658 <nav class=
"md-nav md-nav--secondary" aria-label=
"Table of contents">
2665 <label class=
"md-nav__title" for=
"__toc">
2666 <span class=
"md-nav__icon md-icon"></span>
2669 <ul class=
"md-nav__list" data-md-component=
"toc" data-md-scrollfix
>
2671 <li class=
"md-nav__item">
2672 <a href=
"#package-functionality" class=
"md-nav__link">
2673 Package Functionality
2678 <li class=
"md-nav__item">
2679 <a href=
"#used-components" class=
"md-nav__link">
2685 <li class=
"md-nav__item">
2686 <a href=
"#package-structure" class=
"md-nav__link">
2692 <li class=
"md-nav__item">
2693 <a href=
"#box-controller" class=
"md-nav__link">
2699 <li class=
"md-nav__item">
2700 <a href=
"#conditions" class=
"md-nav__link">
2715 <div class=
"md-content" data-md-component=
"content">
2716 <article class=
"md-content__inner md-typeset">
2724 <h1 id=
"part-4-box-and-box-conditions">Part
4: Box and Box Conditions
<a class=
"headerlink" href=
"#part-4-box-and-box-conditions" title=
"Permanent link">#
</a></h1>
2725 <p>In this part of our tutorial series, we add support for creating boxes listing people.
</p>
2726 <h2 id=
"package-functionality">Package Functionality
<a class=
"headerlink" href=
"#package-functionality" title=
"Permanent link">#
</a></h2>
2727 <p>In addition to the existing functions from
<a href=
"../part_3/">part
3</a>, the package will provide the following functionality after this part of the tutorial:
</p>
2729 <li>Creating boxes dynamically listing people
</li>
2730 <li>Filtering the people listed in boxes using conditions
</li>
2732 <h2 id=
"used-components">Used Components
<a class=
"headerlink" href=
"#used-components" title=
"Permanent link">#
</a></h2>
2733 <p>In addition to the components used in previous parts, we will use the
<a href=
"../../../package/pip/object-type-definition/"><code>objectTypeDefinition
</code> package installation plugin
</a> and use the box and condition APIs.
</p>
2734 <p>To pre-install a specific person list box, we refer to the documentation of the
<a href=
"../../../package/pip/box/"><code>box
</code> package installation plugin
</a>.
</p>
2735 <h2 id=
"package-structure">Package Structure
<a class=
"headerlink" href=
"#package-structure" title=
"Permanent link">#
</a></h2>
2736 <p>The complete package will have the following file structure (
<em>excluding
</em> unchanged files from
<a href=
"../part_3/">part
3</a>):
</p>
2737 <div class=
"highlight"><table class=
"highlighttable"><tr><td class=
"linenos"><div class=
"linenodiv"><pre><span></span><span class=
"normal"> 1</span>
2738 <span class=
"normal"> 2</span>
2739 <span class=
"normal"> 3</span>
2740 <span class=
"normal"> 4</span>
2741 <span class=
"normal"> 5</span>
2742 <span class=
"normal"> 6</span>
2743 <span class=
"normal"> 7</span>
2744 <span class=
"normal"> 8</span>
2745 <span class=
"normal"> 9</span>
2746 <span class=
"normal">10</span>
2747 <span class=
"normal">11</span>
2748 <span class=
"normal">12</span>
2749 <span class=
"normal">13</span>
2750 <span class=
"normal">14</span>
2751 <span class=
"normal">15</span>
2752 <span class=
"normal">16</span></pre></div></td><td class=
"code"><div><pre><span></span><code>├── files
2756 │ │ └── PersonListBoxController.class.php
2759 │ ├── PersonFirstNameTextPropertyCondition.class.php
2760 │ └── PersonLastNameTextPropertyCondition.class.php
2765 ├── objectTypeDefinition.xml
2767 └── boxPersonList.tpl
2768 </code></pre></div></td></tr></table></div>
2769 <p>For all changes, please refer to the
<a href=
"https://github.com/WoltLab/docs.woltlab.com/tree/6.0/snippets/tutorial/tutorial-series/part-4">source code on GitHub
</a>.
</p>
2770 <h2 id=
"box-controller">Box Controller
<a class=
"headerlink" href=
"#box-controller" title=
"Permanent link">#
</a></h2>
2771 <p>In addition to static boxes with fixed contents, administrators are able to create dynamic boxes with contents from the database.
2772 In our case here, we want administrators to be able to create boxes listing people.
2773 To do so, we first have to register a new object type for this person list box controller for the object type definition
<code>com.woltlab.wcf.boxController
</code>:
</p>
2774 <div class=
"highlight"><table class=
"highlighttable"><tr><td class=
"linenos"><div class=
"linenodiv"><pre><span></span><span class=
"normal">1</span>
2775 <span class=
"normal">2</span>
2776 <span class=
"normal">3</span>
2777 <span class=
"normal">4</span>
2778 <span class=
"normal">5</span></pre></div></td><td class=
"code"><div><pre><span></span><code><span class=
"nt"><type
></span>
2779 <span class=
"w"> </span><span class=
"nt"><name
></span>com.woltlab.wcf.personList
<span class=
"nt"></name
></span>
2780 <span class=
"w"> </span><span class=
"nt"><definitionname
></span>com.woltlab.wcf.boxController
<span class=
"nt"></definitionname
></span>
2781 <span class=
"w"> </span><span class=
"nt"><classname
></span>wcf\system\box\PersonListBoxController
<span class=
"nt"></classname
></span>
2782 <span class=
"nt"></type
></span>
2783 </code></pre></div></td></tr></table></div>
2784 <p>The
<code>com.woltlab.wcf.boxController
</code> object type definition requires the provided class to implement
<code>wcf\system\box\IBoxController
</code>:
</p>
2785 <div class=
"highlight"><table class=
"highlighttable"><tr><th colspan=
"2" class=
"filename"><span class=
"filename">files/lib/system/box/PersonListBoxController.class.php
<a class=
"codeBoxTitleGitHubLink" href=
"https://github.com/WoltLab/docs.woltlab.com/tree/6.0/snippets/tutorial/tutorial-series/part-4/files/lib/system/box/PersonListBoxController.class.php" title=
"View on GitHub"><span class=
"twemoji"><svg xmlns=
"http://www.w3.org/2000/svg" viewBox=
"0 0 24 24"><path d=
"M3.9 12c0-1.71 1.39-3.1 3.1-3.1h4V7H7a5 5 0 0 0-5 5 5 5 0 0 0 5 5h4v-1.9H7c-1.71 0-3.1-1.39-3.1-3.1M8 13h8v-2H8v2m9-6h-4v1.9h4c1.71 0 3.1 1.39 3.1 3.1 0 1.71-1.39 3.1-3.1 3.1h-4V17h4a5 5 0 0 0 5-5 5 5 0 0 0-5-5Z"/></svg></span></a></span></th></tr><tr><td class=
"linenos"><div class=
"linenodiv"><pre><span></span><span class=
"normal"> 1</span>
2786 <span class=
"normal"> 2</span>
2787 <span class=
"normal"> 3</span>
2788 <span class=
"normal"> 4</span>
2789 <span class=
"normal"> 5</span>
2790 <span class=
"normal"> 6</span>
2791 <span class=
"normal"> 7</span>
2792 <span class=
"normal"> 8</span>
2793 <span class=
"normal"> 9</span>
2794 <span class=
"normal">10</span>
2795 <span class=
"normal">11</span>
2796 <span class=
"normal">12</span>
2797 <span class=
"normal">13</span>
2798 <span class=
"normal">14</span>
2799 <span class=
"normal">15</span>
2800 <span class=
"normal">16</span>
2801 <span class=
"normal">17</span>
2802 <span class=
"normal">18</span>
2803 <span class=
"normal">19</span>
2804 <span class=
"normal">20</span>
2805 <span class=
"normal">21</span>
2806 <span class=
"normal">22</span>
2807 <span class=
"normal">23</span>
2808 <span class=
"normal">24</span>
2809 <span class=
"normal">25</span>
2810 <span class=
"normal">26</span>
2811 <span class=
"normal">27</span>
2812 <span class=
"normal">28</span>
2813 <span class=
"normal">29</span>
2814 <span class=
"normal">30</span>
2815 <span class=
"normal">31</span>
2816 <span class=
"normal">32</span>
2817 <span class=
"normal">33</span>
2818 <span class=
"normal">34</span>
2819 <span class=
"normal">35</span>
2820 <span class=
"normal">36</span>
2821 <span class=
"normal">37</span>
2822 <span class=
"normal">38</span>
2823 <span class=
"normal">39</span>
2824 <span class=
"normal">40</span>
2825 <span class=
"normal">41</span>
2826 <span class=
"normal">42</span>
2827 <span class=
"normal">43</span>
2828 <span class=
"normal">44</span>
2829 <span class=
"normal">45</span>
2830 <span class=
"normal">46</span>
2831 <span class=
"normal">47</span>
2832 <span class=
"normal">48</span>
2833 <span class=
"normal">49</span>
2834 <span class=
"normal">50</span>
2835 <span class=
"normal">51</span>
2836 <span class=
"normal">52</span>
2837 <span class=
"normal">53</span>
2838 <span class=
"normal">54</span>
2839 <span class=
"normal">55</span>
2840 <span class=
"normal">56</span>
2841 <span class=
"normal">57</span>
2842 <span class=
"normal">58</span>
2843 <span class=
"normal">59</span>
2844 <span class=
"normal">60</span>
2845 <span class=
"normal">61</span>
2846 <span class=
"normal">62</span>
2847 <span class=
"normal">63</span>
2848 <span class=
"normal">64</span>
2849 <span class=
"normal">65</span>
2850 <span class=
"normal">66</span>
2851 <span class=
"normal">67</span>
2852 <span class=
"normal">68</span>
2853 <span class=
"normal">69</span></pre></div></td><td class=
"code"><div><pre><span></span><code><span class=
"o"><?
</span><span class=
"nx">php
</span>
2855 <span class=
"k">namespace
</span> <span class=
"nx">wcf\system\box
</span><span class=
"p">;
</span>
2857 <span class=
"k">use
</span> <span class=
"nx">wcf\data\person\PersonList
</span><span class=
"p">;
</span>
2858 <span class=
"k">use
</span> <span class=
"nx">wcf\system\WCF
</span><span class=
"p">;
</span>
2860 <span class=
"sd">/**
</span>
2861 <span class=
"sd"> * Dynamic box controller implementation for a list of persons.
</span>
2862 <span class=
"sd"> *
</span>
2863 <span class=
"sd"> * @author Matthias Schmidt
</span>
2864 <span class=
"sd"> * @copyright
2001-
2022 WoltLab GmbH
</span>
2865 <span class=
"sd"> * @license GNU Lesser General Public License
<http://opensource.org/licenses/lgpl-license.php
></span>
2866 <span class=
"sd"> * @package WoltLabSuite\Core\System\Box
</span>
2867 <span class=
"sd"> */
</span>
2868 <span class=
"k">final
</span> <span class=
"k">class
</span> <span class=
"nc">PersonListBoxController
</span> <span class=
"k">extends
</span> <span class=
"nx">AbstractDatabaseObjectListBoxController
</span>
2869 <span class=
"p">{
</span>
2870 <span class=
"sd">/**
</span>
2871 <span class=
"sd"> * @inheritDoc
</span>
2872 <span class=
"sd"> */
</span>
2873 <span class=
"k">protected
</span> <span class=
"nv">$conditionDefinition
</span> <span class=
"o">=
</span> <span class=
"s1">'com.woltlab.wcf.box.personList.condition
'</span><span class=
"p">;
</span>
2875 <span class=
"sd">/**
</span>
2876 <span class=
"sd"> * @inheritDoc
</span>
2877 <span class=
"sd"> */
</span>
2878 <span class=
"k">public
</span> <span class=
"nv">$defaultLimit
</span> <span class=
"o">=
</span> <span class=
"mi">5</span><span class=
"p">;
</span>
2880 <span class=
"sd">/**
</span>
2881 <span class=
"sd"> * @inheritDoc
</span>
2882 <span class=
"sd"> */
</span>
2883 <span class=
"k">protected
</span> <span class=
"nv">$sortFieldLanguageItemPrefix
</span> <span class=
"o">=
</span> <span class=
"s1">'wcf.person
'</span><span class=
"p">;
</span>
2885 <span class=
"sd">/**
</span>
2886 <span class=
"sd"> * @inheritDoc
</span>
2887 <span class=
"sd"> */
</span>
2888 <span class=
"k">protected
</span> <span class=
"k">static
</span> <span class=
"nv">$supportedPositions
</span> <span class=
"o">=
</span> <span class=
"p">[
</span>
2889 <span class=
"s1">'sidebarLeft
'</span><span class=
"p">,
</span>
2890 <span class=
"s1">'sidebarRight
'</span><span class=
"p">,
</span>
2891 <span class=
"p">];
</span>
2893 <span class=
"sd">/**
</span>
2894 <span class=
"sd"> * @inheritDoc
</span>
2895 <span class=
"sd"> */
</span>
2896 <span class=
"k">public
</span> <span class=
"nv">$validSortFields
</span> <span class=
"o">=
</span> <span class=
"p">[
</span>
2897 <span class=
"s1">'firstName
'</span><span class=
"p">,
</span>
2898 <span class=
"s1">'lastName
'</span><span class=
"p">,
</span>
2899 <span class=
"s1">'comments
'</span><span class=
"p">,
</span>
2900 <span class=
"p">];
</span>
2902 <span class=
"sd">/**
</span>
2903 <span class=
"sd"> * @inheritDoc
</span>
2904 <span class=
"sd"> */
</span>
2905 <span class=
"k">protected
</span> <span class=
"k">function
</span> <span class=
"nf">getObjectList
</span><span class=
"p">()
</span>
2906 <span class=
"p">{
</span>
2907 <span class=
"k">return
</span> <span class=
"k">new
</span> <span class=
"nx">PersonList
</span><span class=
"p">();
</span>
2908 <span class=
"p">}
</span>
2910 <span class=
"sd">/**
</span>
2911 <span class=
"sd"> * @inheritDoc
</span>
2912 <span class=
"sd"> */
</span>
2913 <span class=
"k">protected
</span> <span class=
"k">function
</span> <span class=
"nf">getTemplate
</span><span class=
"p">()
</span>
2914 <span class=
"p">{
</span>
2915 <span class=
"k">return
</span> <span class=
"nx">WCF
</span><span class=
"o">::
</span><span class=
"na">getTPL
</span><span class=
"p">()
</span><span class=
"o">-
></span><span class=
"na">fetch
</span><span class=
"p">(
</span><span class=
"s1">'boxPersonList
'</span><span class=
"p">,
</span> <span class=
"s1">'wcf
'</span><span class=
"p">,
</span> <span class=
"p">[
</span>
2916 <span class=
"s1">'boxPersonList
'</span> <span class=
"o">=
></span> <span class=
"nv">$this
</span><span class=
"o">-
></span><span class=
"na">objectList
</span><span class=
"p">,
</span>
2917 <span class=
"s1">'boxSortField
'</span> <span class=
"o">=
></span> <span class=
"nv">$this
</span><span class=
"o">-
></span><span class=
"na">sortField
</span><span class=
"p">,
</span>
2918 <span class=
"s1">'boxPosition
'</span> <span class=
"o">=
></span> <span class=
"nv">$this
</span><span class=
"o">-
></span><span class=
"na">box
</span><span class=
"o">-
></span><span class=
"na">position
</span><span class=
"p">,
</span>
2919 <span class=
"p">],
</span> <span class=
"k">true
</span><span class=
"p">);
</span>
2920 <span class=
"p">}
</span>
2921 <span class=
"p">}
</span>
2922 </code></pre></div></td></tr></table></div>
2923 <p>By extending
<code>AbstractDatabaseObjectListBoxController
</code>, we only have to provide minimal data ourself and rely mostly on the default implementation provided by
<code>AbstractDatabaseObjectListBoxController
</code>:
</p>
2925 <li>As we will support
<a href=
"#conditions">conditions
</a> for the listed people, we have to set the relevant condition definition via
<code>$conditionDefinition
</code>.
</li>
2926 <li><code>AbstractDatabaseObjectListBoxController
</code> already supports restricting the number of listed objects.
2927 To do so, you only have to specify the default number of listed objects via
<code>$defaultLimit
</code>.
</li>
2928 <li><code>AbstractDatabaseObjectListBoxController
</code> also supports setting the sort order of the listed objects.
2929 You have to provide the supported sort fields via
<code>$validSortFields
</code> and specify the prefix used for the language items of the sort fields via
<code>$sortFieldLanguageItemPrefix
</code> so that for every
<code>$validSortField
</code> in
<code>$validSortFields
</code>, the language item
<code>{$sortFieldLanguageItemPrefix}.{$validSortField}
</code> must exist.
</li>
2930 <li>The box system supports
<a href=
"../../../package/pip/box/#position">different positions
</a>.
2931 Each box controller specifies the positions it supports via
<code>$supportedPositions
</code>.
2932 To keep the implementation simple here as different positions might require different output in the template, we restrict ourselves to sidebars.
</li>
2933 <li><code>getObjectList()
</code> returns an instance of
<code>DatabaseObjectList
</code> that is used to read the listed objects.
2934 <code>getObjectList()
</code> itself must not call
<code>readObjects()
</code>, as
<code>AbstractDatabaseObjectListBoxController
</code> takes care of calling the method after adding the conditions and setting the sort order.
</li>
2935 <li><code>getTemplate()
</code> returns the contents of the box relying on the
<code>boxPersonList
</code> template here:
</li>
2937 <div class=
"highlight"><table class=
"highlighttable"><tr><th colspan=
"2" class=
"filename"><span class=
"filename">templates/boxPersonList.tpl
<a class=
"codeBoxTitleGitHubLink" href=
"https://github.com/WoltLab/docs.woltlab.com/tree/6.0/snippets/tutorial/tutorial-series/part-4/templates/boxPersonList.tpl" title=
"View on GitHub"><span class=
"twemoji"><svg xmlns=
"http://www.w3.org/2000/svg" viewBox=
"0 0 24 24"><path d=
"M3.9 12c0-1.71 1.39-3.1 3.1-3.1h4V7H7a5 5 0 0 0-5 5 5 5 0 0 0 5 5h4v-1.9H7c-1.71 0-3.1-1.39-3.1-3.1M8 13h8v-2H8v2m9-6h-4v1.9h4c1.71 0 3.1 1.39 3.1 3.1 0 1.71-1.39 3.1-3.1 3.1h-4V17h4a5 5 0 0 0 5-5 5 5 0 0 0-5-5Z"/></svg></span></a></span></th></tr><tr><td class=
"linenos"><div class=
"linenodiv"><pre><span></span><span class=
"normal"> 1</span>
2938 <span class=
"normal"> 2</span>
2939 <span class=
"normal"> 3</span>
2940 <span class=
"normal"> 4</span>
2941 <span class=
"normal"> 5</span>
2942 <span class=
"normal"> 6</span>
2943 <span class=
"normal"> 7</span>
2944 <span class=
"normal"> 8</span>
2945 <span class=
"normal"> 9</span>
2946 <span class=
"normal">10</span>
2947 <span class=
"normal">11</span>
2948 <span class=
"normal">12</span>
2949 <span class=
"normal">13</span>
2950 <span class=
"normal">14</span>
2951 <span class=
"normal">15</span></pre></div></td><td class=
"code"><div><pre><span></span><code><span class=
"x"><ul class=
"sidebarItemList
"></span>
2952 <span class=
"x"> </span><span class=
"cp">{
</span><span class=
"nf">foreach
</span> <span class=
"na">from
</span><span class=
"o">=
</span><span class=
"nv">$boxPersonList
</span> <span class=
"na">item
</span><span class=
"o">=
</span><span class=
"na">boxPerson
</span><span class=
"cp">}
</span>
2953 <span class=
"x"> <li class=
"box24
"></span>
2954 <span class=
"x"> <span class=
"icon icon24 fa-user
"></span
></span>
2956 <span class=
"x"> <div class=
"sidebarItemTitle
"></span>
2957 <span class=
"x"> <h3
></span><span class=
"cp">{
</span><span class=
"nf">anchor
</span> <span class=
"na">object
</span><span class=
"o">=
</span><span class=
"nv">$boxPerson
</span><span class=
"cp">}
</span><span class=
"x"></h3
></span>
2958 <span class=
"x"> </span><span class=
"cp">{
</span><span class=
"nf">capture
</span> <span class=
"na">assign
</span><span class=
"o">=
</span><span class=
"s1">'__boxPersonDescription
'</span><span class=
"cp">}{
</span><span class=
"nf">lang
</span> <span class=
"na">__optional
</span><span class=
"o">=
</span><span class=
"kc">true
</span><span class=
"cp">}
</span><span class=
"x">wcf.person.boxList.description.
</span><span class=
"cp">{
</span><span class=
"nv">$boxSortField
</span><span class=
"cp">}{
</span><span class=
"nf">/lang
</span><span class=
"cp">}{
</span><span class=
"nf">/capture
</span><span class=
"cp">}
</span>
2959 <span class=
"x"> </span><span class=
"cp">{
</span><span class=
"nf">if
</span> <span class=
"nv">$__boxPersonDescription
</span><span class=
"cp">}
</span>
2960 <span class=
"x"> <small
></span><span class=
"cp">{
</span><span class=
"o">@
</span><span class=
"nv">$__boxPersonDescription
</span><span class=
"cp">}
</span><span class=
"x"></small
></span>
2961 <span class=
"x"> </span><span class=
"cp">{
</span><span class=
"nf">/if
</span><span class=
"cp">}
</span>
2962 <span class=
"x"> </div
></span>
2963 <span class=
"x"> </li
></span>
2964 <span class=
"x"> </span><span class=
"cp">{
</span><span class=
"nf">/foreach
</span><span class=
"cp">}
</span>
2965 <span class=
"x"></ul
></span>
2966 </code></pre></div></td></tr></table></div>
2967 <p>The template relies on a
<code>.sidebarItemList
</code> element, which is generally used for sidebar listings.
2968 (If different box positions were supported, we either have to generate different output by considering the value of
<code>$boxPosition
</code> in the template or by using different templates in
<code>getTemplate()
</code>.)
2969 One specific piece of code is the
<code>$__boxPersonDescription
</code> variable, which supports an optional description below the person's name relying on the optional language item
<code>wcf.person.boxList.description.{$boxSortField}
</code>.
2970 We only add one such language item when sorting the people by comments:
2971 In such a case, the number of comments will be shown.
2972 (When sorting by first and last name, there are no additional useful information that could be shown here, though the plugin from
<a href=
"../part_2/">part
2</a> adding support for birthdays might also show the birthday when sorting by first or last name.)
</p>
2973 <p>Lastly, we also provide the language item
<code>wcf.acp.box.boxController.com.woltlab.wcf.personList
</code>, which is used in the list of available box controllers.
</p>
2974 <h2 id=
"conditions">Conditions
<a class=
"headerlink" href=
"#conditions" title=
"Permanent link">#
</a></h2>
2975 <p>The condition system can be used to generally filter a list of objects.
2976 In our case, the box system supports conditions to filter the objects shown in a specific box.
2977 Admittedly, our current person implementation only contains minimal data so that filtering might not make the most sense here but it will still show how to use the condition system for boxes.
2978 We will support filtering the people by their first and last name so that, for example, a box can be created listing all people with a specific first name.
</p>
2979 <p>The first step for condition support is to register a object type definition for the relevant conditions requiring the
<code>IObjectListCondition
</code> interface:
</p>
2980 <div class=
"highlight"><table class=
"highlighttable"><tr><th colspan=
"2" class=
"filename"><span class=
"filename">objectTypeDefinition.xml
<a class=
"codeBoxTitleGitHubLink" href=
"https://github.com/WoltLab/docs.woltlab.com/tree/6.0/snippets/tutorial/tutorial-series/part-4/objectTypeDefinition.xml" title=
"View on GitHub"><span class=
"twemoji"><svg xmlns=
"http://www.w3.org/2000/svg" viewBox=
"0 0 24 24"><path d=
"M3.9 12c0-1.71 1.39-3.1 3.1-3.1h4V7H7a5 5 0 0 0-5 5 5 5 0 0 0 5 5h4v-1.9H7c-1.71 0-3.1-1.39-3.1-3.1M8 13h8v-2H8v2m9-6h-4v1.9h4c1.71 0 3.1 1.39 3.1 3.1 0 1.71-1.39 3.1-3.1 3.1h-4V17h4a5 5 0 0 0 5-5 5 5 0 0 0-5-5Z"/></svg></span></a></span></th></tr><tr><td class=
"linenos"><div class=
"linenodiv"><pre><span></span><span class=
"normal">1</span>
2981 <span class=
"normal">2</span>
2982 <span class=
"normal">3</span>
2983 <span class=
"normal">4</span>
2984 <span class=
"normal">5</span>
2985 <span class=
"normal">6</span>
2986 <span class=
"normal">7</span>
2987 <span class=
"normal">8</span>
2988 <span class=
"normal">9</span></pre></div></td><td class=
"code"><div><pre><span></span><code><span class=
"cp"><?xml version=
"1.0" encoding=
"UTF-
8"?
></span>
2989 <span class=
"nt"><data
</span><span class=
"w"> </span><span class=
"na">xmlns=
</span><span class=
"s">"http://www.woltlab.com
"</span><span class=
"w"> </span><span class=
"na">xmlns:xsi=
</span><span class=
"s">"http://www.w3.org/
2001/XMLSchema-instance
"</span><span class=
"w"> </span><span class=
"na">xsi:schemaLocation=
</span><span class=
"s">"http://www.woltlab.com http://www.woltlab.com/XSD/
5.4/objectTypeDefinition.xsd
"</span><span class=
"nt">></span>
2990 <span class=
"w"> </span><span class=
"nt"><import
></span>
2991 <span class=
"w"> </span><span class=
"nt"><definition
></span>
2992 <span class=
"w"> </span><span class=
"nt"><name
></span>com.woltlab.wcf.box.personList.condition
<span class=
"nt"></name
></span>
2993 <span class=
"w"> </span><span class=
"nt"><interfacename
></span>wcf\system\condition\IObjectListCondition
<span class=
"nt"></interfacename
></span>
2994 <span class=
"w"> </span><span class=
"nt"></definition
></span>
2995 <span class=
"w"> </span><span class=
"nt"></import
></span>
2996 <span class=
"nt"></data
></span>
2997 </code></pre></div></td></tr></table></div>
2998 <p>Next, we register the specific conditions for filtering by the first and last name using this object type condition:
</p>
2999 <div class=
"highlight"><table class=
"highlighttable"><tr><td class=
"linenos"><div class=
"linenodiv"><pre><span></span><span class=
"normal"> 1</span>
3000 <span class=
"normal"> 2</span>
3001 <span class=
"normal"> 3</span>
3002 <span class=
"normal"> 4</span>
3003 <span class=
"normal"> 5</span>
3004 <span class=
"normal"> 6</span>
3005 <span class=
"normal"> 7</span>
3006 <span class=
"normal"> 8</span>
3007 <span class=
"normal"> 9</span>
3008 <span class=
"normal">10</span></pre></div></td><td class=
"code"><div><pre><span></span><code><span class=
"nt"><type
></span>
3009 <span class=
"w"> </span><span class=
"nt"><name
></span>com.woltlab.wcf.people.firstName
<span class=
"nt"></name
></span>
3010 <span class=
"w"> </span><span class=
"nt"><definitionname
></span>com.woltlab.wcf.box.personList.condition
<span class=
"nt"></definitionname
></span>
3011 <span class=
"w"> </span><span class=
"nt"><classname
></span>wcf\system\condition\person\PersonFirstNameTextPropertyCondition
<span class=
"nt"></classname
></span>
3012 <span class=
"nt"></type
></span>
3013 <span class=
"nt"><type
></span>
3014 <span class=
"w"> </span><span class=
"nt"><name
></span>com.woltlab.wcf.people.lastName
<span class=
"nt"></name
></span>
3015 <span class=
"w"> </span><span class=
"nt"><definitionname
></span>com.woltlab.wcf.box.personList.condition
<span class=
"nt"></definitionname
></span>
3016 <span class=
"w"> </span><span class=
"nt"><classname
></span>wcf\system\condition\person\PersonLastNameTextPropertyCondition
<span class=
"nt"></classname
></span>
3017 <span class=
"nt"></type
></span>
3018 </code></pre></div></td></tr></table></div>
3019 <p><code>PersonFirstNameTextPropertyCondition
</code> and
<code>PersonLastNameTextPropertyCondition
</code> only differ minimally so that we only focus on
<code>PersonFirstNameTextPropertyCondition
</code> here, which relies on the default implementation
<code>AbstractObjectTextPropertyCondition
</code> and only requires specifying different object properties:
</p>
3020 <div class=
"highlight"><table class=
"highlighttable"><tr><th colspan=
"2" class=
"filename"><span class=
"filename">files/lib/system/condition/person/PersonFirstNameTextPropertyCondition.class.php
<a class=
"codeBoxTitleGitHubLink" href=
"https://github.com/WoltLab/docs.woltlab.com/tree/6.0/snippets/tutorial/tutorial-series/part-4/files/lib/system/condition/person/PersonFirstNameTextPropertyCondition.class.php" title=
"View on GitHub"><span class=
"twemoji"><svg xmlns=
"http://www.w3.org/2000/svg" viewBox=
"0 0 24 24"><path d=
"M3.9 12c0-1.71 1.39-3.1 3.1-3.1h4V7H7a5 5 0 0 0-5 5 5 5 0 0 0 5 5h4v-1.9H7c-1.71 0-3.1-1.39-3.1-3.1M8 13h8v-2H8v2m9-6h-4v1.9h4c1.71 0 3.1 1.39 3.1 3.1 0 1.71-1.39 3.1-3.1 3.1h-4V17h4a5 5 0 0 0 5-5 5 5 0 0 0-5-5Z"/></svg></span></a></span></th></tr><tr><td class=
"linenos"><div class=
"linenodiv"><pre><span></span><span class=
"normal"> 1</span>
3021 <span class=
"normal"> 2</span>
3022 <span class=
"normal"> 3</span>
3023 <span class=
"normal"> 4</span>
3024 <span class=
"normal"> 5</span>
3025 <span class=
"normal"> 6</span>
3026 <span class=
"normal"> 7</span>
3027 <span class=
"normal"> 8</span>
3028 <span class=
"normal"> 9</span>
3029 <span class=
"normal">10</span>
3030 <span class=
"normal">11</span>
3031 <span class=
"normal">12</span>
3032 <span class=
"normal">13</span>
3033 <span class=
"normal">14</span>
3034 <span class=
"normal">15</span>
3035 <span class=
"normal">16</span>
3036 <span class=
"normal">17</span>
3037 <span class=
"normal">18</span>
3038 <span class=
"normal">19</span>
3039 <span class=
"normal">20</span>
3040 <span class=
"normal">21</span>
3041 <span class=
"normal">22</span>
3042 <span class=
"normal">23</span>
3043 <span class=
"normal">24</span>
3044 <span class=
"normal">25</span>
3045 <span class=
"normal">26</span>
3046 <span class=
"normal">27</span>
3047 <span class=
"normal">28</span>
3048 <span class=
"normal">29</span>
3049 <span class=
"normal">30</span>
3050 <span class=
"normal">31</span>
3051 <span class=
"normal">32</span>
3052 <span class=
"normal">33</span>
3053 <span class=
"normal">34</span>
3054 <span class=
"normal">35</span>
3055 <span class=
"normal">36</span>
3056 <span class=
"normal">37</span>
3057 <span class=
"normal">38</span>
3058 <span class=
"normal">39</span>
3059 <span class=
"normal">40</span>
3060 <span class=
"normal">41</span>
3061 <span class=
"normal">42</span>
3062 <span class=
"normal">43</span>
3063 <span class=
"normal">44</span>
3064 <span class=
"normal">45</span>
3065 <span class=
"normal">46</span>
3066 <span class=
"normal">47</span></pre></div></td><td class=
"code"><div><pre><span></span><code><span class=
"o"><?
</span><span class=
"nx">php
</span>
3068 <span class=
"k">namespace
</span> <span class=
"nx">wcf\system\condition\person
</span><span class=
"p">;
</span>
3070 <span class=
"k">use
</span> <span class=
"nx">wcf\data\person\Person
</span><span class=
"p">;
</span>
3071 <span class=
"k">use
</span> <span class=
"nx">wcf\system\condition\AbstractObjectTextPropertyCondition
</span><span class=
"p">;
</span>
3073 <span class=
"sd">/**
</span>
3074 <span class=
"sd"> * Condition implementation for the first name of a person.
</span>
3075 <span class=
"sd"> *
</span>
3076 <span class=
"sd"> * @author Matthias Schmidt
</span>
3077 <span class=
"sd"> * @copyright
2001-
2022 WoltLab GmbH
</span>
3078 <span class=
"sd"> * @license WoltLab License
<http://www.woltlab.com/license-agreement.html
></span>
3079 <span class=
"sd"> * @package WoltLabSuite\Core\System\Condition
</span>
3080 <span class=
"sd"> */
</span>
3081 <span class=
"k">final
</span> <span class=
"k">class
</span> <span class=
"nc">PersonFirstNameTextPropertyCondition
</span> <span class=
"k">extends
</span> <span class=
"nx">AbstractObjectTextPropertyCondition
</span>
3082 <span class=
"p">{
</span>
3083 <span class=
"sd">/**
</span>
3084 <span class=
"sd"> * @inheritDoc
</span>
3085 <span class=
"sd"> */
</span>
3086 <span class=
"k">protected
</span> <span class=
"nv">$className
</span> <span class=
"o">=
</span> <span class=
"nx">Person
</span><span class=
"o">::
</span><span class=
"na">class
</span><span class=
"p">;
</span>
3088 <span class=
"sd">/**
</span>
3089 <span class=
"sd"> * @inheritDoc
</span>
3090 <span class=
"sd"> */
</span>
3091 <span class=
"k">protected
</span> <span class=
"nv">$description
</span> <span class=
"o">=
</span> <span class=
"s1">'wcf.person.condition.firstName.description
'</span><span class=
"p">;
</span>
3093 <span class=
"sd">/**
</span>
3094 <span class=
"sd"> * @inheritDoc
</span>
3095 <span class=
"sd"> */
</span>
3096 <span class=
"k">protected
</span> <span class=
"nv">$fieldName
</span> <span class=
"o">=
</span> <span class=
"s1">'personFirstName
'</span><span class=
"p">;
</span>
3098 <span class=
"sd">/**
</span>
3099 <span class=
"sd"> * @inheritDoc
</span>
3100 <span class=
"sd"> */
</span>
3101 <span class=
"k">protected
</span> <span class=
"nv">$label
</span> <span class=
"o">=
</span> <span class=
"s1">'wcf.person.firstName
'</span><span class=
"p">;
</span>
3103 <span class=
"sd">/**
</span>
3104 <span class=
"sd"> * @inheritDoc
</span>
3105 <span class=
"sd"> */
</span>
3106 <span class=
"k">protected
</span> <span class=
"nv">$propertyName
</span> <span class=
"o">=
</span> <span class=
"s1">'firstName
'</span><span class=
"p">;
</span>
3108 <span class=
"sd">/**
</span>
3109 <span class=
"sd"> * @inheritDoc
</span>
3110 <span class=
"sd"> */
</span>
3111 <span class=
"k">protected
</span> <span class=
"nv">$supportsMultipleValues
</span> <span class=
"o">=
</span> <span class=
"k">true
</span><span class=
"p">;
</span>
3112 <span class=
"p">}
</span>
3113 </code></pre></div></td></tr></table></div>
3115 <li><code>$className
</code> contains the class name of the relevant database object from which the class name of the database object list is derived and
<code>$propertyName
</code> is the name of the database object's property that contains the value used for filtering.
</li>
3116 <li>By setting
<code>$supportsMultipleValues
</code> to
<code>true
</code>, multiple comma-separated values can be specified so that, for example, a box can also only list people with either of two specific first names.
</li>
3117 <li><code>$description
</code> (optional),
<code>$fieldName
</code>, and
<code>$label
</code> are used in the output of the form field.
</li>
3119 <p>(The implementation here is specific for
<code>AbstractObjectTextPropertyCondition
</code>.
3120 The
<code>wcf\system\condition
</code> namespace also contains several other default condition implementations.)
</p>
3123 <div class=
"md-source-file">
3145 <footer class=
"md-footer">
3147 <div class=
"md-footer-meta md-typeset">
3148 <div class=
"md-footer-meta__inner md-grid">
3149 <div class=
"md-copyright">
3151 <div class=
"md-copyright__highlight">
3152 Copyright ©
2020 WoltLab GmbH
3157 <a href=
"https://squidfunk.github.io/mkdocs-material/" target=
"_blank" rel=
"noopener">
3163 <div class=
"md-copyright">
3164 <a href=
"https://www.woltlab.com/legal-notice/">Legal Notice
</a>
3165 <a href=
"https://www.woltlab.com/privacy-policy/">Privacy Policy
</a>
3173 <div class=
"md-dialog" data-md-component=
"dialog">
3174 <div class=
"md-dialog__inner md-typeset"></div>
3177 <script id=
"__config" type=
"application/json">{
"base":
"../../..",
"features": [
"navigation.tracking"],
"search":
"../../../assets/javascripts/workers/search.208ed371.min.js",
"translations": {
"clipboard.copied":
"Copied to clipboard",
"clipboard.copy":
"Copy to clipboard",
"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":
"Select version"},
"version": {
"provider":
"mike"}}
</script>
3180 <script src=
"../../../assets/javascripts/bundle.b4d07000.min.js"></script>