Commit | Line | Data |
---|---|---|
0c5338dd TD |
1 | |
2 | <!doctype html> | |
3 | <html lang="en" class="no-js"> | |
4 | <head> | |
5 | ||
6 | <meta charset="utf-8"> | |
7 | <meta name="viewport" content="width=device-width,initial-scale=1"> | |
8 | ||
9 | ||
10 | ||
11 | ||
fb962f09 WG |
12 | <link rel="icon" href="../../../assets/default.favicon.ico"> |
13 | <meta name="generator" content="mkdocs-1.1.2, mkdocs-material-7.1.0"> | |
0c5338dd TD |
14 | |
15 | ||
16 | ||
17 | <title>Part 3 - WoltLab Suite Documentation</title> | |
18 | ||
19 | ||
20 | ||
fb962f09 | 21 | <link rel="stylesheet" href="../../../assets/stylesheets/main.33e2939f.min.css"> |
0c5338dd TD |
22 | |
23 | ||
fb962f09 | 24 | <link rel="stylesheet" href="../../../assets/stylesheets/palette.ef6f36e2.min.css"> |
0c5338dd TD |
25 | |
26 | ||
27 | ||
28 | <meta name="theme-color" content="#009485"> | |
29 | ||
30 | ||
31 | ||
32 | ||
33 | ||
fd8430cb WG |
34 | |
35 | ||
0c5338dd TD |
36 | |
37 | ||
38 | <link rel="stylesheet" href="../../../stylesheets/extra.css"> | |
39 | ||
40 | ||
41 | ||
42 | ||
43 | ||
44 | </head> | |
45 | ||
46 | ||
47 | ||
48 | ||
49 | ||
50 | ||
51 | ||
52 | <body dir="ltr" data-md-color-scheme="" data-md-color-primary="teal" data-md-color-accent=""> | |
0c5338dd TD |
53 | |
54 | ||
fb962f09 WG |
55 | <script>function __prefix(e){return new URL("../../..",location).pathname+"."+e}function __get(e,t=localStorage){return JSON.parse(t.getItem(__prefix(e)))}</script> |
56 | ||
0c5338dd TD |
57 | <input class="md-toggle" data-md-toggle="drawer" type="checkbox" id="__drawer" autocomplete="off"> |
58 | <input class="md-toggle" data-md-toggle="search" type="checkbox" id="__search" autocomplete="off"> | |
59 | <label class="md-overlay" for="__drawer"></label> | |
60 | <div data-md-component="skip"> | |
61 | ||
62 | ||
63 | <a href="#tutorial-series-part-3-person-page-and-comments" class="md-skip"> | |
64 | Skip to content | |
65 | </a> | |
66 | ||
67 | </div> | |
68 | <div data-md-component="announce"> | |
69 | ||
70 | <aside class="md-announce"> | |
71 | <div class="md-announce__inner md-grid md-typeset"> | |
72 | ||
73 | <a href="https://www.woltlab.com">Back to <strong>woltlab.com</strong></a> | |
74 | ||
75 | </div> | |
76 | </aside> | |
77 | ||
78 | </div> | |
79 | ||
fb962f09 | 80 | <header class="md-header" data-md-component="header"> |
0c5338dd | 81 | <nav class="md-header__inner md-grid" aria-label="Header"> |
fb962f09 | 82 | <a href="../../.." title="WoltLab Suite Documentation" class="md-header__button md-logo" aria-label="WoltLab Suite Documentation" data-md-component="logo"> |
0c5338dd TD |
83 | |
84 | <img src="../../../assets/logo.png" alt="logo"> | |
85 | ||
86 | </a> | |
87 | <label class="md-header__button md-icon" for="__drawer"> | |
88 | <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M3 6h18v2H3V6m0 5h18v2H3v-2m0 5h18v2H3v-2z"/></svg> | |
89 | </label> | |
90 | <div class="md-header__title" data-md-component="header-title"> | |
91 | <div class="md-header__ellipsis"> | |
92 | <div class="md-header__topic"> | |
93 | <span class="md-ellipsis"> | |
94 | WoltLab Suite Documentation | |
95 | </span> | |
96 | </div> | |
97 | <div class="md-header__topic" data-md-component="header-topic"> | |
98 | <span class="md-ellipsis"> | |
99 | ||
100 | Part 3 | |
101 | ||
102 | </span> | |
103 | </div> | |
104 | </div> | |
0c5338dd TD |
105 | </div> |
106 | ||
fb962f09 WG |
107 | |
108 | ||
a3639e76 WG |
109 | <label class="md-header__button md-icon" for="__search"> |
110 | <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.5 3A6.5 6.5 0 0 1 16 9.5c0 1.61-.59 3.09-1.56 4.23l.27.27h.79l5 5-1.5 1.5-5-5v-.79l-.27-.27A6.516 6.516 0 0 1 9.5 16 6.5 6.5 0 0 1 3 9.5 6.5 6.5 0 0 1 9.5 3m0 2C7 5 5 7 5 9.5S7 14 9.5 14 14 12 14 9.5 12 5 9.5 5z"/></svg> | |
111 | </label> | |
112 | ||
113 | <div class="md-search" data-md-component="search" role="dialog"> | |
114 | <label class="md-search__overlay" for="__search"></label> | |
115 | <div class="md-search__inner" role="search"> | |
116 | <form class="md-search__form" name="search"> | |
117 | <input type="text" class="md-search__input" name="query" aria-label="Search" placeholder="Search" autocapitalize="off" autocorrect="off" autocomplete="off" spellcheck="false" data-md-component="search-query" data-md-state="active" required> | |
118 | <label class="md-search__icon md-icon" for="__search"> | |
119 | <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.5 3A6.5 6.5 0 0 1 16 9.5c0 1.61-.59 3.09-1.56 4.23l.27.27h.79l5 5-1.5 1.5-5-5v-.79l-.27-.27A6.516 6.516 0 0 1 9.5 16 6.5 6.5 0 0 1 3 9.5 6.5 6.5 0 0 1 9.5 3m0 2C7 5 5 7 5 9.5S7 14 9.5 14 14 12 14 9.5 12 5 9.5 5z"/></svg> | |
120 | <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20 11v2H8l5.5 5.5-1.42 1.42L4.16 12l7.92-7.92L13.5 5.5 8 11h12z"/></svg> | |
121 | </label> | |
122 | <button type="reset" class="md-search__icon md-icon" aria-label="Clear" tabindex="-1"> | |
fb962f09 | 123 | <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M19 6.41 17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12 19 6.41z"/></svg> |
a3639e76 WG |
124 | </button> |
125 | </form> | |
126 | <div class="md-search__output"> | |
127 | <div class="md-search__scrollwrap" data-md-scrollfix> | |
128 | <div class="md-search-result" data-md-component="search-result"> | |
129 | <div class="md-search-result__meta"> | |
130 | Initializing search | |
131 | </div> | |
132 | <ol class="md-search-result__list"></ol> | |
133 | </div> | |
134 | </div> | |
135 | </div> | |
136 | </div> | |
137 | </div> | |
138 | ||
0c5338dd | 139 | |
7124f4cb WG |
140 | <div class="md-header__source"> |
141 | ||
142 | <a href="https://github.com/WoltLab/docs.woltlab.com/" title="Go to repository" class="md-source" data-md-component="source"> | |
143 | <div class="md-source__icon md-icon"> | |
144 | ||
fb962f09 | 145 | <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><path d="M439.55 236.05 244 40.45a28.87 28.87 0 0 0-40.81 0l-40.66 40.63 51.52 51.52c27.06-9.14 52.68 16.77 43.39 43.68l49.66 49.66c34.23-11.8 61.18 31 35.47 56.69-26.49 26.49-70.21-2.87-56-37.34L240.22 199v121.85c25.3 12.54 22.26 41.85 9.08 55a34.34 34.34 0 0 1-48.55 0c-17.57-17.6-11.07-46.91 11.25-56v-123c-20.8-8.51-24.6-30.74-18.64-45L142.57 101 8.45 235.14a28.86 28.86 0 0 0 0 40.81l195.61 195.6a28.86 28.86 0 0 0 40.8 0l194.69-194.69a28.86 28.86 0 0 0 0-40.81z"/></svg> |
7124f4cb WG |
146 | </div> |
147 | <div class="md-source__repository"> | |
148 | GitHub | |
149 | </div> | |
150 | </a> | |
151 | </div> | |
152 | ||
0c5338dd TD |
153 | </nav> |
154 | </header> | |
155 | ||
156 | <div class="md-container" data-md-component="container"> | |
157 | ||
158 | ||
159 | ||
160 | ||
161 | <main class="md-main" data-md-component="main"> | |
162 | <div class="md-main__inner md-grid"> | |
163 | ||
164 | ||
165 | ||
166 | <div class="md-sidebar md-sidebar--primary" data-md-component="sidebar" data-md-type="navigation" > | |
167 | <div class="md-sidebar__scrollwrap"> | |
168 | <div class="md-sidebar__inner"> | |
169 | ||
170 | ||
171 | ||
0c5338dd TD |
172 | <nav class="md-nav md-nav--primary" aria-label="Navigation" data-md-level="0"> |
173 | <label class="md-nav__title" for="__drawer"> | |
fb962f09 | 174 | <a href="../../.." title="WoltLab Suite Documentation" class="md-nav__button md-logo" aria-label="WoltLab Suite Documentation" data-md-component="logo"> |
0c5338dd TD |
175 | |
176 | <img src="../../../assets/logo.png" alt="logo"> | |
177 | ||
178 | </a> | |
179 | WoltLab Suite Documentation | |
180 | </label> | |
181 | ||
7124f4cb WG |
182 | <div class="md-nav__source"> |
183 | ||
184 | <a href="https://github.com/WoltLab/docs.woltlab.com/" title="Go to repository" class="md-source" data-md-component="source"> | |
185 | <div class="md-source__icon md-icon"> | |
186 | ||
fb962f09 | 187 | <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><path d="M439.55 236.05 244 40.45a28.87 28.87 0 0 0-40.81 0l-40.66 40.63 51.52 51.52c27.06-9.14 52.68 16.77 43.39 43.68l49.66 49.66c34.23-11.8 61.18 31 35.47 56.69-26.49 26.49-70.21-2.87-56-37.34L240.22 199v121.85c25.3 12.54 22.26 41.85 9.08 55a34.34 34.34 0 0 1-48.55 0c-17.57-17.6-11.07-46.91 11.25-56v-123c-20.8-8.51-24.6-30.74-18.64-45L142.57 101 8.45 235.14a28.86 28.86 0 0 0 0 40.81l195.61 195.6a28.86 28.86 0 0 0 40.8 0l194.69-194.69a28.86 28.86 0 0 0 0-40.81z"/></svg> |
7124f4cb WG |
188 | </div> |
189 | <div class="md-source__repository"> | |
190 | GitHub | |
191 | </div> | |
192 | </a> | |
193 | </div> | |
194 | ||
0c5338dd TD |
195 | <ul class="md-nav__list" data-md-scrollfix> |
196 | ||
197 | ||
198 | ||
199 | ||
200 | ||
201 | ||
202 | ||
203 | ||
204 | <li class="md-nav__item"> | |
205 | <a href="../../../getting-started/" class="md-nav__link"> | |
206 | Getting Started | |
207 | </a> | |
208 | </li> | |
209 | ||
210 | ||
211 | ||
212 | ||
213 | ||
214 | ||
215 | ||
216 | ||
217 | ||
218 | ||
219 | ||
220 | <li class="md-nav__item md-nav__item--nested"> | |
221 | ||
222 | ||
223 | <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_2" type="checkbox" id="__nav_2" > | |
224 | ||
225 | <label class="md-nav__link" for="__nav_2"> | |
226 | PHP API | |
227 | <span class="md-nav__icon md-icon"></span> | |
228 | </label> | |
229 | <nav class="md-nav" aria-label="PHP API" data-md-level="1"> | |
230 | <label class="md-nav__title" for="__nav_2"> | |
231 | <span class="md-nav__icon md-icon"></span> | |
232 | PHP API | |
233 | </label> | |
234 | <ul class="md-nav__list" data-md-scrollfix> | |
235 | ||
236 | ||
237 | ||
238 | ||
239 | ||
240 | <li class="md-nav__item"> | |
241 | <a href="../../../php/pages/" class="md-nav__link"> | |
242 | Pages | |
243 | </a> | |
244 | </li> | |
245 | ||
246 | ||
247 | ||
248 | ||
249 | ||
250 | ||
251 | ||
252 | <li class="md-nav__item"> | |
253 | <a href="../../../php/database-objects/" class="md-nav__link"> | |
254 | Database Objects | |
255 | </a> | |
256 | </li> | |
257 | ||
258 | ||
259 | ||
260 | ||
261 | ||
262 | ||
263 | ||
264 | <li class="md-nav__item"> | |
265 | <a href="../../../php/database-access/" class="md-nav__link"> | |
266 | Database Access | |
267 | </a> | |
268 | </li> | |
269 | ||
270 | ||
271 | ||
272 | ||
273 | ||
274 | ||
275 | ||
276 | <li class="md-nav__item"> | |
277 | <a href="../../../php/exceptions/" class="md-nav__link"> | |
278 | Exceptions | |
279 | </a> | |
280 | </li> | |
281 | ||
282 | ||
283 | ||
284 | ||
285 | ||
286 | ||
287 | ||
288 | ||
289 | <li class="md-nav__item md-nav__item--nested"> | |
290 | ||
291 | ||
292 | <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_2_5" type="checkbox" id="__nav_2_5" > | |
293 | ||
294 | <label class="md-nav__link" for="__nav_2_5"> | |
295 | API | |
296 | <span class="md-nav__icon md-icon"></span> | |
297 | </label> | |
298 | <nav class="md-nav" aria-label="API" data-md-level="2"> | |
299 | <label class="md-nav__title" for="__nav_2_5"> | |
300 | <span class="md-nav__icon md-icon"></span> | |
301 | API | |
302 | </label> | |
303 | <ul class="md-nav__list" data-md-scrollfix> | |
304 | ||
305 | ||
306 | ||
307 | ||
308 | ||
309 | <li class="md-nav__item"> | |
310 | <a href="../../../php/api/caches/" class="md-nav__link"> | |
311 | Caches | |
312 | </a> | |
313 | </li> | |
314 | ||
315 | ||
316 | ||
317 | ||
318 | ||
319 | ||
320 | ||
321 | <li class="md-nav__item"> | |
322 | <a href="../../../php/api/comments/" class="md-nav__link"> | |
323 | Comments | |
324 | </a> | |
325 | </li> | |
326 | ||
327 | ||
328 | ||
329 | ||
330 | ||
331 | ||
332 | ||
333 | <li class="md-nav__item"> | |
334 | <a href="../../../php/api/cronjobs/" class="md-nav__link"> | |
335 | Cronjobs | |
336 | </a> | |
337 | </li> | |
338 | ||
339 | ||
340 | ||
341 | ||
342 | ||
343 | ||
344 | ||
345 | <li class="md-nav__item"> | |
346 | <a href="../../../php/api/events/" class="md-nav__link"> | |
347 | Events | |
348 | </a> | |
349 | </li> | |
350 | ||
351 | ||
352 | ||
353 | ||
354 | ||
355 | ||
356 | ||
357 | ||
358 | <li class="md-nav__item md-nav__item--nested"> | |
359 | ||
360 | ||
361 | <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_2_5_5" type="checkbox" id="__nav_2_5_5" > | |
362 | ||
363 | <label class="md-nav__link" for="__nav_2_5_5"> | |
364 | Form Builder | |
365 | <span class="md-nav__icon md-icon"></span> | |
366 | </label> | |
367 | <nav class="md-nav" aria-label="Form Builder" data-md-level="3"> | |
368 | <label class="md-nav__title" for="__nav_2_5_5"> | |
369 | <span class="md-nav__icon md-icon"></span> | |
370 | Form Builder | |
371 | </label> | |
372 | <ul class="md-nav__list" data-md-scrollfix> | |
373 | ||
374 | ||
375 | ||
376 | ||
377 | ||
378 | <li class="md-nav__item"> | |
379 | <a href="../../../php/api/form_builder/overview/" class="md-nav__link"> | |
380 | Overview | |
381 | </a> | |
382 | </li> | |
383 | ||
384 | ||
385 | ||
386 | ||
387 | ||
388 | ||
389 | ||
390 | <li class="md-nav__item"> | |
391 | <a href="../../../php/api/form_builder/structure/" class="md-nav__link"> | |
392 | Structure | |
393 | </a> | |
394 | </li> | |
395 | ||
396 | ||
397 | ||
398 | ||
399 | ||
400 | ||
401 | ||
402 | <li class="md-nav__item"> | |
403 | <a href="../../../php/api/form_builder/form_fields/" class="md-nav__link"> | |
404 | Fields | |
405 | </a> | |
406 | </li> | |
407 | ||
408 | ||
409 | ||
410 | ||
411 | ||
412 | ||
413 | ||
414 | <li class="md-nav__item"> | |
415 | <a href="../../../php/api/form_builder/validation_data/" class="md-nav__link"> | |
416 | Validation and Data | |
417 | </a> | |
418 | </li> | |
419 | ||
420 | ||
421 | ||
422 | ||
423 | ||
424 | ||
425 | ||
426 | <li class="md-nav__item"> | |
427 | <a href="../../../php/api/form_builder/dependencies/" class="md-nav__link"> | |
428 | Dependencies | |
429 | </a> | |
430 | </li> | |
431 | ||
432 | ||
433 | ||
434 | </ul> | |
435 | </nav> | |
436 | </li> | |
437 | ||
438 | ||
439 | ||
440 | ||
441 | ||
442 | ||
443 | ||
444 | <li class="md-nav__item"> | |
445 | <a href="../../../php/api/package_installation_plugins/" class="md-nav__link"> | |
446 | Package Installation Plugins | |
447 | </a> | |
448 | </li> | |
449 | ||
450 | ||
451 | ||
452 | ||
453 | ||
454 | ||
455 | ||
456 | <li class="md-nav__item"> | |
457 | <a href="../../../php/api/user_activity_points/" class="md-nav__link"> | |
458 | User Activity Points | |
459 | </a> | |
460 | </li> | |
461 | ||
462 | ||
463 | ||
464 | ||
465 | ||
466 | ||
467 | ||
468 | <li class="md-nav__item"> | |
469 | <a href="../../../php/api/user_notifications/" class="md-nav__link"> | |
470 | User Notifications | |
471 | </a> | |
472 | </li> | |
473 | ||
474 | ||
475 | ||
476 | ||
477 | ||
478 | ||
479 | ||
480 | <li class="md-nav__item"> | |
481 | <a href="../../../php/api/sitemaps/" class="md-nav__link"> | |
482 | Sitemaps | |
483 | </a> | |
484 | </li> | |
485 | ||
486 | ||
487 | ||
488 | </ul> | |
489 | </nav> | |
490 | </li> | |
491 | ||
492 | ||
493 | ||
494 | ||
495 | ||
496 | ||
497 | ||
498 | <li class="md-nav__item"> | |
499 | <a href="../../../php/code-style/" class="md-nav__link"> | |
500 | Code Style | |
501 | </a> | |
502 | </li> | |
503 | ||
504 | ||
505 | ||
506 | ||
507 | ||
508 | ||
509 | ||
510 | <li class="md-nav__item"> | |
511 | <a href="../../../php/apps/" class="md-nav__link"> | |
512 | Apps | |
513 | </a> | |
514 | </li> | |
515 | ||
516 | ||
517 | ||
518 | ||
519 | ||
520 | ||
521 | ||
522 | <li class="md-nav__item"> | |
523 | <a href="../../../php/gdpr/" class="md-nav__link"> | |
524 | GDPR | |
525 | </a> | |
526 | </li> | |
527 | ||
528 | ||
529 | ||
530 | </ul> | |
531 | </nav> | |
532 | </li> | |
533 | ||
534 | ||
535 | ||
536 | ||
537 | ||
538 | ||
539 | ||
540 | ||
541 | ||
542 | ||
543 | ||
544 | <li class="md-nav__item md-nav__item--nested"> | |
545 | ||
546 | ||
547 | <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_3" type="checkbox" id="__nav_3" > | |
548 | ||
549 | <label class="md-nav__link" for="__nav_3"> | |
550 | Languages, Templates & CSS | |
551 | <span class="md-nav__icon md-icon"></span> | |
552 | </label> | |
553 | <nav class="md-nav" aria-label="Languages, Templates & CSS" data-md-level="1"> | |
554 | <label class="md-nav__title" for="__nav_3"> | |
555 | <span class="md-nav__icon md-icon"></span> | |
556 | Languages, Templates & CSS | |
557 | </label> | |
558 | <ul class="md-nav__list" data-md-scrollfix> | |
559 | ||
560 | ||
561 | ||
562 | ||
563 | ||
564 | <li class="md-nav__item"> | |
565 | <a href="../../../view/languages/" class="md-nav__link"> | |
566 | Languages | |
567 | </a> | |
568 | </li> | |
569 | ||
570 | ||
571 | ||
572 | ||
573 | ||
574 | ||
575 | ||
576 | <li class="md-nav__item"> | |
577 | <a href="../../../view/templates/" class="md-nav__link"> | |
578 | Templates | |
579 | </a> | |
580 | </li> | |
581 | ||
582 | ||
583 | ||
584 | ||
585 | ||
586 | ||
587 | ||
588 | <li class="md-nav__item"> | |
589 | <a href="../../../view/css/" class="md-nav__link"> | |
590 | CSS | |
591 | </a> | |
592 | </li> | |
593 | ||
594 | ||
595 | ||
596 | </ul> | |
597 | </nav> | |
598 | </li> | |
599 | ||
600 | ||
601 | ||
602 | ||
603 | ||
604 | ||
605 | ||
606 | ||
607 | ||
608 | ||
609 | ||
610 | <li class="md-nav__item md-nav__item--nested"> | |
611 | ||
612 | ||
613 | <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_4" type="checkbox" id="__nav_4" > | |
614 | ||
615 | <label class="md-nav__link" for="__nav_4"> | |
77efcd46 | 616 | TypeScript and JavaScript API |
0c5338dd TD |
617 | <span class="md-nav__icon md-icon"></span> |
618 | </label> | |
77efcd46 | 619 | <nav class="md-nav" aria-label="TypeScript and JavaScript API" data-md-level="1"> |
0c5338dd TD |
620 | <label class="md-nav__title" for="__nav_4"> |
621 | <span class="md-nav__icon md-icon"></span> | |
77efcd46 | 622 | TypeScript and JavaScript API |
0c5338dd TD |
623 | </label> |
624 | <ul class="md-nav__list" data-md-scrollfix> | |
625 | ||
626 | ||
627 | ||
628 | ||
629 | ||
630 | <li class="md-nav__item"> | |
631 | <a href="../../../javascript/general-usage/" class="md-nav__link"> | |
632 | General Usage | |
633 | </a> | |
634 | </li> | |
635 | ||
636 | ||
637 | ||
638 | ||
639 | ||
640 | ||
641 | ||
77efcd46 WG |
642 | <li class="md-nav__item"> |
643 | <a href="../../../javascript/typescript/" class="md-nav__link"> | |
644 | TypeScript | |
645 | </a> | |
646 | </li> | |
647 | ||
648 | ||
649 | ||
650 | ||
651 | ||
652 | ||
653 | ||
0c5338dd TD |
654 | |
655 | <li class="md-nav__item md-nav__item--nested"> | |
656 | ||
657 | ||
77efcd46 | 658 | <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_4_3" type="checkbox" id="__nav_4_3" > |
0c5338dd | 659 | |
77efcd46 | 660 | <label class="md-nav__link" for="__nav_4_3"> |
0c5338dd TD |
661 | New API |
662 | <span class="md-nav__icon md-icon"></span> | |
663 | </label> | |
664 | <nav class="md-nav" aria-label="New API" data-md-level="2"> | |
77efcd46 | 665 | <label class="md-nav__title" for="__nav_4_3"> |
0c5338dd TD |
666 | <span class="md-nav__icon md-icon"></span> |
667 | New API | |
668 | </label> | |
669 | <ul class="md-nav__list" data-md-scrollfix> | |
670 | ||
671 | ||
672 | ||
673 | ||
674 | ||
675 | <li class="md-nav__item"> | |
676 | <a href="../../../javascript/new-api_writing-a-module/" class="md-nav__link"> | |
677 | Writing a module | |
678 | </a> | |
679 | </li> | |
680 | ||
681 | ||
682 | ||
683 | ||
684 | ||
685 | ||
686 | ||
687 | <li class="md-nav__item"> | |
688 | <a href="../../../javascript/new-api_data-structures/" class="md-nav__link"> | |
689 | Data Structures | |
690 | </a> | |
691 | </li> | |
692 | ||
693 | ||
694 | ||
695 | ||
696 | ||
697 | ||
698 | ||
699 | <li class="md-nav__item"> | |
700 | <a href="../../../javascript/new-api_core/" class="md-nav__link"> | |
701 | Core Functions | |
702 | </a> | |
703 | </li> | |
704 | ||
705 | ||
706 | ||
707 | ||
708 | ||
709 | ||
710 | ||
711 | <li class="md-nav__item"> | |
712 | <a href="../../../javascript/new-api_dom/" class="md-nav__link"> | |
713 | DOM | |
714 | </a> | |
715 | </li> | |
716 | ||
717 | ||
718 | ||
719 | ||
720 | ||
721 | ||
722 | ||
723 | <li class="md-nav__item"> | |
724 | <a href="../../../javascript/new-api_events/" class="md-nav__link"> | |
725 | Event Handling | |
726 | </a> | |
727 | </li> | |
728 | ||
729 | ||
730 | ||
731 | ||
732 | ||
733 | ||
734 | ||
735 | <li class="md-nav__item"> | |
736 | <a href="../../../javascript/new-api_ajax/" class="md-nav__link"> | |
737 | Ajax | |
738 | </a> | |
739 | </li> | |
740 | ||
741 | ||
742 | ||
743 | ||
744 | ||
745 | ||
746 | ||
747 | <li class="md-nav__item"> | |
748 | <a href="../../../javascript/new-api_dialogs/" class="md-nav__link"> | |
749 | Dialogs | |
750 | </a> | |
751 | </li> | |
752 | ||
753 | ||
754 | ||
755 | ||
756 | ||
757 | ||
758 | ||
759 | <li class="md-nav__item"> | |
760 | <a href="../../../javascript/new-api_browser/" class="md-nav__link"> | |
761 | Browser and Screen Sizes | |
762 | </a> | |
763 | </li> | |
764 | ||
765 | ||
766 | ||
767 | ||
768 | ||
769 | ||
770 | ||
771 | <li class="md-nav__item"> | |
772 | <a href="../../../javascript/new-api_ui/" class="md-nav__link"> | |
773 | User Interface | |
774 | </a> | |
775 | </li> | |
776 | ||
777 | ||
778 | ||
779 | </ul> | |
780 | </nav> | |
781 | </li> | |
782 | ||
783 | ||
784 | ||
785 | ||
786 | ||
787 | ||
788 | ||
789 | <li class="md-nav__item"> | |
790 | <a href="../../../javascript/legacy-api/" class="md-nav__link"> | |
791 | Legacy API | |
792 | </a> | |
793 | </li> | |
794 | ||
795 | ||
796 | ||
797 | ||
798 | ||
799 | ||
800 | ||
801 | <li class="md-nav__item"> | |
802 | <a href="../../../javascript/helper-functions/" class="md-nav__link"> | |
803 | Helper Functions | |
804 | </a> | |
805 | </li> | |
806 | ||
807 | ||
808 | ||
809 | ||
810 | ||
811 | ||
812 | ||
813 | <li class="md-nav__item"> | |
814 | <a href="../../../javascript/code-snippets/" class="md-nav__link"> | |
815 | Code Snippets | |
816 | </a> | |
817 | </li> | |
818 | ||
819 | ||
820 | ||
821 | </ul> | |
822 | </nav> | |
823 | </li> | |
824 | ||
825 | ||
826 | ||
827 | ||
828 | ||
829 | ||
830 | ||
831 | ||
832 | ||
833 | ||
834 | ||
835 | <li class="md-nav__item md-nav__item--nested"> | |
836 | ||
837 | ||
838 | <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_5" type="checkbox" id="__nav_5" > | |
839 | ||
840 | <label class="md-nav__link" for="__nav_5"> | |
841 | Package Components | |
842 | <span class="md-nav__icon md-icon"></span> | |
843 | </label> | |
844 | <nav class="md-nav" aria-label="Package Components" data-md-level="1"> | |
845 | <label class="md-nav__title" for="__nav_5"> | |
846 | <span class="md-nav__icon md-icon"></span> | |
847 | Package Components | |
848 | </label> | |
849 | <ul class="md-nav__list" data-md-scrollfix> | |
850 | ||
851 | ||
852 | ||
853 | ||
854 | ||
855 | <li class="md-nav__item"> | |
856 | <a href="../../../package/package-xml/" class="md-nav__link"> | |
857 | package.xml | |
858 | </a> | |
859 | </li> | |
860 | ||
861 | ||
862 | ||
863 | ||
864 | ||
865 | ||
866 | ||
867 | ||
868 | <li class="md-nav__item md-nav__item--nested"> | |
869 | ||
870 | ||
871 | <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_5_2" type="checkbox" id="__nav_5_2" > | |
872 | ||
873 | <label class="md-nav__link" for="__nav_5_2"> | |
874 | PIPs | |
875 | <span class="md-nav__icon md-icon"></span> | |
876 | </label> | |
877 | <nav class="md-nav" aria-label="PIPs" data-md-level="2"> | |
878 | <label class="md-nav__title" for="__nav_5_2"> | |
879 | <span class="md-nav__icon md-icon"></span> | |
880 | PIPs | |
881 | </label> | |
882 | <ul class="md-nav__list" data-md-scrollfix> | |
883 | ||
884 | ||
885 | ||
886 | ||
887 | ||
888 | <li class="md-nav__item"> | |
889 | <a href="../../../package/pip/" class="md-nav__link"> | |
890 | Overview | |
891 | </a> | |
892 | </li> | |
893 | ||
894 | ||
895 | ||
896 | ||
897 | ||
898 | ||
899 | ||
900 | <li class="md-nav__item"> | |
901 | <a href="../../../package/pip/acl-option/" class="md-nav__link"> | |
902 | aclOption | |
903 | </a> | |
904 | </li> | |
905 | ||
906 | ||
907 | ||
908 | ||
909 | ||
910 | ||
911 | ||
912 | <li class="md-nav__item"> | |
913 | <a href="../../../package/pip/acp-menu/" class="md-nav__link"> | |
914 | acpMenu | |
915 | </a> | |
916 | </li> | |
917 | ||
918 | ||
919 | ||
920 | ||
921 | ||
922 | ||
923 | ||
924 | <li class="md-nav__item"> | |
925 | <a href="../../../package/pip/acp-search-provider/" class="md-nav__link"> | |
926 | acpSearchProvider | |
927 | </a> | |
928 | </li> | |
929 | ||
930 | ||
931 | ||
932 | ||
933 | ||
934 | ||
935 | ||
936 | <li class="md-nav__item"> | |
937 | <a href="../../../package/pip/acp-template/" class="md-nav__link"> | |
938 | acpTemplate | |
939 | </a> | |
940 | </li> | |
941 | ||
942 | ||
943 | ||
944 | ||
945 | ||
946 | ||
947 | ||
948 | <li class="md-nav__item"> | |
949 | <a href="../../../package/pip/bbcode/" class="md-nav__link"> | |
950 | bbcode | |
951 | </a> | |
952 | </li> | |
953 | ||
954 | ||
955 | ||
956 | ||
957 | ||
958 | ||
959 | ||
960 | <li class="md-nav__item"> | |
961 | <a href="../../../package/pip/box/" class="md-nav__link"> | |
962 | box | |
963 | </a> | |
964 | </li> | |
965 | ||
966 | ||
967 | ||
968 | ||
969 | ||
970 | ||
971 | ||
972 | <li class="md-nav__item"> | |
973 | <a href="../../../package/pip/clipboard-action/" class="md-nav__link"> | |
974 | clipboardAction | |
975 | </a> | |
976 | </li> | |
977 | ||
978 | ||
979 | ||
980 | ||
981 | ||
982 | ||
983 | ||
984 | <li class="md-nav__item"> | |
985 | <a href="../../../package/pip/core-object/" class="md-nav__link"> | |
986 | coreObject | |
987 | </a> | |
988 | </li> | |
989 | ||
990 | ||
991 | ||
992 | ||
993 | ||
994 | ||
995 | ||
996 | <li class="md-nav__item"> | |
997 | <a href="../../../package/pip/cronjob/" class="md-nav__link"> | |
998 | cronjob | |
999 | </a> | |
1000 | </li> | |
1001 | ||
1002 | ||
1003 | ||
1004 | ||
1005 | ||
1006 | ||
1007 | ||
1008 | <li class="md-nav__item"> | |
1009 | <a href="../../../package/pip/event-listener/" class="md-nav__link"> | |
1010 | eventListener | |
1011 | </a> | |
1012 | </li> | |
1013 | ||
1014 | ||
1015 | ||
1016 | ||
1017 | ||
1018 | ||
1019 | ||
1020 | <li class="md-nav__item"> | |
1021 | <a href="../../../package/pip/file/" class="md-nav__link"> | |
1022 | file | |
1023 | </a> | |
1024 | </li> | |
1025 | ||
1026 | ||
1027 | ||
1028 | ||
1029 | ||
1030 | ||
1031 | ||
1032 | <li class="md-nav__item"> | |
1033 | <a href="../../../package/pip/language/" class="md-nav__link"> | |
1034 | language | |
1035 | </a> | |
1036 | </li> | |
1037 | ||
1038 | ||
1039 | ||
1040 | ||
1041 | ||
1042 | ||
1043 | ||
1044 | <li class="md-nav__item"> | |
1045 | <a href="../../../package/pip/media-provider/" class="md-nav__link"> | |
1046 | mediaProvider | |
1047 | </a> | |
1048 | </li> | |
1049 | ||
1050 | ||
1051 | ||
1052 | ||
1053 | ||
1054 | ||
1055 | ||
1056 | <li class="md-nav__item"> | |
1057 | <a href="../../../package/pip/menu/" class="md-nav__link"> | |
1058 | menu | |
1059 | </a> | |
1060 | </li> | |
1061 | ||
1062 | ||
1063 | ||
1064 | ||
1065 | ||
1066 | ||
1067 | ||
1068 | <li class="md-nav__item"> | |
1069 | <a href="../../../package/pip/menu-item/" class="md-nav__link"> | |
1070 | menuItem | |
1071 | </a> | |
1072 | </li> | |
1073 | ||
1074 | ||
1075 | ||
1076 | ||
1077 | ||
1078 | ||
1079 | ||
1080 | <li class="md-nav__item"> | |
1081 | <a href="../../../package/pip/object-type/" class="md-nav__link"> | |
1082 | objectType | |
1083 | </a> | |
1084 | </li> | |
1085 | ||
1086 | ||
1087 | ||
1088 | ||
1089 | ||
1090 | ||
1091 | ||
1092 | <li class="md-nav__item"> | |
1093 | <a href="../../../package/pip/object-type-definition/" class="md-nav__link"> | |
1094 | objectTypeDefinition | |
1095 | </a> | |
1096 | </li> | |
1097 | ||
1098 | ||
1099 | ||
1100 | ||
1101 | ||
1102 | ||
1103 | ||
1104 | <li class="md-nav__item"> | |
1105 | <a href="../../../package/pip/option/" class="md-nav__link"> | |
1106 | option | |
1107 | </a> | |
1108 | </li> | |
1109 | ||
1110 | ||
1111 | ||
1112 | ||
1113 | ||
1114 | ||
1115 | ||
1116 | <li class="md-nav__item"> | |
1117 | <a href="../../../package/pip/page/" class="md-nav__link"> | |
1118 | page | |
1119 | </a> | |
1120 | </li> | |
1121 | ||
1122 | ||
1123 | ||
1124 | ||
1125 | ||
1126 | ||
1127 | ||
1128 | <li class="md-nav__item"> | |
1129 | <a href="../../../package/pip/pip/" class="md-nav__link"> | |
1130 | pip | |
1131 | </a> | |
1132 | </li> | |
1133 | ||
1134 | ||
1135 | ||
1136 | ||
1137 | ||
1138 | ||
1139 | ||
1140 | <li class="md-nav__item"> | |
1141 | <a href="../../../package/pip/script/" class="md-nav__link"> | |
1142 | script | |
1143 | </a> | |
1144 | </li> | |
1145 | ||
1146 | ||
1147 | ||
1148 | ||
1149 | ||
1150 | ||
1151 | ||
1152 | <li class="md-nav__item"> | |
1153 | <a href="../../../package/pip/smiley/" class="md-nav__link"> | |
1154 | smiley | |
1155 | </a> | |
1156 | </li> | |
1157 | ||
1158 | ||
1159 | ||
1160 | ||
1161 | ||
1162 | ||
1163 | ||
1164 | <li class="md-nav__item"> | |
1165 | <a href="../../../package/pip/sql/" class="md-nav__link"> | |
1166 | sql | |
1167 | </a> | |
1168 | </li> | |
1169 | ||
1170 | ||
1171 | ||
1172 | ||
1173 | ||
1174 | ||
1175 | ||
1176 | <li class="md-nav__item"> | |
1177 | <a href="../../../package/pip/style/" class="md-nav__link"> | |
1178 | style | |
1179 | </a> | |
1180 | </li> | |
1181 | ||
1182 | ||
1183 | ||
1184 | ||
1185 | ||
1186 | ||
1187 | ||
1188 | <li class="md-nav__item"> | |
1189 | <a href="../../../package/pip/template/" class="md-nav__link"> | |
1190 | template | |
1191 | </a> | |
1192 | </li> | |
1193 | ||
1194 | ||
1195 | ||
1196 | ||
1197 | ||
1198 | ||
1199 | ||
1200 | <li class="md-nav__item"> | |
1201 | <a href="../../../package/pip/template-listener/" class="md-nav__link"> | |
1202 | templateListener | |
1203 | </a> | |
1204 | </li> | |
1205 | ||
1206 | ||
1207 | ||
1208 | ||
1209 | ||
1210 | ||
1211 | ||
1212 | <li class="md-nav__item"> | |
1213 | <a href="../../../package/pip/user-group-option/" class="md-nav__link"> | |
1214 | userGroupOption | |
1215 | </a> | |
1216 | </li> | |
1217 | ||
1218 | ||
1219 | ||
1220 | ||
1221 | ||
1222 | ||
1223 | ||
1224 | <li class="md-nav__item"> | |
1225 | <a href="../../../package/pip/user-menu/" class="md-nav__link"> | |
1226 | userMenu | |
1227 | </a> | |
1228 | </li> | |
1229 | ||
1230 | ||
1231 | ||
1232 | ||
1233 | ||
1234 | ||
1235 | ||
1236 | <li class="md-nav__item"> | |
1237 | <a href="../../../package/pip/user-notification-event/" class="md-nav__link"> | |
1238 | userNotificationEvent | |
1239 | </a> | |
1240 | </li> | |
1241 | ||
1242 | ||
1243 | ||
1244 | ||
1245 | ||
1246 | ||
1247 | ||
1248 | <li class="md-nav__item"> | |
1249 | <a href="../../../package/pip/user-option/" class="md-nav__link"> | |
1250 | userOption | |
1251 | </a> | |
1252 | </li> | |
1253 | ||
1254 | ||
1255 | ||
1256 | ||
1257 | ||
1258 | ||
1259 | ||
1260 | <li class="md-nav__item"> | |
1261 | <a href="../../../package/pip/user-profile-menu/" class="md-nav__link"> | |
1262 | userProfileMenu | |
1263 | </a> | |
1264 | </li> | |
1265 | ||
1266 | ||
1267 | ||
1268 | </ul> | |
1269 | </nav> | |
1270 | </li> | |
1271 | ||
1272 | ||
1273 | ||
1274 | ||
1275 | ||
1276 | ||
1277 | ||
1278 | <li class="md-nav__item"> | |
1279 | <a href="../../../package/database-php-api/" class="md-nav__link"> | |
1280 | Database PHP API | |
1281 | </a> | |
1282 | </li> | |
1283 | ||
1284 | ||
1285 | ||
1286 | </ul> | |
1287 | </nav> | |
1288 | </li> | |
1289 | ||
1290 | ||
1291 | ||
1292 | ||
1293 | ||
1294 | ||
1295 | ||
1296 | ||
1297 | ||
1298 | ||
1299 | ||
1300 | <li class="md-nav__item md-nav__item--nested"> | |
1301 | ||
1302 | ||
1303 | <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6" type="checkbox" id="__nav_6" > | |
1304 | ||
1305 | <label class="md-nav__link" for="__nav_6"> | |
1306 | Migration | |
1307 | <span class="md-nav__icon md-icon"></span> | |
1308 | </label> | |
1309 | <nav class="md-nav" aria-label="Migration" data-md-level="1"> | |
1310 | <label class="md-nav__title" for="__nav_6"> | |
1311 | <span class="md-nav__icon md-icon"></span> | |
1312 | Migration | |
1313 | </label> | |
1314 | <ul class="md-nav__list" data-md-scrollfix> | |
1315 | ||
1316 | ||
1317 | ||
1318 | ||
1319 | ||
1320 | ||
1321 | <li class="md-nav__item md-nav__item--nested"> | |
1322 | ||
1323 | ||
1324 | <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6_1" type="checkbox" id="__nav_6_1" > | |
1325 | ||
1326 | <label class="md-nav__link" for="__nav_6_1"> | |
1327 | Migrating from WSC 5.3 | |
1328 | <span class="md-nav__icon md-icon"></span> | |
1329 | </label> | |
1330 | <nav class="md-nav" aria-label="Migrating from WSC 5.3" data-md-level="2"> | |
1331 | <label class="md-nav__title" for="__nav_6_1"> | |
1332 | <span class="md-nav__icon md-icon"></span> | |
1333 | Migrating from WSC 5.3 | |
1334 | </label> | |
1335 | <ul class="md-nav__list" data-md-scrollfix> | |
1336 | ||
1337 | ||
1338 | ||
1339 | ||
1340 | ||
1341 | <li class="md-nav__item"> | |
1342 | <a href="../../../migration/wsc53/php/" class="md-nav__link"> | |
1343 | PHP API | |
1344 | </a> | |
1345 | </li> | |
1346 | ||
1347 | ||
1348 | ||
1349 | ||
1350 | ||
1351 | ||
1352 | ||
1353 | <li class="md-nav__item"> | |
1354 | <a href="../../../migration/wsc53/session/" class="md-nav__link"> | |
1355 | Session Handling and Authentication | |
1356 | </a> | |
1357 | </li> | |
1358 | ||
1359 | ||
1360 | ||
1361 | ||
1362 | ||
1363 | ||
1364 | ||
1365 | <li class="md-nav__item"> | |
1366 | <a href="../../../migration/wsc53/javascript/" class="md-nav__link"> | |
77efcd46 | 1367 | TypeScript and JavaScript |
0c5338dd TD |
1368 | </a> |
1369 | </li> | |
1370 | ||
1371 | ||
1372 | ||
1373 | ||
1374 | ||
1375 | ||
1376 | ||
1377 | <li class="md-nav__item"> | |
1378 | <a href="../../../migration/wsc53/templates/" class="md-nav__link"> | |
1379 | Templates | |
1380 | </a> | |
1381 | </li> | |
1382 | ||
1383 | ||
1384 | ||
1385 | ||
1386 | ||
1387 | ||
1388 | ||
1389 | <li class="md-nav__item"> | |
1390 | <a href="../../../migration/wsc53/libraries/" class="md-nav__link"> | |
1391 | Third Party Libraries | |
1392 | </a> | |
1393 | </li> | |
1394 | ||
1395 | ||
1396 | ||
1397 | </ul> | |
1398 | </nav> | |
1399 | </li> | |
1400 | ||
1401 | ||
1402 | ||
1403 | ||
1404 | ||
1405 | ||
1406 | ||
1407 | ||
1408 | <li class="md-nav__item md-nav__item--nested"> | |
1409 | ||
1410 | ||
1411 | <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6_2" type="checkbox" id="__nav_6_2" > | |
1412 | ||
1413 | <label class="md-nav__link" for="__nav_6_2"> | |
1414 | Migrating from WSC 5.2 | |
1415 | <span class="md-nav__icon md-icon"></span> | |
1416 | </label> | |
1417 | <nav class="md-nav" aria-label="Migrating from WSC 5.2" data-md-level="2"> | |
1418 | <label class="md-nav__title" for="__nav_6_2"> | |
1419 | <span class="md-nav__icon md-icon"></span> | |
1420 | Migrating from WSC 5.2 | |
1421 | </label> | |
1422 | <ul class="md-nav__list" data-md-scrollfix> | |
1423 | ||
1424 | ||
1425 | ||
1426 | ||
1427 | ||
1428 | <li class="md-nav__item"> | |
1429 | <a href="../../../migration/wsc52/php/" class="md-nav__link"> | |
1430 | PHP API | |
1431 | </a> | |
1432 | </li> | |
1433 | ||
1434 | ||
1435 | ||
1436 | ||
1437 | ||
1438 | ||
1439 | ||
1440 | <li class="md-nav__item"> | |
1441 | <a href="../../../migration/wsc52/templates/" class="md-nav__link"> | |
1442 | Templates and Languages | |
1443 | </a> | |
1444 | </li> | |
1445 | ||
1446 | ||
1447 | ||
1448 | ||
1449 | ||
1450 | ||
1451 | ||
1452 | <li class="md-nav__item"> | |
1453 | <a href="../../../migration/wsc52/libraries/" class="md-nav__link"> | |
1454 | Third Party Libraries | |
1455 | </a> | |
1456 | </li> | |
1457 | ||
1458 | ||
1459 | ||
1460 | </ul> | |
1461 | </nav> | |
1462 | </li> | |
1463 | ||
1464 | ||
1465 | ||
1466 | ||
1467 | ||
1468 | ||
1469 | ||
1470 | ||
1471 | <li class="md-nav__item md-nav__item--nested"> | |
1472 | ||
1473 | ||
1474 | <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6_3" type="checkbox" id="__nav_6_3" > | |
1475 | ||
1476 | <label class="md-nav__link" for="__nav_6_3"> | |
1477 | Migrating from WSC 3.1 | |
1478 | <span class="md-nav__icon md-icon"></span> | |
1479 | </label> | |
1480 | <nav class="md-nav" aria-label="Migrating from WSC 3.1" data-md-level="2"> | |
1481 | <label class="md-nav__title" for="__nav_6_3"> | |
1482 | <span class="md-nav__icon md-icon"></span> | |
1483 | Migrating from WSC 3.1 | |
1484 | </label> | |
1485 | <ul class="md-nav__list" data-md-scrollfix> | |
1486 | ||
1487 | ||
1488 | ||
1489 | ||
1490 | ||
1491 | <li class="md-nav__item"> | |
1492 | <a href="../../../migration/wsc31/php/" class="md-nav__link"> | |
1493 | PHP API | |
1494 | </a> | |
1495 | </li> | |
1496 | ||
1497 | ||
1498 | ||
1499 | </ul> | |
1500 | </nav> | |
1501 | </li> | |
1502 | ||
1503 | ||
1504 | ||
1505 | ||
1506 | ||
1507 | ||
1508 | ||
1509 | ||
1510 | <li class="md-nav__item md-nav__item--nested"> | |
1511 | ||
1512 | ||
1513 | <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6_4" type="checkbox" id="__nav_6_4" > | |
1514 | ||
1515 | <label class="md-nav__link" for="__nav_6_4"> | |
1516 | Migrating from WSC 3.0 | |
1517 | <span class="md-nav__icon md-icon"></span> | |
1518 | </label> | |
1519 | <nav class="md-nav" aria-label="Migrating from WSC 3.0" data-md-level="2"> | |
1520 | <label class="md-nav__title" for="__nav_6_4"> | |
1521 | <span class="md-nav__icon md-icon"></span> | |
1522 | Migrating from WSC 3.0 | |
1523 | </label> | |
1524 | <ul class="md-nav__list" data-md-scrollfix> | |
1525 | ||
1526 | ||
1527 | ||
1528 | ||
1529 | ||
1530 | <li class="md-nav__item"> | |
1531 | <a href="../../../migration/wsc30/php/" class="md-nav__link"> | |
1532 | PHP API | |
1533 | </a> | |
1534 | </li> | |
1535 | ||
1536 | ||
1537 | ||
1538 | ||
1539 | ||
1540 | ||
1541 | ||
1542 | <li class="md-nav__item"> | |
1543 | <a href="../../../migration/wsc30/javascript/" class="md-nav__link"> | |
1544 | JavaScript API | |
1545 | </a> | |
1546 | </li> | |
1547 | ||
1548 | ||
1549 | ||
1550 | ||
1551 | ||
1552 | ||
1553 | ||
1554 | <li class="md-nav__item"> | |
1555 | <a href="../../../migration/wsc30/templates/" class="md-nav__link"> | |
1556 | Templates | |
1557 | </a> | |
1558 | </li> | |
1559 | ||
1560 | ||
1561 | ||
1562 | ||
1563 | ||
1564 | ||
1565 | ||
1566 | <li class="md-nav__item"> | |
1567 | <a href="../../../migration/wsc30/css/" class="md-nav__link"> | |
1568 | CSS | |
1569 | </a> | |
1570 | </li> | |
1571 | ||
1572 | ||
1573 | ||
1574 | ||
1575 | ||
1576 | ||
1577 | ||
1578 | <li class="md-nav__item"> | |
1579 | <a href="../../../migration/wsc30/package/" class="md-nav__link"> | |
1580 | Package Components | |
1581 | </a> | |
1582 | </li> | |
1583 | ||
1584 | ||
1585 | ||
1586 | </ul> | |
1587 | </nav> | |
1588 | </li> | |
1589 | ||
1590 | ||
1591 | ||
1592 | ||
1593 | ||
1594 | ||
1595 | ||
1596 | ||
1597 | <li class="md-nav__item md-nav__item--nested"> | |
1598 | ||
1599 | ||
1600 | <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6_5" type="checkbox" id="__nav_6_5" > | |
1601 | ||
1602 | <label class="md-nav__link" for="__nav_6_5"> | |
1603 | Migrating from WCF 2.1 | |
1604 | <span class="md-nav__icon md-icon"></span> | |
1605 | </label> | |
1606 | <nav class="md-nav" aria-label="Migrating from WCF 2.1" data-md-level="2"> | |
1607 | <label class="md-nav__title" for="__nav_6_5"> | |
1608 | <span class="md-nav__icon md-icon"></span> | |
1609 | Migrating from WCF 2.1 | |
1610 | </label> | |
1611 | <ul class="md-nav__list" data-md-scrollfix> | |
1612 | ||
1613 | ||
1614 | ||
1615 | ||
1616 | ||
1617 | <li class="md-nav__item"> | |
1618 | <a href="../../../migration/wcf21/php/" class="md-nav__link"> | |
1619 | PHP API | |
1620 | </a> | |
1621 | </li> | |
1622 | ||
1623 | ||
1624 | ||
1625 | ||
1626 | ||
1627 | ||
1628 | ||
1629 | <li class="md-nav__item"> | |
1630 | <a href="../../../migration/wcf21/templates/" class="md-nav__link"> | |
1631 | Templates | |
1632 | </a> | |
1633 | </li> | |
1634 | ||
1635 | ||
1636 | ||
1637 | ||
1638 | ||
1639 | ||
1640 | ||
1641 | <li class="md-nav__item"> | |
1642 | <a href="../../../migration/wcf21/css/" class="md-nav__link"> | |
1643 | CSS | |
1644 | </a> | |
1645 | </li> | |
1646 | ||
1647 | ||
1648 | ||
1649 | ||
1650 | ||
1651 | ||
1652 | ||
1653 | <li class="md-nav__item"> | |
1654 | <a href="../../../migration/wcf21/package/" class="md-nav__link"> | |
1655 | Package Components | |
1656 | </a> | |
1657 | </li> | |
1658 | ||
1659 | ||
1660 | ||
1661 | </ul> | |
1662 | </nav> | |
1663 | </li> | |
1664 | ||
1665 | ||
1666 | ||
1667 | </ul> | |
1668 | </nav> | |
1669 | </li> | |
1670 | ||
1671 | ||
1672 | ||
1673 | ||
1674 | ||
1675 | ||
1676 | ||
1677 | ||
1678 | ||
1679 | ||
1680 | ||
1681 | ||
1682 | ||
1683 | <li class="md-nav__item md-nav__item--active md-nav__item--nested"> | |
1684 | ||
1685 | ||
1686 | <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_7" type="checkbox" id="__nav_7" checked> | |
1687 | ||
1688 | <label class="md-nav__link" for="__nav_7"> | |
1689 | Tutorials | |
1690 | <span class="md-nav__icon md-icon"></span> | |
1691 | </label> | |
1692 | <nav class="md-nav" aria-label="Tutorials" data-md-level="1"> | |
1693 | <label class="md-nav__title" for="__nav_7"> | |
1694 | <span class="md-nav__icon md-icon"></span> | |
1695 | Tutorials | |
1696 | </label> | |
1697 | <ul class="md-nav__list" data-md-scrollfix> | |
1698 | ||
1699 | ||
1700 | ||
1701 | ||
1702 | ||
1703 | ||
1704 | ||
1705 | ||
1706 | <li class="md-nav__item md-nav__item--active md-nav__item--nested"> | |
1707 | ||
1708 | ||
1709 | <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_7_1" type="checkbox" id="__nav_7_1" checked> | |
1710 | ||
1711 | <label class="md-nav__link" for="__nav_7_1"> | |
1712 | Tutorial Series | |
1713 | <span class="md-nav__icon md-icon"></span> | |
1714 | </label> | |
1715 | <nav class="md-nav" aria-label="Tutorial Series" data-md-level="2"> | |
1716 | <label class="md-nav__title" for="__nav_7_1"> | |
1717 | <span class="md-nav__icon md-icon"></span> | |
1718 | Tutorial Series | |
1719 | </label> | |
1720 | <ul class="md-nav__list" data-md-scrollfix> | |
1721 | ||
1722 | ||
1723 | ||
1724 | ||
1725 | ||
1726 | <li class="md-nav__item"> | |
1727 | <a href="../overview/" class="md-nav__link"> | |
1728 | Overview | |
1729 | </a> | |
1730 | </li> | |
1731 | ||
1732 | ||
1733 | ||
1734 | ||
1735 | ||
1736 | ||
1737 | ||
1738 | <li class="md-nav__item"> | |
1739 | <a href="../part_1/" class="md-nav__link"> | |
1740 | Part 1 | |
1741 | </a> | |
1742 | </li> | |
1743 | ||
1744 | ||
1745 | ||
1746 | ||
1747 | ||
1748 | ||
1749 | ||
1750 | <li class="md-nav__item"> | |
1751 | <a href="../part_2/" class="md-nav__link"> | |
1752 | Part 2 | |
1753 | </a> | |
1754 | </li> | |
1755 | ||
1756 | ||
1757 | ||
1758 | ||
1759 | ||
1760 | ||
1761 | ||
1762 | ||
1763 | ||
1764 | <li class="md-nav__item md-nav__item--active"> | |
1765 | ||
1766 | <input class="md-nav__toggle md-toggle" data-md-toggle="toc" type="checkbox" id="__toc"> | |
1767 | ||
1768 | ||
1769 | ||
1770 | ||
1771 | <label class="md-nav__link md-nav__link--active" for="__toc"> | |
1772 | Part 3 | |
1773 | <span class="md-nav__icon md-icon"></span> | |
1774 | </label> | |
1775 | ||
1776 | <a href="./" class="md-nav__link md-nav__link--active"> | |
1777 | Part 3 | |
1778 | </a> | |
1779 | ||
1780 | ||
1781 | <nav class="md-nav md-nav--secondary" aria-label="Table of contents"> | |
1782 | ||
1783 | ||
1784 | ||
1785 | ||
1786 | ||
1787 | <label class="md-nav__title" for="__toc"> | |
1788 | <span class="md-nav__icon md-icon"></span> | |
1789 | Table of contents | |
1790 | </label> | |
1791 | <ul class="md-nav__list" data-md-component="toc" data-md-scrollfix> | |
1792 | ||
1793 | <li class="md-nav__item"> | |
1794 | <a href="#package-functionality" class="md-nav__link"> | |
1795 | Package Functionality | |
1796 | </a> | |
1797 | ||
1798 | </li> | |
1799 | ||
1800 | <li class="md-nav__item"> | |
1801 | <a href="#used-components" class="md-nav__link"> | |
1802 | Used Components | |
1803 | </a> | |
1804 | ||
1805 | </li> | |
1806 | ||
1807 | <li class="md-nav__item"> | |
1808 | <a href="#package-structure" class="md-nav__link"> | |
1809 | Package Structure | |
1810 | </a> | |
1811 | ||
1812 | </li> | |
1813 | ||
1814 | <li class="md-nav__item"> | |
1815 | <a href="#runtime-cache" class="md-nav__link"> | |
1816 | Runtime Cache | |
1817 | </a> | |
1818 | ||
1819 | </li> | |
1820 | ||
1821 | <li class="md-nav__item"> | |
1822 | <a href="#comments" class="md-nav__link"> | |
1823 | Comments | |
1824 | </a> | |
1825 | ||
1826 | </li> | |
1827 | ||
1828 | <li class="md-nav__item"> | |
1829 | <a href="#person-page" class="md-nav__link"> | |
1830 | Person Page | |
1831 | </a> | |
1832 | ||
1833 | <nav class="md-nav" aria-label="Person Page"> | |
1834 | <ul class="md-nav__list"> | |
1835 | ||
1836 | <li class="md-nav__item"> | |
1837 | <a href="#personpage" class="md-nav__link"> | |
1838 | PersonPage | |
1839 | </a> | |
1840 | ||
1841 | </li> | |
1842 | ||
1843 | <li class="md-nav__item"> | |
1844 | <a href="#persontpl" class="md-nav__link"> | |
1845 | person.tpl | |
1846 | </a> | |
1847 | ||
1848 | </li> | |
1849 | ||
1850 | <li class="md-nav__item"> | |
1851 | <a href="#pagexml" class="md-nav__link"> | |
1852 | page.xml | |
1853 | </a> | |
1854 | ||
1855 | </li> | |
1856 | ||
1857 | <li class="md-nav__item"> | |
1858 | <a href="#personpagehandler" class="md-nav__link"> | |
1859 | PersonPageHandler | |
1860 | </a> | |
1861 | ||
1862 | </li> | |
1863 | ||
1864 | </ul> | |
1865 | </nav> | |
1866 | ||
1867 | </li> | |
1868 | ||
1869 | </ul> | |
1870 | ||
1871 | </nav> | |
1872 | ||
1873 | </li> | |
1874 | ||
1875 | ||
1876 | ||
1877 | </ul> | |
1878 | </nav> | |
1879 | </li> | |
1880 | ||
1881 | ||
1882 | ||
1883 | </ul> | |
1884 | </nav> | |
1885 | </li> | |
1886 | ||
1887 | ||
1888 | ||
1889 | </ul> | |
1890 | </nav> | |
1891 | </div> | |
1892 | </div> | |
1893 | </div> | |
1894 | ||
1895 | ||
1896 | ||
1897 | <div class="md-sidebar md-sidebar--secondary" data-md-component="sidebar" data-md-type="toc" > | |
1898 | <div class="md-sidebar__scrollwrap"> | |
1899 | <div class="md-sidebar__inner"> | |
1900 | ||
1901 | <nav class="md-nav md-nav--secondary" aria-label="Table of contents"> | |
1902 | ||
1903 | ||
1904 | ||
1905 | ||
1906 | ||
1907 | <label class="md-nav__title" for="__toc"> | |
1908 | <span class="md-nav__icon md-icon"></span> | |
1909 | Table of contents | |
1910 | </label> | |
1911 | <ul class="md-nav__list" data-md-component="toc" data-md-scrollfix> | |
1912 | ||
1913 | <li class="md-nav__item"> | |
1914 | <a href="#package-functionality" class="md-nav__link"> | |
1915 | Package Functionality | |
1916 | </a> | |
1917 | ||
1918 | </li> | |
1919 | ||
1920 | <li class="md-nav__item"> | |
1921 | <a href="#used-components" class="md-nav__link"> | |
1922 | Used Components | |
1923 | </a> | |
1924 | ||
1925 | </li> | |
1926 | ||
1927 | <li class="md-nav__item"> | |
1928 | <a href="#package-structure" class="md-nav__link"> | |
1929 | Package Structure | |
1930 | </a> | |
1931 | ||
1932 | </li> | |
1933 | ||
1934 | <li class="md-nav__item"> | |
1935 | <a href="#runtime-cache" class="md-nav__link"> | |
1936 | Runtime Cache | |
1937 | </a> | |
1938 | ||
1939 | </li> | |
1940 | ||
1941 | <li class="md-nav__item"> | |
1942 | <a href="#comments" class="md-nav__link"> | |
1943 | Comments | |
1944 | </a> | |
1945 | ||
1946 | </li> | |
1947 | ||
1948 | <li class="md-nav__item"> | |
1949 | <a href="#person-page" class="md-nav__link"> | |
1950 | Person Page | |
1951 | </a> | |
1952 | ||
1953 | <nav class="md-nav" aria-label="Person Page"> | |
1954 | <ul class="md-nav__list"> | |
1955 | ||
1956 | <li class="md-nav__item"> | |
1957 | <a href="#personpage" class="md-nav__link"> | |
1958 | PersonPage | |
1959 | </a> | |
1960 | ||
1961 | </li> | |
1962 | ||
1963 | <li class="md-nav__item"> | |
1964 | <a href="#persontpl" class="md-nav__link"> | |
1965 | person.tpl | |
1966 | </a> | |
1967 | ||
1968 | </li> | |
1969 | ||
1970 | <li class="md-nav__item"> | |
1971 | <a href="#pagexml" class="md-nav__link"> | |
1972 | page.xml | |
1973 | </a> | |
1974 | ||
1975 | </li> | |
1976 | ||
1977 | <li class="md-nav__item"> | |
1978 | <a href="#personpagehandler" class="md-nav__link"> | |
1979 | PersonPageHandler | |
1980 | </a> | |
1981 | ||
1982 | </li> | |
1983 | ||
1984 | </ul> | |
1985 | </nav> | |
1986 | ||
1987 | </li> | |
1988 | ||
1989 | </ul> | |
1990 | ||
1991 | </nav> | |
1992 | </div> | |
1993 | </div> | |
1994 | </div> | |
1995 | ||
1996 | ||
1997 | <div class="md-content" data-md-component="content"> | |
1998 | <article class="md-content__inner md-typeset"> | |
1999 | ||
2000 | ||
9b8bddda | 2001 | <a href="https://github.com/WoltLab/docs.woltlab.com/edit/5.4/docs/tutorial/series/part_3.md" title="Edit this page" class="md-content__button md-icon"> |
7124f4cb WG |
2002 | <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> |
2003 | </a> | |
2004 | ||
0c5338dd TD |
2005 | |
2006 | <h1 id="tutorial-series-part-3-person-page-and-comments">Tutorial Series Part 3: Person Page and Comments<a class="headerlink" href="#tutorial-series-part-3-person-page-and-comments" title="Permanent link">#</a></h1> | |
2007 | <p>In this part of our tutorial series, we will add a new front end page to our package that is dedicated to each person and shows their personal details. | |
2008 | To make good use of this new page and introduce a new API of WoltLab Suite, we will add the opportunity for users to comment on the person using WoltLab Suite’s reusable comment functionality.</p> | |
2009 | <h2 id="package-functionality">Package Functionality<a class="headerlink" href="#package-functionality" title="Permanent link">#</a></h2> | |
2010 | <p>In addition to the existing functions from <a href="../part_1/">part 1</a>, the package will provide the following possibilities/functions after this part of the tutorial:</p> | |
2011 | <ul> | |
2012 | <li>Details page for each person linked in the front end person list</li> | |
2013 | <li>Comment on people on their respective page (can be disabled per person)</li> | |
2014 | <li>User online location for person details page with name and link to person details page</li> | |
2015 | <li>Create menu items linking to specific person details pages</li> | |
2016 | </ul> | |
2017 | <h2 id="used-components">Used Components<a class="headerlink" href="#used-components" title="Permanent link">#</a></h2> | |
2018 | <p>In addition to the components used in <a href="../part_1/">part 1</a>, we will use the <a href="../../../package/pip/object-type/">objectType package installation plugin</a>, use the <a href="../../../php/api/comments/">comment API</a>, create a <a href="../../../php/api/caches_runtime-caches/">runtime cache</a>, and create a page handler.</p> | |
2019 | <h2 id="package-structure">Package Structure<a class="headerlink" href="#package-structure" title="Permanent link">#</a></h2> | |
2020 | <p>The complete package will have the following file structure (including the files from <a href="../part_1/">part 1</a>):</p> | |
2021 | <div class="highlight"><pre><span></span><code>├── acpMenu.xml | |
2022 | ├── acptemplates | |
2023 | │ ├── personAdd.tpl | |
2024 | │ └── personList.tpl | |
2025 | ├── files | |
2026 | │ └── lib | |
2027 | │ ├── acp | |
2028 | │ │ ├── form | |
2029 | │ │ │ ├── PersonAddForm.class.php | |
2030 | │ │ │ └── PersonEditForm.class.php | |
2031 | │ │ └── page | |
2032 | │ │ └── PersonListPage.class.php | |
2033 | │ ├── data | |
2034 | │ │ └── person | |
2035 | │ │ ├── Person.class.php | |
2036 | │ │ ├── PersonAction.class.php | |
2037 | │ │ ├── PersonEditor.class.php | |
2038 | │ │ └── PersonList.class.php | |
2039 | │ ├── page | |
2040 | │ │ ├── PersonListPage.class.php | |
2041 | │ │ └── PersonPage.class.php | |
2042 | │ └── system | |
2043 | │ ├── cache | |
2044 | │ │ └── runtime | |
2045 | │ │ └── PersonRuntimeCache.class.php | |
2046 | │ ├── comment | |
2047 | │ │ └── manager | |
2048 | │ │ └── PersonCommentManager.class.php | |
2049 | │ └── page | |
2050 | │ └── handler | |
2051 | │ └── PersonPageHandler.class.php | |
2052 | ├── install.sql | |
2053 | ├── language | |
2054 | │ ├── de.xml | |
2055 | │ └── en.xml | |
2056 | ├── menuItem.xml | |
2057 | ├── objectType.xml | |
2058 | ├── package.xml | |
2059 | ├── page.xml | |
2060 | ├── templates | |
2061 | │ ├── person.tpl | |
2062 | │ └── personList.tpl | |
2063 | └── userGroupOption.xml | |
2064 | </code></pre></div> | |
0c5338dd | 2065 | <div class="admonition warning"> |
e3413d1b | 2066 | <p class="admonition-title">We will not mention every code change between the first part and this part, as we only want to focus on the important, new parts of the code. For example, there is a new <code>Person::getLink()</code> method and new language items have been added. For all changes, please refer to the <a href="https://github.com/WoltLab/docs.woltlab.com/tree/5.4/snippets/tutorial/tutorial-series/part-3">source code on GitHub</a>.</p> |
0c5338dd TD |
2067 | </div> |
2068 | <h2 id="runtime-cache">Runtime Cache<a class="headerlink" href="#runtime-cache" title="Permanent link">#</a></h2> | |
2069 | <p>To reduce the number of database queries when different APIs require person objects, we implement a <a href="../../../php/api/caches_runtime-caches/">runtime cache</a> for people:</p> | |
2070 | <div class="highlight"><pre><span></span><code><span class="o"><?</span><span class="nx">php</span> | |
2071 | <span class="k">namespace</span> <span class="nx">wcf\system\cache\runtime</span><span class="p">;</span> | |
2072 | <span class="k">use</span> <span class="nx">wcf\data\person\Person</span><span class="p">;</span> | |
2073 | <span class="k">use</span> <span class="nx">wcf\data\person\PersonList</span><span class="p">;</span> | |
2074 | ||
2075 | <span class="sd">/**</span> | |
2076 | <span class="sd"> * Runtime cache implementation for people.</span> | |
2077 | <span class="sd"> *</span> | |
2078 | <span class="sd"> * @author Matthias Schmidt</span> | |
2079 | <span class="sd"> * @copyright 2001-2019 WoltLab GmbH</span> | |
2080 | <span class="sd"> * @license GNU Lesser General Public License <http://opensource.org/licenses/lgpl-license.php></span> | |
2081 | <span class="sd"> * @package WoltLabSuite\Core\System\Cache\Runtime</span> | |
2082 | <span class="sd"> * @since 3.0</span> | |
2083 | <span class="sd"> *</span> | |
2084 | <span class="sd"> * @method Person[] getCachedObjects()</span> | |
2085 | <span class="sd"> * @method Person getObject($objectID)</span> | |
2086 | <span class="sd"> * @method Person[] getObjects(array $objectIDs)</span> | |
2087 | <span class="sd"> */</span> | |
2088 | <span class="k">class</span> <span class="nc">PersonRuntimeCache</span> <span class="k">extends</span> <span class="nx">AbstractRuntimeCache</span> <span class="p">{</span> | |
2089 | <span class="sd">/**</span> | |
2090 | <span class="sd"> * @inheritDoc</span> | |
2091 | <span class="sd"> */</span> | |
2092 | <span class="k">protected</span> <span class="nv">$listClassName</span> <span class="o">=</span> <span class="nx">PersonList</span><span class="o">::</span><span class="na">class</span><span class="p">;</span> | |
2093 | <span class="p">}</span> | |
2094 | </code></pre></div> | |
0c5338dd TD |
2095 | <h2 id="comments">Comments<a class="headerlink" href="#comments" title="Permanent link">#</a></h2> |
2096 | <p>To allow users to comment on people, we need to tell the system that people support comments. | |
2097 | This is done by registering a <code>com.woltlab.wcf.comment.commentableContent</code> object type whose processor implements <a href="https://github.com/WoltLab/WCF/blob/master/wcfsetup/install/files/lib/system/comment/manager/ICommentManager.class.php">ICommentManager</a>:</p> | |
2098 | <div class="highlight"><pre><span></span><code><span class="cp"><?xml version="1.0" encoding="UTF-8"?></span> | |
2099 | <span class="nt"><data</span> <span class="na">xmlns=</span><span class="s">"http://www.woltlab.com"</span> <span class="na">xmlns:xsi=</span><span class="s">"http://www.w3.org/2001/XMLSchema-instance"</span> <span class="na">xsi:schemaLocation=</span><span class="s">"http://www.woltlab.com http://www.woltlab.com/XSD/tornado/objectType.xsd"</span><span class="nt">></span> | |
2100 | <span class="nt"><import></span> | |
2101 | <span class="nt"><type></span> | |
2102 | <span class="nt"><name></span>com.woltlab.wcf.person.personComment<span class="nt"></name></span> | |
2103 | <span class="nt"><definitionname></span>com.woltlab.wcf.comment.commentableContent<span class="nt"></definitionname></span> | |
2104 | <span class="nt"><classname></span>wcf\system\comment\manager\PersonCommentManager<span class="nt"></classname></span> | |
2105 | <span class="nt"></type></span> | |
2106 | <span class="nt"></import></span> | |
2107 | <span class="nt"></data></span> | |
2108 | </code></pre></div> | |
0c5338dd TD |
2109 | <p>The <code>PersonCommentManager</code> class extended <code>ICommentManager</code>’s default implementation <a href="https://github.com/WoltLab/WCF/blob/master/wcfsetup/install/files/lib/system/comment/manager/AbstractCommentManager.class.php">AbstractCommentManager</a>:</p> |
2110 | <div class="highlight"><pre><span></span><code><span class="o"><?</span><span class="nx">php</span> | |
2111 | <span class="k">namespace</span> <span class="nx">wcf\system\comment\manager</span><span class="p">;</span> | |
2112 | <span class="k">use</span> <span class="nx">wcf\data\person\Person</span><span class="p">;</span> | |
2113 | <span class="k">use</span> <span class="nx">wcf\data\person\PersonEditor</span><span class="p">;</span> | |
2114 | <span class="k">use</span> <span class="nx">wcf\system\cache\runtime\PersonRuntimeCache</span><span class="p">;</span> | |
2115 | <span class="k">use</span> <span class="nx">wcf\system\WCF</span><span class="p">;</span> | |
2116 | ||
2117 | <span class="sd">/**</span> | |
2118 | <span class="sd"> * Comment manager implementation for people.</span> | |
2119 | <span class="sd"> *</span> | |
2120 | <span class="sd"> * @author Matthias Schmidt</span> | |
2121 | <span class="sd"> * @copyright 2001-2019 WoltLab GmbH</span> | |
2122 | <span class="sd"> * @license GNU Lesser General Public License <http://opensource.org/licenses/lgpl-license.php></span> | |
2123 | <span class="sd"> * @package WoltLabSuite\Core\System\Comment\Manager</span> | |
2124 | <span class="sd"> */</span> | |
2125 | <span class="k">class</span> <span class="nc">PersonCommentManager</span> <span class="k">extends</span> <span class="nx">AbstractCommentManager</span> <span class="p">{</span> | |
2126 | <span class="sd">/**</span> | |
2127 | <span class="sd"> * @inheritDoc</span> | |
2128 | <span class="sd"> */</span> | |
2129 | <span class="k">protected</span> <span class="nv">$permissionAdd</span> <span class="o">=</span> <span class="s1">'user.person.canAddComment'</span><span class="p">;</span> | |
2130 | ||
2131 | <span class="sd">/**</span> | |
2132 | <span class="sd"> * @inheritDoc</span> | |
2133 | <span class="sd"> */</span> | |
2134 | <span class="k">protected</span> <span class="nv">$permissionAddWithoutModeration</span> <span class="o">=</span> <span class="s1">'user.person.canAddCommentWithoutModeration'</span><span class="p">;</span> | |
2135 | ||
2136 | <span class="sd">/**</span> | |
2137 | <span class="sd"> * @inheritDoc</span> | |
2138 | <span class="sd"> */</span> | |
2139 | <span class="k">protected</span> <span class="nv">$permissionCanModerate</span> <span class="o">=</span> <span class="s1">'mod.person.canModerateComment'</span><span class="p">;</span> | |
2140 | ||
2141 | <span class="sd">/**</span> | |
2142 | <span class="sd"> * @inheritDoc</span> | |
2143 | <span class="sd"> */</span> | |
2144 | <span class="k">protected</span> <span class="nv">$permissionDelete</span> <span class="o">=</span> <span class="s1">'user.person.canDeleteComment'</span><span class="p">;</span> | |
2145 | ||
2146 | <span class="sd">/**</span> | |
2147 | <span class="sd"> * @inheritDoc</span> | |
2148 | <span class="sd"> */</span> | |
2149 | <span class="k">protected</span> <span class="nv">$permissionEdit</span> <span class="o">=</span> <span class="s1">'user.person.canEditComment'</span><span class="p">;</span> | |
2150 | ||
2151 | <span class="sd">/**</span> | |
2152 | <span class="sd"> * @inheritDoc</span> | |
2153 | <span class="sd"> */</span> | |
2154 | <span class="k">protected</span> <span class="nv">$permissionModDelete</span> <span class="o">=</span> <span class="s1">'mod.person.canDeleteComment'</span><span class="p">;</span> | |
2155 | ||
2156 | <span class="sd">/**</span> | |
2157 | <span class="sd"> * @inheritDoc</span> | |
2158 | <span class="sd"> */</span> | |
2159 | <span class="k">protected</span> <span class="nv">$permissionModEdit</span> <span class="o">=</span> <span class="s1">'mod.person.canEditComment'</span><span class="p">;</span> | |
2160 | ||
2161 | <span class="sd">/**</span> | |
2162 | <span class="sd"> * @inheritDoc</span> | |
2163 | <span class="sd"> */</span> | |
2164 | <span class="k">public</span> <span class="k">function</span> <span class="nf">getLink</span><span class="p">(</span><span class="nv">$objectTypeID</span><span class="p">,</span> <span class="nv">$objectID</span><span class="p">)</span> <span class="p">{</span> | |
2165 | <span class="k">return</span> <span class="nx">PersonRuntimeCache</span><span class="o">::</span><span class="na">getInstance</span><span class="p">()</span><span class="o">-></span><span class="na">getObject</span><span class="p">(</span><span class="nv">$objectID</span><span class="p">)</span><span class="o">-></span><span class="na">getLink</span><span class="p">();</span> | |
2166 | <span class="p">}</span> | |
2167 | ||
2168 | <span class="sd">/**</span> | |
2169 | <span class="sd"> * @inheritDoc</span> | |
2170 | <span class="sd"> */</span> | |
2171 | <span class="k">public</span> <span class="k">function</span> <span class="nf">isAccessible</span><span class="p">(</span><span class="nv">$objectID</span><span class="p">,</span> <span class="nv">$validateWritePermission</span> <span class="o">=</span> <span class="k">false</span><span class="p">)</span> <span class="p">{</span> | |
2172 | <span class="k">return</span> <span class="nx">PersonRuntimeCache</span><span class="o">::</span><span class="na">getInstance</span><span class="p">()</span><span class="o">-></span><span class="na">getObject</span><span class="p">(</span><span class="nv">$objectID</span><span class="p">)</span> <span class="o">!==</span> <span class="k">null</span><span class="p">;</span> | |
2173 | <span class="p">}</span> | |
2174 | ||
2175 | <span class="sd">/**</span> | |
2176 | <span class="sd"> * @inheritDoc</span> | |
2177 | <span class="sd"> */</span> | |
2178 | <span class="k">public</span> <span class="k">function</span> <span class="nf">getTitle</span><span class="p">(</span><span class="nv">$objectTypeID</span><span class="p">,</span> <span class="nv">$objectID</span><span class="p">,</span> <span class="nv">$isResponse</span> <span class="o">=</span> <span class="k">false</span><span class="p">)</span> <span class="p">{</span> | |
2179 | <span class="k">if</span> <span class="p">(</span><span class="nv">$isResponse</span><span class="p">)</span> <span class="p">{</span> | |
2180 | <span class="k">return</span> <span class="nx">WCF</span><span class="o">::</span><span class="na">getLanguage</span><span class="p">()</span><span class="o">-></span><span class="na">get</span><span class="p">(</span><span class="s1">'wcf.person.commentResponse'</span><span class="p">);</span> | |
2181 | <span class="p">}</span> | |
2182 | ||
2183 | <span class="k">return</span> <span class="nx">WCF</span><span class="o">::</span><span class="na">getLanguage</span><span class="p">()</span><span class="o">-></span><span class="na">getDynamicVariable</span><span class="p">(</span><span class="s1">'wcf.person.comment'</span><span class="p">);</span> | |
2184 | <span class="p">}</span> | |
2185 | ||
2186 | <span class="sd">/**</span> | |
2187 | <span class="sd"> * @inheritDoc</span> | |
2188 | <span class="sd"> */</span> | |
2189 | <span class="k">public</span> <span class="k">function</span> <span class="nf">updateCounter</span><span class="p">(</span><span class="nv">$objectID</span><span class="p">,</span> <span class="nv">$value</span><span class="p">)</span> <span class="p">{</span> | |
2190 | <span class="p">(</span><span class="k">new</span> <span class="nx">PersonEditor</span><span class="p">(</span><span class="k">new</span> <span class="nx">Person</span><span class="p">(</span><span class="nv">$objectID</span><span class="p">)))</span><span class="o">-></span><span class="na">updateCounters</span><span class="p">([</span><span class="s1">'comments'</span> <span class="o">=></span> <span class="nv">$value</span><span class="p">]);</span> | |
2191 | <span class="p">}</span> | |
2192 | <span class="p">}</span> | |
2193 | </code></pre></div> | |
0c5338dd TD |
2194 | <ul> |
2195 | <li>First, the system is told the names of the permissions via the <code>$permission*</code> properties. | |
2196 | More information about comment permissions can be found <a href="../../../php/api/comments/#user-group-options">here</a>.</li> | |
2197 | <li>The <code>getLink()</code> method returns the link to the person with the passed comment id. | |
2198 | As in <code>isAccessible()</code>, <code>PersonRuntimeCache</code> is used to potentially save database queries.</li> | |
2199 | <li>The <code>isAccessible()</code> method checks if the active user can access the relevant person. | |
2200 | As we do not have any special restrictions for accessing people, we only need to check if the person exists.</li> | |
2201 | <li>The <code>getTitle()</code> method returns the title used for comments and responses, which is just a generic language item in this case.</li> | |
2202 | <li>The <code>updateCounter()</code> updates the comments’ counter of the person. | |
2203 | We have added a new <code>comments</code> database table column to the <code>wcf1_person</code> database table in order to keep track on the number of comments.</li> | |
2204 | </ul> | |
2205 | <p>Additionally, we have added a new <code>enableComments</code> database table column to the <code>wcf1_person</code> database table whose value can be set when creating or editing a person in the ACP. | |
2206 | With this option, comments on individual people can be disabled.</p> | |
2207 | <div class="admonition info"> | |
2208 | <p class="admonition-title">Liking comments is already built-in and only requires some extra code in the <code>PersonPage</code> class for showing the likes of pre-loaded comments.</p> | |
2209 | </div> | |
2210 | <h2 id="person-page">Person Page<a class="headerlink" href="#person-page" title="Permanent link">#</a></h2> | |
2211 | <h3 id="personpage"><code>PersonPage</code><a class="headerlink" href="#personpage" title="Permanent link">#</a></h3> | |
2212 | <div class="highlight"><pre><span></span><code><span class="o"><?</span><span class="nx">php</span> | |
2213 | <span class="k">namespace</span> <span class="nx">wcf\page</span><span class="p">;</span> | |
2214 | <span class="k">use</span> <span class="nx">wcf\data\person\Person</span><span class="p">;</span> | |
2215 | <span class="k">use</span> <span class="nx">wcf\system\comment\CommentHandler</span><span class="p">;</span> | |
2216 | <span class="k">use</span> <span class="nx">wcf\system\comment\manager\PersonCommentManager</span><span class="p">;</span> | |
2217 | <span class="k">use</span> <span class="nx">wcf\system\exception\IllegalLinkException</span><span class="p">;</span> | |
2218 | <span class="k">use</span> <span class="nx">wcf\system\WCF</span><span class="p">;</span> | |
2219 | ||
2220 | <span class="sd">/**</span> | |
2221 | <span class="sd"> * Shows the details of a certain person.</span> | |
2222 | <span class="sd"> * </span> | |
2223 | <span class="sd"> * @author Matthias Schmidt</span> | |
2224 | <span class="sd"> * @copyright 2001-2019 WoltLab GmbH</span> | |
2225 | <span class="sd"> * @license GNU Lesser General Public License <http://opensource.org/licenses/lgpl-license.php></span> | |
2226 | <span class="sd"> * @package WoltLabSuite\Core\Page</span> | |
2227 | <span class="sd"> */</span> | |
2228 | <span class="k">class</span> <span class="nc">PersonPage</span> <span class="k">extends</span> <span class="nx">AbstractPage</span> <span class="p">{</span> | |
2229 | <span class="sd">/**</span> | |
2230 | <span class="sd"> * list of comments</span> | |
2231 | <span class="sd"> * @var StructuredCommentList</span> | |
2232 | <span class="sd"> */</span> | |
2233 | <span class="k">public</span> <span class="nv">$commentList</span><span class="p">;</span> | |
2234 | ||
2235 | <span class="sd">/**</span> | |
2236 | <span class="sd"> * person comment manager object</span> | |
2237 | <span class="sd"> * @var PersonCommentManager</span> | |
2238 | <span class="sd"> */</span> | |
2239 | <span class="k">public</span> <span class="nv">$commentManager</span><span class="p">;</span> | |
2240 | ||
2241 | <span class="sd">/**</span> | |
2242 | <span class="sd"> * id of the person comment object type</span> | |
2243 | <span class="sd"> * @var integer</span> | |
2244 | <span class="sd"> */</span> | |
2245 | <span class="k">public</span> <span class="nv">$commentObjectTypeID</span> <span class="o">=</span> <span class="mi">0</span><span class="p">;</span> | |
2246 | ||
2247 | <span class="sd">/**</span> | |
2248 | <span class="sd"> * shown person</span> | |
2249 | <span class="sd"> * @var Person</span> | |
2250 | <span class="sd"> */</span> | |
2251 | <span class="k">public</span> <span class="nv">$person</span><span class="p">;</span> | |
2252 | ||
2253 | <span class="sd">/**</span> | |
2254 | <span class="sd"> * id of the shown person</span> | |
2255 | <span class="sd"> * @var integer</span> | |
2256 | <span class="sd"> */</span> | |
2257 | <span class="k">public</span> <span class="nv">$personID</span> <span class="o">=</span> <span class="mi">0</span><span class="p">;</span> | |
2258 | ||
2259 | <span class="sd">/**</span> | |
2260 | <span class="sd"> * @inheritDoc</span> | |
2261 | <span class="sd"> */</span> | |
2262 | <span class="k">public</span> <span class="k">function</span> <span class="nf">assignVariables</span><span class="p">()</span> <span class="p">{</span> | |
2263 | <span class="k">parent</span><span class="o">::</span><span class="na">assignVariables</span><span class="p">();</span> | |
2264 | ||
2265 | <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">assign</span><span class="p">([</span> | |
2266 | <span class="s1">'commentCanAdd'</span> <span class="o">=></span> <span class="nx">WCF</span><span class="o">::</span><span class="na">getSession</span><span class="p">()</span><span class="o">-></span><span class="na">getPermission</span><span class="p">(</span><span class="s1">'user.person.canAddComment'</span><span class="p">),</span> | |
2267 | <span class="s1">'commentList'</span> <span class="o">=></span> <span class="nv">$this</span><span class="o">-></span><span class="na">commentList</span><span class="p">,</span> | |
2268 | <span class="s1">'commentObjectTypeID'</span> <span class="o">=></span> <span class="nv">$this</span><span class="o">-></span><span class="na">commentObjectTypeID</span><span class="p">,</span> | |
2269 | <span class="s1">'lastCommentTime'</span> <span class="o">=></span> <span class="nv">$this</span><span class="o">-></span><span class="na">commentList</span> <span class="o">?</span> <span class="nv">$this</span><span class="o">-></span><span class="na">commentList</span><span class="o">-></span><span class="na">getMinCommentTime</span><span class="p">()</span> <span class="o">:</span> <span class="mi">0</span><span class="p">,</span> | |
2270 | <span class="s1">'likeData'</span> <span class="o">=></span> <span class="p">(</span><span class="nx">MODULE_LIKE</span> <span class="o">&&</span> <span class="nv">$this</span><span class="o">-></span><span class="na">commentList</span><span class="p">)</span> <span class="o">?</span> <span class="nv">$this</span><span class="o">-></span><span class="na">commentList</span><span class="o">-></span><span class="na">getLikeData</span><span class="p">()</span> <span class="o">:</span> <span class="p">[],</span> | |
2271 | <span class="s1">'person'</span> <span class="o">=></span> <span class="nv">$this</span><span class="o">-></span><span class="na">person</span> | |
2272 | <span class="p">]);</span> | |
2273 | <span class="p">}</span> | |
2274 | ||
2275 | <span class="sd">/**</span> | |
2276 | <span class="sd"> * @inheritDoc</span> | |
2277 | <span class="sd"> */</span> | |
2278 | <span class="k">public</span> <span class="k">function</span> <span class="nf">readData</span><span class="p">()</span> <span class="p">{</span> | |
2279 | <span class="k">parent</span><span class="o">::</span><span class="na">readData</span><span class="p">();</span> | |
2280 | ||
2281 | <span class="k">if</span> <span class="p">(</span><span class="nv">$this</span><span class="o">-></span><span class="na">person</span><span class="o">-></span><span class="na">enableComments</span><span class="p">)</span> <span class="p">{</span> | |
2282 | <span class="nv">$this</span><span class="o">-></span><span class="na">commentObjectTypeID</span> <span class="o">=</span> <span class="nx">CommentHandler</span><span class="o">::</span><span class="na">getInstance</span><span class="p">()</span><span class="o">-></span><span class="na">getObjectTypeID</span><span class="p">(</span><span class="s1">'com.woltlab.wcf.person.personComment'</span><span class="p">);</span> | |
2283 | <span class="nv">$this</span><span class="o">-></span><span class="na">commentManager</span> <span class="o">=</span> <span class="nx">CommentHandler</span><span class="o">::</span><span class="na">getInstance</span><span class="p">()</span><span class="o">-></span><span class="na">getObjectType</span><span class="p">(</span><span class="nv">$this</span><span class="o">-></span><span class="na">commentObjectTypeID</span><span class="p">)</span><span class="o">-></span><span class="na">getProcessor</span><span class="p">();</span> | |
2284 | <span class="nv">$this</span><span class="o">-></span><span class="na">commentList</span> <span class="o">=</span> <span class="nx">CommentHandler</span><span class="o">::</span><span class="na">getInstance</span><span class="p">()</span><span class="o">-></span><span class="na">getCommentList</span><span class="p">(</span><span class="nv">$this</span><span class="o">-></span><span class="na">commentManager</span><span class="p">,</span> <span class="nv">$this</span><span class="o">-></span><span class="na">commentObjectTypeID</span><span class="p">,</span> <span class="nv">$this</span><span class="o">-></span><span class="na">person</span><span class="o">-></span><span class="na">personID</span><span class="p">);</span> | |
2285 | <span class="p">}</span> | |
2286 | <span class="p">}</span> | |
2287 | ||
2288 | <span class="sd">/**</span> | |
2289 | <span class="sd"> * @inheritDoc</span> | |
2290 | <span class="sd"> */</span> | |
2291 | <span class="k">public</span> <span class="k">function</span> <span class="nf">readParameters</span><span class="p">()</span> <span class="p">{</span> | |
2292 | <span class="k">parent</span><span class="o">::</span><span class="na">readParameters</span><span class="p">();</span> | |
2293 | ||
2294 | <span class="k">if</span> <span class="p">(</span><span class="nb">isset</span><span class="p">(</span><span class="nv">$_REQUEST</span><span class="p">[</span><span class="s1">'id'</span><span class="p">]))</span> <span class="nv">$this</span><span class="o">-></span><span class="na">personID</span> <span class="o">=</span> <span class="nb">intval</span><span class="p">(</span><span class="nv">$_REQUEST</span><span class="p">[</span><span class="s1">'id'</span><span class="p">]);</span> | |
2295 | <span class="nv">$this</span><span class="o">-></span><span class="na">person</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">Person</span><span class="p">(</span><span class="nv">$this</span><span class="o">-></span><span class="na">personID</span><span class="p">);</span> | |
2296 | <span class="k">if</span> <span class="p">(</span><span class="o">!</span><span class="nv">$this</span><span class="o">-></span><span class="na">person</span><span class="o">-></span><span class="na">personID</span><span class="p">)</span> <span class="p">{</span> | |
2297 | <span class="k">throw</span> <span class="k">new</span> <span class="nx">IllegalLinkException</span><span class="p">();</span> | |
2298 | <span class="p">}</span> | |
2299 | <span class="p">}</span> | |
2300 | <span class="p">}</span> | |
2301 | </code></pre></div> | |
0c5338dd TD |
2302 | <p>The <code>PersonPage</code> class is similar to the <code>PersonEditForm</code> in the ACP in that it reads the id of the requested person from the request data and validates the id in <code>readParameters()</code>. |
2303 | The rest of the code only handles fetching the list of comments on the requested person. | |
2304 | In <code>readData()</code>, this list is fetched using <code>CommentHandler::getCommentList()</code> if comments are enabled for the person. | |
2305 | The <code>assignVariables()</code> method assigns some additional template variables like <code>$commentCanAdd</code>, which is <code>1</code> if the active person can add comments and is <code>0</code> otherwise, <code>$lastCommentTime</code>, which contains the UNIX timestamp of the last comment, and <code>$likeData</code>, which contains data related to the likes for the disabled comments.</p> | |
2306 | <h3 id="persontpl"><code>person.tpl</code><a class="headerlink" href="#persontpl" title="Permanent link">#</a></h3> | |
2307 | <div class="highlight"><pre><span></span><code>{capture assign='pageTitle'}{$person} - {lang}wcf.person.list{/lang}{/capture} | |
2308 | ||
2309 | {capture assign='contentTitle'}{$person}{/capture} | |
2310 | ||
2311 | {include file='header'} | |
2312 | ||
2313 | {if $person->enableComments} | |
2314 | {if $commentList|count || $commentCanAdd} | |
2315 | <section id="comments" class="section sectionContainerList"> | |
2316 | <header class="sectionHeader"> | |
2317 | <h2 class="sectionTitle">{lang}wcf.person.comments{/lang}{if $person->comments} <span class="badge">{#$person->comments}</span>{/if}</h2> | |
2318 | </header> | |
2319 | ||
2320 | {include file='__commentJavaScript' commentContainerID='personCommentList'} | |
2321 | ||
2322 | <div class="personComments"> | |
2323 | <ul id="personCommentList" class="commentList containerList" | |
2324 | data-can-add="{if $commentCanAdd}true{else}false{/if}" | |
2325 | data-object-id="{@$person->personID}" | |
2326 | data-object-type-id="{@$commentObjectTypeID}" | |
2327 | data-comments="{if $person->comments}{@$commentList->countObjects()}{else}0{/if}" | |
2328 | data-last-comment-time="{@$lastCommentTime}" | |
2329 | > | |
2330 | {include file='commentListAddComment' wysiwygSelector='personCommentListAddComment'} | |
2331 | {include file='commentList'} | |
2332 | </ul> | |
2333 | </div> | |
2334 | </section> | |
2335 | {/if} | |
2336 | {/if} | |
2337 | ||
2338 | <footer class="contentFooter"> | |
2339 | {hascontent} | |
2340 | <nav class="contentFooterNavigation"> | |
2341 | <ul> | |
2342 | {content}{event name='contentFooterNavigation'}{/content} | |
2343 | </ul> | |
2344 | </nav> | |
2345 | {/hascontent} | |
2346 | </footer> | |
2347 | ||
2348 | {include file='footer'} | |
2349 | </code></pre></div> | |
0c5338dd TD |
2350 | <p>For now, the <code>person</code> template is still very empty and only shows the comments in the content area. |
2351 | The template code shown for comments is very generic and used in this form in many locations as it only sets the header of the comment list and the container <code>ul#personCommentList</code> element for the comments shown by <code>commentList</code> template. | |
2352 | The <code>ul#personCommentList</code> elements has five additional <code>data-</code> attributes required by the JavaScript API for comments for loading more comments or creating new ones. | |
2353 | The <code>commentListAddComment</code> template adds the WYSIWYG support. | |
2354 | The attribute <code>wysiwygSelector</code> should be the id of the comment list <code>personCommentList</code> with an additional <code>AddComment</code> suffix.</p> | |
2355 | <h3 id="pagexml"><code>page.xml</code><a class="headerlink" href="#pagexml" title="Permanent link">#</a></h3> | |
2356 | <div class="highlight"><pre><span></span><code><span class="cp"><?xml version="1.0" encoding="UTF-8"?></span> | |
2357 | <span class="nt"><data</span> <span class="na">xmlns=</span><span class="s">"http://www.woltlab.com"</span> <span class="na">xmlns:xsi=</span><span class="s">"http://www.w3.org/2001/XMLSchema-instance"</span> <span class="na">xsi:schemaLocation=</span><span class="s">"http://www.woltlab.com http://www.woltlab.com/XSD/tornado/page.xsd"</span><span class="nt">></span> | |
2358 | <span class="nt"><import></span> | |
2359 | <span class="nt"><page</span> <span class="na">identifier=</span><span class="s">"com.woltlab.wcf.people.PersonList"</span><span class="nt">></span> | |
2360 | <span class="nt"><pageType></span>system<span class="nt"></pageType></span> | |
2361 | <span class="nt"><controller></span>wcf\page\PersonListPage<span class="nt"></controller></span> | |
2362 | <span class="nt"><name</span> <span class="na">language=</span><span class="s">"de"</span><span class="nt">></span>Personen-Liste<span class="nt"></name></span> | |
2363 | <span class="nt"><name</span> <span class="na">language=</span><span class="s">"en"</span><span class="nt">></span>Person List<span class="nt"></name></span> | |
2364 | ||
2365 | <span class="nt"><content</span> <span class="na">language=</span><span class="s">"de"</span><span class="nt">></span> | |
2366 | <span class="nt"><title></span>Personen<span class="nt"></title></span> | |
2367 | <span class="nt"></content></span> | |
2368 | <span class="nt"><content</span> <span class="na">language=</span><span class="s">"en"</span><span class="nt">></span> | |
2369 | <span class="nt"><title></span>People<span class="nt"></title></span> | |
2370 | <span class="nt"></content></span> | |
2371 | <span class="nt"></page></span> | |
2372 | <span class="nt"><page</span> <span class="na">identifier=</span><span class="s">"com.woltlab.wcf.people.Person"</span><span class="nt">></span> | |
2373 | <span class="nt"><pageType></span>system<span class="nt"></pageType></span> | |
2374 | <span class="nt"><controller></span>wcf\page\PersonPage<span class="nt"></controller></span> | |
2375 | <span class="nt"><handler></span>wcf\system\page\handler\PersonPageHandler<span class="nt"></handler></span> | |
2376 | <span class="nt"><name</span> <span class="na">language=</span><span class="s">"de"</span><span class="nt">></span>Person<span class="nt"></name></span> | |
2377 | <span class="nt"><name</span> <span class="na">language=</span><span class="s">"en"</span><span class="nt">></span>Person<span class="nt"></name></span> | |
2378 | <span class="nt"><requireObjectID></span>1<span class="nt"></requireObjectID></span> | |
2379 | <span class="nt"><parent></span>com.woltlab.wcf.people.PersonList<span class="nt"></parent></span> | |
2380 | <span class="nt"></page></span> | |
2381 | <span class="nt"></import></span> | |
2382 | <span class="nt"></data></span> | |
2383 | </code></pre></div> | |
0c5338dd TD |
2384 | <p>The <code>page.xml</code> file has been extended for the new person page with identifier <code>com.woltlab.wcf.people.Person</code>. |
2385 | Compared to the pre-existing <code>com.woltlab.wcf.people.PersonList</code> page, there are four differences:</p> | |
2386 | <ol> | |
2387 | <li>It has a <code><handler></code> element with a class name as value. | |
2388 | This aspect will be discussed in more detail in the next section.</li> | |
2389 | <li>There are no <code><content></code> elements because, both, the title and the content of the page are dynamically generated in the template.</li> | |
2390 | <li>The <code><requireObjectID></code> tells the system that this page requires an object id to properly work, in this case a valid person id.</li> | |
2391 | <li>This page has a <code><parent></code> page, the person list page. | |
2392 | In general, the details page for any type of object that is listed on a different page has the list page as its parent.</li> | |
2393 | </ol> | |
2394 | <h3 id="personpagehandler"><code>PersonPageHandler</code><a class="headerlink" href="#personpagehandler" title="Permanent link">#</a></h3> | |
2395 | <div class="highlight"><pre><span></span><code><span class="o"><?</span><span class="nx">php</span> | |
2396 | <span class="k">namespace</span> <span class="nx">wcf\system\page\handler</span><span class="p">;</span> | |
2397 | <span class="k">use</span> <span class="nx">wcf\data\page\Page</span><span class="p">;</span> | |
2398 | <span class="k">use</span> <span class="nx">wcf\data\person\PersonList</span><span class="p">;</span> | |
2399 | <span class="k">use</span> <span class="nx">wcf\data\user\online\UserOnline</span><span class="p">;</span> | |
2400 | <span class="k">use</span> <span class="nx">wcf\system\cache\runtime\PersonRuntimeCache</span><span class="p">;</span> | |
2401 | <span class="k">use</span> <span class="nx">wcf\system\database\util\PreparedStatementConditionBuilder</span><span class="p">;</span> | |
2402 | <span class="k">use</span> <span class="nx">wcf\system\WCF</span><span class="p">;</span> | |
2403 | ||
2404 | <span class="sd">/**</span> | |
2405 | <span class="sd"> * Page handler implementation for person page.</span> | |
2406 | <span class="sd"> * </span> | |
2407 | <span class="sd"> * @author Matthias Schmidt</span> | |
2408 | <span class="sd"> * @copyright 2001-2019 WoltLab GmbH</span> | |
2409 | <span class="sd"> * @license GNU Lesser General Public License <http://opensource.org/licenses/lgpl-license.php></span> | |
2410 | <span class="sd"> * @package WoltLabSuite\Core\System\Page\Handler</span> | |
2411 | <span class="sd"> */</span> | |
2412 | <span class="k">class</span> <span class="nc">PersonPageHandler</span> <span class="k">extends</span> <span class="nx">AbstractLookupPageHandler</span> <span class="k">implements</span> <span class="nx">IOnlineLocationPageHandler</span> <span class="p">{</span> | |
2413 | <span class="k">use</span> <span class="nx">TOnlineLocationPageHandler</span><span class="p">;</span> | |
2414 | ||
2415 | <span class="sd">/**</span> | |
2416 | <span class="sd"> * @inheritDoc</span> | |
2417 | <span class="sd"> */</span> | |
2418 | <span class="k">public</span> <span class="k">function</span> <span class="nf">getLink</span><span class="p">(</span><span class="nv">$objectID</span><span class="p">)</span> <span class="p">{</span> | |
2419 | <span class="k">return</span> <span class="nx">PersonRuntimeCache</span><span class="o">::</span><span class="na">getInstance</span><span class="p">()</span><span class="o">-></span><span class="na">getObject</span><span class="p">(</span><span class="nv">$objectID</span><span class="p">)</span><span class="o">-></span><span class="na">getLink</span><span class="p">();</span> | |
2420 | <span class="p">}</span> | |
2421 | ||
2422 | <span class="sd">/**</span> | |
2423 | <span class="sd"> * Returns the textual description if a user is currently online viewing this page.</span> | |
2424 | <span class="sd"> *</span> | |
2425 | <span class="sd"> * @see IOnlineLocationPageHandler::getOnlineLocation()</span> | |
2426 | <span class="sd"> *</span> | |
2427 | <span class="sd"> * @param Page $page visited page</span> | |
2428 | <span class="sd"> * @param UserOnline $user user online object with request data</span> | |
2429 | <span class="sd"> * @return string</span> | |
2430 | <span class="sd"> */</span> | |
2431 | <span class="k">public</span> <span class="k">function</span> <span class="nf">getOnlineLocation</span><span class="p">(</span><span class="nx">Page</span> <span class="nv">$page</span><span class="p">,</span> <span class="nx">UserOnline</span> <span class="nv">$user</span><span class="p">)</span> <span class="p">{</span> | |
2432 | <span class="k">if</span> <span class="p">(</span><span class="nv">$user</span><span class="o">-></span><span class="na">pageObjectID</span> <span class="o">===</span> <span class="k">null</span><span class="p">)</span> <span class="p">{</span> | |
2433 | <span class="k">return</span> <span class="s1">''</span><span class="p">;</span> | |
2434 | <span class="p">}</span> | |
2435 | ||
2436 | <span class="nv">$person</span> <span class="o">=</span> <span class="nx">PersonRuntimeCache</span><span class="o">::</span><span class="na">getInstance</span><span class="p">()</span><span class="o">-></span><span class="na">getObject</span><span class="p">(</span><span class="nv">$user</span><span class="o">-></span><span class="na">pageObjectID</span><span class="p">);</span> | |
2437 | <span class="k">if</span> <span class="p">(</span><span class="nv">$person</span> <span class="o">===</span> <span class="k">null</span><span class="p">)</span> <span class="p">{</span> | |
2438 | <span class="k">return</span> <span class="s1">''</span><span class="p">;</span> | |
2439 | <span class="p">}</span> | |
2440 | ||
2441 | <span class="k">return</span> <span class="nx">WCF</span><span class="o">::</span><span class="na">getLanguage</span><span class="p">()</span><span class="o">-></span><span class="na">getDynamicVariable</span><span class="p">(</span><span class="s1">'wcf.page.onlineLocation.'</span><span class="o">.</span><span class="nv">$page</span><span class="o">-></span><span class="na">identifier</span><span class="p">,</span> <span class="p">[</span><span class="s1">'person'</span> <span class="o">=></span> <span class="nv">$person</span><span class="p">]);</span> | |
2442 | <span class="p">}</span> | |
2443 | ||
2444 | <span class="sd">/**</span> | |
2445 | <span class="sd"> * @inheritDoc</span> | |
2446 | <span class="sd"> */</span> | |
2447 | <span class="k">public</span> <span class="k">function</span> <span class="nf">isValid</span><span class="p">(</span><span class="nv">$objectID</span> <span class="o">=</span> <span class="k">null</span><span class="p">)</span> <span class="p">{</span> | |
2448 | <span class="k">return</span> <span class="nx">PersonRuntimeCache</span><span class="o">::</span><span class="na">getInstance</span><span class="p">()</span><span class="o">-></span><span class="na">getObject</span><span class="p">(</span><span class="nv">$objectID</span><span class="p">)</span> <span class="o">!==</span> <span class="k">null</span><span class="p">;</span> | |
2449 | <span class="p">}</span> | |
2450 | ||
2451 | <span class="sd">/**</span> | |
2452 | <span class="sd"> * @inheritDoc</span> | |
2453 | <span class="sd"> */</span> | |
2454 | <span class="k">public</span> <span class="k">function</span> <span class="nf">lookup</span><span class="p">(</span><span class="nv">$searchString</span><span class="p">)</span> <span class="p">{</span> | |
2455 | <span class="nv">$conditionBuilder</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">PreparedStatementConditionBuilder</span><span class="p">(</span><span class="k">false</span><span class="p">,</span> <span class="s1">'OR'</span><span class="p">);</span> | |
2456 | <span class="nv">$conditionBuilder</span><span class="o">-></span><span class="na">add</span><span class="p">(</span><span class="s1">'person.firstName LIKE ?'</span><span class="p">,</span> <span class="p">[</span><span class="s1">'%'</span> <span class="o">.</span> <span class="nv">$searchString</span> <span class="o">.</span> <span class="s1">'%'</span><span class="p">]);</span> | |
2457 | <span class="nv">$conditionBuilder</span><span class="o">-></span><span class="na">add</span><span class="p">(</span><span class="s1">'person.lastName LIKE ?'</span><span class="p">,</span> <span class="p">[</span><span class="s1">'%'</span> <span class="o">.</span> <span class="nv">$searchString</span> <span class="o">.</span> <span class="s1">'%'</span><span class="p">]);</span> | |
2458 | ||
2459 | <span class="nv">$personList</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">PersonList</span><span class="p">();</span> | |
2460 | <span class="nv">$personList</span><span class="o">-></span><span class="na">getConditionBuilder</span><span class="p">()</span><span class="o">-></span><span class="na">add</span><span class="p">(</span><span class="nv">$conditionBuilder</span><span class="p">,</span> <span class="nv">$conditionBuilder</span><span class="o">-></span><span class="na">getParameters</span><span class="p">());</span> | |
2461 | <span class="nv">$personList</span><span class="o">-></span><span class="na">readObjects</span><span class="p">();</span> | |
2462 | ||
2463 | <span class="nv">$results</span> <span class="o">=</span> <span class="p">[];</span> | |
2464 | <span class="k">foreach</span> <span class="p">(</span><span class="nv">$personList</span> <span class="k">as</span> <span class="nv">$person</span><span class="p">)</span> <span class="p">{</span> | |
2465 | <span class="nv">$results</span><span class="p">[]</span> <span class="o">=</span> <span class="p">[</span> | |
2466 | <span class="s1">'image'</span> <span class="o">=></span> <span class="s1">'fa-user'</span><span class="p">,</span> | |
2467 | <span class="s1">'link'</span> <span class="o">=></span> <span class="nv">$person</span><span class="o">-></span><span class="na">getLink</span><span class="p">(),</span> | |
2468 | <span class="s1">'objectID'</span> <span class="o">=></span> <span class="nv">$person</span><span class="o">-></span><span class="na">personID</span><span class="p">,</span> | |
2469 | <span class="s1">'title'</span> <span class="o">=></span> <span class="nv">$person</span><span class="o">-></span><span class="na">getTitle</span><span class="p">()</span> | |
2470 | <span class="p">];</span> | |
2471 | <span class="p">}</span> | |
2472 | ||
2473 | <span class="k">return</span> <span class="nv">$results</span><span class="p">;</span> | |
2474 | <span class="p">}</span> | |
2475 | ||
2476 | <span class="sd">/**</span> | |
2477 | <span class="sd"> * Prepares fetching all necessary data for the textual description if a user is currently online</span> | |
2478 | <span class="sd"> * viewing this page.</span> | |
2479 | <span class="sd"> * </span> | |
2480 | <span class="sd"> * @see IOnlineLocationPageHandler::prepareOnlineLocation()</span> | |
2481 | <span class="sd"> *</span> | |
2482 | <span class="sd"> * @param Page $page visited page</span> | |
2483 | <span class="sd"> * @param UserOnline $user user online object with request data</span> | |
2484 | <span class="sd"> */</span> | |
2485 | <span class="k">public</span> <span class="k">function</span> <span class="nf">prepareOnlineLocation</span><span class="p">(</span><span class="sd">/** @noinspection PhpUnusedParameterInspection */</span><span class="nx">Page</span> <span class="nv">$page</span><span class="p">,</span> <span class="nx">UserOnline</span> <span class="nv">$user</span><span class="p">)</span> <span class="p">{</span> | |
2486 | <span class="k">if</span> <span class="p">(</span><span class="nv">$user</span><span class="o">-></span><span class="na">pageObjectID</span> <span class="o">!==</span> <span class="k">null</span><span class="p">)</span> <span class="p">{</span> | |
2487 | <span class="nx">PersonRuntimeCache</span><span class="o">::</span><span class="na">getInstance</span><span class="p">()</span><span class="o">-></span><span class="na">cacheObjectID</span><span class="p">(</span><span class="nv">$user</span><span class="o">-></span><span class="na">pageObjectID</span><span class="p">);</span> | |
2488 | <span class="p">}</span> | |
2489 | <span class="p">}</span> | |
2490 | <span class="p">}</span> | |
2491 | </code></pre></div> | |
0c5338dd TD |
2492 | <p>Like any page handler, the <code>PersonPageHandler</code> class has to implement the <a href="https://github.com/WoltLab/WCF/blob/master/wcfsetup/install/files/lib/system/page/handler/IMenuPageHandler.class.php">IMenuPageHandler</a> interface, which should be done by extending the <a href="https://github.com/WoltLab/WCF/blob/master/wcfsetup/install/files/lib/system/page/handler/AbstractMenuPageHandler.class.php">AbstractMenuPageHandler</a> class. |
2493 | As we want administrators to link to specific people in menus, for example, we have to also implement the <a href="https://github.com/WoltLab/WCF/blob/master/wcfsetup/install/files/lib/system/page/handler/ILookupPageHandler.class.php">ILookupPageHandler</a> interface by extending the <a href="https://github.com/WoltLab/WCF/blob/master/wcfsetup/install/files/lib/system/page/handler/AbstractLookupPageHandler.class.php">AbstractLookupPageHandler</a> class.</p> | |
2494 | <p>For the <code>ILookupPageHandler</code> interface, we need to implement three methods:</p> | |
2495 | <ol> | |
2496 | <li><code>getLink($objectID)</code> returns the link to the person page with the given id. | |
2497 | In this case, we simply delegate this method call to the <code>Person</code> object returned by <code>PersonRuntimeCache::getObject()</code>.</li> | |
2498 | <li><code>isValid($objectID)</code> returns <code>true</code> if the person with the given id exists, otherwise <code>false</code>. | |
2499 | Here, we use <code>PersonRuntimeCache::getObject()</code> again and check if the return value is <code>null</code>, which is the case for non-existing people.</li> | |
2500 | <li><code>lookup($searchString)</code> is used when setting up an internal link and when searching for the linked person. | |
2501 | This method simply searches the first and last name of the people and returns an array with the person data. | |
2502 | While the <code>link</code>, the <code>objectID</code>, and the <code>title</code> element are self-explanatory, the <code>image</code> element can either contain an HTML <code><img></code> tag, which is displayed next to the search result (WoltLab Suite uses an image tag for users showing their avatar, for example), or a FontAwesome icon class (starting with <code>fa-</code>).</li> | |
2503 | </ol> | |
2504 | <p>Additionally, the class also implements <a href="https://github.com/WoltLab/WCF/blob/master/wcfsetup/install/files/lib/system/page/handler/IOnlineLocationPageHandler.class.php">IOnlineLocationPageHandler</a> which is used to determine the online location of users. | |
2505 | To ensure upwards-compatibility if the <code>IOnlineLocationPageHandler</code> interface changes, the <a href="https://github.com/WoltLab/WCF/blob/master/wcfsetup/install/files/lib/system/page/handler/TOnlineLocationPageHandler.class.php">TOnlineLocationPageHandler</a> trait is used. | |
2506 | The <code>IOnlineLocationPageHandler</code> interface requires two methods to be implemented:</p> | |
2507 | <ol> | |
2508 | <li><code>getOnlineLocation(Page $page, UserOnline $user)</code> returns the textual description of the online location. | |
2509 | The language item for the user online locations should use the pattern <code>wcf.page.onlineLocation.{page identifier}</code>.</li> | |
2510 | <li><code>prepareOnlineLocation(Page $page, UserOnline $user)</code> is called for each user online before the <code>getOnlineLocation()</code> calls. | |
2511 | In this case, calling <code>prepareOnlineLocation()</code> first enables us to add all relevant person ids to the person runtime cache so that for all <code>getOnlineLocation()</code> calls combined, only one database query is necessary to fetch all person objects.</li> | |
2512 | </ol> | |
2513 | <hr /> | |
2514 | <p>This concludes the third part of our tutorial series after which each person has a dedicated page on which people can comment on the person.</p> | |
e3413d1b | 2515 | <p>The complete source code of this part can be found on <a href="https://github.com/WoltLab/docs.woltlab.com/tree/5.4/snippets/tutorial/tutorial-series/part-3">GitHub</a>.</p> |
0c5338dd | 2516 | |
4a5c32e1 WG |
2517 | |
2518 | ||
2519 | ||
2520 | <hr> | |
2521 | <div class="md-source-date"> | |
2522 | <small> | |
2523 | ||
e3413d1b | 2524 | Last update: 2021-04-07 |
4a5c32e1 WG |
2525 | |
2526 | </small> | |
2527 | </div> | |
2528 | ||
2529 | ||
0c5338dd TD |
2530 | |
2531 | ||
2532 | ||
2533 | ||
2534 | ||
2535 | ||
2536 | </article> | |
2537 | </div> | |
2538 | </div> | |
fb962f09 | 2539 | |
0c5338dd TD |
2540 | </main> |
2541 | ||
2542 | ||
2543 | <footer class="md-footer"> | |
2544 | ||
2545 | <nav class="md-footer__inner md-grid" aria-label="Footer"> | |
2546 | ||
2547 | <a href="../part_2/" class="md-footer__link md-footer__link--prev" rel="prev"> | |
2548 | <div class="md-footer__button md-icon"> | |
2549 | <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> | |
2550 | </div> | |
2551 | <div class="md-footer__title"> | |
2552 | <div class="md-ellipsis"> | |
2553 | <span class="md-footer__direction"> | |
2554 | Previous | |
2555 | </span> | |
2556 | Part 2 | |
2557 | </div> | |
2558 | </div> | |
2559 | </a> | |
2560 | ||
2561 | ||
2562 | </nav> | |
2563 | ||
2564 | <div class="md-footer-meta md-typeset"> | |
2565 | <div class="md-footer-meta__inner md-grid"> | |
2566 | <div class="md-footer-copyright"> | |
2567 | ||
2568 | <div class="md-footer-copyright__highlight"> | |
2569 | Copyright © 2020 WoltLab GmbH | |
2570 | </div> | |
2571 | ||
2572 | Made with | |
2573 | <a href="https://squidfunk.github.io/mkdocs-material/" target="_blank" rel="noopener"> | |
2574 | Material for MkDocs | |
2575 | </a> | |
fb88dc6e | 2576 | |
0c5338dd TD |
2577 | </div> |
2578 | <div class="md-footer-copyright"> | |
2579 | <a href="https://www.woltlab.com/legal-notice/">Legal Notice</a> | |
2580 | <a href="https://www.woltlab.com/privacy-policy/">Privacy Policy</a> | |
2581 | </div> | |
2582 | </div> | |
2583 | </div> | |
2584 | </footer> | |
2585 | ||
2586 | </div> | |
2587 | <div class="md-dialog" data-md-component="dialog"> | |
2588 | <div class="md-dialog__inner md-typeset"></div> | |
2589 | </div> | |
fb962f09 | 2590 | <script id="__config" type="application/json">{"base": "../../..", "features": [], "translations": {"clipboard.copy": "Copy to clipboard", "clipboard.copied": "Copied to clipboard", "search.config.lang": "en", "search.config.pipeline": "trimmer, stopWordFilter", "search.config.separator": "[\\s\\-]+", "search.placeholder": "Search", "search.result.placeholder": "Type to start searching", "search.result.none": "No matching documents", "search.result.one": "1 matching document", "search.result.other": "# matching documents", "search.result.more.one": "1 more on this page", "search.result.more.other": "# more on this page", "search.result.term.missing": "Missing"}, "search": "../../../assets/javascripts/workers/search.fe42c31b.min.js", "version": {"provider": "mike"}}</script> |
0c5338dd TD |
2591 | |
2592 | ||
fb962f09 | 2593 | <script src="../../../assets/javascripts/bundle.d892486b.min.js"></script> |
0c5338dd TD |
2594 | |
2595 | ||
2596 | </body> | |
2597 | </html> |