ILIAS  trunk Revision v12.0_alpha-377-g3641b37b9db
class.ilBookingReservationsTableGUI.php
Go to the documentation of this file.
1<?php
2
24
30{
36 protected \ILIAS\BookingManager\Access\AccessManager $access;
38 protected ilObjUser $user;
39 protected int $ref_id;
40 protected array $filter;
41 protected int $pool_id;
42 protected bool $show_all;
43 protected bool $has_schedule;
44 protected array $objects;
45 protected ?int $group_id;
46 protected array $advmd;
47 protected bool $has_items_with_host_context = false;
48 protected ilTree $tree;
50 protected ?array $context_obj_ids;
52
53 public function __construct(
54 object $a_parent_obj,
55 string $a_parent_cmd,
56 int $a_ref_id,
58 bool $a_show_all,
59 ?array $a_filter_pre = null,
60 ?int $a_group_id = null,
61 ?array $context_obj_ids = null
62 ) {
63 global $DIC;
64
65 $service = $DIC->bookingManager()->internal();
66 $this->gui = $service->gui();
67 $this->domain = $service->domain();
68 $this->pool = $pool;
69 $a_pool_id = $pool->getId();
71 $this->ctrl = $DIC->ctrl();
72 $this->lng = $DIC->language();
73 $this->user = $DIC->user();
74 $this->access = $DIC->bookingManager()->internal()->domain()->access();
75 $ilCtrl = $DIC->ctrl();
76 $lng = $DIC->language();
77 $ilUser = $DIC->user();
78 $this->tree = $DIC->repositoryTree();
79 $this->reservation_repo = $DIC->bookingManager()
80 ->internal()
81 ->repo()
82 ->reservation();
83 $this->schedule_manager = $DIC
84 ->bookingManager()
85 ->internal()
86 ->domain()
87 ->schedules($a_pool_id);
88
89 $this->context_obj_ids = $context_obj_ids;
90 $this->pool_id = $a_pool_id;
91 $this->ref_id = $a_ref_id;
92 $this->show_all = $a_show_all;
93 $this->has_schedule = $a_has_schedule;
94 $this->group_id = $a_group_id;
95
96 $this->table_repo = $DIC->bookingManager()
97 ->internal()
98 ->repo()
99 ->reservationTable();
100
101 $this->advmd = ilObjBookingPool::getAdvancedMDFields($a_ref_id);
102
103 $this->setId("bkrsv" . $a_ref_id);
104
105 parent::__construct($a_parent_obj, $a_parent_cmd);
106
107 $this->setTitle($lng->txt("book_reservations_list"));
108
109 $this->addColumn("", "", 1);
110 $this->addColumn($this->lng->txt("title"), "title");
111
112 $this->lng->loadLanguageModule("crs");
113
114 $selected = $this->getSelectedColumns();
115 $cols = $this->getSelectableColumns();
116
117 if ($this->has_schedule) {
118 $this->lng->loadLanguageModule("dateplaner");
119
120 $this->addColumn($this->lng->txt("date"), "date");
121 if (in_array("week", $selected, true)) {
122 $this->addColumn($this->lng->txt("wk_short"), "week");
123 unset($cols["week"]);
124 }
125 if (in_array("weekday", $selected, true)) {
126 $this->addColumn($this->lng->txt("cal_weekday"), "weekday");
127 unset($cols["weekday"]);
128 }
129 $this->addColumn($this->lng->txt("book_schedule_slot"), "slot");
130 $this->addColumn($this->lng->txt("book_no_of_objects"), "counter");
131
132 $this->setDefaultOrderField("date");
133 } else {
134 $this->addColumn($this->lng->txt("status"), "status");
135
136 $this->setDefaultOrderField("title");
137 }
138 if ($this->showMessages()) {
139 $this->addColumn($this->lng->txt("book_message"));
140 }
141
142 $this->setDefaultOrderDirection("asc");
143
144 // non-user columns
145 $user_cols = $this->getSelectableUserColumns();
146 foreach ($this->getSelectedColumns() as $col) {
147 if (array_key_exists($col, $cols)) {
148 if (!isset($user_cols[$col])) {
149 $this->addColumn($cols[$col]["txt"], $col);
150 }
151 }
152 }
153
154 $this->initFilter($a_filter_pre);
155 if ($this->group_id) {
156 $this->setLimit(9999);
157 $this->disable("numinfo");
158 $this->filters = array();
159 } else {
160 $this->setExportFormats(array(self::EXPORT_CSV, self::EXPORT_EXCEL));
161 }
162 $this->getItems($this->getCurrentFilter());
163
164 if ($this->has_items_with_host_context) {
165 $this->addColumn($this->lng->txt("book_booked_in"), "context_obj_title");
166 }
167
168 $this->addColumn($this->lng->txt("user"), "user_name");
169
170 // user columns
171 foreach ($this->getSelectedColumns() as $col) {
172 if (isset($cols[$col]["txt"], $user_cols[$col])) {
173 $this->addColumn($cols[$col]["txt"], $col);
174 }
175 }
176
177 $this->addColumn($this->lng->txt("actions"));
178
179 $this->setEnableHeader(true);
180 $this->setFormAction($ilCtrl->getFormAction($a_parent_obj, $a_parent_cmd));
181 $this->setRowTemplate("tpl.booking_reservation_row.html", "components/ILIAS/BookingManager/Reservations");
182 $this->setResetCommand("resetLogFilter");
183 $this->setFilterCommand("applyLogFilter");
184 $this->setDisableFilterHiding(true);
185
186 if ($ilUser->getId() !== ANONYMOUS_USER_ID) {
187 if ($this->access->canManageAllReservations($this->ref_id) ||
188 $this->access->canManageOwnReservations($this->ref_id)) {
189 $this->addMultiCommand('rsvConfirmCancel', $lng->txt('book_set_cancel'));
190 }
191 if ($this->access->canManageAllReservations($this->ref_id)) {
192 $this->addMultiCommand('redirectMailToBooker', $lng->txt('book_mail_to_booker'));
193 $this->addMultiCommand('rsvConfirmDelete', $lng->txt('delete'));
194 }
195 }
197 }
198
199 protected function showMessages(): bool
200 {
201 return $this->pool->usesMessages() && $this->access->canManageAllReservations($this->ref_id);
202 }
203
204 public function getSelectableColumns(): array
205 {
206 $cols = [];
207
208 if ($this->has_schedule) {
209 $this->lng->loadLanguageModule('dateplaner');
210
211 $cols['week'] = ['txt' => $this->lng->txt('wk_short'), 'default' => true];
212 $cols['weekday'] = ['txt' => $this->lng->txt('cal_weekday'), 'default' => true];
213 }
214
215 foreach ($this->advmd as $field) {
216 $cols["advmd{$field['id']}"] = ['txt' => $field['title'], 'default' => false];
217 }
218
219 return array_merge($cols, $this->getSelectableUserColumns());
220 }
221
225 protected function getSelectableUserColumns(): array
226 {
227 $cols = [];
228 // additional user fields
229 if ($this->access->canManageMembersOfParent($this->ref_id)) {
230 $parent = $this->access->getParentGroupCourse($this->ref_id);
231 $ef = ilExportFieldsInfo::_getInstanceByType($parent["type"]);
232 foreach ($ef->getSelectableFieldsInfo(ilObject::_lookupObjectId($parent["ref_id"])) as $k => $v) {
233 if ($k !== "login") {
234 $cols[$k] = $v;
235 }
236 }
237 }
238 return $cols;
239 }
240
241 protected function getSelectedUserColumns(): array
242 {
243 $user_cols = $this->getSelectableUserColumns();
244 $sel = [];
245 foreach ($this->getSelectedColumns() as $col) {
246 if (isset($user_cols[$col])) {
247 $sel[] = $col;
248 }
249 }
250 return $sel;
251 }
252
253 public function initFilter(
254 ?array $a_filter_pre = null
255 ): void {
256 if (is_array($a_filter_pre) &&
257 isset($a_filter_pre["object"])) {
258 $this->table_repo->setObjectFilter(
259 $this->getId(),
260 serialize($a_filter_pre["object"])
261 );
262 }
263
264 $this->objects = array();
265 foreach (ilBookingObject::getList($this->pool_id) as $item) {
266 $this->objects[$item["booking_object_id"]] = $item["title"];
267 }
268 $item = $this->addFilterItemByMetaType("object", ilTable2GUI::FILTER_SELECT);
269 if ($item !== null) {
270 $item->setOptions(array("" => $this->lng->txt('book_all')) + $this->objects);
271 $this->filter["object"] = $item->getValue();
273 "title",
275 false,
276 $this->lng->txt("object") . " " . $this->lng->txt("title") . "/" . $this->lng->txt("description")
277 );
278 if ($title !== null) {
279 $this->filter["title"] = $title->getValue();
280 }
281
282 if ($this->has_schedule) {
283 // default period: from:today [ to:(today + n days) ]
284 if (!$this->table_repo->hasFromToFilter($this->getId())) {
285 $from = new ilDateTime(date("Y-m-d"), IL_CAL_DATE); // today
286 $to = null;
287
288 // add period end from pool settings?
289 $bpool = new ilObjBookingPool($this->pool_id, false);
290 $period = $bpool->getReservationFilterPeriod();
291 if ($period !== null) {
292 $to = clone $from;
293 if ($period) {
294 $to->increment(ilDateTime::DAY, $period);
295 }
296 $to = serialize($to);
297 }
298
299 $this->table_repo->setFromToFilter(
300 $this->getId(),
301 serialize(array(
302 "from" => serialize($from),
303 "to" => $to
304 ))
305 );
306 }
307 $item = $this->addFilterItemByMetaType(
308 "fromto",
310 false,
311 $this->lng->txt('book_fromto')
312 );
313 $this->filter["fromto"] = $item->getDate();
314
315 // only needed for full log
316 if ($this->show_all) {
317 // see ilObjBookingPoolGUI::buildDatesBySchedule()
318 $map = array_flip(array('su', 'mo', 'tu', 'we', 'th', 'fr', 'sa'));
319
320 $options = array("" => $this->lng->txt('book_all'));
321
322 // schedule to slot
323 foreach ($this->schedule_manager->getScheduleList() as $id => $title) {
324 $schedule = new ilBookingSchedule($id);
325 foreach ($schedule->getDefinition() as $day => $slots) {
326 $day_caption = ilCalendarUtil::_numericDayToString((int) $map[$day], false);
327
328 foreach ($slots as $slot) {
329 $idx = $map[$day] . "_" . $slot;
330 $options[$idx] = $day_caption . ", " . $slot;
331 }
332 }
333 }
334
335 ksort($options);
336
337 $item = $this->addFilterItemByMetaType("book_schedule_slot", ilTable2GUI::FILTER_SELECT);
338 $item->setOptions($options);
339 $this->filter["slot"] = $item->getValue();
340 }
341 }
342
343 $item = new ilCheckboxInputGUI($this->lng->txt("book_filter_past_reservations"), "past");
344 $this->addFilterItem($item);
345 $item->readFromSession();
346
347 // if period starts in the past we have to include past reservations
348 // :TODO: to be discussed
349 if (isset($this->filter["fromto"]["from"]) &&
350 $this->filter["fromto"]["from"]->get(IL_CAL_DATE) < date("Y-m-d")) {
351 $item->setChecked(true);
352 }
353
354 $this->filter["past"] = $item->getChecked();
355
356 // status
357 $valid_status = array(-ilBookingReservation::STATUS_CANCELLED,
359 );
360 if (!$this->has_schedule) {
361 $options = array("" => $this->lng->txt('book_all'));
362 } else {
363 $options = array();
364 }
365 foreach ($valid_status as $loop) {
366 if ($loop > 0) {
367 $options[$loop] = $this->lng->txt('book_reservation_status_' . $loop);
368 } else {
369 $options[$loop] = $this->lng->txt('book_not') . ' ' . $this->lng->txt('book_reservation_status_' . -$loop);
370 }
371 }
372 $item = $this->addFilterItemByMetaType("status", ilTable2GUI::FILTER_SELECT);
373 $item->setOptions($options);
374 $this->filter["status"] = $item->getValue();
375
376 // only needed for full log
377 if ($this->show_all) {
378 $options = array("" => $this->lng->txt('book_all')) +
379 ilBookingReservation::getUserFilter(array_keys($this->objects));
381 $item->setOptions($options);
382 if (is_array($a_filter_pre) && isset($a_filter_pre["user_id"])) {
383 $item->setValue($a_filter_pre["user_id"]);
384 $this->filter["user_id"] = $a_filter_pre["user_id"];
385 } else {
386 $this->filter["user_id"] = $item->getValue();
387 }
388 }
389 }
390 }
391
395 public function getCurrentFilter(): array
396 {
397 $filter = array();
398 if ($this->filter["object"]) {
399 $filter["object"] = $this->filter["object"];
400 }
401 if ($this->filter["title"]) {
402 $filter["title"] = $this->filter["title"];
403 }
404 if ($this->filter["status"]) {
405 $filter["status"] = $this->filter["status"];
406 }
407 if (isset($this->filter["user_id"])) {
408 $filter["user_id"] = $this->filter["user_id"];
409 }
410 if (!is_null($this->context_obj_ids)) {
411 $filter["context_obj_ids"] = $this->context_obj_ids;
412 }
413
414 if ($this->has_schedule) {
415 if (!isset($filter["status"])) {
416 // needs distinct status because of aggregation
417 $filter["status"] = -ilBookingReservation::STATUS_CANCELLED;
418 }
419 if (isset($this->filter["slot"])) {
420 $filter["slot"] = $this->filter["slot"];
421 }
422
423 if ($this->filter["fromto"]["from"] || $this->filter["fromto"]["to"]) {
424 if ($this->filter["fromto"]["from"]) {
425 $filter["from"] = $this->filter["fromto"]["from"]->get(IL_CAL_UNIX);
426 }
427 if ($this->filter["fromto"]["to"]) {
428 $day_end = new ilDateTime(
429 $this->filter["fromto"]["to"]->get(IL_CAL_DATE) . " 23:59:59",
431 );
432 $filter["to"] = $day_end->get(IL_CAL_UNIX);
433 }
434 }
435
436 $filter["past"] = (bool) $this->filter["past"];
437 }
438 return $filter;
439 }
440
441 public function numericOrdering(string $a_field): bool
442 {
443 return in_array($a_field, array("counter", "date", "week", "weekday"));
444 }
445
449 public function getItems(array $filter): void
450 {
451 $ilUser = $this->user;
452
453 $this->has_items_with_host_context = false;
454
455 if (!isset($filter["object"])) {
456 $ids = array_keys($this->objects);
457 } else {
458 $ids = array($filter["object"]);
459 }
460
461 if (!$this->show_all) {
462 $filter["user_id"] = $ilUser->getId();
463 }
464
465 $repo = $this->reservation_repo;
466 $data = $repo->getListByDate($this->has_schedule, $ids, $filter);
467
468 if ($this->advmd) {
469 // advanced metadata
470 $this->record_gui = new ilAdvancedMDRecordGUI(
472 "book",
473 $this->pool_id,
474 "bobj"
475 );
476 $this->record_gui->setTableGUI($this);
477 $this->record_gui->parse();
478
479 foreach (array_keys($data) as $idx) {
480 $data[$idx]["pool_id"] = $this->pool_id;
481 }
482
484 $this->ref_id,
485 "book",
486 "bobj",
487 [$this->pool_id],
488 "bobj",
489 $data,
490 "pool_id",
491 "object_id",
492 $this->record_gui->getFilterElements()
493 );
494 }
495
496 if (count($this->getSelectedUserColumns()) > 0) {
497 // get additional user data
498 $user_ids = array_unique(array_map(static function ($d) {
499 return $d['user_id'];
500 }, $data));
501
502 $user_columns = [];
503 $odf_ids = [];
504 foreach ($this->getSelectedUserColumns() as $field) {
505 if (str_starts_with($field, 'odf')) {
506 $odf_ids[] = (int) substr($field, 4);
507 continue;
508 }
509
510 $user_columns[] = $field;
511 }
512
513 // see ilCourseParticipantsTableGUI
514 $user_columns = array_diff(
515 $user_columns,
516 ['consultation_hour', 'prtf', 'roles', 'org_units']
517 );
518
519 // user data fields
520 $query = new ilUserQuery();
521 $query->setLimit(9999);
522 $query->setAdditionalFields($user_columns);
523 $query->setUserFilter($user_ids);
524 $ud = $query->query();
525 $usr_data = [];
526 foreach ($ud["set"] as $v) {
527 foreach ($user_columns as $c) {
528 $usr_data[$v["usr_id"]][$c] = $v[$c];
529 }
530 }
531 foreach ($data as $key => $v) {
532 if (isset($usr_data[$v["user_id"]])) {
533 $data[$key] = array_merge($v, $usr_data[$v["user_id"]]);
534 }
535 }
536
537 // object specific user data fields of parent course or group
538 if ($odf_ids !== []) {
539 $parent = $this->access->getParentGroupCourse($this->ref_id);
540 $parent_obj_id = ilObject::_lookupObjectId($parent['ref_id']);
541 $parent_obj_type = ilObject::_lookupType($parent_obj_id);
542
543 $privacy_settings = ilPrivacySettings::getInstance();
544 $confirmation_required = $parent_obj_type === 'crs'
545 ? $privacy_settings->courseConfirmationRequired()
546 : $privacy_settings->groupConfirmationRequired();
547 if ($confirmation_required) {
548 $user_ids = array_diff($user_ids, ilMemberAgreement::lookupAcceptedAgreements($parent_obj_id));
549 }
550 $odf_data = ilCourseUserData::_getValuesByObjId($parent_obj_id);
551 $usr_data = [];
552 foreach ($odf_data as $usr_id => $fields) {
553 if (in_array($usr_id, $user_ids, true)) {
554 foreach ($fields as $field_id => $value) {
555 if (in_array($field_id, $odf_ids, true)) {
556 $usr_data[$usr_id]["odf_{$field_id}"] = $value;
557 }
558 }
559 }
560 }
561
562 foreach ($data as $key => $v) {
563 if (isset($usr_data[$v['user_id']])) {
564 $data[$key] = array_merge($v, $usr_data[$v['user_id']]);
565 }
566 }
567 }
568 }
569
570 foreach ($data as $k => $d) {
571 if ($d["context_obj_id"] > 0) {
572 $this->has_items_with_host_context = true;
573 $data[$k]["context_obj_title"] = ilObject::_lookupTitle($d["context_obj_id"]);
574 }
575 }
576
577 $this->setData($data);
578 }
579
581 {
582 return $this->record_gui;
583 }
584
585 public function getOrderField(): string
586 {
587 $field = parent::getOrderField();
588
589 // #16560 - this will enable matchting slot sorting to date/week
590 if (in_array($field, array("date", "week"))) {
591 $field = "_sortdate";
592 }
593
594 return $field;
595 }
596
597 protected function fillRow(array $a_set): void
598 {
600 $ilAccess = $this->access;
601 $ilCtrl = $this->ctrl;
602 $ilUser = $this->user;
603 $f = $this->gui->ui()->factory();
604
605 $selected = $this->getSelectedColumns();
606
607 $dd_items = [];
608
609 if ($this->has_items_with_host_context) {
610 $this->tpl->setCurrentBlock("context");
611 $this->tpl->setVariable("VALUE_CONTEXT_TITLE", ($a_set["context_obj_title"] ?? "") . " ");
612 $this->tpl->parseCurrentBlock();
613 }
614
615 $this->tpl->setVariable("TXT_TITLE", $a_set["title"]);
616
617 $can_be_cancelled = ($this->access->canManageReservationForUser($this->ref_id, $a_set['user_id']) &&
618 $a_set["can_be_cancelled"]);
619
620 if ($can_be_cancelled) {
621 $this->tpl->setVariable("MULTI_ID", $a_set["booking_reservation_id"]);
622 }
623
624 // #11995
625 $profile = $this->domain->profile();
626 $user_id = (int) $a_set['user_id'];
627 if (!$profile->exists($user_id)) {
628 $uname = $profile->getDeletedUserNamePresentation();
629 } else {
630 $uname = ilUserUtil::getNamePresentation($a_set['user_id'], false, true, "", true);
631 }
632 $this->tpl->setVariable("TXT_CURRENT_USER", $uname);
633 if ($this->has_schedule) {
634 $this->tpl->setVariable(
635 "VALUE_DATE",
637 );
638 if (in_array("week", $selected, true)) {
639 $this->tpl->setVariable("VALUE_WEEK", $a_set["week"]);
640 }
641 if (in_array("weekday", $selected, true)) {
642 $this->tpl->setVariable(
643 "VALUE_WEEKDAY",
644 ilCalendarUtil::_numericDayToString((int) $a_set["weekday"], false)
645 );
646 }
647 $this->tpl->setVariable("VALUE_SLOT", $a_set["slot"]);
648 $this->tpl->setVariable("VALUE_COUNTER", $a_set["counter"]);
649 } elseif (in_array(
650 $a_set['status'],
652 )) {
653 $this->tpl->setVariable("TXT_STATUS", $lng->txt('book_reservation_status_' . $a_set['status']));
654 } else {
655 $this->tpl->setVariable("TXT_STATUS", "&nbsp;");
656 }
657 if ($this->showMessages()) {
658 $this->tpl->setCurrentBlock("message");
659 $this->tpl->setVariable("MESSAGE", ilStr::shortenTextExtended($a_set["message"] . " ", 20, true));
660 $this->tpl->parseCurrentBlock();
661 }
662
663 if ($this->advmd) {
664 foreach ($this->advmd as $item) {
665 $advmd_id = (int) $item["id"];
666
667 if (!in_array("advmd" . $advmd_id, $selected, true)) {
668 continue;
669 }
670
671 $val = " ";
672 $key = "md_" . $advmd_id . "_presentation";
673 if (isset($a_set[$key])) {
674 $pb = $a_set[$key]->getList();
675 if ($pb) {
676 $val = $pb;
677 }
678 }
679
680 $this->tpl->setCurrentBlock("advmd_bl");
681 $this->tpl->setVariable("VALUE_ADVMD", $val);
682 $this->tpl->parseCurrentBlock();
683 }
684 }
685
686 // additional user fields
687 $user_cols = $this->getSelectableUserColumns();
688 foreach ($this->getSelectedColumns() as $col) {
689 if (isset($user_cols[$col])) {
690 $this->tpl->setCurrentBlock("user_col");
691 $this->tpl->setVariable("VALUE_USER_COL", ($a_set[$col] ?? "") . " ");
692 $this->tpl->parseCurrentBlock();
693 }
694 }
695
696 // reservation information
697 if ($a_set['user_id'] == $ilUser->getId() || $ilAccess->canManageAllReservations($this->ref_id)) {
698 if ($a_set['post_text'] !== "" || $a_set['post_file'] !== "") {
699 $ilCtrl->setParameter($this->parent_obj, 'reservation_id', $a_set['booking_reservation_id']);
700 $ilCtrl->setParameter($this->parent_obj, 'object_id', $a_set['object_id']);
701 $dd_items[] = $f->button()->shy(
702 $lng->txt('book_post_booking_information'),
703 $ilCtrl->getLinkTarget($this->parent_obj, 'displayPostInfo')
704 );
705 $ilCtrl->setParameter($this->parent_obj, 'object_id', null);
706 $ilCtrl->setParameter($this->parent_obj, 'reservation_id', "");
707 }
708 }
709
710 if ($can_be_cancelled) {
711 $ilCtrl->setParameter($this->parent_obj, 'reservation_id', $a_set['booking_reservation_id']);
712 $dd_items[] = $f->button()->shy(
713 $lng->txt('book_set_cancel'),
714 $ilCtrl->getLinkTarget($this->parent_obj, 'rsvConfirmCancel')
715 );
716 $ilCtrl->setParameter($this->parent_obj, 'reservation_id', "");
717 }
718
719 if ($this->access->canManageAllReservations($this->ref_id)) {
720 $ilCtrl->setParameter($this->parent_obj, 'reservation_id', $a_set['booking_reservation_id']);
721 $dd_items[] = $f->button()->shy(
722 $lng->txt('book_mail_to_booker'),
723 $ilCtrl->getLinkTarget($this->parent_obj, 'redirectMailToBooker')
724 );
725 $dd_items[] = $f->button()->shy(
726 $lng->txt('delete'),
727 $ilCtrl->getLinkTarget($this->parent_obj, 'rsvConfirmDelete')
728 );
729 $ilCtrl->setParameter($this->parent_obj, 'reservation_id', "");
730 }
731
732 $render_items = [];
733 if ($this->showMessages() && $a_set["message"] !== "") {
734 $c = $this->gui->modal(
735 $this->lng->txt("book_message"),
736 $this->lng->txt("close")
737 )
738 ->legacy(nl2br($a_set["message"]))
739 ->getTriggerButtonComponents(
740 $this->lng->txt("book_show_message"),
741 true
742 );
743 $dd_items[] = $c["button"];
744 $render_items[] = $c["modal"];
745 }
746
747 if (count($dd_items) > 0) {
748 $render_items[] = $f->dropdown()->standard($dd_items);
749 $this->tpl->setVariable("ACTIONS", $this->gui->ui()->renderer()->render($render_items));
750 }
751 }
752
753 protected function getAdditionalExportCols(): array
754 {
755 $add_cols = [];
756 $cols = $this->getSelectableColumns();
757
758 unset($cols["week"], $cols["weekday"]);
759
760 // non-user columns
761 $user_cols = $this->getSelectableUserColumns();
762 foreach ($this->getSelectedColumns() as $col) {
763 if (array_key_exists($col, $cols)) {
764 if (!isset($user_cols[$col])) {
765 $add_cols[$col] = $cols[$col]["txt"];
766 }
767 }
768 }
769
770 $add_cols["user_name"] = $this->lng->txt("user");
771 $add_cols["login"] = $this->lng->txt("login");
772
773 // user columns
774 foreach ($this->getSelectedColumns() as $col) {
775 if (isset($cols[$col]["txt"], $user_cols[$col])) {
776 $add_cols[$col] = $cols[$col]["txt"];
777 }
778 }
779
780 return $add_cols;
781 }
782
783 protected function fillHeaderExcel(
784 ilExcel $a_excel,
785 int &$a_row
786 ): void {
787 $a_excel->setCell($a_row, 0, $this->lng->txt("title"));
788 $col = 0;
789 if ($this->has_schedule) {
790 $a_excel->setCell($a_row, ++$col, $this->lng->txt("date"));
791 $a_excel->setCell($a_row, ++$col, $this->lng->txt("wk_short"));
792 $a_excel->setCell($a_row, ++$col, $this->lng->txt("cal_weekday"));
793 $a_excel->setCell($a_row, ++$col, $this->lng->txt("book_schedule_slot"));
794 $a_excel->setCell($a_row, ++$col, $this->lng->txt("book_no_of_objects"));
795 } else {
796 $a_excel->setCell($a_row, ++$col, $this->lng->txt("status"));
797 }
798 if ($this->showMessages()) {
799 $a_excel->setCell($a_row, ++$col, $this->lng->txt("book_message"));
800 }
801
802 foreach ($this->getAdditionalExportCols() as $txt) {
803 $a_excel->setCell($a_row, ++$col, $txt);
804 }
805
806 $a_excel->setBold("A" . $a_row . ":" . $a_excel->getColumnCoord($col) . $a_row);
807 }
808
809 protected function fillRowExcel(
810 ilExcel $a_excel,
811 int &$a_row,
812 array $a_set
813 ): void {
814 $a_excel->setCell($a_row, 0, $a_set["title"]);
815 $col = 0;
816 if ($this->has_schedule) {
817 $a_excel->setCell($a_row, ++$col, new ilDate($a_set["date"], IL_CAL_DATE));
818 $a_excel->setCell($a_row, ++$col, $a_set["week"]);
819 $a_excel->setCell($a_row, ++$col, ilCalendarUtil::_numericDayToString((int) $a_set["weekday"], false));
820 $a_excel->setCell($a_row, ++$col, $a_set["slot"]);
821 $a_excel->setCell($a_row, ++$col, $a_set["counter"]);
822 } else {
823 $status = "";
824 if (in_array(
825 $a_set['status'],
827 )) {
828 $status = $this->lng->txt('book_reservation_status_' . $a_set['status']);
829 }
830 $a_excel->setCell($a_row, ++$col, $status);
831 }
832 if ($this->showMessages()) {
833 $a_excel->setCell($a_row, ++$col, $a_set["message"]);
834 }
835
836 foreach ($this->getAdditionalExportCols() as $colid => $txt) {
837 if (str_starts_with($colid, "advmd")) {
838 $val = " ";
839 $key = "md_" . (int) substr($colid, 5) . "_presentation";
840 if (isset($a_set[$key])) {
841 $pb = $a_set[$key]->getList();
842 if ($pb) {
843 $val = $pb;
844 }
845 }
846 $a_excel->setCell($a_row, ++$col, $val);
847 } else {
848 $a_excel->setCell($a_row, ++$col, $a_set[$colid] ?? "");
849 }
850 }
851 }
852
853 protected function fillHeaderCSV(
854 ilCSVWriter $a_csv
855 ): void {
856 $a_csv->addColumn($this->lng->txt("title"));
857 if ($this->has_schedule) {
858 $a_csv->addColumn($this->lng->txt("date"));
859 $a_csv->addColumn($this->lng->txt("wk_short"));
860 $a_csv->addColumn($this->lng->txt("cal_weekday"));
861 $a_csv->addColumn($this->lng->txt("book_schedule_slot"));
862 $a_csv->addColumn($this->lng->txt("book_no_of_objects"));
863 } else {
864 $a_csv->addColumn($this->lng->txt("status"));
865 }
866 if ($this->showMessages()) {
867 $a_csv->addColumn($this->lng->txt("book_message"));
868 }
869
870 foreach ($this->getAdditionalExportCols() as $txt) {
871 $a_csv->addColumn($txt);
872 }
873
874 $a_csv->addRow();
875 }
876
877 protected function fillRowCSV(
878 ilCSVWriter $a_csv,
879 array $a_set
880 ): void {
881 $a_csv->addColumn($a_set["title"]);
882 if ($this->has_schedule) {
883 $a_csv->addColumn(ilDatePresentation::formatDate(new ilDate($a_set["date"], IL_CAL_DATE)));
884 $a_csv->addColumn($a_set["week"]);
885 $a_csv->addColumn(ilCalendarUtil::_numericDayToString((int) $a_set["weekday"], false));
886 $a_csv->addColumn($a_set["slot"]);
887 $a_csv->addColumn($a_set["counter"]);
888 } else {
889 $status = "";
890 if (in_array(
891 $a_set['status'],
893 )) {
894 $status = $this->lng->txt('book_reservation_status_' . $a_set['status']);
895 }
896 $a_csv->addColumn($status);
897 }
898 if ($this->showMessages()) {
899 $a_csv->addColumn($a_set["message"]);
900 }
901
902 foreach ($this->getAdditionalExportCols() as $colid => $txt) {
903 if (str_starts_with($colid, "advmd")) {
904 $val = " ";
905 $key = "md_" . (int) substr($colid, 5) . "_presentation";
906 if (isset($a_set[$key])) {
907 $pb = $a_set[$key]->getList();
908 if ($pb) {
909 $val = $pb;
910 }
911 }
912 $a_csv->addColumn($val);
913 } else {
914 $a_csv->addColumn($a_set[$colid] ?? "");
915 }
916 }
917
918 $a_csv->addRow();
919 }
920}
Author: Alexander Killing killing@leifos.de
Repo class for reservations Acts on tables booking_reservation (rw), booking_reservation_group (rw) a...
const IL_CAL_DATE
const IL_CAL_UNIX
const IL_CAL_DATETIME
static queryForRecords(int $adv_rec_obj_ref_id, string $adv_rec_obj_type, string $adv_rec_obj_subtype, array $a_obj_id, string $a_subtype, array $a_records, string $a_obj_id_key, string $a_obj_subid_key, ?array $a_amet_filter=null)
static getList(int $a_pool_id, ?string $a_title=null)
Get list of booking objects.
static getUserFilter(array $a_object_ids)
Get all users who have reservations for object(s)
fillHeaderExcel(ilExcel $a_excel, int &$a_row)
Excel Version of Fill Header.
ILIAS BookingManager Access AccessManager $access
ReservationTableSessionRepository $table_repo
fillHeaderCSV(ilCSVWriter $a_csv)
CSV Version of Fill Header.
fillRow(array $a_set)
Standard Version of Fill Row.
fillRowExcel(ilExcel $a_excel, int &$a_row, array $a_set)
Excel Version of Fill Row.
getItems(array $filter)
Gather data and build rows.
numericOrdering(string $a_field)
Should this field be sorted numeric?
fillRowCSV(ilCSVWriter $a_csv, array $a_set)
CSV Version of Fill Row.
__construct(object $a_parent_obj, string $a_parent_cmd, int $a_ref_id, ilObjBookingPool $pool, bool $a_show_all, ?array $a_filter_pre=null, ?int $a_group_id=null, ?array $context_obj_ids=null)
getSelectableUserColumns()
Get selectable user fields.
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
addColumn(string $a_col)
static _numericDayToString(int $a_day, bool $a_long=true, ?ilLanguage $lng=null)
This class represents a checkbox property in a property form.
static _getValuesByObjId(int $a_obj_id)
static setUseRelativeDates(bool $a_status)
set use relative dates
static formatDate(ilDateTime $date, bool $a_skip_day=false, bool $a_include_wd=false, bool $include_seconds=false, ?ilObjUser $user=null,)
@classDescription Date and time handling
Class for single dates.
setBold(string $a_coords)
Set cell(s) to bold.
setCell(int $a_row, int $col, $value, ?string $datatype=null, bool $disable_strip_tags_for_strings=false)
Set cell value.
getColumnCoord(int $a_col)
Get column "name" from number.
static _getInstanceByType(string $a_type)
Get Singleton Instance.
txt(string $a_topic, string $a_default_lang_fallback_mod="")
gets the text for a given topic if the topic is not in the list, the topic itself with "-" will be re...
static lookupAcceptedAgreements(int $a_obj_id)
Lookup users who have accepted the agreement.
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
static getAdvancedMDFields(int $a_ref_id)
User class.
static _lookupObjectId(int $ref_id)
static _lookupType(int $id, bool $reference=false)
static _lookupTitle(int $obj_id)
static shortenTextExtended(string $a_str, int $a_len, bool $a_dots=false, bool $a_next_blank=false, bool $a_keep_extension=false)
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
setFilterCommand(string $a_val, string $a_caption="")
setLimit(int $a_limit=0, int $a_default_limit=0)
set max.
setTitle(string $a_title, string $a_icon="", string $a_icon_alt="")
setExportFormats(array $formats)
Set available export formats.
addFilterItem(ilTableFilterItem $a_input_item, bool $a_optional=false)
addMultiCommand(string $a_cmd, string $a_text)
addFilterItemByMetaType(string $id, int $type=self::FILTER_TEXT, bool $a_optional=false, string $caption="")
Add filter by standard type.
setFormAction(string $a_form_action, bool $a_multipart=false)
addColumn(string $a_text, string $a_sort_field="", string $a_width="", bool $a_is_checkbox_action_column=false, string $a_class="", string $a_tooltip="", bool $a_tooltip_with_html=false)
setEnableHeader(bool $a_enableheader)
setDefaultOrderField(string $a_defaultorderfield)
setDisableFilterHiding(bool $a_val=true)
setRowTemplate(string $a_template, string $a_template_dir="")
Set row template.
setId(string $a_val)
setDefaultOrderDirection(string $a_defaultorderdirection)
setResetCommand(string $a_val, string $a_caption="")
ilLanguage $lng
disable(string $a_module_name)
Tree class data representation in hierachical trees using the Nested Set Model with Gaps by Joe Celco...
User query class.
static getNamePresentation( $a_user_id, bool $a_user_image=false, bool $a_profile_link=false, string $a_profile_back_link='', bool $a_force_first_lastname=false, bool $a_omit_login=false, bool $a_sortable=true, bool $a_return_data_array=false, $a_ctrl_path=null)
Default behaviour is:
const ANONYMOUS_USER_ID
Definition: constants.php:27
$c
Definition: deliver.php:25
$service
Definition: ltiresult.php:36
__construct(Container $dic, ilPlugin $plugin)
@inheritDoc
filter(string $filter_id, array $class_path, string $cmd, bool $activated=true, bool $expanded=true)
global $lng
Definition: privfeed.php:31
if(!file_exists('../ilias.ini.php'))
global $DIC
Definition: shib_login.php:26