59 array $a_filter_pre = null,
60 int $a_group_id = null,
61 array $context_obj_ids = null
65 $service = $DIC->bookingManager()->internal();
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->access();
75 $ilCtrl = $DIC->ctrl();
76 $lng = $DIC->language();
77 $ilUser = $DIC->user();
78 $this->tree = $DIC->repositoryTree();
79 $this->reservation_repo = $DIC->bookingManager()
83 $this->schedule_manager = $DIC
87 ->schedules($a_pool_id);
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;
96 $this->table_repo = $DIC->bookingManager()
103 $this->
setId(
"bkrsv" . $a_ref_id);
112 $this->
lng->loadLanguageModule(
"crs");
117 if ($this->has_schedule) {
118 $this->
lng->loadLanguageModule(
"dateplaner");
121 if (in_array(
"week", $selected,
true)) {
123 unset($cols[
"week"]);
125 if (in_array(
"weekday", $selected,
true)) {
126 $this->
addColumn($this->
lng->txt(
"cal_weekday"),
"weekday");
127 unset($cols[
"weekday"]);
129 $this->
addColumn($this->
lng->txt(
"book_schedule_slot"),
"slot");
130 $this->
addColumn($this->
lng->txt(
"book_no_of_objects"),
"counter");
147 if (array_key_exists($col, $cols)) {
148 if (!isset($user_cols[$col])) {
149 $this->
addColumn($cols[$col][
"txt"], $col);
157 if ($this->group_id) {
160 $this->filters = array();
166 if ($this->has_items_with_host_context) {
167 $this->
addColumn($this->
lng->txt(
"book_booked_in"),
"context_obj_title");
174 if (array_key_exists($col, $cols)) {
175 if (isset($user_cols[$col])) {
176 $this->
addColumn($cols[$col][
"txt"], $col);
184 $this->
setFormAction($ilCtrl->getFormAction($a_parent_obj, $a_parent_cmd));
185 $this->
setRowTemplate(
"tpl.booking_reservation_row.html",
"Modules/BookingManager/Reservations");
193 if ($this->
access->checkAccess(
'write',
'', $this->ref_id)) {
204 return $this->pool->usesMessages() &&
205 $this->
access->checkAccess(
'write',
'', $this->ref_id);
212 if ($this->has_schedule) {
213 $this->
lng->loadLanguageModule(
"dateplaner");
215 $cols[
"week"] = array(
216 "txt" => $this->
lng->txt(
"wk_short"),
220 $cols[
"weekday"] = array(
221 "txt" => $this->
lng->txt(
"cal_weekday"),
226 foreach ($this->advmd as $field) {
227 $cols[
"advmd" . $field[
"id"]] = array(
228 "txt" => $field[
"title"],
246 if ($this->
access->checkAccess(
"manage_members",
"", $parent[
"ref_id"])) {
249 if ($k !==
"login") {
263 if (isset($user_cols[$col])) {
275 "ref_id" => $par_ref_id,
281 "ref_id" => $par_ref_id,
289 array $a_filter_pre = null
291 if (is_array($a_filter_pre) &&
292 isset($a_filter_pre[
"object"])) {
293 $this->table_repo->setObjectFilter(
295 serialize($a_filter_pre[
"object"])
299 $this->objects = array();
301 $this->objects[$item[
"booking_object_id"]] = $item[
"title"];
304 if ($item !== null) {
305 $item->setOptions(array(
"" => $this->
lng->txt(
'book_all')) + $this->objects);
306 $this->
filter[
"object"] = $item->getValue();
311 $this->
lng->txt(
"object") .
" " . $this->
lng->txt(
"title") .
"/" . $this->
lng->txt(
"description")
317 if ($this->has_schedule) {
319 if (!$this->table_repo->hasFromToFilter($this->getId())) {
325 $period = $bpool->getReservationFilterPeriod();
326 if ($period !== null) {
331 $to = serialize($to);
334 $this->table_repo->setFromToFilter(
337 "from" => serialize($from),
343 $this->
filter[
"fromto"] = $item->getDate();
346 if ($this->show_all) {
348 $map = array_flip(array(
'su',
'mo',
'tu',
'we',
'th',
'fr',
'sa'));
350 $options = array(
"" => $this->
lng->txt(
'book_all'));
353 foreach ($this->schedule_manager->getScheduleList() as
$id =>
$title) {
355 foreach ($schedule->getDefinition() as $day => $slots) {
358 foreach ($slots as $slot) {
359 $idx = $map[$day] .
"_" . $slot;
360 $options[$idx] = $day_caption .
", " . $slot;
368 $item->setOptions($options);
369 $this->filter[
"slot"] = $item->getValue();
375 $item->readFromSession();
379 if (isset($this->
filter[
"fromto"][
"from"]) &&
381 $item->setChecked(
true);
384 $this->
filter[
"past"] = $item->getChecked();
389 if (!$this->has_schedule) {
390 $options = array(
"" => $this->
lng->txt(
'book_all'));
394 foreach ($valid_status as $loop) {
396 $options[$loop] = $this->
lng->txt(
'book_reservation_status_' . $loop);
398 $options[$loop] = $this->
lng->txt(
'book_not') .
' ' . $this->
lng->txt(
'book_reservation_status_' . -$loop);
402 $item->setOptions($options);
403 $this->
filter[
"status"] = $item->getValue();
406 if ($this->show_all) {
407 $options = array(
"" => $this->
lng->txt(
'book_all')) +
410 $item->setOptions($options);
411 if (is_array($a_filter_pre) && isset($a_filter_pre[
"user_id"])) {
412 $item->setValue($a_filter_pre[
"user_id"]);
413 $this->
filter[
"user_id"] = $a_filter_pre[
"user_id"];
415 $this->
filter[
"user_id"] = $item->getValue();
427 if ($this->
filter[
"object"]) {
428 $filter[
"object"] = $this->
filter[
"object"];
430 if ($this->
filter[
"title"]) {
431 $filter[
"title"] = $this->
filter[
"title"];
433 if ($this->
filter[
"status"]) {
434 $filter[
"status"] = $this->
filter[
"status"];
436 if (isset($this->
filter[
"user_id"])) {
437 $filter[
"user_id"] = $this->
filter[
"user_id"];
439 if (!is_null($this->context_obj_ids)) {
443 if ($this->has_schedule) {
444 if (!isset($filter[
"status"])) {
448 if (isset($this->
filter[
"slot"])) {
449 $filter[
"slot"] = $this->
filter[
"slot"];
452 if ($this->
filter[
"fromto"][
"from"] || $this->
filter[
"fromto"][
"to"]) {
453 if ($this->
filter[
"fromto"][
"from"]) {
456 if ($this->
filter[
"fromto"][
"to"]) {
462 $filter[
"past"] = (bool) $this->
filter[
"past"];
469 return in_array($a_field, array(
"counter",
"date",
"week",
"weekday"));
479 $this->has_items_with_host_context =
false;
481 if (!isset($filter[
"object"])) {
482 $ids = array_keys($this->objects);
484 $ids = array($filter[
"object"]);
487 if (!$this->show_all) {
488 $filter[
"user_id"] = $ilUser->getId();
492 $data = $repo->getListByDate($this->has_schedule, $ids, $filter);
502 $this->record_gui->setTableGUI($this);
503 $this->record_gui->parse();
505 foreach (array_keys(
$data) as $idx) {
518 $this->record_gui->getFilterElements()
524 $user_ids = array_unique(array_map(
static function (
$d) {
525 return $d[
'user_id'];
531 if (strpos($field,
'odf') === 0) {
532 $odf_ids[] = substr($field, 4);
534 $user_columns[] = $field;
539 $user_columns = array_diff(
541 [
'consultation_hour',
'prtf',
'roles',
'org_units']
546 $query->setLimit(9999);
547 $query->setAdditionalFields($user_columns);
548 $query->setUserFilter($user_ids);
549 $ud = $query->query();
551 foreach ($ud[
"set"] as $v) {
552 foreach ($user_columns as
$c) {
553 $usr_data[$v[
"usr_id"]][
$c] = $v[
$c];
557 if (isset($usr_data[$v[
"user_id"]])) {
558 $data[
$key] = array_merge($v, $usr_data[$v[
"user_id"]]);
568 $confirmation_required = ($parent_obj_type ===
'crs')
571 if ($confirmation_required) {
576 foreach ($odf_data as $usr_id => $fields) {
579 if (in_array($usr_id, $user_ids)) {
580 foreach ($fields as $field_id => $value) {
581 if (in_array($field_id, $odf_ids,
true)) {
582 $usr_data[$usr_id][
'odf_' . $field_id] = $value;
589 if (isset($usr_data[$v[
"user_id"]])) {
590 $data[
$key] = array_merge($v, $usr_data[$v[
"user_id"]]);
597 if (
$d[
"context_obj_id"] > 0) {
598 $this->has_items_with_host_context =
true;
613 $field = parent::getOrderField();
616 if (in_array($field, array(
"date",
"week"))) {
617 $field =
"_sortdate";
623 protected function fillRow(array $a_set): void
629 $f = $this->gui->ui()->factory();
635 if ($this->has_items_with_host_context) {
636 $this->tpl->setCurrentBlock(
"context");
637 $this->tpl->setVariable(
"VALUE_CONTEXT_TITLE", ($a_set[
"context_obj_title"] ??
"") .
" ");
638 $this->tpl->parseCurrentBlock();
641 $this->tpl->setVariable(
"TXT_TITLE", $a_set[
"title"]);
643 $can_be_cancelled = (($ilAccess->checkAccess(
'write',
'', $this->ref_id) ||
644 $a_set[
'user_id'] == $ilUser->getId()) &&
645 $a_set[
"can_be_cancelled"]);
647 if ($can_be_cancelled) {
648 $this->tpl->setVariable(
"MULTI_ID", $a_set[
"booking_reservation_id"]);
652 $profile = $this->domain->profile();
653 $user_id = (
int) $a_set[
'user_id'];
654 if (!$profile->exists($user_id)) {
655 $uname = $profile->getDeletedUserNamePresentation();
659 $this->tpl->setVariable(
"TXT_CURRENT_USER", $uname);
661 if ($this->has_schedule) {
663 if (in_array(
"week", $selected,
true)) {
664 $this->tpl->setVariable(
"VALUE_WEEK", $a_set[
"week"]);
666 if (in_array(
"weekday", $selected,
true)) {
669 $this->tpl->setVariable(
"VALUE_SLOT", $a_set[
"slot"]);
670 $this->tpl->setVariable(
"VALUE_COUNTER", $a_set[
"counter"]);
675 $this->tpl->setVariable(
"TXT_STATUS",
$lng->
txt(
'book_reservation_status_' . $a_set[
'status']));
677 $this->tpl->setVariable(
"TXT_STATUS",
" ");
680 $this->tpl->setCurrentBlock(
"message");
682 $this->tpl->parseCurrentBlock();
686 foreach ($this->advmd as $item) {
687 $advmd_id = (
int) $item[
"id"];
689 if (!in_array(
"advmd" . $advmd_id, $selected,
true)) {
694 $key =
"md_" . $advmd_id .
"_presentation";
695 if (isset($a_set[
$key])) {
696 $pb = $a_set[
$key]->getList();
702 $this->tpl->setCurrentBlock(
"advmd_bl");
703 $this->tpl->setVariable(
"VALUE_ADVMD", $val);
704 $this->tpl->parseCurrentBlock();
711 if (isset($user_cols[$col])) {
712 $this->tpl->setCurrentBlock(
"user_col");
713 $this->tpl->setVariable(
"VALUE_USER_COL", ($a_set[$col] ??
"") .
" ");
714 $this->tpl->parseCurrentBlock();
719 if ($a_set[
'user_id'] == $ilUser->getId() || $ilAccess->checkAccess(
'write',
'', $this->ref_id)) {
720 if ($a_set[
'post_text'] !==
"" || $a_set[
'post_file'] !==
"") {
721 $ilCtrl->setParameter($this->parent_obj,
'reservation_id', $a_set[
'booking_reservation_id']);
722 $ilCtrl->setParameter($this->parent_obj,
'object_id', $a_set[
'object_id']);
723 $dd_items[] =
$f->button()->shy(
724 $lng->
txt(
'book_post_booking_information'),
725 $ilCtrl->getLinkTarget($this->parent_obj,
'displayPostInfo')
727 $ilCtrl->setParameter($this->parent_obj,
'object_id', null);
728 $ilCtrl->setParameter($this->parent_obj,
'reservation_id',
"");
732 if ($can_be_cancelled) {
733 $ilCtrl->setParameter($this->parent_obj,
'reservation_id', $a_set[
'booking_reservation_id']);
734 $dd_items[] =
$f->button()->shy(
736 $ilCtrl->getLinkTarget($this->parent_obj,
'rsvConfirmCancel')
738 $ilCtrl->setParameter($this->parent_obj,
'reservation_id',
"");
742 if ($ilAccess->checkAccess(
'write',
'', $this->ref_id)) {
743 $ilCtrl->setParameter($this->parent_obj,
'reservation_id', $a_set[
'booking_reservation_id']);
744 $dd_items[] =
$f->button()->shy(
745 $lng->
txt(
'book_mail_to_booker'),
746 $ilCtrl->getLinkTarget($this->parent_obj,
'redirectMailToBooker')
748 $dd_items[] =
$f->button()->shy(
750 $ilCtrl->getLinkTarget($this->parent_obj,
'rsvConfirmDelete')
752 $ilCtrl->setParameter($this->parent_obj,
'reservation_id',
"");
756 if ($this->
showMessages() && $a_set[
"message"] !==
"") {
757 $c = $this->gui->modal(
758 $this->
lng->txt(
"book_message"),
759 $this->
lng->txt(
"close")
761 ->
legacy(nl2br($a_set[
"message"]))
762 ->getTriggerButtonComponents(
763 $this->
lng->txt(
"book_show_message"),
766 $dd_items[] =
$c[
"button"];
767 $render_items[] =
$c[
"modal"];
770 if (count($dd_items) > 0) {
771 $render_items[] =
$f->dropdown()->standard($dd_items);
772 $this->tpl->setVariable(
"ACTIONS", $this->gui->ui()->renderer()->render($render_items));
781 unset($cols[
"week"], $cols[
"weekday"]);
786 if (array_key_exists($col, $cols)) {
787 if (!isset($user_cols[$col])) {
788 $add_cols[$col] = $cols[$col][
"txt"];
793 $add_cols[
"user_name"] = $this->
lng->txt(
"user");
794 $add_cols[
"login"] = $this->
lng->txt(
"login");
798 if (array_key_exists($col, $cols)) {
799 if (isset($user_cols[$col])) {
800 $add_cols[$col] = $cols[$col][
"txt"];
812 $a_excel->
setCell($a_row, 0, $this->
lng->txt(
"title"));
814 if ($this->has_schedule) {
815 $a_excel->
setCell($a_row, ++$col, $this->
lng->txt(
"date"));
816 $a_excel->
setCell($a_row, ++$col, $this->
lng->txt(
"wk_short"));
817 $a_excel->
setCell($a_row, ++$col, $this->
lng->txt(
"cal_weekday"));
818 $a_excel->
setCell($a_row, ++$col, $this->
lng->txt(
"book_schedule_slot"));
819 $a_excel->
setCell($a_row, ++$col, $this->
lng->txt(
"book_no_of_objects"));
821 $a_excel->
setCell($a_row, ++$col, $this->
lng->txt(
"status"));
824 $a_excel->
setCell($a_row, ++$col, $this->
lng->txt(
"book_message"));
840 $a_excel->
setCell($a_row, 0, $a_set[
"title"]);
842 if ($this->has_schedule) {
844 $a_excel->
setCell($a_row, ++$col, $a_set[
"week"]);
846 $a_excel->
setCell($a_row, ++$col, $a_set[
"slot"]);
847 $a_excel->
setCell($a_row, ++$col, $a_set[
"counter"]);
851 $status = $this->
lng->txt(
'book_reservation_status_' . $a_set[
'status']);
853 $a_excel->
setCell($a_row, ++$col, $status);
856 $a_excel->
setCell($a_row, ++$col, $a_set[
"message"]);
860 if (str_starts_with($colid,
"advmd")) {
862 $key =
"md_" . (
int) substr($colid, 5) .
"_presentation";
863 if (isset($a_set[
$key])) {
864 $pb = $a_set[
$key]->getList();
869 $a_excel->
setCell($a_row, ++$col, $val);
871 $a_excel->
setCell($a_row, ++$col, $a_set[$colid]);
880 if ($this->has_schedule) {
884 $a_csv->
addColumn($this->
lng->txt(
"book_schedule_slot"));
885 $a_csv->
addColumn($this->
lng->txt(
"book_no_of_objects"));
905 if ($this->has_schedule) {
914 $status = $this->
lng->txt(
'book_reservation_status_' . $a_set[
'status']);
923 if (str_starts_with($colid,
"advmd")) {
925 $key =
"md_" . (
int) substr($colid, 5) .
"_presentation";
926 if (isset($a_set[
$key])) {
927 $pb = $a_set[
$key]->getList();
__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)
ReservationTableSessionRepository $table_repo
initFilter(array $a_filter_pre=null)
setExportFormats(array $formats)
Set available export formats.
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...
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...
setFormAction(string $a_form_action, bool $a_multipart=false)
addFilterItem(ilTableFilterItem $a_input_item, bool $a_optional=false)
static getUserFilter(array $a_object_ids)
Get all users who have reservations for object(s)
fillRowExcel(ilExcel $a_excel, int &$a_row, array $a_set)
setResetCommand(string $a_val, string $a_caption="")
Repo class for reservations Acts on tables booking_reservation (rw), booking_reservation_group (rw) a...
setSelectAllCheckbox(string $a_select_all_checkbox, bool $a_select_all_on_top=false)
getSelectableUserColumns()
Get selectable user fields.
getItems(array $filter)
Gather data and build rows.
getColumnCoord(int $a_col)
Get column "name" from number.
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
bool $has_items_with_host_context
static formatDate(ilDateTime $date, bool $a_skip_day=false, bool $a_include_wd=false, bool $include_seconds=false)
setDisableFilterHiding(bool $a_val=true)
static _getValuesByObjId(int $a_obj_id)
getAdditionalExportCols()
static getAdvancedMDFields(int $a_ref_id)
setCell(int $a_row, int $a_col, $a_value, ?string $a_datatype=null)
Set cell value.
fillRowCSV(ilCSVWriter $a_csv, array $a_set)
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
ScheduleManager $schedule_manager
InternalDomainService $domain
ilAdvancedMDRecordGUI $record_gui
ReservationDBRepository $reservation_repo
checkForParentType(int $a_ref_id, string $a_type, bool $a_exclude_source_check=false)
Check for parent type e.g check if a folder (ref_id 3) is in a parent course obj => checkForParentTyp...
addFilterItemByMetaType(string $id, int $type=self::FILTER_TEXT, bool $a_optional=false, string $caption="")
Add filter by standard type.
setBold(string $a_coords)
Set cell(s) to bold.
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='ilpublicuserprofilegui')
Default behaviour is:
fillHeaderExcel(ilExcel $a_excel, int &$a_row)
static _lookupTitle(int $obj_id)
setDefaultOrderField(string $a_defaultorderfield)
getCurrentFilter()
Get current filter settings.
Reservation table related session data.
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
setRowTemplate(string $a_template, string $a_template_dir="")
Set row template.
setFilterCommand(string $a_val, string $a_caption="")
setDefaultOrderDirection(string $a_defaultorderdirection)
static _lookupObjectId(int $ref_id)
fillHeaderCSV(ilCSVWriter $a_csv)
static _numericDayToString(int $a_day, bool $a_long=true)
setTitle(string $a_title, string $a_icon="", string $a_icon_alt="")
static _getInstanceByType(string $a_type)
Get Singleton Instance.
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 shortenTextExtended(string $a_str, int $a_len, bool $a_dots=false, bool $a_next_blank=false, bool $a_keep_extension=false)
setLimit(int $a_limit=0, int $a_default_limit=0)
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)
disable(string $a_module_name)
static lookupAcceptedAgreements(int $a_obj_id)
Lookup users who have accepted the agreement.
filter(string $filter_id, $class_path, string $cmd, bool $activated=true, bool $expanded=true)
static _lookupType(int $id, bool $reference=false)
static setUseRelativeDates(bool $a_status)
set use relative dates
addMultiCommand(string $a_cmd, string $a_text)
static getList(int $a_pool_id, string $a_title=null)
Get list of booking objects.
setEnableHeader(bool $a_enableheader)
numericOrdering(string $a_field)