}
}
+ // Include category name into the event name, if applicable.
+ $proxy = $this->event->get_category();
+ if ($proxy && $proxy->get('id')) {
+ $category = $proxy->get_proxied_instance();
+ $eventnameparams = (object) [
+ 'name' => $values['popupname'],
+ 'category' => $category->get_formatted_name(),
+ ];
+ $values['popupname'] = get_string('eventnameandcategory', 'calendar', $eventnameparams);
+ }
+
// Include course's shortname into the event name, if applicable.
$course = $this->event->get_course();
if ($course && $course->get('id') && $course->get('id') !== SITEID) {
*/
public function __construct(\calendar_information $calendar, $data, $related) {
$this->calendar = $calendar;
- $this->url = new moodle_url('/calendar/view.php', [
- 'view' => 'day',
- 'time' => $calendar->time,
- 'course' => $this->calendar->course->id,
- ]);
+
+ $url = new moodle_url('/calendar/view.php', [
+ 'view' => 'day',
+ 'time' => $calendar->time,
+ ]);
+
+ if ($this->calendar->course && SITEID !== $this->calendar->course->id) {
+ $url->param('course', $this->calendar->course->id);
+ } else if ($this->calendar->categoryid) {
+ $url->param('category', $this->calendar->categoryid);
+ }
+
+ $this->url = $url;
+
parent::__construct($data, $related);
}
'navigation' => $this->get_navigation(),
'filter_selector' => $this->get_course_filter_selector($output),
'new_event_button' => $this->get_new_event_button(),
+ 'viewdaylink' => $this->url->out(false),
];
- $return['viewdaylink'] = $this->url->out(false);
$cache = $this->related['cache'];
$eventexporters = array_map(function($event) use ($cache, $output) {
use \core_calendar\local\event\entities\event_interface;
use \core_calendar\local\event\entities\action_event_interface;
use \core_course\external\course_summary_exporter;
+use \core\external\coursecat_summary_exporter;
use \renderer_base;
use moodle_url;
$endtimestamp = $event->get_times()->get_end_time()->getTimestamp();
$groupid = $event->get_group() ? $event->get_group()->get('id') : null;
$userid = $event->get_user() ? $event->get_user()->get('id') : null;
+ $categoryid = $event->get_category() ? $event->get_category()->get('id') : null;
$data = new \stdClass();
$data->id = $event->get_id();
$data->descriptionformat = $event->get_description()->get_format();
$data->groupid = $groupid;
$data->userid = $userid;
+ $data->categoryid = $categoryid;
$data->eventtype = $event->get_type();
$data->timestart = $starttimestamp;
$data->timeduration = $endtimestamp - $starttimestamp;
'default' => null,
'null' => NULL_ALLOWED
],
+ 'categoryid' => [
+ 'type' => PARAM_INT,
+ 'optional' => true,
+ 'default' => null,
+ 'null' => NULL_ALLOWED
+ ],
'groupid' => [
'type' => PARAM_INT,
'optional' => true,
'icon' => [
'type' => event_icon_exporter::read_properties_definition(),
],
+ 'category' => [
+ 'type' => coursecat_summary_exporter::read_properties_definition(),
+ 'optional' => true,
+ ],
'course' => [
'type' => course_summary_exporter::read_properties_definition(),
'optional' => true,
$subscriptionexporter = new event_subscription_exporter($event);
$values['subscription'] = $subscriptionexporter->export($output);
+ $proxy = $this->event->get_category();
+ if ($proxy && $proxy->get('id')) {
+ $category = $proxy->get_proxied_instance();
+ $categorysummaryexporter = new coursecat_summary_exporter($category, ['context' => $context]);
+ $values['category'] = $categorysummaryexporter->export($output);
+ }
+
if ($course = $this->related['course']) {
$coursesummaryexporter = new course_summary_exporter($course, ['context' => $context]);
$values['course'] = $coursesummaryexporter->export($output);
'time' => $calendar->time,
]);
- if ($this->calendar->courseid) {
- $this->url->param('course', $this->calendar->courseid);
+ if ($this->calendar->course && SITEID !== $this->calendar->course->id) {
+ $this->url->param('course', $this->calendar->course->id);
+ } else if ($this->calendar->categoryid) {
+ $this->url->param('category', $this->calendar->categoryid);
}
$related['type'] = $type;
$url = new moodle_url('/calendar/view.php', [
'view' => 'day',
'time' => $timestamp,
- 'course' => $this->calendar->course->id,
- ]);
+ ]);
+
+ if ($this->calendar->course && SITEID !== $this->calendar->course->id) {
+ $url->param('course', $this->calendar->course->id);
+ } else if ($this->calendar->categoryid) {
+ $url->param('category', $this->calendar->categoryid);
+ }
$return['viewdaylink'] = $url->out(false);
+
if ($popovertitle = $this->get_popover_title()) {
$return['popovertitle'] = $popovertitle;
}
$string['eventinstanttime'] = 'Time';
$string['eventkind'] = 'Type of event';
$string['eventname'] = 'Event title';
+$string['eventnameandcategory'] = '{$a->category}: {$a->name}';
$string['eventnameandcourse'] = '{$a->course}: {$a->name}';
$string['eventnone'] = 'No events';
$string['eventrepeat'] = 'Repeats';
--- /dev/null
+<?php
+// 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/>.
+
+/**
+ * Class for exporting summary information for a course category.
+ *
+ * @package core
+ * @copyright 2017 Andrew Nicols <andrew@nicols.co.uk>
+ * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
+ */
+namespace core\external;
+defined('MOODLE_INTERNAL') || die();
+
+use renderer_base;
+use moodle_url;
+
+/**
+ * Class for exporting a course summary from an stdClass.
+ *
+ * @copyright 2017 Andrew Nicols <andrew@nicols.co.uk>
+ * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
+ */
+class coursecat_summary_exporter extends \core\external\exporter {
+
+ /**
+ * @var \coursecat $category
+ */
+ protected $category;
+
+ public function __construct(\coursecat $category, $related) {
+ $this->category = $category;
+
+ $data = [];
+ // Specify some defaults.
+ foreach ($category as $key => $value) {
+ $data[$key] = $value;
+ }
+
+ return parent::__construct($data, $related);
+ }
+
+ protected static function define_related() {
+ return [
+ 'context' => 'context',
+ ];
+ }
+
+ public static function define_other_properties() {
+ return [
+ 'nestedname' => [
+ 'type' => PARAM_RAW,
+ ],
+ 'url' => [
+ 'type' => PARAM_URL,
+ ],
+ ];
+ }
+
+ protected function get_other_values(renderer_base $output) {
+ $return = [
+ 'nestedname' => $this->category->get_nested_name(),
+ 'url' => (new moodle_url('/course/index.php', [
+ 'categoryid' => $this->category->id,
+ ]))->out(false),
+ ];
+
+ return $return;
+ }
+
+ public static function define_properties() {
+ return [
+ 'id' => [
+ 'type' => PARAM_INT,
+ ],
+ 'name' => [
+ 'type' => PARAM_TEXT,
+ 'default' => '',
+ ],
+ 'idnumber' => [
+ 'type' => PARAM_RAW,
+ 'null' => NULL_ALLOWED,
+ ],
+ 'description' => [
+ 'type' => PARAM_RAW,
+ 'optional' => true,
+ ],
+ 'parent' => [
+ 'type' => PARAM_INT,
+ ],
+ 'coursecount' => [
+ 'type' => PARAM_INT,
+ 'default' => 0,
+ ],
+ 'visible' => [
+ 'type' => PARAM_INT,
+ 'default' => 1,
+ ],
+ 'timemodified' => [
+ 'type' => PARAM_INT,
+ 'default' => 0,
+ ],
+ 'depth' => [
+ 'type' => PARAM_INT,
+ 'default' => 0,
+ ],
+ ];
+ }
+
+ /**
+ * Get the formatting parameters for the summary.
+ *
+ * @return array
+ */
+ protected function get_format_parameters_for_description() {
+ return [
+ 'component' => 'coursecat',
+ 'filearea' => 'description',
+ ];
+ }
+}