2009-09-29 02:51:00 +00:00
|
|
|
<?php
|
2012-01-13 17:45:55 +08:00
|
|
|
// This file is part of Moodle - http://moodle.org/
|
|
|
|
//
|
|
|
|
// Moodle is free software: you can redistribute it and/or modify
|
|
|
|
// it under the terms of the GNU General Public License as published by
|
|
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
|
|
// (at your option) any later version.
|
|
|
|
//
|
|
|
|
// Moodle is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU General Public License for more details.
|
|
|
|
//
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
|
|
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
|
2004-03-29 15:28:15 +00:00
|
|
|
|
2012-01-13 17:45:55 +08:00
|
|
|
/**
|
|
|
|
* Calendar extension
|
|
|
|
*
|
|
|
|
* @package core_calendar
|
|
|
|
* @copyright 2004 Greek School Network (http://www.sch.gr), Jon Papaioannou,
|
|
|
|
* Avgoustos Tsinakos
|
|
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|
|
|
*/
|
|
|
|
|
2012-10-15 16:31:12 +08:00
|
|
|
if (!defined('MOODLE_INTERNAL')) {
|
|
|
|
die('Direct access to this script is forbidden.'); /// It must be included from a Moodle page
|
|
|
|
}
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
|
2012-01-13 17:45:55 +08:00
|
|
|
/**
|
|
|
|
* These are read by the administration component to provide default values
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* CALENDAR_DEFAULT_UPCOMING_LOOKAHEAD - default value of upcoming event preference
|
|
|
|
*/
|
2004-12-16 18:49:57 +00:00
|
|
|
define('CALENDAR_DEFAULT_UPCOMING_LOOKAHEAD', 21);
|
2012-01-13 17:45:55 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* CALENDAR_DEFAULT_UPCOMING_MAXEVENTS - default value to display the maximum number of upcoming event
|
|
|
|
*/
|
2004-12-16 18:49:57 +00:00
|
|
|
define('CALENDAR_DEFAULT_UPCOMING_MAXEVENTS', 10);
|
2012-01-13 17:45:55 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* CALENDAR_DEFAULT_STARTING_WEEKDAY - default value to display the starting weekday
|
|
|
|
*/
|
|
|
|
define('CALENDAR_DEFAULT_STARTING_WEEKDAY', 1);
|
|
|
|
|
2004-12-16 18:49:57 +00:00
|
|
|
// This is a packed bitfield: day X is "weekend" if $field & (1 << X) is true
|
|
|
|
// Default value = 65 = 64 + 1 = 2^6 + 2^0 = Saturday & Sunday
|
2012-01-13 17:45:55 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* CALENDAR_DEFAULT_WEEKEND - default value for weekend (Saturday & Sunday)
|
|
|
|
*/
|
|
|
|
define('CALENDAR_DEFAULT_WEEKEND', 65);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* CALENDAR_URL - path to calendar's folder
|
|
|
|
*/
|
2009-11-02 03:50:56 +00:00
|
|
|
define('CALENDAR_URL', $CFG->wwwroot.'/calendar/');
|
2012-01-13 17:45:55 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* CALENDAR_TF_24 - Calendar time in 24 hours format
|
|
|
|
*/
|
2009-11-02 03:50:56 +00:00
|
|
|
define('CALENDAR_TF_24', '%H:%M');
|
2012-01-13 17:45:55 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* CALENDAR_TF_12 - Calendar time in 12 hours format
|
|
|
|
*/
|
2009-11-02 03:50:56 +00:00
|
|
|
define('CALENDAR_TF_12', '%I:%M %p');
|
2004-12-16 18:49:57 +00:00
|
|
|
|
2012-01-13 17:45:55 +08:00
|
|
|
/**
|
|
|
|
* CALENDAR_EVENT_GLOBAL - Global calendar event types
|
|
|
|
*/
|
2011-06-29 14:50:38 +08:00
|
|
|
define('CALENDAR_EVENT_GLOBAL', 1);
|
2012-01-13 17:45:55 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* CALENDAR_EVENT_COURSE - Course calendar event types
|
|
|
|
*/
|
2011-06-29 14:50:38 +08:00
|
|
|
define('CALENDAR_EVENT_COURSE', 2);
|
2012-01-13 17:45:55 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* CALENDAR_EVENT_GROUP - group calendar event types
|
|
|
|
*/
|
2011-06-29 14:50:38 +08:00
|
|
|
define('CALENDAR_EVENT_GROUP', 4);
|
2012-01-13 17:45:55 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* CALENDAR_EVENT_USER - user calendar event types
|
|
|
|
*/
|
2011-06-29 14:50:38 +08:00
|
|
|
define('CALENDAR_EVENT_USER', 8);
|
|
|
|
|
2004-03-29 15:28:15 +00:00
|
|
|
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
/**
|
|
|
|
* CALENDAR_IMPORT_FROM_FILE - import the calendar from a file
|
|
|
|
*/
|
|
|
|
define('CALENDAR_IMPORT_FROM_FILE', 0);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* CALENDAR_IMPORT_FROM_URL - import the calendar from a URL
|
|
|
|
*/
|
|
|
|
define('CALENDAR_IMPORT_FROM_URL', 1);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* CALENDAR_IMPORT_EVENT_UPDATED - imported event was updated
|
|
|
|
*/
|
|
|
|
define('CALENDAR_IMPORT_EVENT_UPDATED', 1);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* CALENDAR_IMPORT_EVENT_INSERTED - imported event was added by insert
|
|
|
|
*/
|
|
|
|
define('CALENDAR_IMPORT_EVENT_INSERTED', 2);
|
|
|
|
|
2013-08-29 14:54:26 +08:00
|
|
|
/**
|
|
|
|
* CALENDAR_SUBSCRIPTION_UPDATE - Used to represent update action for subscriptions in various forms.
|
|
|
|
*/
|
|
|
|
define('CALENDAR_SUBSCRIPTION_UPDATE', 1);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* CALENDAR_SUBSCRIPTION_REMOVE - Used to represent remove action for subscriptions in various forms.
|
|
|
|
*/
|
|
|
|
define('CALENDAR_SUBSCRIPTION_REMOVE', 2);
|
|
|
|
|
2011-06-29 14:50:38 +08:00
|
|
|
/**
|
|
|
|
* Return the days of the week
|
|
|
|
*
|
2012-01-13 17:45:55 +08:00
|
|
|
* @return array array of days
|
2011-06-29 14:50:38 +08:00
|
|
|
*/
|
|
|
|
function calendar_get_days() {
|
2013-09-16 17:30:59 +08:00
|
|
|
$calendartype = \core_calendar\type_factory::get_calendar_instance();
|
|
|
|
return $calendartype->get_weekdays();
|
2011-06-29 14:50:38 +08:00
|
|
|
}
|
2005-05-26 12:54:56 +00:00
|
|
|
|
2013-01-17 11:11:15 +08:00
|
|
|
/**
|
|
|
|
* Get the subscription from a given id
|
|
|
|
*
|
|
|
|
* @since Moodle 2.5
|
|
|
|
* @param int $id id of the subscription
|
|
|
|
* @return stdClass Subscription record from DB
|
|
|
|
* @throws moodle_exception for an invalid id
|
|
|
|
*/
|
|
|
|
function calendar_get_subscription($id) {
|
|
|
|
global $DB;
|
|
|
|
|
|
|
|
$cache = cache::make('core', 'calendar_subscriptions');
|
|
|
|
$subscription = $cache->get($id);
|
|
|
|
if (empty($subscription)) {
|
|
|
|
$subscription = $DB->get_record('event_subscriptions', array('id' => $id), '*', MUST_EXIST);
|
|
|
|
// cache the data.
|
|
|
|
$cache->set($id, $subscription);
|
|
|
|
}
|
|
|
|
return $subscription;
|
|
|
|
}
|
|
|
|
|
2009-11-02 03:50:56 +00:00
|
|
|
/**
|
|
|
|
* Gets the first day of the week
|
|
|
|
*
|
|
|
|
* Used to be define('CALENDAR_STARTING_WEEKDAY', blah);
|
|
|
|
*
|
|
|
|
* @return int
|
|
|
|
*/
|
|
|
|
function calendar_get_starting_weekday() {
|
2013-09-16 17:30:59 +08:00
|
|
|
$calendartype = \core_calendar\type_factory::get_calendar_instance();
|
|
|
|
return $calendartype->get_starting_weekday();
|
2009-11-02 03:50:56 +00:00
|
|
|
}
|
2004-05-07 10:15:10 +00:00
|
|
|
|
2010-09-20 07:00:18 +00:00
|
|
|
/**
|
2010-09-20 07:04:46 +00:00
|
|
|
* Generates the HTML for a miniature calendar
|
2010-09-20 07:00:18 +00:00
|
|
|
*
|
2013-01-10 11:11:12 +08:00
|
|
|
* @param array $courses list of course to list events from
|
2012-01-13 17:45:55 +08:00
|
|
|
* @param array $groups list of group
|
|
|
|
* @param array $users user's info
|
2013-09-16 17:30:59 +08:00
|
|
|
* @param int|bool $calmonth calendar month in numeric, default is set to false
|
|
|
|
* @param int|bool $calyear calendar month in numeric, default is set to false
|
|
|
|
* @param string|bool $placement the place/page the calendar is set to appear - passed on the the controls function
|
|
|
|
* @param int|bool $courseid id of the course the calendar is displayed on - passed on the the controls function
|
|
|
|
* @param int $time the unixtimestamp representing the date we want to view, this is used instead of $calmonth
|
|
|
|
* and $calyear to support multiple calendars
|
2012-01-13 17:45:55 +08:00
|
|
|
* @return string $content return html table for mini calendar
|
2010-09-20 07:00:18 +00:00
|
|
|
*/
|
2013-09-16 17:30:59 +08:00
|
|
|
function calendar_get_mini($courses, $groups, $users, $calmonth = false, $calyear = false, $placement = false,
|
|
|
|
$courseid = false, $time = 0) {
|
|
|
|
global $CFG, $OUTPUT;
|
|
|
|
|
|
|
|
// Get the calendar type we are using.
|
|
|
|
$calendartype = \core_calendar\type_factory::get_calendar_instance();
|
2004-03-29 15:28:15 +00:00
|
|
|
|
2008-01-24 20:33:50 +00:00
|
|
|
$display = new stdClass;
|
2013-09-16 17:30:59 +08:00
|
|
|
|
|
|
|
// Assume we are not displaying this month for now.
|
|
|
|
$display->thismonth = false;
|
2004-03-29 15:28:15 +00:00
|
|
|
|
|
|
|
$content = '';
|
|
|
|
|
2013-09-16 17:30:59 +08:00
|
|
|
// Do this check for backwards compatibility. The core should be passing a timestamp rather than month and year.
|
|
|
|
// If a month and year are passed they will be in Gregorian.
|
|
|
|
if (!empty($calmonth) && !empty($calyear)) {
|
|
|
|
// Ensure it is a valid date, else we will just set it to the current timestamp.
|
|
|
|
if (checkdate($calmonth, 1, $calyear)) {
|
|
|
|
$time = make_timestamp($calyear, $calmonth, 1);
|
2010-06-22 04:03:44 +00:00
|
|
|
} else {
|
2013-09-16 17:30:59 +08:00
|
|
|
$time = time();
|
|
|
|
}
|
|
|
|
$date = usergetdate($time);
|
|
|
|
if ($calmonth == $date['mon'] && $calyear == $date['year']) {
|
|
|
|
$display->thismonth = true;
|
|
|
|
}
|
|
|
|
// We can overwrite date now with the date used by the calendar type, if it is not Gregorian, otherwise
|
|
|
|
// there is no need as it is already in Gregorian.
|
|
|
|
if ($calendartype->get_name() != 'gregorian') {
|
|
|
|
$date = $calendartype->timestamp_to_date_array($time);
|
|
|
|
}
|
|
|
|
} else if (!empty($time)) {
|
|
|
|
// Get the specified date in the calendar type being used.
|
|
|
|
$date = $calendartype->timestamp_to_date_array($time);
|
|
|
|
$thisdate = $calendartype->timestamp_to_date_array(time());
|
|
|
|
if ($date['month'] == $thisdate['month'] && $date['year'] == $thisdate['year']) {
|
|
|
|
$display->thismonth = true;
|
|
|
|
// If we are the current month we want to set the date to the current date, not the start of the month.
|
|
|
|
$date = $thisdate;
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
2010-06-22 04:03:44 +00:00
|
|
|
} else {
|
2013-09-16 17:30:59 +08:00
|
|
|
// Get the current date in the calendar type being used.
|
|
|
|
$time = time();
|
|
|
|
$date = $calendartype->timestamp_to_date_array($time);
|
2004-03-29 15:28:15 +00:00
|
|
|
$display->thismonth = true;
|
|
|
|
}
|
|
|
|
|
2013-09-16 17:30:59 +08:00
|
|
|
list($d, $m, $y) = array($date['mday'], $date['mon'], $date['year']); // This is what we want to display.
|
2004-03-29 15:28:15 +00:00
|
|
|
|
2013-10-09 16:39:53 +08:00
|
|
|
// Get Gregorian date for the start of the month.
|
2013-09-16 17:30:59 +08:00
|
|
|
$gregoriandate = $calendartype->convert_to_gregorian($date['year'], $date['mon'], 1);
|
|
|
|
|
2013-10-09 16:39:53 +08:00
|
|
|
// Store the gregorian date values to be used later.
|
2013-09-16 17:30:59 +08:00
|
|
|
list($gy, $gm, $gd, $gh, $gmin) = array($gregoriandate['year'], $gregoriandate['month'], $gregoriandate['day'],
|
|
|
|
$gregoriandate['hour'], $gregoriandate['minute']);
|
2004-03-29 15:28:15 +00:00
|
|
|
|
2013-09-16 17:30:59 +08:00
|
|
|
// Get the max number of days in this month for this calendar type.
|
|
|
|
$display->maxdays = calendar_days_in_month($m, $y);
|
|
|
|
// Get the starting week day for this month.
|
2005-02-26 06:30:19 +00:00
|
|
|
$startwday = dayofweek(1, $m, $y);
|
2013-09-16 17:30:59 +08:00
|
|
|
// Get the days in a week.
|
|
|
|
$daynames = calendar_get_days();
|
|
|
|
// Store the number of days in a week.
|
|
|
|
$numberofdaysinweek = $calendartype->get_num_weekdays();
|
|
|
|
|
|
|
|
// Set the min and max weekday.
|
|
|
|
$display->minwday = calendar_get_starting_weekday();
|
|
|
|
$display->maxwday = $display->minwday + ($numberofdaysinweek - 1);
|
|
|
|
|
|
|
|
// These are used for DB queries, so we want unixtime, so we need to use Gregorian dates.
|
|
|
|
$display->tstart = make_timestamp($gy, $gm, $gd, $gh, $gmin, 0);
|
2013-10-09 16:39:53 +08:00
|
|
|
$display->tend = $display->tstart + ($display->maxdays * DAYSECS) - 1;
|
2004-03-29 15:28:15 +00:00
|
|
|
|
|
|
|
// Align the starting weekday to fall in our display range
|
|
|
|
// This is simple, not foolproof.
|
2013-09-16 17:30:59 +08:00
|
|
|
if ($startwday < $display->minwday) {
|
|
|
|
$startwday += $numberofdaysinweek;
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Get the events matching our criteria. Don't forget to offset the timestamps for the user's TZ!
|
2013-09-16 17:30:59 +08:00
|
|
|
$events = calendar_get_events($display->tstart, $display->tend, $users, $groups, $courses);
|
2004-03-29 15:28:15 +00:00
|
|
|
|
2007-06-12 16:26:38 +00:00
|
|
|
// Set event course class for course events
|
|
|
|
if (!empty($events)) {
|
2007-08-20 10:52:59 +00:00
|
|
|
foreach ($events as $eventid => $event) {
|
|
|
|
if (!empty($event->modulename)) {
|
|
|
|
$cm = get_coursemodule_from_instance($event->modulename, $event->instance);
|
2014-03-21 11:34:15 +00:00
|
|
|
if (!\core_availability\info_module::is_user_visible($cm, 0, false)) {
|
2007-08-20 10:52:59 +00:00
|
|
|
unset($events[$eventid]);
|
|
|
|
}
|
|
|
|
}
|
2007-06-12 16:26:38 +00:00
|
|
|
}
|
|
|
|
}
|
2007-09-11 07:29:48 +00:00
|
|
|
|
2004-05-24 10:35:43 +00:00
|
|
|
// This is either a genius idea or an idiot idea: in order to not complicate things, we use this rule: if, after
|
2004-09-16 10:14:44 +00:00
|
|
|
// possibly removing SITEID from $courses, there is only one course left, then clicking on a day in the month
|
2004-05-24 10:35:43 +00:00
|
|
|
// will also set the $SESSION->cal_courses_shown variable to that one course. Otherwise, we 'd need to add extra
|
|
|
|
// arguments to this function.
|
2010-09-20 07:00:18 +00:00
|
|
|
$hrefparams = array();
|
2004-05-26 11:03:27 +00:00
|
|
|
if(!empty($courses)) {
|
2004-08-30 11:46:08 +00:00
|
|
|
$courses = array_diff($courses, array(SITEID));
|
2004-05-26 11:03:27 +00:00
|
|
|
if(count($courses) == 1) {
|
2010-09-20 07:00:18 +00:00
|
|
|
$hrefparams['course'] = reset($courses);
|
2004-05-26 11:03:27 +00:00
|
|
|
}
|
2004-05-24 10:35:43 +00:00
|
|
|
}
|
|
|
|
|
2004-03-29 15:28:15 +00:00
|
|
|
// We want to have easy access by day, since the display is on a per-day basis.
|
2007-06-13 10:00:30 +00:00
|
|
|
calendar_events_by_day($events, $m, $y, $eventsbyday, $durationbyday, $typesbyday, $courses);
|
2004-03-29 15:28:15 +00:00
|
|
|
|
2013-09-16 17:30:59 +08:00
|
|
|
// Accessibility: added summary and <abbr> elements.
|
|
|
|
$summary = get_string('calendarheading', 'calendar', userdate($display->tstart, get_string('strftimemonthyear')));
|
|
|
|
$content .= '<table class="minicalendar calendartable" summary="'.$summary.'">'; // Begin table.
|
|
|
|
if (($placement !== false) && ($courseid !== false)) {
|
|
|
|
$content .= '<caption>'. calendar_top_controls($placement, array('id' => $courseid, 'time' => $time)) .'</caption>';
|
2013-01-10 11:11:12 +08:00
|
|
|
}
|
2005-02-14 16:50:02 +00:00
|
|
|
$content .= '<tr class="weekdays">'; // Header row: day names
|
2004-03-29 15:28:15 +00:00
|
|
|
|
2013-09-16 17:30:59 +08:00
|
|
|
// Print out the names of the weekdays.
|
|
|
|
for ($i = $display->minwday; $i <= $display->maxwday; ++$i) {
|
|
|
|
$pos = $i % $numberofdaysinweek;
|
|
|
|
$content .= '<th scope="col"><abbr title="'. $daynames[$pos]['fullname'] .'">'.
|
|
|
|
$daynames[$pos]['shortname'] ."</abbr></th>\n";
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
|
|
|
|
2005-02-14 16:50:02 +00:00
|
|
|
$content .= '</tr><tr>'; // End of day names; prepare for day numbers
|
2004-03-29 15:28:15 +00:00
|
|
|
|
|
|
|
// For the table display. $week is the row; $dayweek is the column.
|
|
|
|
$dayweek = $startwday;
|
|
|
|
|
|
|
|
// Paddding (the first week may have blank days in the beginning)
|
|
|
|
for($i = $display->minwday; $i < $startwday; ++$i) {
|
2007-06-28 14:08:08 +00:00
|
|
|
$content .= '<td class="dayblank"> </td>'."\n";
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
|
|
|
|
2011-06-29 14:50:38 +08:00
|
|
|
$weekend = CALENDAR_DEFAULT_WEEKEND;
|
|
|
|
if (isset($CFG->calendar_weekend)) {
|
|
|
|
$weekend = intval($CFG->calendar_weekend);
|
|
|
|
}
|
|
|
|
|
2004-03-29 15:28:15 +00:00
|
|
|
// Now display all the calendar
|
2013-09-16 17:30:59 +08:00
|
|
|
$daytime = $display->tstart - DAYSECS;
|
2004-03-29 15:28:15 +00:00
|
|
|
for($day = 1; $day <= $display->maxdays; ++$day, ++$dayweek) {
|
2013-09-16 17:30:59 +08:00
|
|
|
$daytime += DAYSECS;
|
2004-03-29 15:28:15 +00:00
|
|
|
if($dayweek > $display->maxwday) {
|
|
|
|
// We need to change week (table row)
|
2004-05-24 14:45:02 +00:00
|
|
|
$content .= '</tr><tr>';
|
2004-03-29 15:28:15 +00:00
|
|
|
$dayweek = $display->minwday;
|
|
|
|
}
|
2004-04-20 11:14:55 +00:00
|
|
|
|
2013-09-16 17:30:59 +08:00
|
|
|
// Reset vars.
|
|
|
|
if ($weekend & (1 << ($dayweek % $numberofdaysinweek))) {
|
2004-03-29 15:28:15 +00:00
|
|
|
// Weekend. This is true no matter what the exact range is.
|
2005-04-11 22:58:10 +00:00
|
|
|
$class = 'weekend day';
|
2010-03-25 06:38:21 +00:00
|
|
|
} else {
|
2004-03-29 15:28:15 +00:00
|
|
|
// Normal working day.
|
2005-04-11 22:58:10 +00:00
|
|
|
$class = 'day';
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Special visual fx if an event is defined
|
|
|
|
if(isset($eventsbyday[$day])) {
|
2013-09-16 17:30:59 +08:00
|
|
|
|
2010-03-25 06:38:21 +00:00
|
|
|
$class .= ' hasevent';
|
2010-09-20 07:00:18 +00:00
|
|
|
$hrefparams['view'] = 'day';
|
2013-09-16 17:30:59 +08:00
|
|
|
$dayhref = calendar_get_link_href(new moodle_url(CALENDAR_URL . 'view.php', $hrefparams), 0, 0, 0, $daytime);
|
2004-05-21 11:24:22 +00:00
|
|
|
|
2004-03-29 15:28:15 +00:00
|
|
|
$popupcontent = '';
|
|
|
|
foreach($eventsbyday[$day] as $eventid) {
|
2004-05-24 03:39:05 +00:00
|
|
|
if (!isset($events[$eventid])) {
|
|
|
|
continue;
|
2004-05-18 07:51:46 +00:00
|
|
|
}
|
2012-12-27 16:05:24 +08:00
|
|
|
$event = new calendar_event($events[$eventid]);
|
2010-09-20 07:00:18 +00:00
|
|
|
$popupalt = '';
|
|
|
|
$component = 'moodle';
|
2013-09-16 17:30:59 +08:00
|
|
|
if (!empty($event->modulename)) {
|
2010-09-20 07:00:18 +00:00
|
|
|
$popupicon = 'icon';
|
2004-05-24 03:39:05 +00:00
|
|
|
$popupalt = $event->modulename;
|
2010-09-20 07:00:18 +00:00
|
|
|
$component = $event->modulename;
|
2013-09-16 17:30:59 +08:00
|
|
|
} else if ($event->courseid == SITEID) { // Site event.
|
2012-11-23 14:11:07 +08:00
|
|
|
$popupicon = 'i/siteevent';
|
2013-09-16 17:30:59 +08:00
|
|
|
} else if ($event->courseid != 0 && $event->courseid != SITEID && $event->groupid == 0) { // Course event.
|
2012-11-23 14:11:07 +08:00
|
|
|
$popupicon = 'i/courseevent';
|
2013-09-16 17:30:59 +08:00
|
|
|
} else if ($event->groupid) { // Group event.
|
2012-11-23 14:11:07 +08:00
|
|
|
$popupicon = 'i/groupevent';
|
2013-09-16 17:30:59 +08:00
|
|
|
} else { // Must be a user event.
|
2012-11-23 14:11:07 +08:00
|
|
|
$popupicon = 'i/userevent';
|
2004-05-18 07:51:46 +00:00
|
|
|
}
|
2010-11-17 07:56:40 +00:00
|
|
|
|
2010-09-20 07:00:18 +00:00
|
|
|
$dayhref->set_anchor('event_'.$event->id);
|
2010-11-17 07:56:40 +00:00
|
|
|
|
2010-09-20 07:00:18 +00:00
|
|
|
$popupcontent .= html_writer::start_tag('div');
|
2011-01-03 18:26:50 +00:00
|
|
|
$popupcontent .= $OUTPUT->pix_icon($popupicon, $popupalt, $component);
|
2012-12-27 16:05:24 +08:00
|
|
|
$name = format_string($event->name, true);
|
2013-01-17 11:11:15 +08:00
|
|
|
// Show ical source if needed.
|
|
|
|
if (!empty($event->subscription) && $CFG->calendar_showicalsource) {
|
2012-12-27 16:05:24 +08:00
|
|
|
$a = new stdClass();
|
|
|
|
$a->name = $name;
|
|
|
|
$a->source = $event->subscription->name;
|
|
|
|
$name = get_string('namewithsource', 'calendar', $a);
|
|
|
|
}
|
|
|
|
$popupcontent .= html_writer::link($dayhref, $name);
|
2010-09-20 07:00:18 +00:00
|
|
|
$popupcontent .= html_writer::end_tag('div');
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
2007-08-17 11:18:58 +00:00
|
|
|
|
2006-03-08 16:52:23 +00:00
|
|
|
//Accessibility: functionality moved to calendar_get_popup.
|
|
|
|
if($display->thismonth && $day == $d) {
|
2012-09-17 11:28:05 +08:00
|
|
|
$popupid = calendar_get_popup(true, $events[$eventid]->timestart, $popupcontent);
|
2006-03-08 16:52:23 +00:00
|
|
|
} else {
|
2012-09-17 11:28:05 +08:00
|
|
|
$popupid = calendar_get_popup(false, $events[$eventid]->timestart, $popupcontent);
|
2007-08-17 11:18:58 +00:00
|
|
|
}
|
2006-03-08 17:03:02 +00:00
|
|
|
|
2004-03-29 15:28:15 +00:00
|
|
|
// Class and cell content
|
|
|
|
if(isset($typesbyday[$day]['startglobal'])) {
|
2010-03-25 06:38:21 +00:00
|
|
|
$class .= ' calendar_event_global';
|
|
|
|
} else if(isset($typesbyday[$day]['startcourse'])) {
|
|
|
|
$class .= ' calendar_event_course';
|
|
|
|
} else if(isset($typesbyday[$day]['startgroup'])) {
|
|
|
|
$class .= ' calendar_event_group';
|
|
|
|
} else if(isset($typesbyday[$day]['startuser'])) {
|
|
|
|
$class .= ' calendar_event_user';
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
2013-10-14 15:13:20 +08:00
|
|
|
$cell = html_writer::link($dayhref, $day, array('id' => $popupid));
|
2010-03-25 06:38:21 +00:00
|
|
|
} else {
|
2005-03-27 15:36:47 +00:00
|
|
|
$cell = $day;
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
|
|
|
|
2010-03-25 06:38:21 +00:00
|
|
|
$durationclass = false;
|
|
|
|
if (isset($typesbyday[$day]['durationglobal'])) {
|
|
|
|
$durationclass = ' duration_global';
|
|
|
|
} else if(isset($typesbyday[$day]['durationcourse'])) {
|
|
|
|
$durationclass = ' duration_course';
|
|
|
|
} else if(isset($typesbyday[$day]['durationgroup'])) {
|
|
|
|
$durationclass = ' duration_group';
|
|
|
|
} else if(isset($typesbyday[$day]['durationuser'])) {
|
|
|
|
$durationclass = ' duration_user';
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
2010-03-25 06:38:21 +00:00
|
|
|
if ($durationclass) {
|
|
|
|
$class .= ' duration '.$durationclass;
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
|
|
|
|
2007-06-12 16:26:38 +00:00
|
|
|
// If event has a class set then add it to the table day <td> tag
|
|
|
|
// Note: only one colour for minicalendar
|
|
|
|
if(isset($eventsbyday[$day])) {
|
|
|
|
foreach($eventsbyday[$day] as $eventid) {
|
|
|
|
if (!isset($events[$eventid])) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
$event = $events[$eventid];
|
|
|
|
if (!empty($event->class)) {
|
|
|
|
$class .= ' '.$event->class;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2004-03-29 15:28:15 +00:00
|
|
|
// Special visual fx for today
|
2006-05-17 16:47:44 +00:00
|
|
|
//Accessibility: hidden text for today, and popup.
|
2004-03-29 15:28:15 +00:00
|
|
|
if($display->thismonth && $day == $d) {
|
2005-02-11 03:54:33 +00:00
|
|
|
$class .= ' today';
|
2006-03-08 16:52:23 +00:00
|
|
|
$today = get_string('today', 'calendar').' '.userdate(time(), get_string('strftimedayshort'));
|
2007-08-17 11:18:58 +00:00
|
|
|
|
2006-03-08 16:52:23 +00:00
|
|
|
if(! isset($eventsbyday[$day])) {
|
2006-05-17 16:47:44 +00:00
|
|
|
$class .= ' eventnone';
|
2012-09-17 11:28:05 +08:00
|
|
|
$popupid = calendar_get_popup(true, false);
|
2013-10-14 15:13:20 +08:00
|
|
|
$cell = html_writer::link('#', $day, array('id' => $popupid));
|
2006-03-08 16:52:23 +00:00
|
|
|
}
|
2007-10-15 10:04:41 +00:00
|
|
|
$cell = get_accesshide($today.' ').$cell;
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Just display it
|
2004-04-20 11:14:55 +00:00
|
|
|
if(!empty($class)) {
|
2004-05-24 14:45:02 +00:00
|
|
|
$class = ' class="'.$class.'"';
|
2004-04-20 11:14:55 +00:00
|
|
|
}
|
|
|
|
$content .= '<td'.$class.'>'.$cell."</td>\n";
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Paddding (the last week may have blank days at the end)
|
|
|
|
for($i = $dayweek; $i <= $display->maxwday; ++$i) {
|
2007-06-28 14:08:08 +00:00
|
|
|
$content .= '<td class="dayblank"> </td>';
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
|
|
|
$content .= '</tr>'; // Last row ends
|
|
|
|
|
2005-02-14 16:50:02 +00:00
|
|
|
$content .= '</table>'; // Tabular display of days ends
|
2004-03-29 15:28:15 +00:00
|
|
|
|
|
|
|
return $content;
|
|
|
|
}
|
|
|
|
|
2006-03-08 16:52:23 +00:00
|
|
|
/**
|
2012-01-13 17:45:55 +08:00
|
|
|
* Gets the calendar popup
|
|
|
|
*
|
|
|
|
* It called at multiple points in from calendar_get_mini.
|
|
|
|
* Copied and modified from calendar_get_mini.
|
|
|
|
*
|
|
|
|
* @param bool $is_today false except when called on the current day.
|
|
|
|
* @param mixed $event_timestart $events[$eventid]->timestart, OR false if there are no events.
|
2012-09-17 11:28:05 +08:00
|
|
|
* @param string $popupcontent content for the popup window/layout.
|
|
|
|
* @return string eventid for the calendar_tooltip popup window/layout.
|
2006-03-08 16:52:23 +00:00
|
|
|
*/
|
|
|
|
function calendar_get_popup($is_today, $event_timestart, $popupcontent='') {
|
2009-09-17 07:46:20 +00:00
|
|
|
global $PAGE;
|
|
|
|
static $popupcount;
|
|
|
|
if ($popupcount === null) {
|
|
|
|
$popupcount = 1;
|
|
|
|
}
|
2006-03-08 16:52:23 +00:00
|
|
|
$popupcaption = '';
|
|
|
|
if($is_today) {
|
|
|
|
$popupcaption = get_string('today', 'calendar').' ';
|
|
|
|
}
|
|
|
|
if (false === $event_timestart) {
|
|
|
|
$popupcaption .= userdate(time(), get_string('strftimedayshort'));
|
|
|
|
$popupcontent = get_string('eventnone', 'calendar');
|
2006-05-17 16:47:44 +00:00
|
|
|
|
2006-03-08 16:52:23 +00:00
|
|
|
} else {
|
|
|
|
$popupcaption .= get_string('eventsfor', 'calendar', userdate($event_timestart, get_string('strftimedayshort')));
|
|
|
|
}
|
2009-09-17 07:46:20 +00:00
|
|
|
$id = 'calendar_tooltip_'.$popupcount;
|
2010-07-09 04:22:26 +00:00
|
|
|
$PAGE->requires->yui_module('moodle-calendar-eventmanager', 'M.core_calendar.add_event', array(array('eventId'=>$id,'title'=>$popupcaption, 'content'=>$popupcontent)));
|
2010-01-22 03:06:01 +00:00
|
|
|
|
2009-09-17 07:46:20 +00:00
|
|
|
$popupcount++;
|
2012-09-17 11:28:05 +08:00
|
|
|
return $id;
|
2006-03-08 16:52:23 +00:00
|
|
|
}
|
|
|
|
|
2012-01-13 17:45:55 +08:00
|
|
|
/**
|
|
|
|
* Gets the calendar upcoming event
|
|
|
|
*
|
|
|
|
* @param array $courses array of courses
|
|
|
|
* @param array|int|bool $groups array of groups, group id or boolean for all/no group events
|
|
|
|
* @param array|int|bool $users array of users, user id or boolean for all/no user events
|
|
|
|
* @param int $daysinfuture number of days in the future we 'll look
|
|
|
|
* @param int $maxevents maximum number of events
|
|
|
|
* @param int $fromtime start time
|
|
|
|
* @return array $output array of upcoming events
|
|
|
|
*/
|
2004-05-23 11:05:45 +00:00
|
|
|
function calendar_get_upcoming($courses, $groups, $users, $daysinfuture, $maxevents, $fromtime=0) {
|
2008-06-01 14:25:05 +00:00
|
|
|
global $CFG, $COURSE, $DB;
|
2004-03-29 15:28:15 +00:00
|
|
|
|
2008-01-24 20:33:50 +00:00
|
|
|
$display = new stdClass;
|
2004-03-29 15:28:15 +00:00
|
|
|
$display->range = $daysinfuture; // How many days in the future we 'll look
|
|
|
|
$display->maxevents = $maxevents;
|
|
|
|
|
|
|
|
$output = array();
|
|
|
|
|
|
|
|
// Prepare "course caching", since it may save us a lot of queries
|
|
|
|
$coursecache = array();
|
|
|
|
|
|
|
|
$processed = 0;
|
|
|
|
$now = time(); // We 'll need this later
|
2004-06-02 09:15:07 +00:00
|
|
|
$usermidnighttoday = usergetmidnight($now);
|
2004-03-29 15:28:15 +00:00
|
|
|
|
2004-05-23 11:05:45 +00:00
|
|
|
if ($fromtime) {
|
|
|
|
$display->tstart = $fromtime;
|
|
|
|
} else {
|
2004-06-02 09:15:07 +00:00
|
|
|
$display->tstart = $usermidnighttoday;
|
2004-05-23 11:05:45 +00:00
|
|
|
}
|
2004-03-29 15:28:15 +00:00
|
|
|
|
2005-02-17 01:10:17 +00:00
|
|
|
// This works correctly with respect to the user's DST, but it is accurate
|
|
|
|
// only because $fromtime is always the exact midnight of some day!
|
|
|
|
$display->tend = usergetmidnight($display->tstart + DAYSECS * $display->range + 3 * HOURSECS) - 1;
|
2004-03-29 15:28:15 +00:00
|
|
|
|
|
|
|
// Get the events matching our criteria
|
2007-11-26 14:43:28 +00:00
|
|
|
$events = calendar_get_events($display->tstart, $display->tend, $users, $groups, $courses);
|
2004-03-29 15:28:15 +00:00
|
|
|
|
2004-05-24 10:35:43 +00:00
|
|
|
// This is either a genius idea or an idiot idea: in order to not complicate things, we use this rule: if, after
|
2004-09-16 10:14:44 +00:00
|
|
|
// possibly removing SITEID from $courses, there is only one course left, then clicking on a day in the month
|
2004-05-24 10:35:43 +00:00
|
|
|
// will also set the $SESSION->cal_courses_shown variable to that one course. Otherwise, we 'd need to add extra
|
|
|
|
// arguments to this function.
|
|
|
|
|
2010-09-20 07:00:18 +00:00
|
|
|
$hrefparams = array();
|
2004-05-26 11:03:27 +00:00
|
|
|
if(!empty($courses)) {
|
2004-08-30 11:46:08 +00:00
|
|
|
$courses = array_diff($courses, array(SITEID));
|
2004-05-26 11:03:27 +00:00
|
|
|
if(count($courses) == 1) {
|
2010-09-20 07:00:18 +00:00
|
|
|
$hrefparams['course'] = reset($courses);
|
2004-05-26 11:03:27 +00:00
|
|
|
}
|
2004-05-24 10:35:43 +00:00
|
|
|
}
|
|
|
|
|
2008-01-24 20:33:50 +00:00
|
|
|
if ($events !== false) {
|
|
|
|
|
2012-03-18 18:37:24 +01:00
|
|
|
$modinfo = get_fast_modinfo($COURSE);
|
2005-11-08 07:19:27 +00:00
|
|
|
|
2004-03-29 15:28:15 +00:00
|
|
|
foreach($events as $event) {
|
2007-11-16 02:52:48 +00:00
|
|
|
|
2008-01-24 20:33:50 +00:00
|
|
|
|
|
|
|
if (!empty($event->modulename)) {
|
|
|
|
if ($event->courseid == $COURSE->id) {
|
|
|
|
if (isset($modinfo->instances[$event->modulename][$event->instance])) {
|
|
|
|
$cm = $modinfo->instances[$event->modulename][$event->instance];
|
|
|
|
if (!$cm->uservisible) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if (!$cm = get_coursemodule_from_instance($event->modulename, $event->instance)) {
|
2007-11-16 02:52:48 +00:00
|
|
|
continue;
|
|
|
|
}
|
2014-03-21 11:34:15 +00:00
|
|
|
if (!\core_availability\info_module::is_user_visible($cm, 0, false)) {
|
2007-11-16 02:52:48 +00:00
|
|
|
continue;
|
|
|
|
}
|
2008-01-24 20:33:50 +00:00
|
|
|
}
|
2007-11-16 02:52:48 +00:00
|
|
|
}
|
2004-06-02 09:15:07 +00:00
|
|
|
|
2008-01-24 20:33:50 +00:00
|
|
|
if ($processed >= $display->maxevents) {
|
2004-06-02 09:15:07 +00:00
|
|
|
break;
|
|
|
|
}
|
2004-03-29 15:28:15 +00:00
|
|
|
|
2010-09-20 07:00:18 +00:00
|
|
|
$event->time = calendar_format_event_time($event, $now, $hrefparams);
|
2005-02-11 15:52:59 +00:00
|
|
|
$output[] = $event;
|
|
|
|
++$processed;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return $output;
|
|
|
|
}
|
2004-03-29 15:28:15 +00:00
|
|
|
|
2013-08-01 21:05:02 +01:00
|
|
|
|
|
|
|
/**
|
2013-08-13 10:06:34 +08:00
|
|
|
* Get a HTML link to a course.
|
2013-08-01 21:05:02 +01:00
|
|
|
*
|
|
|
|
* @param int $courseid the course id
|
|
|
|
* @return string a link to the course (as HTML); empty if the course id is invalid
|
|
|
|
*/
|
|
|
|
function calendar_get_courselink($courseid) {
|
|
|
|
|
|
|
|
if (!$courseid) {
|
|
|
|
return '';
|
|
|
|
}
|
|
|
|
|
2013-08-13 10:06:34 +08:00
|
|
|
calendar_get_course_cached($coursecache, $courseid);
|
2013-08-01 21:05:02 +01:00
|
|
|
$context = context_course::instance($courseid);
|
|
|
|
$fullname = format_string($coursecache[$courseid]->fullname, true, array('context' => $context));
|
|
|
|
$url = new moodle_url('/course/view.php', array('id' => $courseid));
|
|
|
|
$link = html_writer::link($url, $fullname);
|
|
|
|
|
|
|
|
return $link;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-01-13 17:45:55 +08:00
|
|
|
/**
|
|
|
|
* Add calendar event metadata
|
|
|
|
*
|
|
|
|
* @param stdClass $event event info
|
|
|
|
* @return stdClass $event metadata
|
|
|
|
*/
|
2005-02-12 09:42:23 +00:00
|
|
|
function calendar_add_event_metadata($event) {
|
2009-07-02 10:53:31 +00:00
|
|
|
global $CFG, $OUTPUT;
|
2005-03-27 16:41:04 +00:00
|
|
|
|
2007-08-17 11:18:58 +00:00
|
|
|
//Support multilang in event->name
|
2005-03-27 16:41:04 +00:00
|
|
|
$event->name = format_string($event->name,true);
|
2007-08-17 11:18:58 +00:00
|
|
|
|
2005-02-11 15:52:59 +00:00
|
|
|
if(!empty($event->modulename)) { // Activity event
|
|
|
|
// The module name is set. I will assume that it has to be displayed, and
|
|
|
|
// also that it is an automatically-generated event. And of course that the
|
|
|
|
// fields for get_coursemodule_from_instance are set correctly.
|
|
|
|
$module = calendar_get_module_cached($coursecache, $event->modulename, $event->instance);
|
2004-03-29 15:28:15 +00:00
|
|
|
|
2005-02-11 15:52:59 +00:00
|
|
|
if ($module === false) {
|
|
|
|
return;
|
|
|
|
}
|
2004-05-23 11:05:45 +00:00
|
|
|
|
2005-02-11 15:52:59 +00:00
|
|
|
$modulename = get_string('modulename', $event->modulename);
|
2010-04-30 10:53:39 +00:00
|
|
|
if (get_string_manager()->string_exists($event->eventtype, $event->modulename)) {
|
|
|
|
// will be used as alt text if the event icon
|
|
|
|
$eventtype = get_string($event->eventtype, $event->modulename);
|
|
|
|
} else {
|
|
|
|
$eventtype = '';
|
|
|
|
}
|
2009-12-16 21:50:45 +00:00
|
|
|
$icon = $OUTPUT->pix_url('icon', $event->modulename) . '';
|
2004-05-23 11:05:45 +00:00
|
|
|
|
2012-11-23 14:45:29 +08:00
|
|
|
$event->icon = '<img src="'.$icon.'" alt="'.$eventtype.'" title="'.$modulename.'" class="icon" />';
|
2005-03-27 16:41:04 +00:00
|
|
|
$event->referer = '<a href="'.$CFG->wwwroot.'/mod/'.$event->modulename.'/view.php?id='.$module->id.'">'.$event->name.'</a>';
|
2013-08-01 21:05:02 +01:00
|
|
|
$event->courselink = calendar_get_courselink($module->course);
|
2005-02-11 15:52:59 +00:00
|
|
|
$event->cmid = $module->id;
|
2004-05-23 11:05:45 +00:00
|
|
|
|
2005-02-11 15:52:59 +00:00
|
|
|
} else if($event->courseid == SITEID) { // Site event
|
2012-11-23 14:45:29 +08:00
|
|
|
$event->icon = '<img src="'.$OUTPUT->pix_url('i/siteevent') . '" alt="'.get_string('globalevent', 'calendar').'" class="icon" />';
|
2010-03-25 06:38:21 +00:00
|
|
|
$event->cssclass = 'calendar_event_global';
|
2005-02-11 15:52:59 +00:00
|
|
|
} else if($event->courseid != 0 && $event->courseid != SITEID && $event->groupid == 0) { // Course event
|
2012-11-23 14:45:29 +08:00
|
|
|
$event->icon = '<img src="'.$OUTPUT->pix_url('i/courseevent') . '" alt="'.get_string('courseevent', 'calendar').'" class="icon" />';
|
2013-08-01 21:05:02 +01:00
|
|
|
$event->courselink = calendar_get_courselink($event->courseid);
|
2010-03-25 06:38:21 +00:00
|
|
|
$event->cssclass = 'calendar_event_course';
|
2005-02-11 15:52:59 +00:00
|
|
|
} else if ($event->groupid) { // Group event
|
2012-11-23 14:45:29 +08:00
|
|
|
$event->icon = '<img src="'.$OUTPUT->pix_url('i/groupevent') . '" alt="'.get_string('groupevent', 'calendar').'" class="icon" />';
|
2013-08-01 21:05:02 +01:00
|
|
|
$event->courselink = calendar_get_courselink($event->courseid);
|
2010-03-25 06:38:21 +00:00
|
|
|
$event->cssclass = 'calendar_event_group';
|
2005-02-11 15:52:59 +00:00
|
|
|
} else if($event->userid) { // User event
|
2012-11-23 14:45:29 +08:00
|
|
|
$event->icon = '<img src="'.$OUTPUT->pix_url('i/userevent') . '" alt="'.get_string('userevent', 'calendar').'" class="icon" />';
|
2010-03-25 06:38:21 +00:00
|
|
|
$event->cssclass = 'calendar_event_user';
|
2005-02-11 15:52:59 +00:00
|
|
|
}
|
2005-02-12 09:42:23 +00:00
|
|
|
return $event;
|
2007-08-17 11:18:58 +00:00
|
|
|
}
|
2005-02-12 09:42:23 +00:00
|
|
|
|
2007-11-26 14:43:28 +00:00
|
|
|
/**
|
|
|
|
* Get calendar events
|
2012-01-13 17:45:55 +08:00
|
|
|
*
|
2007-11-26 14:43:28 +00:00
|
|
|
* @param int $tstart Start time of time range for events
|
2012-01-13 17:45:55 +08:00
|
|
|
* @param int $tend End time of time range for events
|
|
|
|
* @param array|int|boolean $users array of users, user id or boolean for all/no user events
|
|
|
|
* @param array|int|boolean $groups array of groups, group id or boolean for all/no group events
|
|
|
|
* @param array|int|boolean $courses array of courses, course id or boolean for all/no course events
|
2007-11-26 14:43:28 +00:00
|
|
|
* @param boolean $withduration whether only events starting within time range selected
|
|
|
|
* or events in progress/already started selected as well
|
|
|
|
* @param boolean $ignorehidden whether to select only visible events or all events
|
2012-01-13 17:45:55 +08:00
|
|
|
* @return array $events of selected events or an empty array if there aren't any (or there was an error)
|
2007-11-26 14:43:28 +00:00
|
|
|
*/
|
|
|
|
function calendar_get_events($tstart, $tend, $users, $groups, $courses, $withduration=true, $ignorehidden=true) {
|
2008-06-01 14:25:05 +00:00
|
|
|
global $DB;
|
|
|
|
|
2004-03-29 15:28:15 +00:00
|
|
|
$whereclause = '';
|
|
|
|
// Quick test
|
|
|
|
if(is_bool($users) && is_bool($groups) && is_bool($courses)) {
|
2007-11-26 14:43:28 +00:00
|
|
|
return array();
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
2004-11-19 02:47:00 +00:00
|
|
|
|
2004-03-29 15:28:15 +00:00
|
|
|
if(is_array($users) && !empty($users)) {
|
|
|
|
// Events from a number of users
|
|
|
|
if(!empty($whereclause)) $whereclause .= ' OR';
|
2005-04-11 23:21:29 +00:00
|
|
|
$whereclause .= ' (userid IN ('.implode(',', $users).') AND courseid = 0 AND groupid = 0)';
|
2010-06-22 04:03:44 +00:00
|
|
|
} else if(is_numeric($users)) {
|
2004-03-29 15:28:15 +00:00
|
|
|
// Events from one user
|
|
|
|
if(!empty($whereclause)) $whereclause .= ' OR';
|
2005-04-11 23:21:29 +00:00
|
|
|
$whereclause .= ' (userid = '.$users.' AND courseid = 0 AND groupid = 0)';
|
2010-06-22 04:03:44 +00:00
|
|
|
} else if($users === true) {
|
2004-03-29 15:28:15 +00:00
|
|
|
// Events from ALL users
|
|
|
|
if(!empty($whereclause)) $whereclause .= ' OR';
|
2005-04-11 23:21:29 +00:00
|
|
|
$whereclause .= ' (userid != 0 AND courseid = 0 AND groupid = 0)';
|
2010-06-22 04:03:44 +00:00
|
|
|
} else if($users === false) {
|
2005-04-11 23:21:29 +00:00
|
|
|
// No user at all, do nothing
|
2004-06-01 14:12:26 +00:00
|
|
|
}
|
2004-11-19 02:47:00 +00:00
|
|
|
|
2004-03-29 15:28:15 +00:00
|
|
|
if(is_array($groups) && !empty($groups)) {
|
|
|
|
// Events from a number of groups
|
|
|
|
if(!empty($whereclause)) $whereclause .= ' OR';
|
|
|
|
$whereclause .= ' groupid IN ('.implode(',', $groups).')';
|
2010-06-22 04:03:44 +00:00
|
|
|
} else if(is_numeric($groups)) {
|
2004-03-29 15:28:15 +00:00
|
|
|
// Events from one group
|
|
|
|
if(!empty($whereclause)) $whereclause .= ' OR ';
|
|
|
|
$whereclause .= ' groupid = '.$groups;
|
2010-06-22 04:03:44 +00:00
|
|
|
} else if($groups === true) {
|
2004-03-29 15:28:15 +00:00
|
|
|
// Events from ALL groups
|
|
|
|
if(!empty($whereclause)) $whereclause .= ' OR ';
|
|
|
|
$whereclause .= ' groupid != 0';
|
|
|
|
}
|
2004-11-19 02:47:00 +00:00
|
|
|
// boolean false (no groups at all): we don't need to do anything
|
|
|
|
|
2010-06-22 04:03:44 +00:00
|
|
|
if(is_array($courses) && !empty($courses)) {
|
|
|
|
if(!empty($whereclause)) {
|
|
|
|
$whereclause .= ' OR';
|
2004-06-01 14:12:26 +00:00
|
|
|
}
|
2010-06-22 04:03:44 +00:00
|
|
|
$whereclause .= ' (groupid = 0 AND courseid IN ('.implode(',', $courses).'))';
|
|
|
|
} else if(is_numeric($courses)) {
|
2004-03-29 15:28:15 +00:00
|
|
|
// One course
|
|
|
|
if(!empty($whereclause)) $whereclause .= ' OR';
|
2005-04-11 23:21:29 +00:00
|
|
|
$whereclause .= ' (groupid = 0 AND courseid = '.$courses.')';
|
2010-06-22 04:03:44 +00:00
|
|
|
} else if ($courses === true) {
|
2004-03-29 15:28:15 +00:00
|
|
|
// Events from ALL courses
|
|
|
|
if(!empty($whereclause)) $whereclause .= ' OR';
|
2005-04-11 23:21:29 +00:00
|
|
|
$whereclause .= ' (groupid = 0 AND courseid != 0)';
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
2004-05-24 01:44:48 +00:00
|
|
|
|
2004-11-19 02:47:00 +00:00
|
|
|
// Security check: if, by now, we have NOTHING in $whereclause, then it means
|
|
|
|
// that NO event-selecting clauses were defined. Thus, we won't be returning ANY
|
|
|
|
// events no matter what. Allowing the code to proceed might return a completely
|
|
|
|
// valid query with only time constraints, thus selecting ALL events in that time frame!
|
|
|
|
if(empty($whereclause)) {
|
2007-11-26 14:43:28 +00:00
|
|
|
return array();
|
2004-11-19 02:47:00 +00:00
|
|
|
}
|
|
|
|
|
2004-03-29 15:28:15 +00:00
|
|
|
if($withduration) {
|
2007-06-12 16:26:38 +00:00
|
|
|
$timeclause = '(timestart >= '.$tstart.' OR timestart + timeduration > '.$tstart.') AND timestart <= '.$tend;
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
$timeclause = 'timestart >= '.$tstart.' AND timestart <= '.$tend;
|
|
|
|
}
|
|
|
|
if(!empty($whereclause)) {
|
|
|
|
// We have additional constraints
|
|
|
|
$whereclause = $timeclause.' AND ('.$whereclause.')';
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
// Just basic time filtering
|
|
|
|
$whereclause = $timeclause;
|
|
|
|
}
|
2004-06-01 14:12:26 +00:00
|
|
|
|
2005-04-11 23:24:23 +00:00
|
|
|
if ($ignorehidden) {
|
|
|
|
$whereclause .= ' AND visible = 1';
|
|
|
|
}
|
|
|
|
|
2008-06-01 14:25:05 +00:00
|
|
|
$events = $DB->get_records_select('event', $whereclause, null, 'timestart');
|
2007-11-26 14:43:28 +00:00
|
|
|
if ($events === false) {
|
|
|
|
$events = array();
|
|
|
|
}
|
|
|
|
return $events;
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
|
|
|
|
2012-12-13 15:57:46 +08:00
|
|
|
/** Get calendar events by id
|
|
|
|
*
|
|
|
|
* @since Moodle 2.5
|
|
|
|
* @param array $eventids list of event ids
|
|
|
|
* @return array Array of event entries, empty array if nothing found
|
|
|
|
*/
|
|
|
|
|
|
|
|
function calendar_get_events_by_id($eventids) {
|
|
|
|
global $DB;
|
|
|
|
|
|
|
|
if (!is_array($eventids) || empty($eventids)) {
|
|
|
|
return array();
|
|
|
|
}
|
|
|
|
list($wheresql, $params) = $DB->get_in_or_equal($eventids);
|
|
|
|
$wheresql = "id $wheresql";
|
|
|
|
|
|
|
|
return $DB->get_records_select('event', $wheresql, $params);
|
|
|
|
}
|
|
|
|
|
2012-01-13 17:45:55 +08:00
|
|
|
/**
|
|
|
|
* Get control options for Calendar
|
|
|
|
*
|
|
|
|
* @param string $type of calendar
|
|
|
|
* @param array $data calendar information
|
|
|
|
* @return string $content return available control for the calender in html
|
|
|
|
*/
|
2004-03-29 15:28:15 +00:00
|
|
|
function calendar_top_controls($type, $data) {
|
2014-09-10 14:08:50 +12:00
|
|
|
global $PAGE, $OUTPUT;
|
2013-09-16 17:30:59 +08:00
|
|
|
|
|
|
|
// Get the calendar type we are using.
|
|
|
|
$calendartype = \core_calendar\type_factory::get_calendar_instance();
|
|
|
|
|
2004-03-29 15:28:15 +00:00
|
|
|
$content = '';
|
2005-02-18 01:11:10 +00:00
|
|
|
|
2013-09-16 17:30:59 +08:00
|
|
|
// Ensure course id passed if relevant.
|
2007-06-21 15:46:04 +00:00
|
|
|
$courseid = '';
|
|
|
|
if (!empty($data['id'])) {
|
|
|
|
$courseid = '&course='.$data['id'];
|
|
|
|
}
|
|
|
|
|
2013-09-16 17:30:59 +08:00
|
|
|
// If we are passing a month and year then we need to convert this to a timestamp to
|
|
|
|
// support multiple calendars. No where in core should these be passed, this logic
|
|
|
|
// here is for third party plugins that may use this function.
|
|
|
|
if (!empty($data['m']) && !empty($date['y'])) {
|
|
|
|
if (!isset($data['d'])) {
|
|
|
|
$data['d'] = 1;
|
|
|
|
}
|
|
|
|
if (!checkdate($data['m'], $data['d'], $data['y'])) {
|
|
|
|
$time = time();
|
|
|
|
} else {
|
|
|
|
$time = make_timestamp($data['y'], $data['m'], $data['d']);
|
|
|
|
}
|
|
|
|
} else if (!empty($data['time'])) {
|
|
|
|
$time = $data['time'];
|
|
|
|
} else {
|
2005-02-18 01:11:10 +00:00
|
|
|
$time = time();
|
|
|
|
}
|
2007-08-17 11:18:58 +00:00
|
|
|
|
2013-09-16 17:30:59 +08:00
|
|
|
// Get the date for the calendar type.
|
|
|
|
$date = $calendartype->timestamp_to_date_array($time);
|
|
|
|
|
2013-01-30 08:59:11 +08:00
|
|
|
$urlbase = $PAGE->url;
|
2004-03-29 15:28:15 +00:00
|
|
|
|
2013-09-16 17:30:59 +08:00
|
|
|
// We need to get the previous and next months in certain cases.
|
|
|
|
if ($type == 'frontpage' || $type == 'course' || $type == 'month') {
|
|
|
|
$prevmonth = calendar_sub_month($date['mon'], $date['year']);
|
2013-10-09 16:39:53 +08:00
|
|
|
$prevmonthtime = $calendartype->convert_to_gregorian($prevmonth[1], $prevmonth[0], 1);
|
|
|
|
$prevmonthtime = make_timestamp($prevmonthtime['year'], $prevmonthtime['month'], $prevmonthtime['day'],
|
|
|
|
$prevmonthtime['hour'], $prevmonthtime['minute']);
|
2013-09-16 17:30:59 +08:00
|
|
|
|
|
|
|
$nextmonth = calendar_add_month($date['mon'], $date['year']);
|
2013-10-09 16:39:53 +08:00
|
|
|
$nextmonthtime = $calendartype->convert_to_gregorian($nextmonth[1], $nextmonth[0], 1);
|
|
|
|
$nextmonthtime = make_timestamp($nextmonthtime['year'], $nextmonthtime['month'], $nextmonthtime['day'],
|
|
|
|
$nextmonthtime['hour'], $nextmonthtime['minute']);
|
2013-09-16 17:30:59 +08:00
|
|
|
}
|
2006-03-08 17:27:56 +00:00
|
|
|
|
2013-09-16 17:30:59 +08:00
|
|
|
switch ($type) {
|
2004-03-29 15:28:15 +00:00
|
|
|
case 'frontpage':
|
2013-09-16 17:30:59 +08:00
|
|
|
$prevlink = calendar_get_link_previous(get_string('monthprev', 'access'), $urlbase, false, false, false, true, $prevmonthtime);
|
|
|
|
$nextlink = calendar_get_link_next(get_string('monthnext', 'access'), $urlbase, false, false, false, true, $nextmonthtime);
|
|
|
|
$calendarlink = calendar_get_link_href(new moodle_url(CALENDAR_URL.'view.php', array('view' => 'month')), false, false, false, $time);
|
2010-08-02 12:49:08 +00:00
|
|
|
|
2010-09-20 07:00:18 +00:00
|
|
|
if (!empty($data['id'])) {
|
|
|
|
$calendarlink->param('course', $data['id']);
|
|
|
|
}
|
|
|
|
|
2010-07-13 09:01:58 +00:00
|
|
|
if (right_to_left()) {
|
2010-09-20 07:00:18 +00:00
|
|
|
$left = $nextlink;
|
|
|
|
$right = $prevlink;
|
2010-07-13 09:01:58 +00:00
|
|
|
} else {
|
2010-09-20 07:00:18 +00:00
|
|
|
$left = $prevlink;
|
|
|
|
$right = $nextlink;
|
2010-07-13 09:01:58 +00:00
|
|
|
}
|
2010-08-02 12:49:08 +00:00
|
|
|
|
2010-09-20 07:00:18 +00:00
|
|
|
$content .= html_writer::start_tag('div', array('class'=>'calendar-controls'));
|
|
|
|
$content .= $left.'<span class="hide"> | </span>';
|
2010-09-20 07:30:35 +00:00
|
|
|
$content .= html_writer::tag('span', html_writer::link($calendarlink, userdate($time, get_string('strftimemonthyear')), array('title'=>get_string('monththis','calendar'))), array('class'=>'current'));
|
2010-09-20 07:00:18 +00:00
|
|
|
$content .= '<span class="hide"> | </span>'. $right;
|
2010-09-23 05:50:15 +00:00
|
|
|
$content .= "<span class=\"clearer\"><!-- --></span>\n";
|
2010-09-20 07:00:18 +00:00
|
|
|
$content .= html_writer::end_tag('div');
|
|
|
|
|
|
|
|
break;
|
2004-03-29 15:28:15 +00:00
|
|
|
case 'course':
|
2013-09-16 17:30:59 +08:00
|
|
|
$prevlink = calendar_get_link_previous(get_string('monthprev', 'access'), $urlbase, false, false, false, true, $prevmonthtime);
|
|
|
|
$nextlink = calendar_get_link_next(get_string('monthnext', 'access'), $urlbase, false, false, false, true, $nextmonthtime);
|
|
|
|
$calendarlink = calendar_get_link_href(new moodle_url(CALENDAR_URL.'view.php', array('view' => 'month')), false, false, false, $time);
|
2010-09-20 07:00:18 +00:00
|
|
|
|
|
|
|
if (!empty($data['id'])) {
|
|
|
|
$calendarlink->param('course', $data['id']);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (right_to_left()) {
|
|
|
|
$left = $nextlink;
|
|
|
|
$right = $prevlink;
|
|
|
|
} else {
|
|
|
|
$left = $prevlink;
|
|
|
|
$right = $nextlink;
|
|
|
|
}
|
|
|
|
|
|
|
|
$content .= html_writer::start_tag('div', array('class'=>'calendar-controls'));
|
|
|
|
$content .= $left.'<span class="hide"> | </span>';
|
2010-09-20 07:30:35 +00:00
|
|
|
$content .= html_writer::tag('span', html_writer::link($calendarlink, userdate($time, get_string('strftimemonthyear')), array('title'=>get_string('monththis','calendar'))), array('class'=>'current'));
|
2010-09-20 07:00:18 +00:00
|
|
|
$content .= '<span class="hide"> | </span>'. $right;
|
|
|
|
$content .= "<span class=\"clearer\"><!-- --></span>";
|
|
|
|
$content .= html_writer::end_tag('div');
|
|
|
|
break;
|
2004-03-29 15:28:15 +00:00
|
|
|
case 'upcoming':
|
2013-09-16 17:30:59 +08:00
|
|
|
$calendarlink = calendar_get_link_href(new moodle_url(CALENDAR_URL.'view.php', array('view' => 'upcoming')), false, false, false, $time);
|
2010-09-20 07:00:18 +00:00
|
|
|
if (!empty($data['id'])) {
|
|
|
|
$calendarlink->param('course', $data['id']);
|
|
|
|
}
|
|
|
|
$calendarlink = html_writer::link($calendarlink, userdate($time, get_string('strftimemonthyear')));
|
|
|
|
$content .= html_writer::tag('div', $calendarlink, array('class'=>'centered'));
|
|
|
|
break;
|
2004-03-29 15:28:15 +00:00
|
|
|
case 'display':
|
2013-09-16 17:30:59 +08:00
|
|
|
$calendarlink = calendar_get_link_href(new moodle_url(CALENDAR_URL.'view.php', array('view' => 'month')), false, false, false, $time);
|
2010-09-20 07:00:18 +00:00
|
|
|
if (!empty($data['id'])) {
|
|
|
|
$calendarlink->param('course', $data['id']);
|
|
|
|
}
|
|
|
|
$calendarlink = html_writer::link($calendarlink, userdate($time, get_string('strftimemonthyear')));
|
|
|
|
$content .= html_writer::tag('h3', $calendarlink);
|
|
|
|
break;
|
2004-03-29 15:28:15 +00:00
|
|
|
case 'month':
|
2013-09-16 17:30:59 +08:00
|
|
|
$prevlink = calendar_get_link_previous(userdate($prevmonthtime, get_string('strftimemonthyear')), 'view.php?view=month'.$courseid.'&', false, false, false, false, $prevmonthtime);
|
|
|
|
$nextlink = calendar_get_link_next(userdate($nextmonthtime, get_string('strftimemonthyear')), 'view.php?view=month'.$courseid.'&', false, false, false, false, $nextmonthtime);
|
2010-09-20 07:00:18 +00:00
|
|
|
|
|
|
|
if (right_to_left()) {
|
|
|
|
$left = $nextlink;
|
|
|
|
$right = $prevlink;
|
|
|
|
} else {
|
|
|
|
$left = $prevlink;
|
|
|
|
$right = $nextlink;
|
|
|
|
}
|
|
|
|
|
|
|
|
$content .= html_writer::start_tag('div', array('class'=>'calendar-controls'));
|
2014-09-10 14:08:50 +12:00
|
|
|
$content .= $left . '<span class="hide"> | </span>';
|
|
|
|
$content .= $OUTPUT->heading(userdate($time, get_string('strftimemonthyear')), 2, 'current');
|
2010-09-20 07:00:18 +00:00
|
|
|
$content .= '<span class="hide"> | </span>' . $right;
|
|
|
|
$content .= '<span class="clearer"><!-- --></span>';
|
|
|
|
$content .= html_writer::end_tag('div')."\n";
|
|
|
|
break;
|
2004-03-29 15:28:15 +00:00
|
|
|
case 'day':
|
2011-06-29 14:50:38 +08:00
|
|
|
$days = calendar_get_days();
|
2013-09-16 17:30:59 +08:00
|
|
|
|
|
|
|
$prevtimestamp = $time - DAYSECS;
|
|
|
|
$nexttimestamp = $time + DAYSECS;
|
|
|
|
|
|
|
|
$prevdate = $calendartype->timestamp_to_date_array($prevtimestamp);
|
|
|
|
$nextdate = $calendartype->timestamp_to_date_array($nexttimestamp);
|
|
|
|
|
|
|
|
$prevname = $days[$prevdate['wday']]['fullname'];
|
|
|
|
$nextname = $days[$nextdate['wday']]['fullname'];
|
|
|
|
$prevlink = calendar_get_link_previous($prevname, 'view.php?view=day'.$courseid.'&', false, false, false, false, $prevtimestamp);
|
|
|
|
$nextlink = calendar_get_link_next($nextname, 'view.php?view=day'.$courseid.'&', false, false, false, false, $nexttimestamp);
|
2010-09-20 07:00:18 +00:00
|
|
|
|
|
|
|
if (right_to_left()) {
|
|
|
|
$left = $nextlink;
|
|
|
|
$right = $prevlink;
|
|
|
|
} else {
|
|
|
|
$left = $prevlink;
|
|
|
|
$right = $nextlink;
|
|
|
|
}
|
|
|
|
|
|
|
|
$content .= html_writer::start_tag('div', array('class'=>'calendar-controls'));
|
|
|
|
$content .= $left;
|
|
|
|
$content .= '<span class="hide"> | </span><span class="current">'.userdate($time, get_string('strftimedaydate')).'</span>';
|
|
|
|
$content .= '<span class="hide"> | </span>'. $right;
|
|
|
|
$content .= "<span class=\"clearer\"><!-- --></span>";
|
|
|
|
$content .= html_writer::end_tag('div')."\n";
|
|
|
|
|
|
|
|
break;
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
|
|
|
return $content;
|
|
|
|
}
|
|
|
|
|
2012-09-05 19:15:31 +08:00
|
|
|
/**
|
|
|
|
* Formats a filter control element.
|
|
|
|
*
|
|
|
|
* @param moodle_url $url of the filter
|
|
|
|
* @param int $type constant defining the type filter
|
|
|
|
* @return string html content of the element
|
|
|
|
*/
|
|
|
|
function calendar_filter_controls_element(moodle_url $url, $type) {
|
|
|
|
global $OUTPUT;
|
|
|
|
switch ($type) {
|
|
|
|
case CALENDAR_EVENT_GLOBAL:
|
|
|
|
$typeforhumans = 'global';
|
|
|
|
$class = 'calendar_event_global';
|
|
|
|
break;
|
|
|
|
case CALENDAR_EVENT_COURSE:
|
|
|
|
$typeforhumans = 'course';
|
|
|
|
$class = 'calendar_event_course';
|
|
|
|
break;
|
|
|
|
case CALENDAR_EVENT_GROUP:
|
|
|
|
$typeforhumans = 'groups';
|
|
|
|
$class = 'calendar_event_group';
|
|
|
|
break;
|
|
|
|
case CALENDAR_EVENT_USER:
|
|
|
|
$typeforhumans = 'user';
|
|
|
|
$class = 'calendar_event_user';
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
if (calendar_show_event_type($type)) {
|
|
|
|
$icon = $OUTPUT->pix_icon('t/hide', get_string('hide'));
|
|
|
|
$str = get_string('hide'.$typeforhumans.'events', 'calendar');
|
|
|
|
} else {
|
|
|
|
$icon = $OUTPUT->pix_icon('t/show', get_string('show'));
|
|
|
|
$str = get_string('show'.$typeforhumans.'events', 'calendar');
|
|
|
|
}
|
|
|
|
$content = html_writer::start_tag('li', array('class' => 'calendar_event'));
|
|
|
|
$content .= html_writer::start_tag('a', array('href' => $url));
|
|
|
|
$content .= html_writer::tag('span', $icon, array('class' => $class));
|
|
|
|
$content .= html_writer::tag('span', $str, array('class' => 'eventname'));
|
|
|
|
$content .= html_writer::end_tag('a');
|
|
|
|
$content .= html_writer::end_tag('li');
|
|
|
|
return $content;
|
|
|
|
}
|
|
|
|
|
2012-01-13 17:45:55 +08:00
|
|
|
/**
|
|
|
|
* Get the controls filter for calendar.
|
|
|
|
*
|
|
|
|
* Filter is used to hide calendar info from the display page
|
|
|
|
*
|
|
|
|
* @param moodle_url $returnurl return-url for filter controls
|
|
|
|
* @return string $content return filter controls in html
|
|
|
|
*/
|
2011-06-29 14:50:38 +08:00
|
|
|
function calendar_filter_controls(moodle_url $returnurl) {
|
|
|
|
global $CFG, $USER, $OUTPUT;
|
2004-03-29 15:28:15 +00:00
|
|
|
|
2004-04-20 08:24:37 +00:00
|
|
|
$groupevents = true;
|
2005-06-15 14:58:17 +00:00
|
|
|
$id = optional_param( 'id',0,PARAM_INT );
|
2014-07-03 14:30:36 +01:00
|
|
|
$seturl = new moodle_url('/calendar/set.php', array('return' => base64_encode($returnurl->out_as_local_url(false)), 'sesskey'=>sesskey()));
|
2012-09-05 19:15:31 +08:00
|
|
|
$content = html_writer::start_tag('ul');
|
2011-06-29 14:50:38 +08:00
|
|
|
|
|
|
|
$seturl->param('var', 'showglobal');
|
2012-09-05 19:15:31 +08:00
|
|
|
$content .= calendar_filter_controls_element($seturl, CALENDAR_EVENT_GLOBAL);
|
2009-11-04 08:11:02 +00:00
|
|
|
|
2011-06-29 14:50:38 +08:00
|
|
|
$seturl->param('var', 'showcourses');
|
2012-09-05 19:15:31 +08:00
|
|
|
$content .= calendar_filter_controls_element($seturl, CALENDAR_EVENT_COURSE);
|
2004-04-20 08:24:37 +00:00
|
|
|
|
2010-03-31 07:41:31 +00:00
|
|
|
if (isloggedin() && !isguestuser()) {
|
2011-06-29 14:50:38 +08:00
|
|
|
if ($groupevents) {
|
2004-05-20 15:16:42 +00:00
|
|
|
// This course MIGHT have group events defined, so show the filter
|
2011-06-29 14:50:38 +08:00
|
|
|
$seturl->param('var', 'showgroups');
|
2012-09-05 19:15:31 +08:00
|
|
|
$content .= calendar_filter_controls_element($seturl, CALENDAR_EVENT_GROUP);
|
2007-10-09 04:02:43 +00:00
|
|
|
} else {
|
2004-05-20 15:16:42 +00:00
|
|
|
// This course CANNOT have group events, so lose the filter
|
2007-11-08 15:16:16 +00:00
|
|
|
}
|
2011-06-29 14:50:38 +08:00
|
|
|
$seturl->param('var', 'showuser');
|
2012-09-05 19:15:31 +08:00
|
|
|
$content .= calendar_filter_controls_element($seturl, CALENDAR_EVENT_USER);
|
2004-04-20 08:24:37 +00:00
|
|
|
}
|
2012-09-05 19:15:31 +08:00
|
|
|
$content .= html_writer::end_tag('ul');
|
2004-04-20 08:24:37 +00:00
|
|
|
|
2004-03-29 15:28:15 +00:00
|
|
|
return $content;
|
|
|
|
}
|
|
|
|
|
2012-01-13 17:45:55 +08:00
|
|
|
/**
|
|
|
|
* Return the representation day
|
|
|
|
*
|
|
|
|
* @param int $tstamp Timestamp in GMT
|
|
|
|
* @param int $now current Unix timestamp
|
|
|
|
* @param bool $usecommonwords
|
|
|
|
* @return string the formatted date/time
|
|
|
|
*/
|
2004-03-29 15:28:15 +00:00
|
|
|
function calendar_day_representation($tstamp, $now = false, $usecommonwords = true) {
|
|
|
|
|
2004-04-29 07:50:12 +00:00
|
|
|
static $shortformat;
|
|
|
|
if(empty($shortformat)) {
|
2004-05-03 15:26:55 +00:00
|
|
|
$shortformat = get_string('strftimedayshort');
|
2004-04-29 07:50:12 +00:00
|
|
|
}
|
|
|
|
|
2004-03-29 15:28:15 +00:00
|
|
|
if($now === false) {
|
|
|
|
$now = time();
|
|
|
|
}
|
|
|
|
|
|
|
|
// To have it in one place, if a change is needed
|
2004-05-03 15:26:55 +00:00
|
|
|
$formal = userdate($tstamp, $shortformat);
|
2004-03-29 15:28:15 +00:00
|
|
|
|
2004-06-02 11:21:14 +00:00
|
|
|
$datestamp = usergetdate($tstamp);
|
|
|
|
$datenow = usergetdate($now);
|
2004-03-29 15:28:15 +00:00
|
|
|
|
|
|
|
if($usecommonwords == false) {
|
|
|
|
// We don't want words, just a date
|
|
|
|
return $formal;
|
|
|
|
}
|
2004-06-02 11:21:14 +00:00
|
|
|
else if($datestamp['year'] == $datenow['year'] && $datestamp['yday'] == $datenow['yday']) {
|
2004-03-29 15:28:15 +00:00
|
|
|
// Today
|
|
|
|
return get_string('today', 'calendar');
|
|
|
|
}
|
2004-06-02 11:21:14 +00:00
|
|
|
else if(
|
|
|
|
($datestamp['year'] == $datenow['year'] && $datestamp['yday'] == $datenow['yday'] - 1 ) ||
|
|
|
|
($datestamp['year'] == $datenow['year'] - 1 && $datestamp['mday'] == 31 && $datestamp['mon'] == 12 && $datenow['yday'] == 1)
|
|
|
|
) {
|
2004-03-29 15:28:15 +00:00
|
|
|
// Yesterday
|
|
|
|
return get_string('yesterday', 'calendar');
|
|
|
|
}
|
2004-06-02 11:21:14 +00:00
|
|
|
else if(
|
|
|
|
($datestamp['year'] == $datenow['year'] && $datestamp['yday'] == $datenow['yday'] + 1 ) ||
|
|
|
|
($datestamp['year'] == $datenow['year'] + 1 && $datenow['mday'] == 31 && $datenow['mon'] == 12 && $datestamp['yday'] == 1)
|
|
|
|
) {
|
2004-03-29 15:28:15 +00:00
|
|
|
// Tomorrow
|
|
|
|
return get_string('tomorrow', 'calendar');
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
return $formal;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-01-13 17:45:55 +08:00
|
|
|
/**
|
|
|
|
* return the formatted representation time
|
|
|
|
*
|
|
|
|
* @param int $time the timestamp in UTC, as obtained from the database
|
|
|
|
* @return string the formatted date/time
|
|
|
|
*/
|
2004-03-29 15:28:15 +00:00
|
|
|
function calendar_time_representation($time) {
|
2004-04-22 09:02:23 +00:00
|
|
|
static $langtimeformat = NULL;
|
|
|
|
if($langtimeformat === NULL) {
|
|
|
|
$langtimeformat = get_string('strftimetime');
|
|
|
|
}
|
|
|
|
$timeformat = get_user_preferences('calendar_timeformat');
|
2007-02-27 01:19:46 +00:00
|
|
|
if(empty($timeformat)){
|
|
|
|
$timeformat = get_config(NULL,'calendar_site_timeformat');
|
|
|
|
}
|
2004-04-22 09:02:23 +00:00
|
|
|
// The ? is needed because the preference might be present, but empty
|
|
|
|
return userdate($time, empty($timeformat) ? $langtimeformat : $timeformat);
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
|
|
|
|
2007-08-17 11:18:58 +00:00
|
|
|
/**
|
2010-09-20 07:04:46 +00:00
|
|
|
* Adds day, month, year arguments to a URL and returns a moodle_url object.
|
|
|
|
*
|
|
|
|
* @param string|moodle_url $linkbase
|
2012-01-13 17:45:55 +08:00
|
|
|
* @param int $d The number of the day.
|
|
|
|
* @param int $m The number of the month.
|
|
|
|
* @param int $y The number of the year.
|
2013-09-16 17:30:59 +08:00
|
|
|
* @param int $time the unixtime, used for multiple calendar support. The values $d,
|
|
|
|
* $m and $y are kept for backwards compatibility.
|
2012-01-13 17:45:55 +08:00
|
|
|
* @return moodle_url|null $linkbase
|
2007-08-17 11:18:58 +00:00
|
|
|
*/
|
2013-09-16 17:30:59 +08:00
|
|
|
function calendar_get_link_href($linkbase, $d, $m, $y, $time = 0) {
|
2010-09-20 07:00:18 +00:00
|
|
|
if (empty($linkbase)) {
|
|
|
|
return '';
|
|
|
|
}
|
|
|
|
if (!($linkbase instanceof moodle_url)) {
|
2012-10-15 16:31:12 +08:00
|
|
|
$linkbase = new moodle_url($linkbase);
|
2010-09-20 07:00:18 +00:00
|
|
|
}
|
2013-09-16 17:30:59 +08:00
|
|
|
|
|
|
|
// If a day, month and year were passed then convert it to a timestamp. If these were passed
|
|
|
|
// then we can assume the day, month and year are passed as Gregorian, as no where in core
|
|
|
|
// should we be passing these values rather than the time.
|
|
|
|
if (!empty($d) && !empty($m) && !empty($y)) {
|
|
|
|
if (checkdate($m, $d, $y)) {
|
|
|
|
$time = make_timestamp($y, $m, $d);
|
|
|
|
} else {
|
|
|
|
$time = time();
|
|
|
|
}
|
|
|
|
} else if (empty($time)) {
|
|
|
|
$time = time();
|
2010-09-20 07:00:18 +00:00
|
|
|
}
|
2013-09-16 17:30:59 +08:00
|
|
|
|
|
|
|
$linkbase->param('time', $time);
|
|
|
|
|
2010-09-20 07:00:18 +00:00
|
|
|
return $linkbase;
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
|
|
|
|
2007-05-14 13:28:21 +00:00
|
|
|
/**
|
|
|
|
* Build and return a previous month HTML link, with an arrow.
|
2010-09-20 07:04:46 +00:00
|
|
|
*
|
2007-05-14 13:28:21 +00:00
|
|
|
* @param string $text The text label.
|
2010-09-20 07:04:46 +00:00
|
|
|
* @param string|moodle_url $linkbase The URL stub.
|
2012-01-13 17:45:55 +08:00
|
|
|
* @param int $d The number of the date.
|
|
|
|
* @param int $m The number of the month.
|
|
|
|
* @param int $y year The number of the year.
|
2007-05-14 13:28:21 +00:00
|
|
|
* @param bool $accesshide Default visible, or hide from all except screenreaders.
|
2013-09-16 17:30:59 +08:00
|
|
|
* @param int $time the unixtime, used for multiple calendar support. The values $d,
|
|
|
|
* $m and $y are kept for backwards compatibility.
|
2007-05-14 13:28:21 +00:00
|
|
|
* @return string HTML string.
|
|
|
|
*/
|
2013-09-16 17:30:59 +08:00
|
|
|
function calendar_get_link_previous($text, $linkbase, $d, $m, $y, $accesshide = false, $time = 0) {
|
|
|
|
$href = calendar_get_link_href(new moodle_url($linkbase), $d, $m, $y, $time);
|
2010-09-20 07:00:18 +00:00
|
|
|
if (empty($href)) {
|
|
|
|
return $text;
|
|
|
|
}
|
|
|
|
return link_arrow_left($text, (string)$href, $accesshide, 'previous');
|
2007-05-14 13:28:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Build and return a next month HTML link, with an arrow.
|
2010-11-17 07:56:40 +00:00
|
|
|
*
|
2007-05-14 13:28:21 +00:00
|
|
|
* @param string $text The text label.
|
2010-09-20 07:04:46 +00:00
|
|
|
* @param string|moodle_url $linkbase The URL stub.
|
2012-01-13 17:45:55 +08:00
|
|
|
* @param int $d the number of the Day
|
|
|
|
* @param int $m The number of the month.
|
|
|
|
* @param int $y The number of the year.
|
2007-05-14 13:28:21 +00:00
|
|
|
* @param bool $accesshide Default visible, or hide from all except screenreaders.
|
2013-09-16 17:30:59 +08:00
|
|
|
* @param int $time the unixtime, used for multiple calendar support. The values $d,
|
|
|
|
* $m and $y are kept for backwards compatibility.
|
2007-05-14 13:28:21 +00:00
|
|
|
* @return string HTML string.
|
|
|
|
*/
|
2013-09-16 17:30:59 +08:00
|
|
|
function calendar_get_link_next($text, $linkbase, $d, $m, $y, $accesshide = false, $time = 0) {
|
|
|
|
$href = calendar_get_link_href(new moodle_url($linkbase), $d, $m, $y, $time);
|
2010-09-20 07:00:18 +00:00
|
|
|
if (empty($href)) {
|
|
|
|
return $text;
|
|
|
|
}
|
|
|
|
return link_arrow_right($text, (string)$href, $accesshide, 'next');
|
2007-05-14 13:28:21 +00:00
|
|
|
}
|
|
|
|
|
2012-01-13 17:45:55 +08:00
|
|
|
/**
|
|
|
|
* Return the name of the weekday
|
|
|
|
*
|
|
|
|
* @param string $englishname
|
|
|
|
* @return string of the weekeday
|
|
|
|
*/
|
2004-03-29 15:28:15 +00:00
|
|
|
function calendar_wday_name($englishname) {
|
|
|
|
return get_string(strtolower($englishname), 'calendar');
|
|
|
|
}
|
|
|
|
|
2012-01-13 17:45:55 +08:00
|
|
|
/**
|
|
|
|
* Return the number of days in month
|
|
|
|
*
|
|
|
|
* @param int $month the number of the month.
|
|
|
|
* @param int $year the number of the year
|
|
|
|
* @return int
|
|
|
|
*/
|
2004-03-29 15:28:15 +00:00
|
|
|
function calendar_days_in_month($month, $year) {
|
2013-09-16 17:30:59 +08:00
|
|
|
$calendartype = \core_calendar\type_factory::get_calendar_instance();
|
|
|
|
return $calendartype->get_num_days_in_month($year, $month);
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
|
|
|
|
2012-01-13 17:45:55 +08:00
|
|
|
/**
|
|
|
|
* Get the upcoming event block
|
|
|
|
*
|
|
|
|
* @param array $events list of events
|
|
|
|
* @param moodle_url|string $linkhref link to event referer
|
2013-08-01 21:05:02 +01:00
|
|
|
* @param boolean $showcourselink whether links to courses should be shown
|
2012-01-13 17:45:55 +08:00
|
|
|
* @return string|null $content html block content
|
|
|
|
*/
|
2013-08-01 21:05:02 +01:00
|
|
|
function calendar_get_block_upcoming($events, $linkhref = NULL, $showcourselink = false) {
|
2004-03-29 15:28:15 +00:00
|
|
|
$content = '';
|
|
|
|
$lines = count($events);
|
2004-05-01 17:42:32 +00:00
|
|
|
if (!$lines) {
|
|
|
|
return $content;
|
|
|
|
}
|
2004-03-29 15:28:15 +00:00
|
|
|
|
2004-05-01 17:42:32 +00:00
|
|
|
for ($i = 0; $i < $lines; ++$i) {
|
2005-02-22 10:37:54 +00:00
|
|
|
if (!isset($events[$i]->time)) { // Just for robustness
|
|
|
|
continue;
|
|
|
|
}
|
2005-02-12 09:42:23 +00:00
|
|
|
$events[$i] = calendar_add_event_metadata($events[$i]);
|
2012-11-23 14:45:29 +08:00
|
|
|
$content .= '<div class="event"><span class="icon c0">'.$events[$i]->icon.'</span>';
|
2004-05-20 15:16:42 +00:00
|
|
|
if (!empty($events[$i]->referer)) {
|
2004-03-29 15:28:15 +00:00
|
|
|
// That's an activity event, so let's provide the hyperlink
|
2004-05-01 17:42:32 +00:00
|
|
|
$content .= $events[$i]->referer;
|
|
|
|
} else {
|
2004-08-30 11:46:08 +00:00
|
|
|
if(!empty($linkhref)) {
|
2013-09-16 17:30:59 +08:00
|
|
|
$href = calendar_get_link_href(new moodle_url(CALENDAR_URL . $linkhref), 0, 0, 0, $events[$i]->timestart);
|
2010-09-20 07:00:18 +00:00
|
|
|
$href->set_anchor('event_'.$events[$i]->id);
|
|
|
|
$content .= html_writer::link($href, $events[$i]->name);
|
2004-08-30 11:46:08 +00:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
$content .= $events[$i]->name;
|
|
|
|
}
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
2005-02-11 05:27:19 +00:00
|
|
|
$events[$i]->time = str_replace('»', '<br />»', $events[$i]->time);
|
2013-08-01 21:05:02 +01:00
|
|
|
if ($showcourselink && !empty($events[$i]->courselink)) {
|
|
|
|
$content .= html_writer::div($events[$i]->courselink, 'course');
|
|
|
|
}
|
2005-02-11 05:27:19 +00:00
|
|
|
$content .= '<div class="date">'.$events[$i]->time.'</div></div>';
|
2004-05-01 17:42:32 +00:00
|
|
|
if ($i < $lines - 1) $content .= '<hr />';
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return $content;
|
|
|
|
}
|
|
|
|
|
2012-01-13 17:45:55 +08:00
|
|
|
/**
|
|
|
|
* Get the next following month
|
|
|
|
*
|
|
|
|
* @param int $month the number of the month.
|
|
|
|
* @param int $year the number of the year.
|
|
|
|
* @return array the following month
|
|
|
|
*/
|
2004-03-29 15:28:15 +00:00
|
|
|
function calendar_add_month($month, $year) {
|
2013-09-16 17:30:59 +08:00
|
|
|
// Get the calendar type we are using.
|
|
|
|
$calendartype = \core_calendar\type_factory::get_calendar_instance();
|
|
|
|
return $calendartype->get_next_month($year, $month);
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
|
|
|
|
2012-01-13 17:45:55 +08:00
|
|
|
/**
|
2013-09-16 17:30:59 +08:00
|
|
|
* Get the previous month.
|
2012-01-13 17:45:55 +08:00
|
|
|
*
|
|
|
|
* @param int $month the number of the month.
|
|
|
|
* @param int $year the number of the year.
|
|
|
|
* @return array previous month
|
|
|
|
*/
|
2004-03-29 15:28:15 +00:00
|
|
|
function calendar_sub_month($month, $year) {
|
2013-09-16 17:30:59 +08:00
|
|
|
// Get the calendar type we are using.
|
|
|
|
$calendartype = \core_calendar\type_factory::get_calendar_instance();
|
|
|
|
return $calendartype->get_prev_month($year, $month);
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
|
|
|
|
2012-01-13 17:45:55 +08:00
|
|
|
/**
|
|
|
|
* Get per-day basis events
|
|
|
|
*
|
|
|
|
* @param array $events list of events
|
|
|
|
* @param int $month the number of the month
|
|
|
|
* @param int $year the number of the year
|
|
|
|
* @param array $eventsbyday event on specific day
|
|
|
|
* @param array $durationbyday duration of the event in days
|
|
|
|
* @param array $typesbyday event type (eg: global, course, user, or group)
|
|
|
|
* @param array $courses list of courses
|
|
|
|
* @return void
|
|
|
|
*/
|
2007-06-13 10:00:30 +00:00
|
|
|
function calendar_events_by_day($events, $month, $year, &$eventsbyday, &$durationbyday, &$typesbyday, &$courses) {
|
2013-09-16 17:30:59 +08:00
|
|
|
// Get the calendar type we are using.
|
|
|
|
$calendartype = \core_calendar\type_factory::get_calendar_instance();
|
|
|
|
|
2004-03-29 15:28:15 +00:00
|
|
|
$eventsbyday = array();
|
|
|
|
$typesbyday = array();
|
|
|
|
$durationbyday = array();
|
|
|
|
|
|
|
|
if($events === false) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2013-09-16 17:30:59 +08:00
|
|
|
foreach ($events as $event) {
|
|
|
|
$startdate = $calendartype->timestamp_to_date_array($event->timestart);
|
2007-06-12 16:26:38 +00:00
|
|
|
// Set end date = start date if no duration
|
|
|
|
if ($event->timeduration) {
|
2013-09-16 17:30:59 +08:00
|
|
|
$enddate = $calendartype->timestamp_to_date_array($event->timestart + $event->timeduration - 1);
|
2007-06-12 16:26:38 +00:00
|
|
|
} else {
|
|
|
|
$enddate = $startdate;
|
|
|
|
}
|
2004-03-29 15:28:15 +00:00
|
|
|
|
2004-06-02 11:21:14 +00:00
|
|
|
// Simple arithmetic: $year * 13 + $month is a distinct integer for each distinct ($year, $month) pair
|
2004-07-09 13:39:34 +00:00
|
|
|
if(!($startdate['year'] * 13 + $startdate['mon'] <= $year * 13 + $month) && ($enddate['year'] * 13 + $enddate['mon'] >= $year * 13 + $month)) {
|
2004-06-02 11:21:14 +00:00
|
|
|
// Out of bounds
|
|
|
|
continue;
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
|
|
|
|
2004-06-02 11:21:14 +00:00
|
|
|
$eventdaystart = intval($startdate['mday']);
|
2004-03-29 15:28:15 +00:00
|
|
|
|
2004-06-02 11:21:14 +00:00
|
|
|
if($startdate['mon'] == $month && $startdate['year'] == $year) {
|
|
|
|
// Give the event to its day
|
|
|
|
$eventsbyday[$eventdaystart][] = $event->id;
|
2004-03-29 15:28:15 +00:00
|
|
|
|
2004-06-02 11:21:14 +00:00
|
|
|
// Mark the day as having such an event
|
2004-09-16 10:14:44 +00:00
|
|
|
if($event->courseid == SITEID && $event->groupid == 0) {
|
2004-06-02 11:21:14 +00:00
|
|
|
$typesbyday[$eventdaystart]['startglobal'] = true;
|
2007-06-12 16:26:38 +00:00
|
|
|
// Set event class for global event
|
2010-03-25 06:38:21 +00:00
|
|
|
$events[$event->id]->class = 'calendar_event_global';
|
2004-06-02 11:21:14 +00:00
|
|
|
}
|
2004-09-16 10:30:40 +00:00
|
|
|
else if($event->courseid != 0 && $event->courseid != SITEID && $event->groupid == 0) {
|
2004-06-02 11:21:14 +00:00
|
|
|
$typesbyday[$eventdaystart]['startcourse'] = true;
|
2007-06-12 16:26:38 +00:00
|
|
|
// Set event class for course event
|
2010-03-25 06:38:21 +00:00
|
|
|
$events[$event->id]->class = 'calendar_event_course';
|
2004-06-02 11:21:14 +00:00
|
|
|
}
|
|
|
|
else if($event->groupid) {
|
|
|
|
$typesbyday[$eventdaystart]['startgroup'] = true;
|
2007-06-12 16:26:38 +00:00
|
|
|
// Set event class for group event
|
2010-03-25 06:38:21 +00:00
|
|
|
$events[$event->id]->class = 'calendar_event_group';
|
2004-06-02 11:21:14 +00:00
|
|
|
}
|
|
|
|
else if($event->userid) {
|
|
|
|
$typesbyday[$eventdaystart]['startuser'] = true;
|
2007-06-12 16:26:38 +00:00
|
|
|
// Set event class for user event
|
2010-03-25 06:38:21 +00:00
|
|
|
$events[$event->id]->class = 'calendar_event_user';
|
2004-06-02 11:21:14 +00:00
|
|
|
}
|
|
|
|
}
|
2004-03-29 15:28:15 +00:00
|
|
|
|
2004-06-02 11:21:14 +00:00
|
|
|
if($event->timeduration == 0) {
|
|
|
|
// Proceed with the next
|
|
|
|
continue;
|
|
|
|
}
|
2004-03-29 15:28:15 +00:00
|
|
|
|
2004-06-02 11:21:14 +00:00
|
|
|
// The event starts on $month $year or before. So...
|
2004-07-09 13:39:34 +00:00
|
|
|
$lowerbound = $startdate['mon'] == $month && $startdate['year'] == $year ? intval($startdate['mday']) : 0;
|
2004-06-02 11:21:14 +00:00
|
|
|
|
|
|
|
// Also, it ends on $month $year or later...
|
|
|
|
$upperbound = $enddate['mon'] == $month && $enddate['year'] == $year ? intval($enddate['mday']) : calendar_days_in_month($month, $year);
|
|
|
|
|
|
|
|
// Mark all days between $lowerbound and $upperbound (inclusive) as duration
|
|
|
|
for($i = $lowerbound + 1; $i <= $upperbound; ++$i) {
|
|
|
|
$durationbyday[$i][] = $event->id;
|
2004-09-16 10:14:44 +00:00
|
|
|
if($event->courseid == SITEID && $event->groupid == 0) {
|
2004-06-02 11:21:14 +00:00
|
|
|
$typesbyday[$i]['durationglobal'] = true;
|
|
|
|
}
|
2004-09-16 10:30:40 +00:00
|
|
|
else if($event->courseid != 0 && $event->courseid != SITEID && $event->groupid == 0) {
|
2004-06-02 11:21:14 +00:00
|
|
|
$typesbyday[$i]['durationcourse'] = true;
|
|
|
|
}
|
|
|
|
else if($event->groupid) {
|
|
|
|
$typesbyday[$i]['durationgroup'] = true;
|
|
|
|
}
|
|
|
|
else if($event->userid) {
|
|
|
|
$typesbyday[$i]['durationuser'] = true;
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
|
|
|
}
|
2004-06-02 11:21:14 +00:00
|
|
|
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2012-01-13 17:45:55 +08:00
|
|
|
/**
|
|
|
|
* Get current module cache
|
|
|
|
*
|
|
|
|
* @param array $coursecache list of course cache
|
|
|
|
* @param string $modulename name of the module
|
|
|
|
* @param int $instance module instance number
|
|
|
|
* @return stdClass|bool $module information
|
|
|
|
*/
|
2004-12-26 13:58:07 +00:00
|
|
|
function calendar_get_module_cached(&$coursecache, $modulename, $instance) {
|
|
|
|
$module = get_coursemodule_from_instance($modulename, $instance);
|
2004-03-29 15:28:15 +00:00
|
|
|
|
|
|
|
if($module === false) return false;
|
2004-12-26 13:58:07 +00:00
|
|
|
if(!calendar_get_course_cached($coursecache, $module->course)) {
|
2004-03-29 15:28:15 +00:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
return $module;
|
|
|
|
}
|
|
|
|
|
2012-01-13 17:45:55 +08:00
|
|
|
/**
|
|
|
|
* Get current course cache
|
|
|
|
*
|
|
|
|
* @param array $coursecache list of course cache
|
|
|
|
* @param int $courseid id of the course
|
|
|
|
* @return stdClass $coursecache[$courseid] return the specific course cache
|
|
|
|
*/
|
2004-03-29 15:28:15 +00:00
|
|
|
function calendar_get_course_cached(&$coursecache, $courseid) {
|
2007-08-26 08:24:50 +00:00
|
|
|
if (!isset($coursecache[$courseid])) {
|
2013-08-14 10:46:19 +08:00
|
|
|
$coursecache[$courseid] = get_course($courseid);
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
|
|
|
return $coursecache[$courseid];
|
|
|
|
}
|
|
|
|
|
2011-06-29 14:50:38 +08:00
|
|
|
/**
|
|
|
|
* Returns the courses to load events for, the
|
|
|
|
*
|
|
|
|
* @param array $courseeventsfrom An array of courses to load calendar events for
|
2012-01-13 17:45:55 +08:00
|
|
|
* @param bool $ignorefilters specify the use of filters, false is set as default
|
2011-06-29 14:50:38 +08:00
|
|
|
* @return array An array of courses, groups, and user to load calendar events for based upon filters
|
|
|
|
*/
|
|
|
|
function calendar_set_filters(array $courseeventsfrom, $ignorefilters = false) {
|
|
|
|
global $USER, $CFG, $DB;
|
2004-03-29 15:28:15 +00:00
|
|
|
|
2011-06-29 14:50:38 +08:00
|
|
|
// For backwards compatability we have to check whether the courses array contains
|
|
|
|
// just id's in which case we need to load course objects.
|
|
|
|
$coursestoload = array();
|
|
|
|
foreach ($courseeventsfrom as $id => $something) {
|
|
|
|
if (!is_object($something)) {
|
|
|
|
$coursestoload[] = $id;
|
|
|
|
unset($courseeventsfrom[$id]);
|
2010-09-20 07:23:54 +00:00
|
|
|
}
|
2008-01-24 20:33:50 +00:00
|
|
|
}
|
2011-06-29 14:50:38 +08:00
|
|
|
if (!empty($coursestoload)) {
|
|
|
|
// TODO remove this in 2.2
|
|
|
|
debugging('calendar_set_filters now preferes an array of course objects with preloaded contexts', DEBUG_DEVELOPER);
|
|
|
|
$courseeventsfrom = array_merge($courseeventsfrom, $DB->get_records_list('course', 'id', $coursestoload));
|
2004-05-28 10:53:54 +00:00
|
|
|
}
|
2004-03-29 15:28:15 +00:00
|
|
|
|
2011-06-29 14:50:38 +08:00
|
|
|
$courses = array();
|
|
|
|
$user = false;
|
|
|
|
$group = false;
|
2004-03-29 15:28:15 +00:00
|
|
|
|
2011-10-22 23:43:11 +01:00
|
|
|
// capabilities that allow seeing group events from all groups
|
|
|
|
// TODO: rewrite so that moodle/calendar:manageentries is not necessary here
|
|
|
|
$allgroupscaps = array('moodle/site:accessallgroups', 'moodle/calendar:manageentries');
|
|
|
|
|
2011-06-29 14:50:38 +08:00
|
|
|
$isloggedin = isloggedin();
|
2007-11-12 06:27:42 +00:00
|
|
|
|
2011-06-29 14:50:38 +08:00
|
|
|
if ($ignorefilters || calendar_show_event_type(CALENDAR_EVENT_COURSE)) {
|
|
|
|
$courses = array_keys($courseeventsfrom);
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
2011-06-29 14:50:38 +08:00
|
|
|
if ($ignorefilters || calendar_show_event_type(CALENDAR_EVENT_GLOBAL)) {
|
|
|
|
$courses[] = SITEID;
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
2011-06-29 14:50:38 +08:00
|
|
|
$courses = array_unique($courses);
|
|
|
|
sort($courses);
|
2007-06-13 10:00:30 +00:00
|
|
|
|
2011-06-29 14:50:38 +08:00
|
|
|
if (!empty($courses) && in_array(SITEID, $courses)) {
|
2007-06-13 10:00:30 +00:00
|
|
|
// Sort courses for consistent colour highlighting
|
|
|
|
// Effectively ignoring SITEID as setting as last course id
|
|
|
|
$key = array_search(SITEID, $courses);
|
2011-06-29 14:50:38 +08:00
|
|
|
unset($courses[$key]);
|
|
|
|
$courses[] = SITEID;
|
2007-02-27 00:41:28 +00:00
|
|
|
}
|
2004-03-29 15:28:15 +00:00
|
|
|
|
2011-06-29 14:50:38 +08:00
|
|
|
if ($ignorefilters || ($isloggedin && calendar_show_event_type(CALENDAR_EVENT_USER))) {
|
|
|
|
$user = $USER->id;
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
2005-04-12 01:09:31 +00:00
|
|
|
|
2011-06-29 14:50:38 +08:00
|
|
|
if (!empty($courseeventsfrom) && (calendar_show_event_type(CALENDAR_EVENT_GROUP) || $ignorefilters)) {
|
|
|
|
|
2011-10-22 23:43:11 +01:00
|
|
|
if (count($courseeventsfrom)==1) {
|
|
|
|
$course = reset($courseeventsfrom);
|
2012-07-23 16:22:36 +08:00
|
|
|
if (has_any_capability($allgroupscaps, context_course::instance($course->id))) {
|
2011-10-22 23:43:11 +01:00
|
|
|
$coursegroups = groups_get_all_groups($course->id, 0, 0, 'g.id');
|
|
|
|
$group = array_keys($coursegroups);
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
2011-10-22 23:43:11 +01:00
|
|
|
}
|
|
|
|
if ($group === false) {
|
2013-07-03 14:39:10 +08:00
|
|
|
if (!empty($CFG->calendar_adminseesall) && has_any_capability($allgroupscaps, context_system::instance())) {
|
2011-10-22 23:43:11 +01:00
|
|
|
$group = true;
|
|
|
|
} else if ($isloggedin) {
|
|
|
|
$groupids = array();
|
2012-05-25 11:08:14 +08:00
|
|
|
|
2011-10-22 23:43:11 +01:00
|
|
|
// We already have the courses to examine in $courses
|
|
|
|
// For each course...
|
|
|
|
foreach ($courseeventsfrom as $courseid => $course) {
|
|
|
|
// If the user is an editing teacher in there,
|
|
|
|
if (!empty($USER->groupmember[$course->id])) {
|
|
|
|
// We've already cached the users groups for this course so we can just use that
|
|
|
|
$groupids = array_merge($groupids, $USER->groupmember[$course->id]);
|
|
|
|
} else if ($course->groupmode != NOGROUPS || !$course->groupmodeforce) {
|
|
|
|
// If this course has groups, show events from all of those related to the current user
|
|
|
|
$coursegroups = groups_get_user_groups($course->id, $USER->id);
|
|
|
|
$groupids = array_merge($groupids, $coursegroups['0']);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (!empty($groupids)) {
|
|
|
|
$group = $groupids;
|
|
|
|
}
|
2004-05-13 10:32:12 +00:00
|
|
|
}
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
|
|
|
}
|
2011-06-29 14:50:38 +08:00
|
|
|
if (empty($courses)) {
|
|
|
|
$courses = false;
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
2011-06-29 14:50:38 +08:00
|
|
|
|
|
|
|
return array($courses, $group, $user);
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
|
|
|
|
2012-01-13 17:45:55 +08:00
|
|
|
/**
|
|
|
|
* Return the capability for editing calendar event
|
|
|
|
*
|
|
|
|
* @param calendar_event $event event object
|
|
|
|
* @return bool capability to edit event
|
|
|
|
*/
|
2004-03-29 15:28:15 +00:00
|
|
|
function calendar_edit_event_allowed($event) {
|
2008-06-01 14:25:05 +00:00
|
|
|
global $USER, $DB;
|
2004-03-29 15:28:15 +00:00
|
|
|
|
2008-02-21 06:10:17 +00:00
|
|
|
// Must be logged in
|
|
|
|
if (!isloggedin()) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2006-10-11 05:24:33 +00:00
|
|
|
// can not be using guest account
|
2010-08-25 08:58:22 +00:00
|
|
|
if (isguestuser()) {
|
2007-08-17 11:18:58 +00:00
|
|
|
return false;
|
2006-10-11 05:24:33 +00:00
|
|
|
}
|
2007-08-17 11:18:58 +00:00
|
|
|
|
2012-11-14 13:34:54 +13:00
|
|
|
// You cannot edit calendar subscription events presently.
|
|
|
|
if (!empty($event->subscriptionid)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2012-07-23 16:22:36 +08:00
|
|
|
$sitecontext = context_system::instance();
|
2006-10-11 05:24:33 +00:00
|
|
|
// if user has manageentries at site level, return true
|
2006-10-23 22:28:52 +00:00
|
|
|
if (has_capability('moodle/calendar:manageentries', $sitecontext)) {
|
2006-10-11 05:24:33 +00:00
|
|
|
return true;
|
2004-06-01 14:12:26 +00:00
|
|
|
}
|
2007-08-17 11:18:58 +00:00
|
|
|
|
2007-04-05 07:58:31 +00:00
|
|
|
// if groupid is set, it's definitely a group event
|
2010-05-27 02:13:18 +00:00
|
|
|
if (!empty($event->groupid)) {
|
2007-10-30 16:19:47 +00:00
|
|
|
// Allow users to add/edit group events if:
|
|
|
|
// 1) They have manageentries (= entries for whole course)
|
|
|
|
// 2) They have managegroupentries AND are in the group
|
2008-06-01 14:25:05 +00:00
|
|
|
$group = $DB->get_record('groups', array('id'=>$event->groupid));
|
2007-10-30 16:19:47 +00:00
|
|
|
return $group && (
|
2011-04-18 18:27:10 +08:00
|
|
|
has_capability('moodle/calendar:manageentries', $event->context) ||
|
|
|
|
(has_capability('moodle/calendar:managegroupentries', $event->context)
|
2007-10-30 16:19:47 +00:00
|
|
|
&& groups_is_member($event->groupid)));
|
2010-05-27 02:13:18 +00:00
|
|
|
} else if (!empty($event->courseid)) {
|
2007-04-05 07:58:31 +00:00
|
|
|
// if groupid is not set, but course is set,
|
|
|
|
// it's definiely a course event
|
2011-04-18 18:27:10 +08:00
|
|
|
return has_capability('moodle/calendar:manageentries', $event->context);
|
2010-05-27 02:13:18 +00:00
|
|
|
} else if (!empty($event->userid) && $event->userid == $USER->id) {
|
2007-04-05 07:58:31 +00:00
|
|
|
// if course is not set, but userid id set, it's a user event
|
2011-04-18 18:27:10 +08:00
|
|
|
return (has_capability('moodle/calendar:manageownentries', $event->context));
|
|
|
|
} else if (!empty($event->userid)) {
|
|
|
|
return (has_capability('moodle/calendar:manageentries', $event->context));
|
2007-08-17 11:18:58 +00:00
|
|
|
}
|
2004-03-29 15:28:15 +00:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2011-06-29 14:50:38 +08:00
|
|
|
/**
|
|
|
|
* Returns the default courses to display on the calendar when there isn't a specific
|
|
|
|
* course to display.
|
|
|
|
*
|
2012-01-13 17:45:55 +08:00
|
|
|
* @return array $courses Array of courses to display
|
2011-06-29 14:50:38 +08:00
|
|
|
*/
|
|
|
|
function calendar_get_default_courses() {
|
|
|
|
global $CFG, $DB;
|
2004-03-29 15:28:15 +00:00
|
|
|
|
2010-03-31 07:41:31 +00:00
|
|
|
if (!isloggedin()) {
|
2004-05-24 11:10:00 +00:00
|
|
|
return array();
|
|
|
|
}
|
|
|
|
|
2004-03-29 15:28:15 +00:00
|
|
|
$courses = array();
|
2012-05-09 17:34:12 +01:00
|
|
|
if (!empty($CFG->calendar_adminseesall) && has_capability('moodle/calendar:manageentries', context_system::instance())) {
|
2013-07-05 13:02:00 +08:00
|
|
|
$select = ', ' . context_helper::get_preload_record_columns_sql('ctx');
|
|
|
|
$join = "LEFT JOIN {context} ctx ON (ctx.instanceid = c.id AND ctx.contextlevel = :contextlevel)";
|
2012-05-09 17:34:12 +01:00
|
|
|
$sql = "SELECT c.* $select
|
2011-06-29 14:50:38 +08:00
|
|
|
FROM {course} c
|
2012-05-09 17:34:12 +01:00
|
|
|
$join
|
|
|
|
WHERE EXISTS (SELECT 1 FROM {event} e WHERE e.courseid = c.id)
|
|
|
|
";
|
2013-07-05 13:02:00 +08:00
|
|
|
$courses = $DB->get_records_sql($sql, array('contextlevel' => CONTEXT_COURSE), 0, 20);
|
2011-06-29 14:50:38 +08:00
|
|
|
foreach ($courses as $course) {
|
2012-05-09 17:34:12 +01:00
|
|
|
context_helper::preload_from_record($course);
|
2004-12-15 07:14:41 +00:00
|
|
|
}
|
2011-06-29 14:50:38 +08:00
|
|
|
return $courses;
|
2004-04-20 13:00:39 +00:00
|
|
|
}
|
2007-08-17 11:18:58 +00:00
|
|
|
|
MDL-21782 reworked enrolment framework, the core infrastructure is in place, the basic plugins are all implemented; see the tracker issue for list of unfinished bits, expect more changes and improvements during the next week
AMOS START
MOV [sendcoursewelcomemessage,core_admin],[sendcoursewelcomemessage,enrol_self]
MOV [configsendcoursewelcomemessage,core_admin],[sendcoursewelcomemessage_desc,enrol_self]
MOV [enrolstartdate,core],[enrolstartdate,enrol_self]
MOV [enrolenddate,core],[enrolenddate,enrol_self]
CPY [welcometocourse,core],[welcometocourse,enrol_self]
CPY [welcometocoursetext,core],[welcometocoursetext,enrol_self]
MOV [notenrollable,core],[notenrollable,core_enrol]
MOV [enrolenddaterror,core],[enrolenddaterror,enrol_self]
MOV [enrolmentkeyhint,core],[passwordinvalidhint,enrol_self]
MOV [coursemanager,core_admin],[coursecontact,core_admin]
MOV [configcoursemanager,core_admin],[coursecontact_desc,core_admin]
MOV [enrolledincourserole,core],[enrolledincourserole,enrol_manual]
MOV [enrolme,core],[enrolme,core_enrol]
MOV [unenrol,core],[unenrol,core_enrol]
MOV [unenrolme,core],[unenrolme,core_enrol]
MOV [enrolmentnew,core],[enrolmentnew,core_enrol]
MOV [enrolmentnewuser,core],[enrolmentnewuser,core_enrol]
MOV [enrolments,core],[enrolments,core_enrol]
MOV [enrolperiod,core],[enrolperiod,core_enrol]
MOV [unenrolroleusers,core],[unenrolroleusers,core_enrol]
AMOS END
2010-06-21 15:30:49 +00:00
|
|
|
$courses = enrol_get_my_courses();
|
2007-05-06 04:28:11 +00:00
|
|
|
|
|
|
|
return $courses;
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
|
|
|
|
2012-01-13 17:45:55 +08:00
|
|
|
/**
|
|
|
|
* Display calendar preference button
|
|
|
|
*
|
|
|
|
* @param stdClass $course course object
|
|
|
|
* @return string return preference button in html
|
|
|
|
*/
|
2011-06-29 14:50:38 +08:00
|
|
|
function calendar_preferences_button(stdClass $course) {
|
|
|
|
global $OUTPUT;
|
2004-03-29 15:28:15 +00:00
|
|
|
|
|
|
|
// Guests have no preferences
|
2010-03-31 07:41:31 +00:00
|
|
|
if (!isloggedin() || isguestuser()) {
|
2004-03-29 15:28:15 +00:00
|
|
|
return '';
|
|
|
|
}
|
|
|
|
|
2011-06-29 14:50:38 +08:00
|
|
|
return $OUTPUT->single_button(new moodle_url('/calendar/preferences.php', array('course' => $course->id)), get_string("preferences", "calendar"));
|
2004-03-29 15:28:15 +00:00
|
|
|
}
|
|
|
|
|
2012-01-13 17:45:55 +08:00
|
|
|
/**
|
|
|
|
* Get event format time
|
|
|
|
*
|
|
|
|
* @param calendar_event $event event object
|
|
|
|
* @param int $now current time in gmt
|
|
|
|
* @param array $linkparams list of params for event link
|
|
|
|
* @param bool $usecommonwords the words as formatted date/time.
|
|
|
|
* @param int $showtime determine the show time GMT timestamp
|
|
|
|
* @return string $eventtime link/string for event time
|
|
|
|
*/
|
2013-09-16 17:30:59 +08:00
|
|
|
function calendar_format_event_time($event, $now, $linkparams = null, $usecommonwords = true, $showtime = 0) {
|
|
|
|
$starttime = $event->timestart;
|
|
|
|
$endtime = $event->timestart + $event->timeduration;
|
2004-08-22 17:19:24 +00:00
|
|
|
|
2010-09-20 07:00:18 +00:00
|
|
|
if (empty($linkparams) || !is_array($linkparams)) {
|
|
|
|
$linkparams = array();
|
|
|
|
}
|
2013-09-16 17:30:59 +08:00
|
|
|
|
2010-09-20 07:00:18 +00:00
|
|
|
$linkparams['view'] = 'day';
|
|
|
|
|
2004-08-22 17:19:24 +00:00
|
|
|
// OK, now to get a meaningful display...
|
2013-09-16 17:30:59 +08:00
|
|
|
// Check if there is a duration for this event.
|
|
|
|
if ($event->timeduration) {
|
|
|
|
// Get the midnight of the day the event will start.
|
|
|
|
$usermidnightstart = usergetmidnight($starttime);
|
|
|
|
// Get the midnight of the day the event will end.
|
|
|
|
$usermidnightend = usergetmidnight($endtime);
|
|
|
|
// Check if we will still be on the same day.
|
|
|
|
if ($usermidnightstart == $usermidnightend) {
|
|
|
|
// Check if we are running all day.
|
|
|
|
if ($event->timeduration == DAYSECS) {
|
2007-06-12 16:26:38 +00:00
|
|
|
$time = get_string('allday', 'calendar');
|
2013-09-16 17:30:59 +08:00
|
|
|
} else { // Specify the time we will be running this from.
|
|
|
|
$datestart = calendar_time_representation($starttime);
|
|
|
|
$dateend = calendar_time_representation($endtime);
|
|
|
|
$time = $datestart . ' <strong>»</strong> ' . $dateend;
|
2007-06-12 16:26:38 +00:00
|
|
|
}
|
2004-08-22 17:19:24 +00:00
|
|
|
|
2013-09-16 17:30:59 +08:00
|
|
|
// Set printable representation.
|
2007-06-12 16:26:38 +00:00
|
|
|
if (!$showtime) {
|
|
|
|
$day = calendar_day_representation($event->timestart, $now, $usecommonwords);
|
2013-09-16 17:30:59 +08:00
|
|
|
$url = calendar_get_link_href(new moodle_url(CALENDAR_URL . 'view.php', $linkparams), 0, 0, 0, $endtime);
|
|
|
|
$eventtime = html_writer::link($url, $day) . ', ' . $time;
|
2007-06-12 16:26:38 +00:00
|
|
|
} else {
|
|
|
|
$eventtime = $time;
|
|
|
|
}
|
2013-09-16 17:30:59 +08:00
|
|
|
} else { // It must spans two or more days.
|
|
|
|
$daystart = calendar_day_representation($event->timestart, $now, $usecommonwords) . ', ';
|
2007-06-12 16:26:38 +00:00
|
|
|
if ($showtime == $usermidnightstart) {
|
|
|
|
$daystart = '';
|
|
|
|
}
|
2004-08-22 17:19:24 +00:00
|
|
|
$timestart = calendar_time_representation($event->timestart);
|
2013-09-16 17:30:59 +08:00
|
|
|
$dayend = calendar_day_representation($event->timestart + $event->timeduration, $now, $usecommonwords) . ', ';
|
2007-06-12 16:26:38 +00:00
|
|
|
if ($showtime == $usermidnightend) {
|
|
|
|
$dayend = '';
|
|
|
|
}
|
2004-08-22 17:19:24 +00:00
|
|
|
$timeend = calendar_time_representation($event->timestart + $event->timeduration);
|
|
|
|
|
2013-09-16 17:30:59 +08:00
|
|
|
// Set printable representation.
|
|
|
|
if ($now >= $usermidnightstart && $now < ($usermidnightstart + DAYSECS)) {
|
|
|
|
$url = calendar_get_link_href(new moodle_url(CALENDAR_URL . 'view.php', $linkparams), 0, 0, 0, $endtime);
|
|
|
|
$eventtime = $timestart . ' <strong>»</strong> ' . html_writer::link($url, $dayend) . $timeend;
|
2007-06-12 16:26:38 +00:00
|
|
|
} else {
|
2013-09-16 17:30:59 +08:00
|
|
|
$url = calendar_get_link_href(new moodle_url(CALENDAR_URL . 'view.php', $linkparams), 0, 0, 0, $endtime);
|
|
|
|
$eventtime = html_writer::link($url, $daystart) . $timestart . ' <strong>»</strong> ';
|
2010-11-17 07:56:40 +00:00
|
|
|
|
2013-09-16 17:30:59 +08:00
|
|
|
$url = calendar_get_link_href(new moodle_url(CALENDAR_URL . 'view.php', $linkparams), 0, 0, 0, $starttime);
|
|
|
|
$eventtime .= html_writer::link($url, $dayend) . $timeend;
|
2007-06-12 16:26:38 +00:00
|
|
|
}
|
2004-08-22 17:19:24 +00:00
|
|
|
}
|
2013-09-16 17:30:59 +08:00
|
|
|
} else { // There is no time duration.
|
2012-02-24 08:58:31 -05:00
|
|
|
$time = calendar_time_representation($event->timestart);
|
2013-09-16 17:30:59 +08:00
|
|
|
// Set printable representation.
|
2007-06-12 16:26:38 +00:00
|
|
|
if (!$showtime) {
|
|
|
|
$day = calendar_day_representation($event->timestart, $now, $usecommonwords);
|
2013-09-16 17:30:59 +08:00
|
|
|
$url = calendar_get_link_href(new moodle_url(CALENDAR_URL . 'view.php', $linkparams), 0, 0, 0, $starttime);
|
|
|
|
$eventtime = html_writer::link($url, $day) . ', ' . trim($time);
|
2007-06-12 16:26:38 +00:00
|
|
|
} else {
|
|
|
|
$eventtime = $time;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-09-16 17:30:59 +08:00
|
|
|
// Check if It has expired.
|
|
|
|
if ($event->timestart + $event->timeduration < $now) {
|
|
|
|
$eventtime = '<span class="dimmed_text">' . str_replace(' href=', ' class="dimmed" href=', $eventtime) . '</span>';
|
2004-08-22 17:19:24 +00:00
|
|
|
}
|
2004-08-26 10:52:00 +00:00
|
|
|
|
2004-08-22 17:19:24 +00:00
|
|
|
return $eventtime;
|
|
|
|
}
|
2005-01-12 11:55:01 +00:00
|
|
|
|
2012-01-13 17:45:55 +08:00
|
|
|
/**
|
|
|
|
* Display month selector options
|
|
|
|
*
|
|
|
|
* @param string $name for the select element
|
|
|
|
* @param string|array $selected options for select elements
|
|
|
|
*/
|
2004-12-15 07:14:41 +00:00
|
|
|
function calendar_print_month_selector($name, $selected) {
|
|
|
|
$months = array();
|
|
|
|
for ($i=1; $i<=12; $i++) {
|
2007-04-13 05:04:57 +00:00
|
|
|
$months[$i] = userdate(gmmktime(12, 0, 0, $i, 15, 2000), '%B');
|
2004-12-15 07:14:41 +00:00
|
|
|
}
|
2012-07-27 18:13:06 +08:00
|
|
|
echo html_writer::label(get_string('months'), 'menu'. $name, false, array('class' => 'accesshide'));
|
2010-01-16 18:29:51 +00:00
|
|
|
echo html_writer::select($months, $name, $selected, false);
|
2004-12-15 07:14:41 +00:00
|
|
|
}
|
|
|
|
|
2011-06-29 14:50:38 +08:00
|
|
|
/**
|
|
|
|
* Checks to see if the requested type of event should be shown for the given user.
|
|
|
|
*
|
|
|
|
* @param CALENDAR_EVENT_GLOBAL|CALENDAR_EVENT_COURSE|CALENDAR_EVENT_GROUP|CALENDAR_EVENT_USER $type
|
|
|
|
* The type to check the display for (default is to display all)
|
|
|
|
* @param stdClass|int|null $user The user to check for - by default the current user
|
|
|
|
* @return bool True if the tyep should be displayed false otherwise
|
|
|
|
*/
|
|
|
|
function calendar_show_event_type($type, $user = null) {
|
|
|
|
$default = CALENDAR_EVENT_GLOBAL + CALENDAR_EVENT_COURSE + CALENDAR_EVENT_GROUP + CALENDAR_EVENT_USER;
|
|
|
|
if (get_user_preferences('calendar_persistflt', 0, $user) === 0) {
|
|
|
|
global $SESSION;
|
|
|
|
if (!isset($SESSION->calendarshoweventtype)) {
|
|
|
|
$SESSION->calendarshoweventtype = $default;
|
|
|
|
}
|
|
|
|
return $SESSION->calendarshoweventtype & $type;
|
|
|
|
} else {
|
|
|
|
return get_user_preferences('calendar_savedflt', $default, $user) & $type;
|
2005-01-12 11:55:01 +00:00
|
|
|
}
|
2011-06-29 14:50:38 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the display of the event type given $display.
|
2012-01-13 17:45:55 +08:00
|
|
|
*
|
2011-06-29 14:50:38 +08:00
|
|
|
* If $display = true the event type will be shown.
|
|
|
|
* If $display = false the event type will NOT be shown.
|
|
|
|
* If $display = null the current value will be toggled and saved.
|
|
|
|
*
|
2012-01-13 17:45:55 +08:00
|
|
|
* @param CALENDAR_EVENT_GLOBAL|CALENDAR_EVENT_COURSE|CALENDAR_EVENT_GROUP|CALENDAR_EVENT_USER $type object of CALENDAR_EVENT_XXX
|
|
|
|
* @param bool $display option to display event type
|
|
|
|
* @param stdClass|int $user moodle user object or id, null means current user
|
2011-06-29 14:50:38 +08:00
|
|
|
*/
|
|
|
|
function calendar_set_event_type_display($type, $display = null, $user = null) {
|
|
|
|
$persist = get_user_preferences('calendar_persistflt', 0, $user);
|
|
|
|
$default = CALENDAR_EVENT_GLOBAL + CALENDAR_EVENT_COURSE + CALENDAR_EVENT_GROUP + CALENDAR_EVENT_USER;
|
|
|
|
if ($persist === 0) {
|
|
|
|
global $SESSION;
|
|
|
|
if (!isset($SESSION->calendarshoweventtype)) {
|
|
|
|
$SESSION->calendarshoweventtype = $default;
|
|
|
|
}
|
|
|
|
$preference = $SESSION->calendarshoweventtype;
|
|
|
|
} else {
|
|
|
|
$preference = get_user_preferences('calendar_savedflt', $default, $user);
|
2005-01-12 11:55:01 +00:00
|
|
|
}
|
2011-06-29 14:50:38 +08:00
|
|
|
$current = $preference & $type;
|
|
|
|
if ($display === null) {
|
|
|
|
$display = !$current;
|
2005-01-12 11:55:01 +00:00
|
|
|
}
|
2011-06-29 14:50:38 +08:00
|
|
|
if ($display && !$current) {
|
|
|
|
$preference += $type;
|
|
|
|
} else if (!$display && $current) {
|
|
|
|
$preference -= $type;
|
2005-01-12 11:55:01 +00:00
|
|
|
}
|
2011-06-29 14:50:38 +08:00
|
|
|
if ($persist === 0) {
|
|
|
|
$SESSION->calendarshoweventtype = $preference;
|
|
|
|
} else {
|
|
|
|
if ($preference == $default) {
|
|
|
|
unset_user_preference('calendar_savedflt', $user);
|
|
|
|
} else {
|
|
|
|
set_user_preference('calendar_savedflt', $preference, $user);
|
|
|
|
}
|
2005-01-12 11:55:01 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-01-13 17:45:55 +08:00
|
|
|
/**
|
|
|
|
* Get calendar's allowed types
|
|
|
|
*
|
|
|
|
* @param stdClass $allowed list of allowed edit for event type
|
|
|
|
* @param stdClass|int $course object of a course or course id
|
|
|
|
*/
|
2011-06-29 14:50:38 +08:00
|
|
|
function calendar_get_allowed_types(&$allowed, $course = null) {
|
|
|
|
global $USER, $CFG, $DB;
|
2012-01-15 13:37:53 +01:00
|
|
|
$allowed = new stdClass();
|
2013-07-03 14:39:10 +08:00
|
|
|
$allowed->user = has_capability('moodle/calendar:manageownentries', context_system::instance());
|
2007-06-28 04:03:30 +00:00
|
|
|
$allowed->groups = false; // This may change just below
|
|
|
|
$allowed->courses = false; // This may change just below
|
2012-07-23 16:22:36 +08:00
|
|
|
$allowed->site = has_capability('moodle/calendar:manageentries', context_course::instance(SITEID));
|
2007-06-28 04:03:30 +00:00
|
|
|
|
2011-06-29 14:50:38 +08:00
|
|
|
if (!empty($course)) {
|
|
|
|
if (!is_object($course)) {
|
2013-08-21 13:42:30 +08:00
|
|
|
$course = $DB->get_record('course', array('id' => $course), '*', MUST_EXIST);
|
2011-06-29 14:50:38 +08:00
|
|
|
}
|
|
|
|
if ($course->id != SITEID) {
|
2012-07-23 16:22:36 +08:00
|
|
|
$coursecontext = context_course::instance($course->id);
|
2012-04-30 17:41:54 +08:00
|
|
|
$allowed->user = has_capability('moodle/calendar:manageownentries', $coursecontext);
|
2007-06-28 04:03:30 +00:00
|
|
|
|
2011-06-29 14:50:38 +08:00
|
|
|
if (has_capability('moodle/calendar:manageentries', $coursecontext)) {
|
|
|
|
$allowed->courses = array($course->id => 1);
|
2009-11-04 08:11:02 +00:00
|
|
|
|
2011-06-29 14:50:38 +08:00
|
|
|
if ($course->groupmode != NOGROUPS || !$course->groupmodeforce) {
|
2012-10-23 10:17:16 +01:00
|
|
|
if (has_capability('moodle/site:accessallgroups', $coursecontext)) {
|
|
|
|
$allowed->groups = groups_get_all_groups($course->id);
|
|
|
|
} else {
|
|
|
|
$allowed->groups = groups_get_all_groups($course->id, $USER->id);
|
|
|
|
}
|
2011-06-29 14:50:38 +08:00
|
|
|
}
|
|
|
|
} else if (has_capability('moodle/calendar:managegroupentries', $coursecontext)) {
|
|
|
|
if($course->groupmode != NOGROUPS || !$course->groupmodeforce) {
|
2012-10-23 10:17:16 +01:00
|
|
|
if (has_capability('moodle/site:accessallgroups', $coursecontext)) {
|
|
|
|
$allowed->groups = groups_get_all_groups($course->id);
|
|
|
|
} else {
|
|
|
|
$allowed->groups = groups_get_all_groups($course->id, $USER->id);
|
|
|
|
}
|
2011-06-29 14:50:38 +08:00
|
|
|
}
|
2007-10-30 16:19:47 +00:00
|
|
|
}
|
2007-06-28 04:03:30 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2012-01-13 17:45:55 +08:00
|
|
|
* See if user can add calendar entries at all
|
2007-06-28 04:03:30 +00:00
|
|
|
* used to print the "New Event" button
|
2012-01-13 17:45:55 +08:00
|
|
|
*
|
|
|
|
* @param stdClass $course object of a course or course id
|
|
|
|
* @return bool has the capability to add at least one event type
|
2007-06-28 04:03:30 +00:00
|
|
|
*/
|
2011-06-29 14:50:38 +08:00
|
|
|
function calendar_user_can_add_event($course) {
|
|
|
|
if (!isloggedin() || isguestuser()) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
calendar_get_allowed_types($allowed, $course);
|
2007-08-17 11:18:58 +00:00
|
|
|
return (bool)($allowed->user || $allowed->groups || $allowed->courses || $allowed->site);
|
2007-06-28 04:03:30 +00:00
|
|
|
}
|
2009-11-02 03:50:56 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Check wether the current user is permitted to add events
|
|
|
|
*
|
2012-01-13 17:45:55 +08:00
|
|
|
* @param stdClass $event object of event
|
|
|
|
* @return bool has the capability to add event
|
2009-11-02 03:50:56 +00:00
|
|
|
*/
|
|
|
|
function calendar_add_event_allowed($event) {
|
|
|
|
global $USER, $DB;
|
|
|
|
|
|
|
|
// can not be using guest account
|
2010-03-31 07:41:31 +00:00
|
|
|
if (!isloggedin() or isguestuser()) {
|
2009-11-02 03:50:56 +00:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2012-07-23 16:22:36 +08:00
|
|
|
$sitecontext = context_system::instance();
|
2009-11-02 03:50:56 +00:00
|
|
|
// if user has manageentries at site level, always return true
|
|
|
|
if (has_capability('moodle/calendar:manageentries', $sitecontext)) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
switch ($event->eventtype) {
|
|
|
|
case 'course':
|
2011-04-18 18:27:10 +08:00
|
|
|
return has_capability('moodle/calendar:manageentries', $event->context);
|
2009-11-02 03:50:56 +00:00
|
|
|
|
|
|
|
case 'group':
|
|
|
|
// Allow users to add/edit group events if:
|
|
|
|
// 1) They have manageentries (= entries for whole course)
|
|
|
|
// 2) They have managegroupentries AND are in the group
|
|
|
|
$group = $DB->get_record('groups', array('id'=>$event->groupid));
|
|
|
|
return $group && (
|
2011-04-18 18:27:10 +08:00
|
|
|
has_capability('moodle/calendar:manageentries', $event->context) ||
|
|
|
|
(has_capability('moodle/calendar:managegroupentries', $event->context)
|
2009-11-02 03:50:56 +00:00
|
|
|
&& groups_is_member($event->groupid)));
|
|
|
|
|
|
|
|
case 'user':
|
|
|
|
if ($event->userid == $USER->id) {
|
2011-04-18 18:27:10 +08:00
|
|
|
return (has_capability('moodle/calendar:manageownentries', $event->context));
|
2009-11-02 03:50:56 +00:00
|
|
|
}
|
|
|
|
//there is no 'break;' intentionally
|
|
|
|
|
|
|
|
case 'site':
|
2011-04-18 18:27:10 +08:00
|
|
|
return has_capability('moodle/calendar:manageentries', $event->context);
|
2009-11-02 03:50:56 +00:00
|
|
|
|
|
|
|
default:
|
2011-04-18 18:27:10 +08:00
|
|
|
return has_capability('moodle/calendar:manageentries', $event->context);
|
2009-11-02 03:50:56 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2012-01-13 17:45:55 +08:00
|
|
|
* Manage calendar events
|
2009-11-02 03:50:56 +00:00
|
|
|
*
|
|
|
|
* This class provides the required functionality in order to manage calendar events.
|
|
|
|
* It was introduced as part of Moodle 2.0 and was created in order to provide a
|
|
|
|
* better framework for dealing with calendar events in particular regard to file
|
|
|
|
* handling through the new file API
|
|
|
|
*
|
2012-01-13 17:45:55 +08:00
|
|
|
* @package core_calendar
|
|
|
|
* @category calendar
|
|
|
|
* @copyright 2009 Sam Hemelryk
|
|
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|
|
|
*
|
2009-11-02 03:50:56 +00:00
|
|
|
* @property int $id The id within the event table
|
|
|
|
* @property string $name The name of the event
|
|
|
|
* @property string $description The description of the event
|
|
|
|
* @property int $format The format of the description FORMAT_?
|
|
|
|
* @property int $courseid The course the event is associated with (0 if none)
|
|
|
|
* @property int $groupid The group the event is associated with (0 if none)
|
|
|
|
* @property int $userid The user the event is associated with (0 if none)
|
|
|
|
* @property int $repeatid If this is a repeated event this will be set to the
|
|
|
|
* id of the original
|
|
|
|
* @property string $modulename If added by a module this will be the module name
|
|
|
|
* @property int $instance If added by a module this will be the module instance
|
|
|
|
* @property string $eventtype The event type
|
|
|
|
* @property int $timestart The start time as a timestamp
|
|
|
|
* @property int $timeduration The duration of the event in seconds
|
|
|
|
* @property int $visible 1 if the event is visible
|
|
|
|
* @property int $uuid ?
|
|
|
|
* @property int $sequence ?
|
|
|
|
* @property int $timemodified The time last modified as a timestamp
|
|
|
|
*/
|
|
|
|
class calendar_event {
|
|
|
|
|
2012-01-13 17:45:55 +08:00
|
|
|
/** @var array An object containing the event properties can be accessed via the magic __get/set methods */
|
2009-11-02 03:50:56 +00:00
|
|
|
protected $properties = null;
|
2012-01-13 17:45:55 +08:00
|
|
|
|
2009-11-02 03:50:56 +00:00
|
|
|
/**
|
2012-01-13 17:45:55 +08:00
|
|
|
* @var string The converted event discription with file paths resolved. This gets populated when someone requests description for the first time */
|
2009-11-02 03:50:56 +00:00
|
|
|
protected $_description = null;
|
2012-01-13 17:45:55 +08:00
|
|
|
|
|
|
|
/** @var array The options to use with this description editor */
|
2009-11-02 03:50:56 +00:00
|
|
|
protected $editoroptions = array(
|
|
|
|
'subdirs'=>false,
|
|
|
|
'forcehttps'=>false,
|
2010-09-20 03:18:53 +00:00
|
|
|
'maxfiles'=>-1,
|
2009-11-02 03:50:56 +00:00
|
|
|
'maxbytes'=>null,
|
|
|
|
'trusttext'=>false);
|
2012-01-13 17:45:55 +08:00
|
|
|
|
|
|
|
/** @var object The context to use with the description editor */
|
2009-11-02 03:50:56 +00:00
|
|
|
protected $editorcontext = null;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Instantiates a new event and optionally populates its properties with the
|
|
|
|
* data provided
|
|
|
|
*
|
|
|
|
* @param stdClass $data Optional. An object containing the properties to for
|
|
|
|
* an event
|
|
|
|
*/
|
|
|
|
public function __construct($data=null) {
|
2010-08-25 06:08:16 +00:00
|
|
|
global $CFG, $USER;
|
2009-11-02 03:50:56 +00:00
|
|
|
|
|
|
|
// First convert to object if it is not already (should either be object or assoc array)
|
|
|
|
if (!is_object($data)) {
|
|
|
|
$data = (object)$data;
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->editoroptions['maxbytes'] = $CFG->maxbytes;
|
|
|
|
|
|
|
|
$data->eventrepeats = 0;
|
|
|
|
|
|
|
|
if (empty($data->id)) {
|
|
|
|
$data->id = null;
|
|
|
|
}
|
|
|
|
|
2012-12-27 15:06:37 +08:00
|
|
|
if (!empty($data->subscriptionid)) {
|
2013-01-17 11:11:15 +08:00
|
|
|
$data->subscription = calendar_get_subscription($data->subscriptionid);
|
2012-12-27 15:06:37 +08:00
|
|
|
}
|
|
|
|
|
2010-08-25 06:08:16 +00:00
|
|
|
// Default to a user event
|
|
|
|
if (empty($data->eventtype)) {
|
|
|
|
$data->eventtype = 'user';
|
|
|
|
}
|
|
|
|
|
|
|
|
// Default to the current user
|
|
|
|
if (empty($data->userid)) {
|
|
|
|
$data->userid = $USER->id;
|
|
|
|
}
|
|
|
|
|
2009-11-02 03:50:56 +00:00
|
|
|
if (!empty($data->timeduration) && is_array($data->timeduration)) {
|
|
|
|
$data->timeduration = make_timestamp($data->timeduration['year'], $data->timeduration['month'], $data->timeduration['day'], $data->timeduration['hour'], $data->timeduration['minute']) - $data->timestart;
|
|
|
|
}
|
|
|
|
if (!empty($data->description) && is_array($data->description)) {
|
|
|
|
$data->format = $data->description['format'];
|
|
|
|
$data->description = $data->description['text'];
|
|
|
|
} else if (empty($data->description)) {
|
|
|
|
$data->description = '';
|
2010-07-10 12:12:59 +00:00
|
|
|
$data->format = editors_get_preferred_format();
|
2009-11-02 03:50:56 +00:00
|
|
|
}
|
2010-08-25 06:08:16 +00:00
|
|
|
// Ensure form is defaulted correctly
|
|
|
|
if (empty($data->format)) {
|
|
|
|
$data->format = editors_get_preferred_format();
|
|
|
|
}
|
2009-11-02 03:50:56 +00:00
|
|
|
|
2011-04-18 18:27:10 +08:00
|
|
|
if (empty($data->context)) {
|
|
|
|
$data->context = $this->calculate_context($data);
|
|
|
|
}
|
2009-11-02 03:50:56 +00:00
|
|
|
$this->properties = $data;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Magic property method
|
|
|
|
*
|
|
|
|
* Attempts to call a set_$key method if one exists otherwise falls back
|
|
|
|
* to simply set the property
|
|
|
|
*
|
2012-01-13 17:45:55 +08:00
|
|
|
* @param string $key property name
|
|
|
|
* @param mixed $value value of the property
|
2009-11-02 03:50:56 +00:00
|
|
|
*/
|
|
|
|
public function __set($key, $value) {
|
|
|
|
if (method_exists($this, 'set_'.$key)) {
|
|
|
|
$this->{'set_'.$key}($value);
|
|
|
|
}
|
|
|
|
$this->properties->{$key} = $value;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Magic get method
|
|
|
|
*
|
|
|
|
* Attempts to call a get_$key method to return the property and ralls over
|
|
|
|
* to return the raw property
|
|
|
|
*
|
2012-01-13 17:45:55 +08:00
|
|
|
* @param string $key property name
|
|
|
|
* @return mixed property value
|
2009-11-02 03:50:56 +00:00
|
|
|
*/
|
|
|
|
public function __get($key) {
|
|
|
|
if (method_exists($this, 'get_'.$key)) {
|
|
|
|
return $this->{'get_'.$key}();
|
|
|
|
}
|
2010-08-25 06:08:16 +00:00
|
|
|
if (!isset($this->properties->{$key})) {
|
|
|
|
throw new coding_exception('Undefined property requested');
|
|
|
|
}
|
2009-11-02 03:50:56 +00:00
|
|
|
return $this->properties->{$key};
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Stupid PHP needs an isset magic method if you use the get magic method and
|
|
|
|
* still want empty calls to work.... blah ~!
|
|
|
|
*
|
2012-01-13 17:45:55 +08:00
|
|
|
* @param string $key $key property name
|
|
|
|
* @return bool|mixed property value, false if property is not exist
|
2009-11-02 03:50:56 +00:00
|
|
|
*/
|
|
|
|
public function __isset($key) {
|
|
|
|
return !empty($this->properties->{$key});
|
|
|
|
}
|
|
|
|
|
2011-04-18 18:27:10 +08:00
|
|
|
/**
|
|
|
|
* Calculate the context value needed for calendar_event.
|
|
|
|
* Event's type can be determine by the available value store in $data
|
|
|
|
* It is important to check for the existence of course/courseid to determine
|
|
|
|
* the course event.
|
|
|
|
* Default value is set to CONTEXT_USER
|
|
|
|
*
|
2012-01-13 17:45:55 +08:00
|
|
|
* @param stdClass $data information about event
|
|
|
|
* @return stdClass The context object.
|
2011-04-18 18:27:10 +08:00
|
|
|
*/
|
|
|
|
protected function calculate_context(stdClass $data) {
|
2012-01-21 19:57:01 +01:00
|
|
|
global $USER, $DB;
|
2011-04-18 18:27:10 +08:00
|
|
|
|
|
|
|
$context = null;
|
|
|
|
if (isset($data->courseid) && $data->courseid > 0) {
|
2012-07-23 16:22:36 +08:00
|
|
|
$context = context_course::instance($data->courseid);
|
2011-04-18 18:27:10 +08:00
|
|
|
} else if (isset($data->course) && $data->course > 0) {
|
2012-07-23 16:22:36 +08:00
|
|
|
$context = context_course::instance($data->course);
|
2011-04-18 18:27:10 +08:00
|
|
|
} else if (isset($data->groupid) && $data->groupid > 0) {
|
|
|
|
$group = $DB->get_record('groups', array('id'=>$data->groupid));
|
2012-07-23 16:22:36 +08:00
|
|
|
$context = context_course::instance($group->courseid);
|
2011-04-18 18:27:10 +08:00
|
|
|
} else if (isset($data->userid) && $data->userid > 0 && $data->userid == $USER->id) {
|
2012-07-23 16:22:36 +08:00
|
|
|
$context = context_user::instance($data->userid);
|
2011-04-18 18:27:10 +08:00
|
|
|
} else if (isset($data->userid) && $data->userid > 0 && $data->userid != $USER->id &&
|
|
|
|
isset($data->instance) && $data->instance > 0) {
|
2011-06-20 14:32:47 +08:00
|
|
|
$cm = get_coursemodule_from_instance($data->modulename, $data->instance, 0, false, MUST_EXIST);
|
2012-07-23 16:22:36 +08:00
|
|
|
$context = context_course::instance($cm->course);
|
2011-04-18 18:27:10 +08:00
|
|
|
} else {
|
2012-10-15 16:31:12 +08:00
|
|
|
$context = context_user::instance($data->userid);
|
2011-04-18 18:27:10 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
return $context;
|
|
|
|
}
|
|
|
|
|
2009-11-02 03:50:56 +00:00
|
|
|
/**
|
|
|
|
* Returns an array of editoroptions for this event: Called by __get
|
|
|
|
* Please use $blah = $event->editoroptions;
|
2012-01-13 17:45:55 +08:00
|
|
|
*
|
|
|
|
* @return array event editor options
|
2009-11-02 03:50:56 +00:00
|
|
|
*/
|
|
|
|
protected function get_editoroptions() {
|
|
|
|
return $this->editoroptions;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns an event description: Called by __get
|
|
|
|
* Please use $blah = $event->description;
|
|
|
|
*
|
2012-01-13 17:45:55 +08:00
|
|
|
* @return string event description
|
2009-11-02 03:50:56 +00:00
|
|
|
*/
|
|
|
|
protected function get_description() {
|
2011-04-18 18:27:10 +08:00
|
|
|
global $CFG;
|
2011-01-23 18:34:41 +01:00
|
|
|
|
|
|
|
require_once($CFG->libdir . '/filelib.php');
|
|
|
|
|
2009-11-02 03:50:56 +00:00
|
|
|
if ($this->_description === null) {
|
|
|
|
// Check if we have already resolved the context for this event
|
|
|
|
if ($this->editorcontext === null) {
|
|
|
|
// Switch on the event type to decide upon the appropriate context
|
|
|
|
// to use for this event
|
2011-04-18 18:27:10 +08:00
|
|
|
$this->editorcontext = $this->properties->context;
|
|
|
|
if ($this->properties->eventtype != 'user' && $this->properties->eventtype != 'course'
|
|
|
|
&& $this->properties->eventtype != 'site' && $this->properties->eventtype != 'group') {
|
|
|
|
return clean_text($this->properties->description, $this->properties->format);
|
2009-11-02 03:50:56 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Work out the item id for the editor, if this is a repeated event then the files will
|
|
|
|
// be associated with the original
|
|
|
|
if (!empty($this->properties->repeatid) && $this->properties->repeatid > 0) {
|
|
|
|
$itemid = $this->properties->repeatid;
|
|
|
|
} else {
|
|
|
|
$itemid = $this->properties->id;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Convert file paths in the description so that things display correctly
|
2010-07-03 13:37:13 +00:00
|
|
|
$this->_description = file_rewrite_pluginfile_urls($this->properties->description, 'pluginfile.php', $this->editorcontext->id, 'calendar', 'event_description', $itemid);
|
2009-11-02 03:50:56 +00:00
|
|
|
// Clean the text so no nasties get through
|
|
|
|
$this->_description = clean_text($this->_description, $this->properties->format);
|
|
|
|
}
|
|
|
|
// Finally return the description
|
|
|
|
return $this->_description;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the number of repeat events there are in this events series
|
2009-11-04 08:11:02 +00:00
|
|
|
*
|
2012-01-13 17:45:55 +08:00
|
|
|
* @return int number of event repeated
|
2009-11-02 03:50:56 +00:00
|
|
|
*/
|
|
|
|
public function count_repeats() {
|
|
|
|
global $DB;
|
|
|
|
if (!empty($this->properties->repeatid)) {
|
|
|
|
$this->properties->eventrepeats = $DB->count_records('event', array('repeatid'=>$this->properties->repeatid));
|
|
|
|
// We don't want to count ourselves
|
|
|
|
$this->properties->eventrepeats--;
|
|
|
|
}
|
|
|
|
return $this->properties->eventrepeats;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Update or create an event within the database
|
|
|
|
*
|
|
|
|
* Pass in a object containing the event properties and this function will
|
|
|
|
* insert it into the database and deal with any associated files
|
|
|
|
*
|
|
|
|
* @see add_event()
|
|
|
|
* @see update_event()
|
|
|
|
*
|
2012-01-13 17:45:55 +08:00
|
|
|
* @param stdClass $data object of event
|
|
|
|
* @param bool $checkcapability if moodle should check calendar managing capability or not
|
|
|
|
* @return bool event updated
|
2009-11-02 03:50:56 +00:00
|
|
|
*/
|
2010-11-17 07:56:40 +00:00
|
|
|
public function update($data, $checkcapability=true) {
|
2014-03-21 11:30:56 +08:00
|
|
|
global $DB, $USER;
|
2009-11-02 03:50:56 +00:00
|
|
|
|
2010-05-27 02:13:18 +00:00
|
|
|
foreach ($data as $key=>$value) {
|
|
|
|
$this->properties->$key = $value;
|
|
|
|
}
|
|
|
|
|
2009-11-02 03:50:56 +00:00
|
|
|
$this->properties->timemodified = time();
|
|
|
|
$usingeditor = (!empty($this->properties->description) && is_array($this->properties->description));
|
|
|
|
|
2014-03-21 11:30:56 +08:00
|
|
|
// Prepare event data.
|
|
|
|
$eventargs = array(
|
|
|
|
'context' => $this->properties->context,
|
|
|
|
'objectid' => $this->properties->id,
|
|
|
|
'other' => array(
|
|
|
|
'repeatid' => empty($this->properties->repeatid) ? 0 : $this->properties->repeatid,
|
|
|
|
'timestart' => $this->properties->timestart,
|
|
|
|
'name' => $this->properties->name
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
2009-11-02 03:50:56 +00:00
|
|
|
if (empty($this->properties->id) || $this->properties->id < 1) {
|
|
|
|
|
2010-11-17 07:56:40 +00:00
|
|
|
if ($checkcapability) {
|
|
|
|
if (!calendar_add_event_allowed($this->properties)) {
|
|
|
|
print_error('nopermissiontoupdatecalendar');
|
|
|
|
}
|
2009-11-02 03:50:56 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if ($usingeditor) {
|
|
|
|
switch ($this->properties->eventtype) {
|
|
|
|
case 'user':
|
|
|
|
$this->properties->courseid = 0;
|
2012-11-02 13:08:07 +08:00
|
|
|
$this->properties->course = 0;
|
2009-11-02 03:50:56 +00:00
|
|
|
$this->properties->groupid = 0;
|
|
|
|
$this->properties->userid = $USER->id;
|
|
|
|
break;
|
|
|
|
case 'site':
|
|
|
|
$this->properties->courseid = SITEID;
|
2012-11-02 13:08:07 +08:00
|
|
|
$this->properties->course = SITEID;
|
2009-11-02 03:50:56 +00:00
|
|
|
$this->properties->groupid = 0;
|
|
|
|
$this->properties->userid = $USER->id;
|
|
|
|
break;
|
|
|
|
case 'course':
|
|
|
|
$this->properties->groupid = 0;
|
|
|
|
$this->properties->userid = $USER->id;
|
|
|
|
break;
|
|
|
|
case 'group':
|
|
|
|
$this->properties->userid = $USER->id;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
// Ewww we should NEVER get here, but just incase we do lets
|
|
|
|
// fail gracefully
|
|
|
|
$usingeditor = false;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2012-11-02 13:08:07 +08:00
|
|
|
// If we are actually using the editor, we recalculate the context because some default values
|
|
|
|
// were set when calculate_context() was called from the constructor.
|
|
|
|
if ($usingeditor) {
|
|
|
|
$this->properties->context = $this->calculate_context($this->properties);
|
|
|
|
$this->editorcontext = $this->properties->context;
|
|
|
|
}
|
|
|
|
|
2009-11-02 03:50:56 +00:00
|
|
|
$editor = $this->properties->description;
|
|
|
|
$this->properties->format = $this->properties->description['format'];
|
|
|
|
$this->properties->description = $this->properties->description['text'];
|
|
|
|
}
|
|
|
|
|
|
|
|
// Insert the event into the database
|
|
|
|
$this->properties->id = $DB->insert_record('event', $this->properties);
|
|
|
|
|
|
|
|
if ($usingeditor) {
|
|
|
|
$this->properties->description = file_save_draft_area_files(
|
|
|
|
$editor['itemid'],
|
|
|
|
$this->editorcontext->id,
|
2010-07-03 13:37:13 +00:00
|
|
|
'calendar',
|
|
|
|
'event_description',
|
2009-11-02 03:50:56 +00:00
|
|
|
$this->properties->id,
|
|
|
|
$this->editoroptions,
|
|
|
|
$editor['text'],
|
|
|
|
$this->editoroptions['forcehttps']);
|
|
|
|
$DB->set_field('event', 'description', $this->properties->description, array('id'=>$this->properties->id));
|
|
|
|
}
|
2009-11-04 08:11:02 +00:00
|
|
|
|
2009-11-02 03:50:56 +00:00
|
|
|
// Log the event entry.
|
2014-03-21 11:30:56 +08:00
|
|
|
$eventargs['objectid'] = $this->properties->id;
|
|
|
|
$eventargs['context'] = $this->properties->context;
|
|
|
|
$event = \core\event\calendar_event_created::create($eventargs);
|
|
|
|
$event->trigger();
|
2009-11-02 03:50:56 +00:00
|
|
|
|
|
|
|
$repeatedids = array();
|
|
|
|
|
|
|
|
if (!empty($this->properties->repeat)) {
|
|
|
|
$this->properties->repeatid = $this->properties->id;
|
|
|
|
$DB->set_field('event', 'repeatid', $this->properties->repeatid, array('id'=>$this->properties->id));
|
|
|
|
|
|
|
|
$eventcopy = clone($this->properties);
|
|
|
|
unset($eventcopy->id);
|
|
|
|
|
|
|
|
for($i = 1; $i < $eventcopy->repeats; $i++) {
|
|
|
|
|
|
|
|
$eventcopy->timestart = ($eventcopy->timestart+WEEKSECS) + dst_offset_on($eventcopy->timestart) - dst_offset_on($eventcopy->timestart+WEEKSECS);
|
|
|
|
|
|
|
|
// Get the event id for the log record.
|
|
|
|
$eventcopyid = $DB->insert_record('event', $eventcopy);
|
|
|
|
|
|
|
|
// If the context has been set delete all associated files
|
|
|
|
if ($usingeditor) {
|
|
|
|
$fs = get_file_storage();
|
2010-07-03 13:37:13 +00:00
|
|
|
$files = $fs->get_area_files($this->editorcontext->id, 'calendar', 'event_description', $this->properties->id);
|
2009-11-02 03:50:56 +00:00
|
|
|
foreach ($files as $file) {
|
|
|
|
$fs->create_file_from_storedfile(array('itemid'=>$eventcopyid), $file);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$repeatedids[] = $eventcopyid;
|
2014-03-21 11:30:56 +08:00
|
|
|
|
|
|
|
// Trigger an event.
|
|
|
|
$eventargs['objectid'] = $eventcopyid;
|
|
|
|
$eventargs['other']['timestart'] = $eventcopy->timestart;
|
|
|
|
$event = \core\event\calendar_event_created::create($eventargs);
|
|
|
|
$event->trigger();
|
2009-11-02 03:50:56 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Hook for tracking added events
|
|
|
|
self::calendar_event_hook('add_event', array($this->properties, $repeatedids));
|
|
|
|
return true;
|
|
|
|
} else {
|
|
|
|
|
2010-11-17 07:56:40 +00:00
|
|
|
if ($checkcapability) {
|
|
|
|
if(!calendar_edit_event_allowed($this->properties)) {
|
|
|
|
print_error('nopermissiontoupdatecalendar');
|
|
|
|
}
|
2009-11-02 03:50:56 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if ($usingeditor) {
|
|
|
|
if ($this->editorcontext !== null) {
|
|
|
|
$this->properties->description = file_save_draft_area_files(
|
|
|
|
$this->properties->description['itemid'],
|
|
|
|
$this->editorcontext->id,
|
2010-07-03 13:37:13 +00:00
|
|
|
'calendar',
|
|
|
|
'event_description',
|
2009-11-02 03:50:56 +00:00
|
|
|
$this->properties->id,
|
|
|
|
$this->editoroptions,
|
|
|
|
$this->properties->description['text'],
|
|
|
|
$this->editoroptions['forcehttps']);
|
|
|
|
} else {
|
|
|
|
$this->properties->format = $this->properties->description['format'];
|
|
|
|
$this->properties->description = $this->properties->description['text'];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$event = $DB->get_record('event', array('id'=>$this->properties->id));
|
|
|
|
|
|
|
|
$updaterepeated = (!empty($this->properties->repeatid) && !empty($this->properties->repeateditall));
|
|
|
|
|
|
|
|
if ($updaterepeated) {
|
|
|
|
// Update all
|
|
|
|
if ($this->properties->timestart != $event->timestart) {
|
|
|
|
$timestartoffset = $this->properties->timestart - $event->timestart;
|
|
|
|
$sql = "UPDATE {event}
|
|
|
|
SET name = ?,
|
|
|
|
description = ?,
|
|
|
|
timestart = timestart + ?,
|
|
|
|
timeduration = ?,
|
|
|
|
timemodified = ?
|
|
|
|
WHERE repeatid = ?";
|
|
|
|
$params = array($this->properties->name, $this->properties->description, $timestartoffset, $this->properties->timeduration, time(), $event->repeatid);
|
|
|
|
} else {
|
|
|
|
$sql = "UPDATE {event} SET name = ?, description = ?, timeduration = ?, timemodified = ? WHERE repeatid = ?";
|
|
|
|
$params = array($this->properties->name, $this->properties->description, $this->properties->timeduration, time(), $event->repeatid);
|
|
|
|
}
|
|
|
|
$DB->execute($sql, $params);
|
|
|
|
|
2014-03-21 11:30:56 +08:00
|
|
|
// Trigger an update event for each of the calendar event.
|
|
|
|
$events = $DB->get_records('event', array('repeatid' => $event->repeatid), '', 'id,timestart');
|
|
|
|
foreach ($events as $event) {
|
|
|
|
$eventargs['objectid'] = $event->id;
|
|
|
|
$eventargs['other']['timestart'] = $event->timestart;
|
|
|
|
$event = \core\event\calendar_event_updated::create($eventargs);
|
|
|
|
$event->trigger();
|
|
|
|
}
|
2009-11-02 03:50:56 +00:00
|
|
|
} else {
|
|
|
|
$DB->update_record('event', $this->properties);
|
2009-11-20 06:36:11 +00:00
|
|
|
$event = calendar_event::load($this->properties->id);
|
|
|
|
$this->properties = $event->properties();
|
2014-03-21 11:30:56 +08:00
|
|
|
|
|
|
|
// Trigger an update event.
|
|
|
|
$event = \core\event\calendar_event_updated::create($eventargs);
|
|
|
|
$event->trigger();
|
2009-11-02 03:50:56 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Hook for tracking event updates
|
|
|
|
self::calendar_event_hook('update_event', array($this->properties, $updaterepeated));
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Deletes an event and if selected an repeated events in the same series
|
|
|
|
*
|
|
|
|
* This function deletes an event, any associated events if $deleterepeated=true,
|
|
|
|
* and cleans up any files associated with the events.
|
|
|
|
*
|
|
|
|
* @see delete_event()
|
|
|
|
*
|
2012-01-13 17:45:55 +08:00
|
|
|
* @param bool $deleterepeated delete event repeatedly
|
|
|
|
* @return bool succession of deleting event
|
2009-11-02 03:50:56 +00:00
|
|
|
*/
|
|
|
|
public function delete($deleterepeated=false) {
|
2011-04-18 18:27:10 +08:00
|
|
|
global $DB;
|
2009-11-02 03:50:56 +00:00
|
|
|
|
|
|
|
// If $this->properties->id is not set then something is wrong
|
|
|
|
if (empty($this->properties->id)) {
|
|
|
|
debugging('Attempting to delete an event before it has been loaded', DEBUG_DEVELOPER);
|
|
|
|
return false;
|
|
|
|
}
|
2014-03-21 11:30:56 +08:00
|
|
|
$calevent = $DB->get_record('event', array('id' => $this->properties->id), '*', MUST_EXIST);
|
2009-11-02 03:50:56 +00:00
|
|
|
// Delete the event
|
|
|
|
$DB->delete_records('event', array('id'=>$this->properties->id));
|
|
|
|
|
2014-03-21 11:30:56 +08:00
|
|
|
// Trigger an event for the delete action.
|
|
|
|
$eventargs = array(
|
|
|
|
'context' => $this->properties->context,
|
|
|
|
'objectid' => $this->properties->id,
|
|
|
|
'other' => array(
|
|
|
|
'repeatid' => empty($this->properties->repeatid) ? 0 : $this->properties->repeatid,
|
|
|
|
'timestart' => $this->properties->timestart,
|
|
|
|
'name' => $this->properties->name
|
|
|
|
));
|
|
|
|
$event = \core\event\calendar_event_deleted::create($eventargs);
|
|
|
|
$event->add_record_snapshot('event', $calevent);
|
|
|
|
$event->trigger();
|
|
|
|
|
2012-04-27 16:33:26 +08:00
|
|
|
// If we are deleting parent of a repeated event series, promote the next event in the series as parent
|
|
|
|
if (($this->properties->id == $this->properties->repeatid) && !$deleterepeated) {
|
|
|
|
$newparent = $DB->get_field_sql("SELECT id from {event} where repeatid = ? order by id ASC", array($this->properties->id), IGNORE_MULTIPLE);
|
|
|
|
if (!empty($newparent)) {
|
|
|
|
$DB->execute("UPDATE {event} SET repeatid = ? WHERE repeatid = ?", array($newparent, $this->properties->id));
|
2012-05-01 10:58:00 +08:00
|
|
|
// Get all records where the repeatid is the same as the event being removed
|
|
|
|
$events = $DB->get_records('event', array('repeatid' => $newparent));
|
2014-03-21 11:30:56 +08:00
|
|
|
// For each of the returned events trigger the event_update hook and an update event.
|
2012-05-01 10:58:00 +08:00
|
|
|
foreach ($events as $event) {
|
2014-03-21 11:30:56 +08:00
|
|
|
// Trigger an event for the update.
|
|
|
|
$eventargs['objectid'] = $event->id;
|
|
|
|
$eventargs['other']['timestart'] = $event->timestart;
|
|
|
|
$event = \core\event\calendar_event_updated::create($eventargs);
|
|
|
|
$event->trigger();
|
|
|
|
|
2012-05-01 10:58:00 +08:00
|
|
|
self::calendar_event_hook('update_event', array($event, false));
|
|
|
|
}
|
2012-04-27 16:33:26 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2009-11-02 03:50:56 +00:00
|
|
|
// If the editor context hasn't already been set then set it now
|
|
|
|
if ($this->editorcontext === null) {
|
2011-04-18 18:27:10 +08:00
|
|
|
$this->editorcontext = $this->properties->context;
|
2009-11-02 03:50:56 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// If the context has been set delete all associated files
|
|
|
|
if ($this->editorcontext !== null) {
|
|
|
|
$fs = get_file_storage();
|
2010-07-03 13:37:13 +00:00
|
|
|
$files = $fs->get_area_files($this->editorcontext->id, 'calendar', 'event_description', $this->properties->id);
|
2009-11-02 03:50:56 +00:00
|
|
|
foreach ($files as $file) {
|
|
|
|
$file->delete();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Fire the event deleted hook
|
|
|
|
self::calendar_event_hook('delete_event', array($this->properties->id, $deleterepeated));
|
|
|
|
|
|
|
|
// If we need to delete repeated events then we will fetch them all and delete one by one
|
|
|
|
if ($deleterepeated && !empty($this->properties->repeatid) && $this->properties->repeatid > 0) {
|
|
|
|
// Get all records where the repeatid is the same as the event being removed
|
|
|
|
$events = $DB->get_records('event', array('repeatid'=>$this->properties->repeatid));
|
|
|
|
// For each of the returned events populate a calendar_event object and call delete
|
|
|
|
// make sure the arg passed is false as we are already deleting all repeats
|
|
|
|
foreach ($events as $event) {
|
|
|
|
$event = new calendar_event($event);
|
|
|
|
$event->delete(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Fetch all event properties
|
|
|
|
*
|
|
|
|
* This function returns all of the events properties as an object and optionally
|
|
|
|
* can prepare an editor for the description field at the same time. This is
|
|
|
|
* designed to work when the properties are going to be used to set the default
|
|
|
|
* values of a moodle forms form.
|
|
|
|
*
|
|
|
|
* @param bool $prepareeditor If set to true a editor is prepared for use with
|
|
|
|
* the mforms editor element. (for description)
|
|
|
|
* @return stdClass Object containing event properties
|
|
|
|
*/
|
|
|
|
public function properties($prepareeditor=false) {
|
|
|
|
global $USER, $CFG, $DB;
|
|
|
|
|
|
|
|
// First take a copy of the properties. We don't want to actually change the
|
|
|
|
// properties or we'd forever be converting back and forwards between an
|
|
|
|
// editor formatted description and not
|
|
|
|
$properties = clone($this->properties);
|
|
|
|
// Clean the description here
|
|
|
|
$properties->description = clean_text($properties->description, $properties->format);
|
|
|
|
|
|
|
|
// If set to true we need to prepare the properties for use with an editor
|
|
|
|
// and prepare the file area
|
|
|
|
if ($prepareeditor) {
|
|
|
|
|
|
|
|
// We may or may not have a property id. If we do then we need to work
|
|
|
|
// out the context so we can copy the existing files to the draft area
|
|
|
|
if (!empty($properties->id)) {
|
|
|
|
|
|
|
|
if ($properties->eventtype === 'site') {
|
|
|
|
// Site context
|
2011-04-18 18:27:10 +08:00
|
|
|
$this->editorcontext = $this->properties->context;
|
2009-11-02 03:50:56 +00:00
|
|
|
} else if ($properties->eventtype === 'user') {
|
|
|
|
// User context
|
2011-04-18 18:27:10 +08:00
|
|
|
$this->editorcontext = $this->properties->context;
|
2009-11-02 03:50:56 +00:00
|
|
|
} else if ($properties->eventtype === 'group' || $properties->eventtype === 'course') {
|
|
|
|
// First check the course is valid
|
|
|
|
$course = $DB->get_record('course', array('id'=>$properties->courseid));
|
|
|
|
if (!$course) {
|
|
|
|
print_error('invalidcourse');
|
|
|
|
}
|
|
|
|
// Course context
|
2011-04-18 18:27:10 +08:00
|
|
|
$this->editorcontext = $this->properties->context;
|
2009-11-02 03:50:56 +00:00
|
|
|
// We have a course and are within the course context so we had
|
|
|
|
// better use the courses max bytes value
|
|
|
|
$this->editoroptions['maxbytes'] = $course->maxbytes;
|
|
|
|
} else {
|
|
|
|
// If we get here we have a custom event type as used by some
|
|
|
|
// modules. In this case the event will have been added by
|
|
|
|
// code and we won't need the editor
|
|
|
|
$this->editoroptions['maxbytes'] = 0;
|
|
|
|
$this->editoroptions['maxfiles'] = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (empty($this->editorcontext) || empty($this->editorcontext->id)) {
|
|
|
|
$contextid = false;
|
|
|
|
} else {
|
|
|
|
// Get the context id that is what we really want
|
|
|
|
$contextid = $this->editorcontext->id;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
|
|
|
|
// If we get here then this is a new event in which case we don't need a
|
|
|
|
// context as there is no existing files to copy to the draft area.
|
|
|
|
$contextid = null;
|
|
|
|
}
|
|
|
|
|
|
|
|
// If the contextid === false we don't support files so no preparing
|
|
|
|
// a draft area
|
|
|
|
if ($contextid !== false) {
|
|
|
|
// Just encase it has already been submitted
|
|
|
|
$draftiddescription = file_get_submitted_draft_itemid('description');
|
|
|
|
// Prepare the draft area, this copies existing files to the draft area as well
|
2010-07-03 13:37:13 +00:00
|
|
|
$properties->description = file_prepare_draft_area($draftiddescription, $contextid, 'calendar', 'event_description', $properties->id, $this->editoroptions, $properties->description);
|
2009-11-02 03:50:56 +00:00
|
|
|
} else {
|
|
|
|
$draftiddescription = 0;
|
|
|
|
}
|
2009-11-04 08:11:02 +00:00
|
|
|
|
2009-11-02 03:50:56 +00:00
|
|
|
// Structure the description field as the editor requires
|
|
|
|
$properties->description = array('text'=>$properties->description, 'format'=>$properties->format, 'itemid'=>$draftiddescription);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Finally return the properties
|
|
|
|
return $properties;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Toggles the visibility of an event
|
|
|
|
*
|
|
|
|
* @param null|bool $force If it is left null the events visibility is flipped,
|
|
|
|
* If it is false the event is made hidden, if it is true it
|
|
|
|
* is made visible.
|
2012-01-13 17:45:55 +08:00
|
|
|
* @return bool if event is successfully updated, toggle will be visible
|
2009-11-02 03:50:56 +00:00
|
|
|
*/
|
|
|
|
public function toggle_visibility($force=null) {
|
|
|
|
global $CFG, $DB;
|
|
|
|
|
|
|
|
// Set visible to the default if it is not already set
|
|
|
|
if (empty($this->properties->visible)) {
|
|
|
|
$this->properties->visible = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($force === true || ($force !== false && $this->properties->visible == 0)) {
|
|
|
|
// Make this event visible
|
|
|
|
$this->properties->visible = 1;
|
|
|
|
// Fire the hook
|
|
|
|
self::calendar_event_hook('show_event', array($this->properties));
|
|
|
|
} else {
|
|
|
|
// Make this event hidden
|
|
|
|
$this->properties->visible = 0;
|
|
|
|
// Fire the hook
|
|
|
|
self::calendar_event_hook('hide_event', array($this->properties));
|
|
|
|
}
|
|
|
|
|
|
|
|
// Update the database to reflect this change
|
|
|
|
return $DB->set_field('event', 'visible', $this->properties->visible, array('id'=>$this->properties->id));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Attempts to call the hook for the specified action should a calendar type
|
|
|
|
* by set $CFG->calendar, and the appopriate function defined
|
|
|
|
*
|
|
|
|
* @param string $action One of `update_event`, `add_event`, `delete_event`, `show_event`, `hide_event`
|
|
|
|
* @param array $args The args to pass to the hook, usually the event is the first element
|
2012-01-13 17:45:55 +08:00
|
|
|
* @return bool attempts to call event hook
|
2009-11-02 03:50:56 +00:00
|
|
|
*/
|
|
|
|
public static function calendar_event_hook($action, array $args) {
|
|
|
|
global $CFG;
|
|
|
|
static $extcalendarinc;
|
|
|
|
if ($extcalendarinc === null) {
|
2012-04-03 11:45:43 -06:00
|
|
|
if (!empty($CFG->calendar)) {
|
|
|
|
if (is_readable($CFG->dirroot .'/calendar/'. $CFG->calendar .'/lib.php')) {
|
|
|
|
include_once($CFG->dirroot .'/calendar/'. $CFG->calendar .'/lib.php');
|
|
|
|
$extcalendarinc = true;
|
|
|
|
} else {
|
|
|
|
debugging("Calendar lib file missing or not readable at /calendar/{$CFG->calendar}/lib.php.",
|
|
|
|
DEBUG_DEVELOPER);
|
|
|
|
$extcalendarinc = false;
|
|
|
|
}
|
2009-11-02 03:50:56 +00:00
|
|
|
} else {
|
|
|
|
$extcalendarinc = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if($extcalendarinc === false) {
|
|
|
|
return false;
|
|
|
|
}
|
2010-05-27 02:13:18 +00:00
|
|
|
$hook = $CFG->calendar .'_'.$action;
|
2009-11-02 03:50:56 +00:00
|
|
|
if (function_exists($hook)) {
|
|
|
|
call_user_func_array($hook, $args);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns a calendar_event object when provided with an event id
|
|
|
|
*
|
|
|
|
* This function makes use of MUST_EXIST, if the event id passed in is invalid
|
|
|
|
* it will result in an exception being thrown
|
|
|
|
*
|
2012-01-13 17:45:55 +08:00
|
|
|
* @param int|object $param event object or event id
|
|
|
|
* @return calendar_event|false status for loading calendar_event
|
2009-11-02 03:50:56 +00:00
|
|
|
*/
|
2009-12-03 03:59:22 +00:00
|
|
|
public static function load($param) {
|
2009-11-02 03:50:56 +00:00
|
|
|
global $DB;
|
2009-12-03 03:59:22 +00:00
|
|
|
if (is_object($param)) {
|
|
|
|
$event = new calendar_event($param);
|
|
|
|
} else {
|
|
|
|
$event = $DB->get_record('event', array('id'=>(int)$param), '*', MUST_EXIST);
|
|
|
|
$event = new calendar_event($event);
|
|
|
|
}
|
2009-11-02 03:50:56 +00:00
|
|
|
return $event;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates a new event and returns a calendar_event object
|
|
|
|
*
|
2014-02-28 13:25:16 +08:00
|
|
|
* @param stdClass|array $properties An object containing event properties
|
|
|
|
* @param bool $checkcapability Check caps or not
|
|
|
|
* @throws coding_exception
|
|
|
|
*
|
|
|
|
* @return calendar_event|bool The event object or false if it failed
|
2009-11-02 03:50:56 +00:00
|
|
|
*/
|
2014-02-28 13:25:16 +08:00
|
|
|
public static function create($properties, $checkcapability = true) {
|
2009-11-02 03:50:56 +00:00
|
|
|
if (is_array($properties)) {
|
|
|
|
$properties = (object)$properties;
|
|
|
|
}
|
|
|
|
if (!is_object($properties)) {
|
|
|
|
throw new coding_exception('When creating an event properties should be either an object or an assoc array');
|
|
|
|
}
|
2011-04-18 18:27:10 +08:00
|
|
|
$event = new calendar_event($properties);
|
2014-02-28 13:25:16 +08:00
|
|
|
if ($event->update($properties, $checkcapability)) {
|
2009-11-02 03:50:56 +00:00
|
|
|
return $event;
|
|
|
|
} else {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2010-06-22 04:03:44 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Calendar information class
|
|
|
|
*
|
|
|
|
* This class is used simply to organise the information pertaining to a calendar
|
|
|
|
* and is used primarily to make information easily available.
|
2012-01-13 17:45:55 +08:00
|
|
|
*
|
|
|
|
* @package core_calendar
|
|
|
|
* @category calendar
|
|
|
|
* @copyright 2010 Sam Hemelryk
|
|
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
2010-06-22 04:03:44 +00:00
|
|
|
*/
|
|
|
|
class calendar_information {
|
2012-01-13 17:45:55 +08:00
|
|
|
|
2013-09-16 17:30:59 +08:00
|
|
|
/**
|
|
|
|
* @var int The timestamp
|
|
|
|
*
|
|
|
|
* Rather than setting the day, month and year we will set a timestamp which will be able
|
|
|
|
* to be used by multiple calendars.
|
|
|
|
*/
|
|
|
|
public $time;
|
2010-06-22 04:03:44 +00:00
|
|
|
|
2012-01-13 17:45:55 +08:00
|
|
|
/** @var int A course id */
|
2010-06-22 04:03:44 +00:00
|
|
|
public $courseid = null;
|
2012-01-13 17:45:55 +08:00
|
|
|
|
|
|
|
/** @var array An array of courses */
|
2010-06-22 04:03:44 +00:00
|
|
|
public $courses = array();
|
2012-01-13 17:45:55 +08:00
|
|
|
|
|
|
|
/** @var array An array of groups */
|
2010-06-22 04:03:44 +00:00
|
|
|
public $groups = array();
|
2012-01-13 17:45:55 +08:00
|
|
|
|
|
|
|
/** @var array An array of users */
|
2010-06-22 04:03:44 +00:00
|
|
|
public $users = array();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates a new instance
|
|
|
|
*
|
2012-01-13 17:45:55 +08:00
|
|
|
* @param int $day the number of the day
|
|
|
|
* @param int $month the number of the month
|
|
|
|
* @param int $year the number of the year
|
2013-09-16 17:30:59 +08:00
|
|
|
* @param int $time the unixtimestamp representing the date we want to view, this is used instead of $calmonth
|
|
|
|
* and $calyear to support multiple calendars
|
2010-06-22 04:03:44 +00:00
|
|
|
*/
|
2013-09-16 17:30:59 +08:00
|
|
|
public function __construct($day = 0, $month = 0, $year = 0, $time = 0) {
|
|
|
|
// If a day, month and year were passed then convert it to a timestamp. If these were passed
|
|
|
|
// then we can assume the day, month and year are passed as Gregorian, as no where in core
|
|
|
|
// should we be passing these values rather than the time. This is done for BC.
|
|
|
|
if (!empty($day) || !empty($month) || !empty($year)) {
|
|
|
|
$date = usergetdate(time());
|
|
|
|
if (empty($day)) {
|
|
|
|
$day = $date['mday'];
|
|
|
|
}
|
|
|
|
if (empty($month)) {
|
|
|
|
$month = $date['mon'];
|
|
|
|
}
|
|
|
|
if (empty($year)) {
|
|
|
|
$year = $date['year'];
|
|
|
|
}
|
|
|
|
if (checkdate($month, $day, $year)) {
|
|
|
|
$this->time = make_timestamp($year, $month, $day);
|
|
|
|
} else {
|
|
|
|
$this->time = time();
|
|
|
|
}
|
|
|
|
} else if (!empty($time)) {
|
|
|
|
$this->time = $time;
|
|
|
|
} else {
|
|
|
|
$this->time = time();
|
2010-09-28 02:02:04 +00:00
|
|
|
}
|
2010-06-22 04:03:44 +00:00
|
|
|
}
|
|
|
|
|
2011-06-29 14:50:38 +08:00
|
|
|
/**
|
2012-01-13 17:45:55 +08:00
|
|
|
* Initialize calendar information
|
2011-06-29 14:50:38 +08:00
|
|
|
*
|
2012-01-13 17:45:55 +08:00
|
|
|
* @param stdClass $course object
|
2011-06-29 14:50:38 +08:00
|
|
|
* @param array $coursestoload An array of courses [$course->id => $course]
|
2012-01-13 17:45:55 +08:00
|
|
|
* @param bool $ignorefilters options to use filter
|
2011-06-29 14:50:38 +08:00
|
|
|
*/
|
|
|
|
public function prepare_for_view(stdClass $course, array $coursestoload, $ignorefilters = false) {
|
|
|
|
$this->courseid = $course->id;
|
|
|
|
$this->course = $course;
|
|
|
|
list($courses, $group, $user) = calendar_set_filters($coursestoload, $ignorefilters);
|
|
|
|
$this->courses = $courses;
|
|
|
|
$this->groups = $group;
|
|
|
|
$this->users = $user;
|
|
|
|
}
|
|
|
|
|
2010-06-22 04:03:44 +00:00
|
|
|
/**
|
|
|
|
* Ensures the date for the calendar is correct and either sets it to now
|
|
|
|
* or throws a moodle_exception if not
|
|
|
|
*
|
2012-01-13 17:45:55 +08:00
|
|
|
* @param bool $defaultonow use current time
|
|
|
|
* @throws moodle_exception
|
|
|
|
* @return bool validation of checkdate
|
2010-06-22 04:03:44 +00:00
|
|
|
*/
|
|
|
|
public function checkdate($defaultonow = true) {
|
|
|
|
if (!checkdate($this->month, $this->day, $this->year)) {
|
|
|
|
if ($defaultonow) {
|
|
|
|
$now = usergetdate(time());
|
|
|
|
$this->day = intval($now['mday']);
|
|
|
|
$this->month = intval($now['mon']);
|
|
|
|
$this->year = intval($now['year']);
|
|
|
|
return true;
|
|
|
|
} else {
|
|
|
|
throw new moodle_exception('invaliddate');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
2013-09-16 17:30:59 +08:00
|
|
|
|
2010-06-22 04:03:44 +00:00
|
|
|
/**
|
|
|
|
* Gets todays timestamp for the calendar
|
2012-01-13 17:45:55 +08:00
|
|
|
*
|
|
|
|
* @return int today timestamp
|
2010-06-22 04:03:44 +00:00
|
|
|
*/
|
|
|
|
public function timestamp_today() {
|
2013-09-16 17:30:59 +08:00
|
|
|
return $this->time;
|
2010-06-22 04:03:44 +00:00
|
|
|
}
|
|
|
|
/**
|
|
|
|
* Gets tomorrows timestamp for the calendar
|
2012-01-13 17:45:55 +08:00
|
|
|
*
|
|
|
|
* @return int tomorrow timestamp
|
2010-06-22 04:03:44 +00:00
|
|
|
*/
|
|
|
|
public function timestamp_tomorrow() {
|
2013-09-16 17:30:59 +08:00
|
|
|
return $this->time + DAYSECS;
|
2010-06-22 04:03:44 +00:00
|
|
|
}
|
|
|
|
/**
|
2012-10-15 16:31:12 +08:00
|
|
|
* Adds the pretend blocks for the calendar
|
2010-06-22 04:03:44 +00:00
|
|
|
*
|
|
|
|
* @param core_calendar_renderer $renderer
|
2012-01-13 17:45:55 +08:00
|
|
|
* @param bool $showfilters display filters, false is set as default
|
|
|
|
* @param string|null $view preference view options (eg: day, month, upcoming)
|
2010-06-22 04:03:44 +00:00
|
|
|
*/
|
|
|
|
public function add_sidecalendar_blocks(core_calendar_renderer $renderer, $showfilters=false, $view=null) {
|
|
|
|
if ($showfilters) {
|
|
|
|
$filters = new block_contents();
|
2013-09-16 17:30:59 +08:00
|
|
|
$filters->content = $renderer->fake_block_filters($this->courseid, 0, 0, 0, $view, $this->courses);
|
2010-06-22 04:03:44 +00:00
|
|
|
$filters->footer = '';
|
|
|
|
$filters->title = get_string('eventskey', 'calendar');
|
|
|
|
$renderer->add_pretend_calendar_block($filters, BLOCK_POS_RIGHT);
|
|
|
|
}
|
|
|
|
$block = new block_contents;
|
|
|
|
$block->content = $renderer->fake_block_threemonths($this);
|
|
|
|
$block->footer = '';
|
|
|
|
$block->title = get_string('monthlyview', 'calendar');
|
|
|
|
$renderer->add_pretend_calendar_block($block, BLOCK_POS_RIGHT);
|
|
|
|
}
|
2010-11-17 07:56:40 +00:00
|
|
|
}
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
|
|
|
|
/**
|
2012-10-15 16:31:12 +08:00
|
|
|
* Returns option list for the poll interval setting.
|
|
|
|
*
|
|
|
|
* @return array An array of poll interval options. Interval => description.
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
*/
|
|
|
|
function calendar_get_pollinterval_choices() {
|
|
|
|
return array(
|
2012-10-15 16:31:12 +08:00
|
|
|
'0' => new lang_string('never', 'calendar'),
|
2014-02-28 13:25:16 +08:00
|
|
|
HOURSECS => new lang_string('hourly', 'calendar'),
|
|
|
|
DAYSECS => new lang_string('daily', 'calendar'),
|
|
|
|
WEEKSECS => new lang_string('weekly', 'calendar'),
|
2012-10-15 16:31:12 +08:00
|
|
|
'2628000' => new lang_string('monthly', 'calendar'),
|
2014-02-28 13:25:16 +08:00
|
|
|
YEARSECS => new lang_string('annually', 'calendar')
|
2012-10-15 16:31:12 +08:00
|
|
|
);
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2012-10-15 16:31:12 +08:00
|
|
|
* Returns option list of available options for the calendar event type, given the current user and course.
|
|
|
|
*
|
2012-10-12 11:57:32 +13:00
|
|
|
* @param int $courseid The id of the course
|
2012-10-15 16:31:12 +08:00
|
|
|
* @return array An array containing the event types the user can create.
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
*/
|
|
|
|
function calendar_get_eventtype_choices($courseid) {
|
|
|
|
$choices = array();
|
|
|
|
$allowed = new stdClass;
|
|
|
|
calendar_get_allowed_types($allowed, $courseid);
|
|
|
|
|
|
|
|
if ($allowed->user) {
|
2012-11-16 13:52:44 +08:00
|
|
|
$choices['user'] = get_string('userevents', 'calendar');
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
}
|
|
|
|
if ($allowed->site) {
|
2012-11-21 10:29:04 +08:00
|
|
|
$choices['site'] = get_string('siteevents', 'calendar');
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
}
|
|
|
|
if (!empty($allowed->courses)) {
|
2012-11-16 13:52:44 +08:00
|
|
|
$choices['course'] = get_string('courseevents', 'calendar');
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
}
|
|
|
|
if (!empty($allowed->groups) and is_array($allowed->groups)) {
|
|
|
|
$choices['group'] = get_string('group');
|
|
|
|
}
|
|
|
|
|
|
|
|
return array($choices, $allowed->groups);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add an iCalendar subscription to the database.
|
2012-10-15 16:31:12 +08:00
|
|
|
*
|
|
|
|
* @param stdClass $sub The subscription object (e.g. from the form)
|
|
|
|
* @return int The insert ID, if any.
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
*/
|
|
|
|
function calendar_add_subscription($sub) {
|
2012-11-16 13:52:44 +08:00
|
|
|
global $DB, $USER, $SITE;
|
2012-10-15 16:31:12 +08:00
|
|
|
|
2012-11-16 13:52:44 +08:00
|
|
|
if ($sub->eventtype === 'site') {
|
|
|
|
$sub->courseid = $SITE->id;
|
|
|
|
} else if ($sub->eventtype === 'group' || $sub->eventtype === 'course') {
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
$sub->courseid = $sub->course;
|
2012-11-16 13:52:44 +08:00
|
|
|
} else {
|
|
|
|
// User events.
|
|
|
|
$sub->courseid = 0;
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
}
|
|
|
|
$sub->userid = $USER->id;
|
|
|
|
|
2012-10-15 16:31:12 +08:00
|
|
|
// File subscriptions never update.
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
if (empty($sub->url)) {
|
|
|
|
$sub->pollinterval = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!empty($sub->name)) {
|
|
|
|
if (empty($sub->id)) {
|
|
|
|
$id = $DB->insert_record('event_subscriptions', $sub);
|
2013-01-17 11:11:15 +08:00
|
|
|
// we cannot cache the data here because $sub is not complete.
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
return $id;
|
|
|
|
} else {
|
2013-01-17 11:11:15 +08:00
|
|
|
// Why are we doing an update here?
|
2013-03-21 15:19:15 +08:00
|
|
|
calendar_update_subscription($sub);
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
return $sub->id;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
print_error('errorbadsubscription', 'importcalendar');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add an iCalendar event to the Moodle calendar.
|
2012-10-15 16:31:12 +08:00
|
|
|
*
|
2014-02-28 13:25:16 +08:00
|
|
|
* @param stdClass $event The RFC-2445 iCalendar event
|
2012-10-15 16:31:12 +08:00
|
|
|
* @param int $courseid The course ID
|
|
|
|
* @param int $subscriptionid The iCalendar subscription ID
|
2014-09-25 09:42:10 -04:00
|
|
|
* @param string $timezone The X-WR-TIMEZONE iCalendar property if provided
|
2013-01-17 11:11:15 +08:00
|
|
|
* @throws dml_exception A DML specific exception is thrown for invalid subscriptionids.
|
2014-02-28 13:25:16 +08:00
|
|
|
* @return int Code: CALENDAR_IMPORT_EVENT_UPDATED = updated, CALENDAR_IMPORT_EVENT_INSERTED = inserted, 0 = error
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
*/
|
2014-09-25 09:42:10 -04:00
|
|
|
function calendar_add_icalendar_event($event, $courseid, $subscriptionid, $timezone='UTC') {
|
2014-02-28 13:25:16 +08:00
|
|
|
global $DB;
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
|
2012-10-15 16:31:12 +08:00
|
|
|
// Probably an unsupported X-MICROSOFT-CDO-BUSYSTATUS event.
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
if (empty($event->properties['SUMMARY'])) {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
$name = $event->properties['SUMMARY'][0]->value;
|
|
|
|
$name = str_replace('\n', '<br />', $name);
|
|
|
|
$name = str_replace('\\', '', $name);
|
|
|
|
$name = preg_replace('/\s+/', ' ', $name);
|
2012-10-15 16:31:12 +08:00
|
|
|
|
|
|
|
$eventrecord = new stdClass;
|
2012-10-12 11:57:32 +13:00
|
|
|
$eventrecord->name = clean_param($name, PARAM_NOTAGS);
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
|
|
|
|
if (empty($event->properties['DESCRIPTION'][0]->value)) {
|
|
|
|
$description = '';
|
|
|
|
} else {
|
|
|
|
$description = $event->properties['DESCRIPTION'][0]->value;
|
|
|
|
$description = str_replace('\n', '<br />', $description);
|
|
|
|
$description = str_replace('\\', '', $description);
|
|
|
|
$description = preg_replace('/\s+/', ' ', $description);
|
|
|
|
}
|
2012-10-12 11:57:32 +13:00
|
|
|
$eventrecord->description = clean_param($description, PARAM_NOTAGS);
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
|
2012-10-15 16:31:12 +08:00
|
|
|
// Probably a repeating event with RRULE etc. TODO: skip for now.
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
if (empty($event->properties['DTSTART'][0]->value)) {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2014-02-28 13:25:16 +08:00
|
|
|
$defaulttz = date_default_timezone_get();
|
|
|
|
$tz = isset($event->properties['DTSTART'][0]->parameters['TZID']) ? $event->properties['DTSTART'][0]->parameters['TZID'] :
|
2014-09-25 09:42:10 -04:00
|
|
|
$timezone;
|
2014-02-28 13:25:16 +08:00
|
|
|
$eventrecord->timestart = strtotime($event->properties['DTSTART'][0]->value . ' ' . $tz);
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
if (empty($event->properties['DTEND'])) {
|
2014-08-15 15:31:48 -04:00
|
|
|
$eventrecord->timeduration = 0; // no duration if no end time specified
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
} else {
|
2014-02-28 13:25:16 +08:00
|
|
|
$endtz = isset($event->properties['DTEND'][0]->parameters['TZID']) ? $event->properties['DTEND'][0]->parameters['TZID'] :
|
2014-09-25 09:42:10 -04:00
|
|
|
$timezone;
|
2014-02-28 13:25:16 +08:00
|
|
|
$eventrecord->timeduration = strtotime($event->properties['DTEND'][0]->value . ' ' . $endtz) - $eventrecord->timestart;
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
}
|
2014-09-25 09:42:10 -04:00
|
|
|
|
|
|
|
// Check to see if it should be treated as an all day event.
|
|
|
|
if ($eventrecord->timeduration == DAYSECS) {
|
|
|
|
// Check to see if the event started at Midnight on the imported calendar.
|
|
|
|
date_default_timezone_set($timezone);
|
|
|
|
if (date('H:i:s', $eventrecord->timestart) === "00:00:00") {
|
|
|
|
// This event should be an all day event.
|
|
|
|
$eventrecord->timeduration = 0;
|
|
|
|
}
|
|
|
|
date_default_timezone_set($defaulttz);
|
|
|
|
}
|
|
|
|
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
$eventrecord->uuid = $event->properties['UID'][0]->value;
|
|
|
|
$eventrecord->timemodified = time();
|
|
|
|
|
2012-10-15 16:31:12 +08:00
|
|
|
// Add the iCal subscription details if required.
|
2013-01-17 11:11:15 +08:00
|
|
|
// We should never do anything with an event without a subscription reference.
|
|
|
|
$sub = calendar_get_subscription($subscriptionid);
|
|
|
|
$eventrecord->subscriptionid = $subscriptionid;
|
|
|
|
$eventrecord->userid = $sub->userid;
|
|
|
|
$eventrecord->groupid = $sub->groupid;
|
|
|
|
$eventrecord->courseid = $sub->courseid;
|
|
|
|
$eventrecord->eventtype = $sub->eventtype;
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
|
|
|
|
if ($updaterecord = $DB->get_record('event', array('uuid' => $eventrecord->uuid))) {
|
|
|
|
$eventrecord->id = $updaterecord->id;
|
2014-02-28 13:25:16 +08:00
|
|
|
$return = CALENDAR_IMPORT_EVENT_UPDATED; // Update.
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
} else {
|
2014-02-28 13:25:16 +08:00
|
|
|
$return = CALENDAR_IMPORT_EVENT_INSERTED; // Insert.
|
|
|
|
}
|
|
|
|
if ($createdevent = calendar_event::create($eventrecord, false)) {
|
|
|
|
if (!empty($event->properties['RRULE'])) {
|
|
|
|
// Repeating events.
|
|
|
|
date_default_timezone_set($tz); // Change time zone to parse all events.
|
|
|
|
$rrule = new \core_calendar\rrule_manager($event->properties['RRULE'][0]->value);
|
|
|
|
$rrule->parse_rrule();
|
|
|
|
$rrule->create_events($createdevent);
|
|
|
|
date_default_timezone_set($defaulttz); // Change time zone back to what it was.
|
|
|
|
}
|
|
|
|
return $return;
|
|
|
|
} else {
|
|
|
|
return 0;
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2012-10-15 16:31:12 +08:00
|
|
|
* Update a subscription from the form data in one of the rows in the existing subscriptions table.
|
|
|
|
*
|
|
|
|
* @param int $subscriptionid The ID of the subscription we are acting upon.
|
|
|
|
* @param int $pollinterval The poll interval to use.
|
|
|
|
* @param int $action The action to be performed. One of update or remove.
|
2013-01-17 11:11:15 +08:00
|
|
|
* @throws dml_exception if invalid subscriptionid is provided
|
2012-10-15 16:31:12 +08:00
|
|
|
* @return string A log of the import progress, including errors
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
*/
|
2012-10-15 16:31:12 +08:00
|
|
|
function calendar_process_subscription_row($subscriptionid, $pollinterval, $action) {
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
|
2012-10-15 16:31:12 +08:00
|
|
|
// Fetch the subscription from the database making sure it exists.
|
2013-01-17 11:11:15 +08:00
|
|
|
$sub = calendar_get_subscription($subscriptionid);
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
|
2012-10-15 16:31:12 +08:00
|
|
|
// Update or remove the subscription, based on action.
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
switch ($action) {
|
2013-08-29 14:54:26 +08:00
|
|
|
case CALENDAR_SUBSCRIPTION_UPDATE:
|
2012-10-15 16:31:12 +08:00
|
|
|
// Skip updating file subscriptions.
|
|
|
|
if (empty($sub->url)) {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
$sub->pollinterval = $pollinterval;
|
2013-03-21 15:19:15 +08:00
|
|
|
calendar_update_subscription($sub);
|
2013-01-17 11:11:15 +08:00
|
|
|
|
2012-10-15 16:31:12 +08:00
|
|
|
// Update the events.
|
|
|
|
return "<p>".get_string('subscriptionupdated', 'calendar', $sub->name)."</p>" . calendar_update_subscription_events($subscriptionid);
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
|
2013-08-29 14:54:26 +08:00
|
|
|
case CALENDAR_SUBSCRIPTION_REMOVE:
|
2013-01-15 16:29:16 +08:00
|
|
|
calendar_delete_subscription($subscriptionid);
|
2012-10-15 16:31:12 +08:00
|
|
|
return get_string('subscriptionremoved', 'calendar', $sub->name);
|
|
|
|
break;
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
|
2012-10-15 16:31:12 +08:00
|
|
|
default:
|
|
|
|
break;
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
}
|
|
|
|
return '';
|
|
|
|
}
|
|
|
|
|
2013-01-15 16:29:16 +08:00
|
|
|
/**
|
|
|
|
* Delete subscription and all related events.
|
|
|
|
*
|
|
|
|
* @param int|stdClass $subscription subscription or it's id, which needs to be deleted.
|
|
|
|
*/
|
|
|
|
function calendar_delete_subscription($subscription) {
|
|
|
|
global $DB;
|
|
|
|
|
|
|
|
if (is_object($subscription)) {
|
|
|
|
$subscription = $subscription->id;
|
|
|
|
}
|
|
|
|
// Delete subscription and related events.
|
|
|
|
$DB->delete_records('event', array('subscriptionid' => $subscription));
|
|
|
|
$DB->delete_records('event_subscriptions', array('id' => $subscription));
|
2013-01-22 16:35:03 +13:00
|
|
|
cache_helper::invalidate_by_definition('core', 'calendar_subscriptions', array(), array($subscription));
|
2013-01-15 16:29:16 +08:00
|
|
|
}
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
/**
|
|
|
|
* From a URL, fetch the calendar and return an iCalendar object.
|
2012-10-15 16:31:12 +08:00
|
|
|
*
|
|
|
|
* @param string $url The iCalendar URL
|
|
|
|
* @return stdClass The iCalendar object
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
*/
|
|
|
|
function calendar_get_icalendar($url) {
|
2012-10-15 16:31:12 +08:00
|
|
|
global $CFG;
|
|
|
|
|
|
|
|
require_once($CFG->libdir.'/filelib.php');
|
|
|
|
|
|
|
|
$curl = new curl();
|
2012-11-14 14:13:31 +08:00
|
|
|
$curl->setopt(array('CURLOPT_FOLLOWLOCATION' => 1, 'CURLOPT_MAXREDIRS' => 5));
|
2012-10-15 16:31:12 +08:00
|
|
|
$calendar = $curl->get($url);
|
2012-11-14 14:13:31 +08:00
|
|
|
// Http code validation should actually be the job of curl class.
|
|
|
|
if (!$calendar || $curl->info['http_code'] != 200 || !empty($curl->errorno)) {
|
2012-10-15 16:31:12 +08:00
|
|
|
throw new moodle_exception('errorinvalidicalurl', 'calendar');
|
|
|
|
}
|
|
|
|
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
$ical = new iCalendar();
|
|
|
|
$ical->unserialize($calendar);
|
|
|
|
return $ical;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Import events from an iCalendar object into a course calendar.
|
2012-10-15 16:31:12 +08:00
|
|
|
*
|
|
|
|
* @param stdClass $ical The iCalendar object.
|
|
|
|
* @param int $courseid The course ID for the calendar.
|
|
|
|
* @param int $subscriptionid The subscription ID.
|
|
|
|
* @return string A log of the import progress, including errors.
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
*/
|
2012-10-15 16:31:12 +08:00
|
|
|
function calendar_import_icalendar_events($ical, $courseid, $subscriptionid = null) {
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
global $DB;
|
|
|
|
$return = '';
|
|
|
|
$eventcount = 0;
|
|
|
|
$updatecount = 0;
|
|
|
|
|
2012-10-15 16:31:12 +08:00
|
|
|
// Large calendars take a while...
|
2013-10-15 13:22:19 +01:00
|
|
|
core_php_time_limit::raise(300);
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
|
2012-10-15 16:31:12 +08:00
|
|
|
// Mark all events in a subscription with a zero timestamp.
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
if (!empty($subscriptionid)) {
|
2012-10-15 16:31:12 +08:00
|
|
|
$sql = "UPDATE {event} SET timemodified = :time WHERE subscriptionid = :id";
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
$DB->execute($sql, array('time' => 0, 'id' => $subscriptionid));
|
|
|
|
}
|
2014-09-25 09:42:10 -04:00
|
|
|
// Grab the timezone from the iCalendar file to be used later.
|
|
|
|
if (isset($ical->properties['X-WR-TIMEZONE'][0]->value)) {
|
|
|
|
$timezone = $ical->properties['X-WR-TIMEZONE'][0]->value;
|
|
|
|
} else {
|
|
|
|
$timezone = 'UTC';
|
|
|
|
}
|
2012-10-12 11:57:32 +13:00
|
|
|
foreach ($ical->components['VEVENT'] as $event) {
|
2014-09-25 09:42:10 -04:00
|
|
|
$res = calendar_add_icalendar_event($event, $courseid, $subscriptionid, $timezone);
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
switch ($res) {
|
|
|
|
case CALENDAR_IMPORT_EVENT_UPDATED:
|
|
|
|
$updatecount++;
|
|
|
|
break;
|
|
|
|
case CALENDAR_IMPORT_EVENT_INSERTED:
|
|
|
|
$eventcount++;
|
|
|
|
break;
|
|
|
|
case 0:
|
2012-10-12 11:57:32 +13:00
|
|
|
$return .= '<p>'.get_string('erroraddingevent', 'calendar').': '.(empty($event->properties['SUMMARY'])?'('.get_string('notitle', 'calendar').')':$event->properties['SUMMARY'][0]->value)." </p>\n";
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2012-10-15 16:31:12 +08:00
|
|
|
$return .= "<p> ".get_string('eventsimported', 'calendar', $eventcount)."</p>";
|
|
|
|
$return .= "<p> ".get_string('eventsupdated', 'calendar', $updatecount)."</p>";
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
|
2012-10-15 16:31:12 +08:00
|
|
|
// Delete remaining zero-marked events since they're not in remote calendar.
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
if (!empty($subscriptionid)) {
|
|
|
|
$deletecount = $DB->count_records('event', array('timemodified' => 0, 'subscriptionid' => $subscriptionid));
|
|
|
|
if (!empty($deletecount)) {
|
2012-10-15 16:31:12 +08:00
|
|
|
$sql = "DELETE FROM {event} WHERE timemodified = :time AND subscriptionid = :id";
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
$DB->execute($sql, array('time' => 0, 'id' => $subscriptionid));
|
2012-10-12 11:57:32 +13:00
|
|
|
$return .= "<p> ".get_string('eventsdeleted', 'calendar').": {$deletecount} </p>\n";
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return $return;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Fetch a calendar subscription and update the events in the calendar.
|
2012-10-15 16:31:12 +08:00
|
|
|
*
|
|
|
|
* @param int $subscriptionid The course ID for the calendar.
|
|
|
|
* @return string A log of the import progress, including errors.
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
*/
|
|
|
|
function calendar_update_subscription_events($subscriptionid) {
|
|
|
|
global $DB;
|
|
|
|
|
2013-01-17 11:11:15 +08:00
|
|
|
$sub = calendar_get_subscription($subscriptionid);
|
2012-10-15 16:31:12 +08:00
|
|
|
// Don't update a file subscription. TODO: Update from a new uploaded file.
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
if (empty($sub->url)) {
|
|
|
|
return 'File subscription not updated.';
|
|
|
|
}
|
|
|
|
$ical = calendar_get_icalendar($sub->url);
|
|
|
|
$return = calendar_import_icalendar_events($ical, $sub->courseid, $subscriptionid);
|
|
|
|
$sub->lastupdated = time();
|
2013-03-21 15:19:15 +08:00
|
|
|
calendar_update_subscription($sub);
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
return $return;
|
|
|
|
}
|
|
|
|
|
2013-03-21 14:09:30 +08:00
|
|
|
/**
|
|
|
|
* Update a calendar subscription. Also updates the associated cache.
|
|
|
|
*
|
|
|
|
* @param stdClass|array $subscription Subscription record.
|
|
|
|
* @throws coding_exception If something goes wrong
|
|
|
|
* @since Moodle 2.5
|
|
|
|
*/
|
|
|
|
function calendar_update_subscription($subscription) {
|
|
|
|
global $DB;
|
|
|
|
|
|
|
|
if (is_array($subscription)) {
|
|
|
|
$subscription = (object)$subscription;
|
|
|
|
}
|
|
|
|
if (empty($subscription->id) || !$DB->record_exists('event_subscriptions', array('id' => $subscription->id))) {
|
|
|
|
throw new coding_exception('Cannot update a subscription without a valid id');
|
|
|
|
}
|
|
|
|
|
|
|
|
$DB->update_record('event_subscriptions', $subscription);
|
|
|
|
// Update cache.
|
|
|
|
$cache = cache::make('core', 'calendar_subscriptions');
|
|
|
|
$cache->set($subscription->id, $subscription);
|
|
|
|
}
|
|
|
|
|
2013-01-02 15:00:49 +08:00
|
|
|
/**
|
|
|
|
* Checks to see if the user can edit a given subscription feed.
|
|
|
|
*
|
|
|
|
* @param mixed $subscriptionorid Subscription object or id
|
|
|
|
* @return bool true if current user can edit the subscription else false
|
|
|
|
*/
|
|
|
|
function calendar_can_edit_subscription($subscriptionorid) {
|
|
|
|
global $DB;
|
|
|
|
|
|
|
|
if (is_array($subscriptionorid)) {
|
|
|
|
$subscription = (object)$subscriptionorid;
|
|
|
|
} else if (is_object($subscriptionorid)) {
|
|
|
|
$subscription = $subscriptionorid;
|
|
|
|
} else {
|
2013-01-17 11:11:15 +08:00
|
|
|
$subscription = calendar_get_subscription($subscriptionorid);
|
2013-01-02 15:00:49 +08:00
|
|
|
}
|
|
|
|
$allowed = new stdClass;
|
|
|
|
$courseid = $subscription->courseid;
|
|
|
|
$groupid = $subscription->groupid;
|
|
|
|
calendar_get_allowed_types($allowed, $courseid);
|
|
|
|
switch ($subscription->eventtype) {
|
|
|
|
case 'user':
|
|
|
|
return $allowed->user;
|
|
|
|
case 'course':
|
|
|
|
if (isset($allowed->courses[$courseid])) {
|
|
|
|
return $allowed->courses[$courseid];
|
|
|
|
} else {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
case 'site':
|
|
|
|
return $allowed->site;
|
|
|
|
case 'group':
|
|
|
|
if (isset($allowed->groups[$groupid])) {
|
|
|
|
return $allowed->groups[$groupid];
|
|
|
|
} else {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
default:
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
/**
|
|
|
|
* Update calendar subscriptions.
|
2012-10-15 16:31:12 +08:00
|
|
|
*
|
|
|
|
* @return bool
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
*/
|
|
|
|
function calendar_cron() {
|
2012-10-15 16:31:12 +08:00
|
|
|
global $CFG, $DB;
|
|
|
|
|
|
|
|
// In order to execute this we need bennu.
|
|
|
|
require_once($CFG->libdir.'/bennu/bennu.inc.php');
|
|
|
|
|
2012-10-30 15:27:02 +08:00
|
|
|
mtrace('Updating calendar subscriptions:');
|
2013-02-26 14:01:18 +00:00
|
|
|
cron_trace_time_and_memory();
|
2012-10-15 16:31:12 +08:00
|
|
|
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
$time = time();
|
2012-10-15 16:31:12 +08:00
|
|
|
$subscriptions = $DB->get_records_sql('SELECT * FROM {event_subscriptions} WHERE pollinterval > 0 AND lastupdated + pollinterval < ?', array($time));
|
2012-10-12 11:57:32 +13:00
|
|
|
foreach ($subscriptions as $sub) {
|
2012-10-30 15:27:02 +08:00
|
|
|
mtrace("Updating calendar subscription {$sub->name} in course {$sub->courseid}");
|
2012-10-15 16:31:12 +08:00
|
|
|
try {
|
|
|
|
$log = calendar_update_subscription_events($sub->id);
|
2014-07-04 12:02:34 -04:00
|
|
|
mtrace(trim(strip_tags($log)));
|
2012-10-15 16:31:12 +08:00
|
|
|
} catch (moodle_exception $ex) {
|
2014-07-04 12:02:34 -04:00
|
|
|
mtrace('Error updating calendar subscription: ' . $ex->getMessage());
|
2012-10-15 16:31:12 +08:00
|
|
|
}
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
}
|
2012-10-15 16:31:12 +08:00
|
|
|
|
2012-10-30 15:27:02 +08:00
|
|
|
mtrace('Finished updating calendar subscriptions.');
|
MDL-16660: Add calendar import.
Adds an extra import section alongside the existing export in the
calendar views. Allows the user to import from either a file or a
URL as a subscription, with an optional polling interval of hourly,
daily, weekly, monthly, or annually. This subscription may be added
to the user, group, global or course calendars. These subscriptions
are tracked in a separate database table, and an extra column added
to the events table to relate them to the subscription. The event
uuid field is also expanded to allow for the RFC-2445 UID property.
Subscriptions are listed on the calendar view page, and can be
added and removed, manually polled, and the polling interval
adjusted. Subscription events are updated on cron.
2012-07-23 13:49:43 +12:00
|
|
|
|
2012-10-15 16:31:12 +08:00
|
|
|
return true;
|
2012-10-30 15:27:02 +08:00
|
|
|
}
|