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)