Fixes bug MDL-9753, "THEME->larrow, rarrow don't work in stock IE6"
[moodle-pu.git] / calendar / view.php
blob8fe19f658b59f1aa0c2c3b780990680bb4b703d6
1 <?php // $Id$
3 /////////////////////////////////////////////////////////////////////////////
4 // //
5 // NOTICE OF COPYRIGHT //
6 // //
7 // Moodle - Calendar extension //
8 // //
9 // Copyright (C) 2003-2004 Greek School Network www.sch.gr //
10 // //
11 // Designed by: //
12 // Avgoustos Tsinakos (tsinakos@teikav.edu.gr) //
13 // Jon Papaioannou (pj@moodle.org) //
14 // //
15 // Programming and development: //
16 // Jon Papaioannou (pj@moodle.org) //
17 // //
18 // For bugs, suggestions, etc contact: //
19 // Jon Papaioannou (pj@moodle.org) //
20 // //
21 // The current module was developed at the University of Macedonia //
22 // (www.uom.gr) under the funding of the Greek School Network (www.sch.gr) //
23 // The aim of this project is to provide additional and improved //
24 // functionality to the Asynchronous Distance Education service that the //
25 // Greek School Network deploys. //
26 // //
27 // This program is free software; you can redistribute it and/or modify //
28 // it under the terms of the GNU General Public License as published by //
29 // the Free Software Foundation; either version 2 of the License, or //
30 // (at your option) any later version. //
31 // //
32 // This program is distributed in the hope that it will be useful, //
33 // but WITHOUT ANY WARRANTY; without even the implied warranty of //
34 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the //
35 // GNU General Public License for more details: //
36 // //
37 // http://www.gnu.org/copyleft/gpl.html //
38 // //
39 /////////////////////////////////////////////////////////////////////////////
41 // Display the calendar page.
43 require_once('../config.php');
44 require_once($CFG->dirroot.'/course/lib.php');
45 require_once($CFG->dirroot.'/calendar/lib.php');
47 $courseid = optional_param('course', 0, PARAM_INT);
48 $view = optional_param('view', 'upcoming', PARAM_ALPHA);
49 $day = optional_param('cal_d', 0, PARAM_INT);
50 $mon = optional_param('cal_m', 0, PARAM_INT);
51 $yr = optional_param('cal_y', 0, PARAM_INT);
53 if(!$site = get_site()) {
54 redirect($CFG->wwwroot.'/'.$CFG->admin.'/index.php');
57 if ($courseid) {
58 require_login($courseid);
59 } else if ($CFG->forcelogin) {
60 require_login();
63 // Initialize the session variables
64 calendar_session_vars();
66 //add_to_log($course->id, "course", "view", "view.php?id=$course->id", "$course->id");
67 $now = usergetdate(time());
68 $pagetitle = '';
70 $nav = calendar_get_link_tag(get_string('calendar', 'calendar'), CALENDAR_URL.'view.php?view=upcoming&amp;', $now['mday'], $now['mon'], $now['year']);
73 if(!checkdate($mon, $day, $yr)) {
74 $day = intval($now['mday']);
75 $mon = intval($now['mon']);
76 $yr = intval($now['year']);
78 $time = make_timestamp($yr, $mon, $day);
80 switch($view) {
81 case 'day':
82 $nav .= ' -> '.userdate($time, get_string('strftimedate'));
83 $pagetitle = get_string('dayview', 'calendar');
84 break;
85 case 'month':
86 $nav .= ' -> '.userdate($time, get_string('strftimemonthyear'));
87 $pagetitle = get_string('detailedmonthview', 'calendar');
88 break;
89 case 'upcoming':
90 $pagetitle = get_string('upcomingevents', 'calendar');
91 break;
94 // If a course has been supplied in the URL, change the filters to show that one
95 if (!empty($courseid)) {
96 if ($course = get_record('course', 'id', $courseid)) {
97 if ($course->id == SITEID) {
98 // If coming from the home page, show all courses
99 $SESSION->cal_courses_shown = calendar_get_default_courses(true);
100 calendar_set_referring_course(0);
102 } else {
103 // Otherwise show just this one
104 $SESSION->cal_courses_shown = $course->id;
105 calendar_set_referring_course($SESSION->cal_courses_shown);
108 } else {
109 $course = null;
112 if (empty($USER->id) or isguest()) {
113 $defaultcourses = calendar_get_default_courses();
114 calendar_set_filters($courses, $groups, $users, $defaultcourses, $defaultcourses);
116 } else {
117 calendar_set_filters($courses, $groups, $users);
120 // Let's see if we are supposed to provide a referring course link
121 // but NOT for the "main page" course
122 if ($SESSION->cal_course_referer != SITEID &&
123 ($shortname = get_field('course', 'shortname', 'id', $SESSION->cal_course_referer)) !== false) {
124 // If we know about the referring course, show a return link and ALSO require login!
125 require_login();
126 $nav = '<a href="'.$CFG->wwwroot.'/course/view.php?id='.$SESSION->cal_course_referer.'">'.$shortname.'</a> -> '.$nav;
127 if (empty($course)) {
128 $course = get_record('course', 'id', $SESSION->cal_course_referer); // Useful to have around
132 $strcalendar = get_string('calendar', 'calendar');
133 $prefsbutton = calendar_preferences_button();
135 // Print title and header
136 print_header("$site->shortname: $strcalendar: $pagetitle", $strcalendar, $nav,
137 '', '', true, $prefsbutton, user_login_string($site));
139 echo calendar_overlib_html();
141 // Layout the whole page as three big columns.
142 echo '<table id="calendar" style="height:100%;">';
143 echo '<tr>';
145 // START: Main column
147 echo '<td class="maincalendar">';
148 echo '<div class="heightcontainer">';
150 switch($view) {
151 case 'day':
152 calendar_show_day($day, $mon, $yr, $courses, $groups, $users);
153 break;
154 case 'month':
155 calendar_show_month_detailed($mon, $yr, $courses, $groups, $users);
156 break;
157 case 'upcoming':
158 calendar_show_upcoming_events($courses, $groups, $users, get_user_preferences('calendar_lookahead', CALENDAR_UPCOMING_DAYS), get_user_preferences('calendar_maxevents', CALENDAR_UPCOMING_MAXEVENTS));
159 break;
162 //Link to calendar export page
163 echo '<div class="bottom">';
164 print_single_button('export.php', false, get_string('exportcalendar', 'calendar'));
166 if (!empty($USER->id)) {
167 $authtoken = sha1($USER->username . $USER->password);
168 $usernameencoded = urlencode($USER->username);
170 echo "<a href=\"export_execute.php?preset_what=all&amp;preset_time=recentupcoming&amp;username=$usernameencoded&amp;authtoken=$authtoken\">"
171 .'<img src="'.$CFG->pixpath.'/i/ical.gif" height="14" width="36" '
172 .'alt="'.get_string('ical', 'calendar').'" '
173 .'title="'.get_string('quickdownloadcalendar', 'calendar').'" />'
174 .'</a>';
177 echo '</div>';
178 echo '</div>';
179 echo '</td>';
181 // END: Main column
183 // START: Last column (3-month display)
184 echo '<td class="sidecalendar">';
185 echo '<div class="header">'.get_string('monthlyview', 'calendar').'</div>';
187 list($prevmon, $prevyr) = calendar_sub_month($mon, $yr);
188 list($nextmon, $nextyr) = calendar_add_month($mon, $yr);
189 $getvars = 'cal_d='.$day.'&amp;cal_m='.$mon.'&amp;cal_y='.$yr; // For filtering
191 echo '<div class="filters">';
192 echo calendar_filter_controls($view, $getvars);
193 echo '</div>';
195 echo '<div class="minicalendarblock">';
196 echo calendar_top_controls('display', array('m' => $prevmon, 'y' => $prevyr));
197 echo calendar_get_mini($courses, $groups, $users, $prevmon, $prevyr);
198 echo '</div><div class="minicalendarblock">';
199 echo calendar_top_controls('display', array('m' => $mon, 'y' => $yr));
200 echo calendar_get_mini($courses, $groups, $users, $mon, $yr);
201 echo '</div><div class="minicalendarblock">';
202 echo calendar_top_controls('display', array('m' => $nextmon, 'y' => $nextyr));
203 echo calendar_get_mini($courses, $groups, $users, $nextmon, $nextyr);
204 echo '</div>';
206 echo '</td>';
208 echo '</tr></table>';
210 print_footer();
214 function calendar_show_day($d, $m, $y, $courses, $groups, $users) {
215 global $CFG, $USER;
217 if (!checkdate($m, $d, $y)) {
218 $now = usergetdate(time());
219 list($d, $m, $y) = array(intval($now['mday']), intval($now['mon']), intval($now['year']));
222 $getvars = 'from=day&amp;cal_d='.$d.'&amp;cal_m='.$m.'&amp;cal_y='.$y; // For filtering
224 $starttime = make_timestamp($y, $m, $d);
225 $endtime = make_timestamp($y, $m, $d + 1) - 1;
227 $events = calendar_get_upcoming($courses, $groups, $users, 1, 100, $starttime);
229 $text = '';
230 if (!isguest() && !empty($USER->id)) {
231 $text.= '<div class="buttons">';
232 $text.= '<form action="'.CALENDAR_URL.'event.php" method="get">';
233 $text.= '<div>';
234 $text.= '<input type="hidden" name="action" value="new" />';
235 $text.= '<input type="hidden" name="cal_d" value="'.$d.'" />';
236 $text.= '<input type="hidden" name="cal_m" value="'.$m.'" />';
237 $text.= '<input type="hidden" name="cal_y" value="'.$y.'" />';
238 $text.= '<input type="submit" value="'.get_string('newevent', 'calendar').'" />';
239 $text.= '</div></form></div>';
242 $text .= get_string('dayview', 'calendar').': '.calendar_course_filter_selector($getvars);
244 echo '<div class="header">'.$text.'</div>';
246 echo '<div class="controls">'.calendar_top_controls('day', array('d' => $d, 'm' => $m, 'y' => $y)).'</div>';
248 if (empty($events)) {
249 // There is nothing to display today.
250 echo '<h3>'.get_string('daywithnoevents', 'calendar').'</h3>';
252 } else {
254 echo '<div class="eventlist">';
256 $underway = array();
258 // First, print details about events that start today
259 foreach ($events as $event) {
260 if ($event->timestart >= $starttime && $event->timestart <= $endtime) { // Print it now
264 $dayend = calendar_day_representation($event->timestart + $event->timeduration);
265 $timeend = calendar_time_representation($event->timestart + $event->timeduration);
266 $enddate = usergetdate($event->timestart + $event->timeduration);
267 // Set printable representation
268 echo calendar_get_link_tag($dayend, CALENDAR_URL.'view.php?view=day'.$morehref.'&amp;', $enddate['mday'], $enddate['mon'], $enddate['year']).' ('.$timeend.')';
270 //unset($event->time);
271 $event->time = calendar_format_event_time($event, time(), '', false);
272 calendar_print_event($event);
274 } else { // Save this for later
275 $underway[] = $event;
279 // Then, show a list of all events that just span this day
280 if (!empty($underway)) {
281 echo '<h3>'.get_string('spanningevents', 'calendar').':</h3>';
282 foreach ($underway as $event) {
283 $event->time = calendar_format_event_time($event, time(), '', false);
284 calendar_print_event($event);
288 echo '</div>';
293 function calendar_show_month_detailed($m, $y, $courses, $groups, $users) {
294 global $CFG, $SESSION, $USER, $CALENDARDAYS;
295 global $day, $mon, $yr;
297 $getvars = 'from=month&amp;cal_d='.$day.'&amp;cal_m='.$mon.'&amp;cal_y='.$yr; // For filtering
299 $display = &New stdClass;
300 $display->minwday = get_user_preferences('calendar_startwday', CALENDAR_STARTING_WEEKDAY);
301 $display->maxwday = $display->minwday + 6;
303 if(!empty($m) && !empty($y)) {
304 $thisdate = usergetdate(time()); // Time and day at the user's location
305 if($m == $thisdate['mon'] && $y == $thisdate['year']) {
306 // Navigated to this month
307 $date = $thisdate;
308 $display->thismonth = true;
310 else {
311 // Navigated to other month, let's do a nice trick and save us a lot of work...
312 if(!checkdate($m, 1, $y)) {
313 $date = array('mday' => 1, 'mon' => $thisdate['mon'], 'year' => $thisdate['year']);
314 $display->thismonth = true;
316 else {
317 $date = array('mday' => 1, 'mon' => $m, 'year' => $y);
318 $display->thismonth = false;
322 else {
323 $date = usergetdate(time());
324 $display->thismonth = true;
327 // Fill in the variables we 're going to use, nice and tidy
328 list($d, $m, $y) = array($date['mday'], $date['mon'], $date['year']); // This is what we want to display
329 $display->maxdays = calendar_days_in_month($m, $y);
331 if (get_user_timezone_offset() < 99) {
332 // We 'll keep these values as GMT here, and offset them when the time comes to query the db
333 $display->tstart = gmmktime(0, 0, 0, $m, 1, $y); // This is GMT
334 $display->tend = gmmktime(23, 59, 59, $m, $display->maxdays, $y); // GMT
335 } else {
336 // no timezone info specified
337 $display->tstart = mktime(0, 0, 0, $m, 1, $y);
338 $display->tend = mktime(23, 59, 59, $m, $display->maxdays, $y);
341 $startwday = gmdate('w', $display->tstart); // $display->tstart is already GMT, so don't use date(): messes with server's TZ
343 // Align the starting weekday to fall in our display range
344 if($startwday < $display->minwday) {
345 $startwday += 7;
348 // Get events from database
349 $whereclause = calendar_sql_where(usertime($display->tstart), usertime($display->tend), $users, $groups, $courses);
350 if($whereclause === false) {
351 $events = array();
353 else {
354 $events = get_records_select('event', $whereclause, 'timestart');
357 // Extract information: events vs. time
358 calendar_events_by_day($events, $m, $y, $eventsbyday, $durationbyday, $typesbyday);
360 $text = '';
361 if(!isguest() && !empty($USER->id)) {
362 $text.= '<div class="buttons"><form action="'.CALENDAR_URL.'event.php" method="get">';
363 $text.= '<div>';
364 $text.= '<input type="hidden" name="action" value="new" />';
365 $text.= '<input type="hidden" name="cal_m" value="'.$m.'" />';
366 $text.= '<input type="hidden" name="cal_y" value="'.$y.'" />';
367 $text.= '<input type="submit" value="'.get_string('newevent', 'calendar').'" />';
368 $text.= '</div></form></div>';
371 $text .= get_string('detailedmonthview', 'calendar').': '.calendar_course_filter_selector($getvars);
373 echo '<div class="header">'.$text.'</div>';
375 echo '<div class="controls">';
376 echo calendar_top_controls('month', array('m' => $m, 'y' => $y));
377 echo '</div>';
379 // Start calendar display
380 echo '<table class="calendarmonth"><tr class="weekdays">'; // Begin table. First row: day names
382 // Print out the names of the weekdays
383 for($i = $display->minwday; $i <= $display->maxwday; ++$i) {
384 // This uses the % operator to get the correct weekday no matter what shift we have
385 // applied to the $display->minwday : $display->maxwday range from the default 0 : 6
386 echo '<th scope="col">'.get_string($CALENDARDAYS[$i % 7], 'calendar').'</th>';
389 echo '</tr><tr>'; // End of day names; prepare for day numbers
391 // For the table display. $week is the row; $dayweek is the column.
392 $week = 1;
393 $dayweek = $startwday;
395 // Paddding (the first week may have blank days in the beginning)
396 for($i = $display->minwday; $i < $startwday; ++$i) {
397 echo '<td>&nbsp;</td>'."\n";
400 // Now display all the calendar
401 for($day = 1; $day <= $display->maxdays; ++$day, ++$dayweek) {
402 if($dayweek > $display->maxwday) {
403 // We need to change week (table row)
404 echo "</tr>\n<tr>";
405 $dayweek = $display->minwday;
406 ++$week;
409 // Reset vars
410 $cell = '';
411 $dayhref = calendar_get_link_href(CALENDAR_URL.'view.php?view=day&amp;', $day, $m, $y);
413 if(CALENDAR_WEEKEND & (1 << ($dayweek % 7))) {
414 // Weekend. This is true no matter what the exact range is.
415 $class = 'weekend';
417 else {
418 // Normal working day.
419 $class = '';
422 // Special visual fx if an event is defined
423 if(isset($eventsbyday[$day])) {
424 if(isset($typesbyday[$day]['startglobal'])) {
425 $class .= ' event_global';
427 else if(isset($typesbyday[$day]['startcourse'])) {
428 $class .= ' event_course';
430 else if(isset($typesbyday[$day]['startgroup'])) {
431 $class .= ' event_group';
433 else if(isset($typesbyday[$day]['startuser'])) {
434 $class .= ' event_user';
436 if(count($eventsbyday[$day]) == 1) {
437 $title = get_string('oneevent', 'calendar');
439 else {
440 $title = get_string('manyevents', 'calendar', count($eventsbyday[$day]));
442 $cell = '<div class="day"><a href="'.$dayhref.'" title="'.$title.'">'.$day.'</a></div>';
444 else {
445 $cell = '<div class="day">'.$day.'</div>';
448 // Special visual fx if an event spans many days
449 if(isset($typesbyday[$day]['durationglobal'])) {
450 $class .= ' duration_global';
452 else if(isset($typesbyday[$day]['durationcourse'])) {
453 $class .= ' duration_course';
455 else if(isset($typesbyday[$day]['durationgroup'])) {
456 $class .= ' duration_group';
458 else if(isset($typesbyday[$day]['durationuser'])) {
459 $class .= ' duration_user';
462 // Special visual fx for today
463 if($display->thismonth && $day == $d) {
464 $class .= ' today';
467 // Just display it
468 if(!empty($class)) {
469 $class = ' class="'.trim($class).'"';
471 echo '<td'.$class.'>'.$cell;
473 if(isset($eventsbyday[$day])) {
474 echo '<ul class="events-new">';
475 foreach($eventsbyday[$day] as $eventindex) {
476 echo '<li><a href="'.$dayhref.'#event_'.$events[$eventindex]->id.'">'.format_string($events[$eventindex]->name, true).'</a></li>';
478 echo '</ul>';
480 if(isset($durationbyday[$day])) {
481 echo '<ul class="events-underway">';
482 foreach($durationbyday[$day] as $eventindex) {
483 echo '<li>['.format_string($events[$eventindex]->name,true).']</li>';
485 echo '</ul>';
487 echo "</td>\n";
490 // Paddding (the last week may have blank days at the end)
491 for($i = $dayweek; $i <= $display->maxwday; ++$i) {
492 echo '<td>&nbsp;</td>';
494 echo "</tr>\n"; // Last row ends
496 echo "</table>\n"; // Tabular display of days ends
498 // OK, now for the filtering display
499 echo '<div class="filters"><table><tr>';
501 // Global events
502 if($SESSION->cal_show_global) {
503 echo '<td class="event_global" style="width: 8px;"></td><td><strong>'.get_string('globalevents', 'calendar').':</strong> ';
504 echo get_string('shown', 'calendar').' (<a href="'.CALENDAR_URL.'set.php?var=showglobal&amp;'.$getvars.'">'.get_string('clickhide', 'calendar').'</a>)</td>'."\n";
506 else {
507 echo '<td style="width: 8px;"></td><td><strong>'.get_string('globalevents', 'calendar').':</strong> ';
508 echo get_string('hidden', 'calendar').' (<a href="'.CALENDAR_URL.'set.php?var=showglobal&amp;'.$getvars.'">'.get_string('clickshow', 'calendar').'</a>)</td>'."\n";
511 // Course events
512 if(!empty($SESSION->cal_show_course)) {
513 echo '<td class="event_course" style="width: 8px;"></td><td><strong>'.get_string('courseevents', 'calendar').':</strong> ';
514 echo get_string('shown', 'calendar').' (<a href="'.CALENDAR_URL.'set.php?var=showcourses&amp;'.$getvars.'">'.get_string('clickhide', 'calendar').'</a>)</td>'."\n";
516 else {
517 echo '<td style="width: 8px;"></td><td><strong>'.get_string('courseevents', 'calendar').':</strong> ';
518 echo get_string('hidden', 'calendar').' (<a href="'.CALENDAR_URL.'set.php?var=showcourses&amp;'.$getvars.'">'.get_string('clickshow', 'calendar').'</a>)</td>'."\n";
521 echo "</tr>\n";
523 if(!empty($USER->id) && !isguest()) {
524 echo '<tr>';
525 // Group events
526 if($SESSION->cal_show_groups) {
527 echo '<td class="event_group" style="width: 8px;"></td><td><strong>'.get_string('groupevents', 'calendar').':</strong> ';
528 echo get_string('shown', 'calendar').' (<a href="'.CALENDAR_URL.'set.php?var=showgroups&amp;'.$getvars.'">'.get_string('clickhide', 'calendar').'</a>)</td>'."\n";
530 else {
531 echo '<td style="width: 8px;"></td><td><strong>'.get_string('groupevents', 'calendar').':</strong> ';
532 echo get_string('hidden', 'calendar').' (<a href="'.CALENDAR_URL.'set.php?var=showgroups&amp;'.$getvars.'">'.get_string('clickshow', 'calendar').'</a>)</td>'."\n";
534 // User events
535 if($SESSION->cal_show_user) {
536 echo '<td class="event_user" style="width: 8px;"></td><td><strong>'.get_string('userevents', 'calendar').':</strong> ';
537 echo get_string('shown', 'calendar').' (<a href="'.CALENDAR_URL.'set.php?var=showuser&amp;'.$getvars.'">'.get_string('clickhide', 'calendar').'</a>)</td>'."\n";
539 else {
540 echo '<td style="width: 8px;"></td><td><strong>'.get_string('userevents', 'calendar').':</strong> ';
541 echo get_string('hidden', 'calendar').' (<a href="'.CALENDAR_URL.'set.php?var=showuser&amp;'.$getvars.'">'.get_string('clickshow', 'calendar').'</a>)</td>'."\n";
543 echo "</tr>\n";
546 echo '</table></div>';
549 function calendar_show_upcoming_events($courses, $groups, $users, $futuredays, $maxevents) {
550 global $USER;
552 $events = calendar_get_upcoming($courses, $groups, $users, $futuredays, $maxevents);
554 $text = '';
556 if(!isguest() && !empty($USER->id)) {
557 $text.= '<div class="buttons">';
558 $text.= '<form action="'.CALENDAR_URL.'event.php" method="get">';
559 $text.= '<div>';
560 $text.= '<input type="hidden" name="action" value="new" />';
562 $text.= '<input type="hidden" name="cal_m" value="'.$m.'" />';
563 $text.= '<input type="hidden" name="cal_y" value="'.$y.'" />';
565 $text.= '<input type="submit" value="'.get_string('newevent', 'calendar').'" />';
566 $text.= '</div></form></div>';
569 $text .= get_string('upcomingevents', 'calendar').': '.calendar_course_filter_selector('from=upcoming');
571 echo '<div class="header">'.$text.'</div>';
573 if ($events) {
574 echo '<div class="eventlist">';
575 foreach ($events as $event) {
576 calendar_print_event($event);
578 echo '</div>';
579 } else {
580 print_heading(get_string('noupcomingevents', 'calendar'));
584 function calendar_course_filter_selector($getvars = '') {
585 global $USER, $SESSION;
587 if (empty($USER->id) or isguest()) {
588 return '';
591 if (has_capability('moodle/calendar:manageentries', get_context_instance(CONTEXT_SYSTEM, SITEID)) && !empty($CFG->calendar_adminseesall)) {
592 $courses = get_courses('all', 'c.shortname','c.id,c.shortname');
593 } else {
594 $courses = get_my_courses($USER->id, 'shortname');
597 unset($courses[SITEID]);
599 $courseoptions[SITEID] = get_string('fulllistofcourses');
600 foreach ($courses as $course) {
601 $courseoptions[$course->id] = format_string($course->shortname);
604 if (is_numeric($SESSION->cal_courses_shown)) {
605 $selected = $SESSION->cal_courses_shown;
606 } else {
607 $selected = '';
610 return popup_form(CALENDAR_URL.'set.php?var=setcourse&amp;'.$getvars.'&amp;id=',
611 $courseoptions, 'cal_course_flt', $selected, '', '', '', true);