ILIAS  release_9 Revision v9.13-25-g2c18ec4c24f
ilCalendarMonthGUI Class Reference

This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Learning e.V. More...

+ Inheritance diagram for ilCalendarMonthGUI:
+ Collaboration diagram for ilCalendarMonthGUI:

Public Member Functions

 __construct (ilDate $seed_date)
 
 setBkId (int $bkid=0)
 
 initialize (int $a_calendar_presentation_type)
 
 executeCommand ()
 
 addScheduleFilter (ilCalendarScheduleFilter $a_filter)
 Add schedule filter. More...
 
 show ()
 
 getHTML ()
 
- Public Member Functions inherited from ilCalendarViewGUI
 __construct (ilDate $seed, int $presentation_type)
 
 setConsulationHoursUserId (int $a_user_id)
 
 getConsultationHoursUserId ()
 
 initialize (int $a_calendar_presentation_type)
 
 getCurrentApp ()
 
 getEvents ()
 
 getDatesForItem ($item)
 
 getModalForApp ()
 Get modal for appointment (see similar code in ilCalendarBlockGUI) More...
 
 getAppointmentShyButton (ilCalendarEntry $a_calendar_entry, string $a_dstart, string $a_title_forced="")
 
 getActivePlugins (string $a_slot_id)
 
 getModalTitleByPlugins (string $a_current_title)
 
 getContentByPlugins (ilCalendarEntry $a_cal_entry, int $a_start_date, string $a_content, ilTemplate $a_tpl)
 
 addToolbarFileDownload ()
 Add download link to toolbar. More...
 
 downloadFiles ()
 Download files related to the appointments showed in the current calendar view (day,week,month,list). More...
 
 getBucketTitle ()
 get proper label to add in the background task popover More...
 
 countEventsInView ()
 get the events starting between 2 dates based in seed + view options. More...
 

Protected Member Functions

 showEvents (ilCalendarSchedule $scheduler, ilDate $date)
 
- Protected Member Functions inherited from ilCalendarViewGUI
 initAppointmentIdFromQuery ()
 
 initInitialDateFromQuery ()
 
 initInitialDateTimeFromQuery ()
 
 initBookingUserFromQuery ()
 

Protected Attributes

int $bkid
 
int $num_appointments = 1
 
array $schedule_filters = array()
 
ilCalendarUserSettings $user_settings
 
ilCalendarAppointmentColors $app_colors
 
string $timezone = 'UTC'
 
- Protected Attributes inherited from ilCalendarViewGUI
int $presentation_type = self::CAL_PRESENTATION_UNDEFINED
 
bool $view_with_appointments = false
 
ilDate $seed
 
int $ch_user_id = 0
 
string $period_end_day = null
 
Factory $ui_factory
 
Renderer $ui_renderer
 
ilCtrlInterface $ctrl
 
ilToolbarGUI $toolbar
 
ilLogger $logger
 
ILIAS DI UIServices $ui
 
ilLanguage $lng
 
ilObjUser $user
 
ilTemplate $tpl
 
ilGlobalTemplateInterface $main_tpl
 
ilComponentFactory $component_factory
 
ilTabsGUI $tabs_gui
 
RefineryFactory $refinery
 
HttpServices $http
 

Additional Inherited Members

- Data Fields inherited from ilCalendarViewGUI
const CAL_PRESENTATION_UNDEFINED = 0
 
const CAL_PRESENTATION_DAY = 1
 
const CAL_PRESENTATION_WEEK = 2
 
const CAL_PRESENTATION_MONTH = 3
 
const CAL_PRESENTATION_AGENDA_LIST = 9
 

Detailed Description

This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Learning e.V.

ILIAS is licensed with the GPL-3.0, see https://www.gnu.org/licenses/gpl-3.0.en.html You should have received a copy of said license along with the source code, too.

If this is not the case or you just want to try ILIAS, you'll find us at: https://www.ilias.de https://github.com/ILIAS-eLearning

Author
Stefan Meyer meyer.nosp@m.@lei.nosp@m.fos.c.nosp@m.om ilCalendarMonthGUI: ilCalendarAppointmentGUI ilCalendarMonthGUI: ilCalendarAppointmentPresentationGUI

Definition at line 27 of file class.ilCalendarMonthGUI.php.

Constructor & Destructor Documentation

◆ __construct()

ilCalendarMonthGUI::__construct ( ilDate  $seed_date)

Member Function Documentation

◆ addScheduleFilter()

ilCalendarMonthGUI::addScheduleFilter ( ilCalendarScheduleFilter  $a_filter)

Add schedule filter.

Definition at line 91 of file class.ilCalendarMonthGUI.php.

91  : void
92  {
93  $this->schedule_filters[] = $a_filter;
94  }

◆ executeCommand()

ilCalendarMonthGUI::executeCommand ( )

Definition at line 59 of file class.ilCalendarMonthGUI.php.

References $app, ilCalendarAppointmentPresentationGUI\_getInstance(), ILIAS\Repository\ctrl(), ilSession\get(), ilCalendarViewGUI\getCurrentApp(), IL_CAL_DATE, ilCalendarViewGUI\initAppointmentIdFromQuery(), and ilCalendarViewGUI\initInitialDateFromQuery().

59  : void
60  {
61  $this->ctrl->saveParameter($this, 'seed');
62 
63  $next_class = $this->ctrl->getNextClass();
64  switch ($next_class) {
65  case "ilcalendarappointmentpresentationgui":
66  $this->ctrl->setReturn($this, "");
67  $gui = ilCalendarAppointmentPresentationGUI::_getInstance($this->seed, (array) $this->getCurrentApp());
68  $this->ctrl->forwardCommand($gui);
69  break;
70  case 'ilcalendarappointmentgui':
71  $this->ctrl->setReturn($this, '');
72  $this->tabs_gui->setSubTabActive((string) ilSession::get('cal_last_tab'));
73  // initial date for new calendar appointments
74  $idate = new ilDate($this->initInitialDateFromQuery(), IL_CAL_DATE);
75  $app = new ilCalendarAppointmentGUI($this->seed, $idate, $this->initAppointmentIdFromQuery());
76  $this->ctrl->forwardCommand($app);
77  break;
78 
79  default:
80  $time = microtime(true);
81  $cmd = $this->ctrl->getCmd("show");
82  $this->$cmd();
83  $this->main_tpl->setContent($this->tpl->get());
84  break;
85  }
86  }
static _getInstance(ilDate $seed, array $a_app)
get singleton instance
$app
Definition: cli.php:39
static get(string $a_var)
const IL_CAL_DATE
Administrate calendar appointments.
+ Here is the call graph for this function:

◆ getHTML()

ilCalendarMonthGUI::getHTML ( )

Definition at line 215 of file class.ilCalendarMonthGUI.php.

References show().

215  : string
216  {
217  $this->show();
218  return $this->tpl->get();
219  }
+ Here is the call graph for this function:

◆ initialize()

ilCalendarMonthGUI::initialize ( int  $a_calendar_presentation_type)

Definition at line 48 of file class.ilCalendarMonthGUI.php.

References ilCalendarUserSettings\_getInstanceByUserId(), and ILIAS\Repository\user().

48  : void
49  {
50  parent::initialize($a_calendar_presentation_type);
51  $this->tabs_gui->setSubTabActive('app_month');
52  $this->user_settings = ilCalendarUserSettings::_getInstanceByUserId($this->user->getId());
53  $this->app_colors = new ilCalendarAppointmentColors($this->user->getId());
54  if ($this->user->getTimeZone()) {
55  $this->timezone = $this->user->getTimeZone();
56  }
57  }
static _getInstanceByUserId(int $a_user_id)
+ Here is the call graph for this function:

◆ setBkId()

ilCalendarMonthGUI::setBkId ( int  $bkid = 0)

Definition at line 43 of file class.ilCalendarMonthGUI.php.

References $bkid.

43  : void
44  {
45  $this->bkid = $bkid;
46  }

◆ show()

ilCalendarMonthGUI::show ( )

Definition at line 96 of file class.ilCalendarMonthGUI.php.

References $bkid, ILIAS\LTI\ToolProvider\$settings, ilDateTime\_before(), ilCalendarUtil\_buildMonthDayList(), ilDateTime\_equals(), ilCalendarCategories\_getInstance(), ilCalendarSettings\_getInstance(), ilCalendarUtil\_isToday(), ilCalendarUtil\_numericDayToString(), ilCalendarUtil\_numericMonthToString(), ANONYMOUS_USER_ID, ILIAS\Repository\ctrl(), IL_CAL_DATE, IL_CAL_FKT_DATE, IL_CAL_MONTH, ilYuiUtil\initDragDrop(), ILIAS\Repository\int(), ilCalendarCategories\MODE_PORTFOLIO_CONSULTATION, ilDateTime\MONTH, showEvents(), ilCalendarSchedule\TYPE_MONTH, and ILIAS\Repository\user().

Referenced by getHTML().

96  : void
97  {
98  $this->tpl = new ilTemplate('tpl.month_view.html', true, true, 'Services/Calendar');
99 
101 
102  $navigation = new ilCalendarHeaderNavigationGUI($this, $this->seed, ilDateTime::MONTH);
103  $this->tpl->setVariable('NAVIGATION', $navigation->getHTML());
104 
105  for ($i = $this->user_settings->getWeekStart(); $i < (7 + $this->user_settings->getWeekStart()); $i++) {
106  $this->tpl->setCurrentBlock('month_header_col');
107  $this->tpl->setVariable('TXT_WEEKDAY', ilCalendarUtil::_numericDayToString($i, true));
108  $this->tpl->parseCurrentBlock();
109  }
110 
111  if ($this->bkid) {
112  $user_id = $this->bkid;
113  $disable_empty = true;
114  $no_add = true;
115  } else {
116  if ($this->user->getId() == ANONYMOUS_USER_ID) {
117  $user_id = $this->user->getId();
118  $disable_empty = false;
119  $no_add = true;
120  } else {
121  $user_id = $this->user->getId();
122  $disable_empty = false;
123  $no_add = false;
124  }
125  }
126 
127  $is_portfolio_embedded = false;
129  $no_add = true;
130  $is_portfolio_embedded = true;
131  }
132  $scheduler = new ilCalendarSchedule($this->seed, ilCalendarSchedule::TYPE_MONTH, $user_id);
133  $scheduler->addSubitemCalendars(true);
134  if (sizeof($this->schedule_filters)) {
135  foreach ($this->schedule_filters as $filter) {
136  $scheduler->addFilter($filter);
137  }
138  }
139  $scheduler->calculate();
140 
142 
143  $counter = 0;
145  (int) $this->seed->get(IL_CAL_FKT_DATE, 'm'),
146  (int) $this->seed->get(IL_CAL_FKT_DATE, 'Y'),
147  $this->user_settings->getWeekStart()
148  )->get() as $date) {
149  $counter++;
150  $has_events = (bool) $this->showEvents($scheduler, $date);
151 
152  if (!$this->view_with_appointments && $has_events) {
153  $this->view_with_appointments = true;
154  }
155 
156  if (!$no_add) {
157  $this->ctrl->clearParametersByClass('ilcalendarappointmentgui');
158  $this->ctrl->setParameterByClass('ilcalendarappointmentgui', 'idate', $date->get(IL_CAL_DATE));
159  $this->ctrl->setParameterByClass('ilcalendarappointmentgui', 'seed', $this->seed->get(IL_CAL_DATE));
160  $new_app_url = $this->ctrl->getLinkTargetByClass('ilcalendarappointmentgui', 'add');
161 
162  $this->tpl->setCurrentBlock("new_app");
163  $this->tpl->setVariable(
164  'NEW_GLYPH',
165  $this->ui_renderer->render($this->ui_factory->symbol()->glyph()->add($new_app_url))
166  );
167  $this->tpl->parseCurrentBlock();
168 
169  // }
170  }
171 
172  $day = (int) $date->get(IL_CAL_FKT_DATE, 'j');
173  $month = (int) $date->get(IL_CAL_FKT_DATE, 'n');
174 
175  if ($day == 1) {
176  $month_day = '1 ' . ilCalendarUtil::_numericMonthToString($month, false);
177  } else {
178  $month_day = $day;
179  }
180 
181  if (!$is_portfolio_embedded &&
182  (!$disable_empty || $has_events)) {
183  $this->tpl->setCurrentBlock('month_day_link');
184  $this->ctrl->clearParametersByClass('ilcalendardaygui');
185  $this->ctrl->setParameterByClass('ilcalendardaygui', 'seed', $date->get(IL_CAL_DATE));
186  $this->tpl->setVariable('OPEN_DAY_VIEW', $this->ctrl->getLinkTargetByClass('ilcalendardaygui', ''));
187  $this->ctrl->clearParametersByClass('ilcalendardaygui');
188  } else {
189  $this->tpl->setCurrentBlock('month_day_no_link');
190  }
191 
192  $this->tpl->setVariable('MONTH_DAY', $month_day);
193 
194  $this->tpl->parseCurrentBlock();
195 
196  $this->tpl->setCurrentBlock('month_col');
197 
198  if (ilCalendarUtil::_isToday($date)) {
199  $this->tpl->setVariable('TD_CLASS', 'caltoday');
200  } elseif (ilDateTime::_equals($date, $this->seed, IL_CAL_MONTH)) {
201  $this->tpl->setVariable('TD_CLASS', 'calstd');
202  } elseif (ilDateTime::_before($date, $this->seed, IL_CAL_MONTH)) {
203  $this->tpl->setVariable('TD_CLASS', 'calprev');
204  } else {
205  $this->tpl->setVariable('TD_CLASS', 'calnext');
206  }
207  $this->tpl->parseCurrentBlock();
208  if ($counter && !($counter % 7)) {
209  $this->tpl->setCurrentBlock('month_row');
210  $this->tpl->parseCurrentBlock();
211  }
212  }
213  }
array $settings
Setting values (LTI parameters, custom parameters and local parameters).
Definition: System.php:200
static _buildMonthDayList(int $a_month, int $a_year, int $weekstart)
Build a month day list.
const ANONYMOUS_USER_ID
Definition: constants.php:27
static _numericMonthToString(int $a_month, bool $a_long=true)
numeric month to string
showEvents(ilCalendarSchedule $scheduler, ilDate $date)
static _before(ilDateTime $start, ilDateTime $end, string $a_compare_field='', string $a_tz='')
compare two dates and check start is before end This method does not consider tz offsets.
const IL_CAL_MONTH
const IL_CAL_FKT_DATE
static initDragDrop(?ilGlobalTemplateInterface $a_main_tpl=null)
Init YUI Drag and Drop used in Modules/Survey, Services/Calendar, Services/COPage, Services/Form (Jan 2022)
static _numericDayToString(int $a_day, bool $a_long=true)
static _getInstance($a_usr_id=0)
get singleton instance
const IL_CAL_DATE
static _equals(ilDateTime $start, ilDateTime $end, string $a_compare_field='', string $a_tz='')
Check if two date are equal.
static _isToday(ilDateTime $date)
Represents a list of calendar appointments (including recurring events) for a specific user in a give...
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ showEvents()

ilCalendarMonthGUI::showEvents ( ilCalendarSchedule  $scheduler,
ilDate  $date 
)
protected

Definition at line 221 of file class.ilCalendarMonthGUI.php.

References ilCalendarUtil\calculateFontColor(), ILIAS\Repository\ctrl(), ilCalendarViewGUI\getAppointmentShyButton(), ilCalendarSchedule\getByDay(), ilCalendarViewGUI\getContentByPlugins(), IL_CAL_FKT_DATE, ilCalendarSettings\TIME_FORMAT_12, and ilCalendarSettings\TIME_FORMAT_24.

Referenced by show().

221  : int
222  {
223  $count = 0;
224  $time = '';
225  foreach ($scheduler->getByDay($date, $this->timezone) as $item) {
226  $this->ctrl->clearParametersByClass('ilcalendarappointmentgui');
227  $this->ctrl->setParameterByClass('ilcalendarappointmentgui', 'app_id', $item['event']->getEntryId());
228 
229  $event_tpl = new ilTemplate('tpl.month_event_view.html', true, true, 'Services/Calendar');
230 
231  if (!$item['event']->isFullDay()) {
232  switch ($this->user_settings->getTimeFormat()) {
234  $time = $item['event']->getStart()->get(IL_CAL_FKT_DATE, 'H:i', $this->timezone);
235  break;
236 
238  $time = $item['event']->getStart()->get(IL_CAL_FKT_DATE, 'h:ia', $this->timezone);
239  break;
240  }
241  }
242 
243  //plugins can change the modal title.
244  $shy = $this->getAppointmentShyButton($item['event'], (string) $item['dstart'], "");
245  $event_html = ($time != "") ? $time . " " . $shy : $shy;
246  $event_tpl->setCurrentBlock('il_event');
247 
248  //Start configuring the default template
249  $event_tpl->setVariable(
250  'EVENT_EDIT_LINK',
251  $this->ctrl->getLinkTargetByClass('ilcalendarappointmentgui', 'edit')
252  );
253  $event_tpl->setVariable('EVENT_NUM', $item['event']->getEntryId());
254  $event_tpl->setVariable('EVENT_CONTENT', $event_html);
255  $color = $this->app_colors->getColorByAppointment($item['event']->getEntryId());
256  $event_tpl->setVariable('EVENT_BGCOLOR', $color);
257  $event_tpl->setVariable('EVENT_ADD_STYLES', $item['event']->getPresentationStyle());
258  $event_tpl->setVariable('EVENT_FONTCOLOR', ilCalendarUtil::calculateFontColor($color));
259 
260  //plugins can override the previous template variables. The plugin slot parses the current block because
261  //it needs to call the template get method to use the resulting HTML in the replaceContent method.
262  if ($event_html_by_plugin = $this->getContentByPlugins(
263  $item['event'],
264  $item['dstart'],
265  $event_html,
266  $event_tpl
267  )) {
268  $event_body_html = $event_html_by_plugin;
269  } else {
270  $event_tpl->parseCurrentBlock();
271  $event_body_html = $event_tpl->get();
272  }
273 
274  $this->tpl->setCurrentBlock("event_nfd");
275  $this->tpl->setVariable("EVENT_CONTENT", $event_body_html);
276  $this->tpl->parseCurrentBlock();
277 
278  $this->num_appointments++;
279  $count++;
280  }
281  return $count;
282  }
getByDay(ilDate $a_start, string $a_timezone)
getContentByPlugins(ilCalendarEntry $a_cal_entry, int $a_start_date, string $a_content, ilTemplate $a_tpl)
const IL_CAL_FKT_DATE
static calculateFontColor(string $a_html_color_code)
Calculate best font color from html hex color code.
getAppointmentShyButton(ilCalendarEntry $a_calendar_entry, string $a_dstart, string $a_title_forced="")
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

Field Documentation

◆ $app_colors

ilCalendarAppointmentColors ilCalendarMonthGUI::$app_colors
protected

Definition at line 34 of file class.ilCalendarMonthGUI.php.

◆ $bkid

int ilCalendarMonthGUI::$bkid
protected

Definition at line 29 of file class.ilCalendarMonthGUI.php.

Referenced by setBkId(), and show().

◆ $num_appointments

int ilCalendarMonthGUI::$num_appointments = 1
protected

Definition at line 30 of file class.ilCalendarMonthGUI.php.

◆ $schedule_filters

array ilCalendarMonthGUI::$schedule_filters = array()
protected

Definition at line 31 of file class.ilCalendarMonthGUI.php.

◆ $timezone

string ilCalendarMonthGUI::$timezone = 'UTC'
protected

Definition at line 35 of file class.ilCalendarMonthGUI.php.

◆ $user_settings

ilCalendarUserSettings ilCalendarMonthGUI::$user_settings
protected

Definition at line 33 of file class.ilCalendarMonthGUI.php.


The documentation for this class was generated from the following file: