MDL-36754 tests: Move moodle_url tests to own file
[moodle.git] / blocks / calendar_upcoming / block_calendar_upcoming.php
blob137ba2607575339c37c3cf248ae1e83cb52b6ce1
1 <?php
2 // This file is part of Moodle - http://moodle.org/
3 //
4 // Moodle is free software: you can redistribute it and/or modify
5 // it under the terms of the GNU General Public License as published by
6 // the Free Software Foundation, either version 3 of the License, or
7 // (at your option) any later version.
8 //
9 // Moodle is distributed in the hope that it will be useful,
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 // GNU General Public License for more details.
14 // You should have received a copy of the GNU General Public License
15 // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
17 /**
18 * Handles displaying the calendar upcoming events block.
20 * @package block_calendar_upcoming
21 * @copyright 2004 Eloy Lafuente (stronk7) {@link http://stronk7.com}
22 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
24 class block_calendar_upcoming extends block_base {
26 /**
27 * Initialise the block.
29 public function init() {
30 $this->title = get_string('pluginname', 'block_calendar_upcoming');
33 /**
34 * Return the content of this block.
36 * @return stdClass the content
38 public function get_content() {
39 global $CFG;
41 require_once($CFG->dirroot.'/calendar/lib.php');
43 if ($this->content !== null) {
44 return $this->content;
46 $this->content = new stdClass;
47 $this->content->text = '';
48 $this->content->footer = '';
50 $courseid = $this->page->course->id;
51 $categoryid = ($this->page->context->contextlevel === CONTEXT_COURSECAT) ? $this->page->category->id : null;
52 $calendar = \calendar_information::create(time(), $courseid, $categoryid);
53 list($data, $template) = calendar_get_view($calendar, 'upcoming_mini');
55 $renderer = $this->page->get_renderer('core_calendar');
56 $this->content->text .= $renderer->render_from_template($template, $data);
58 $url = new \moodle_url('/calendar/view.php', ['view' => 'upcoming']);
59 if ($courseid != SITEID) {
60 $url->param('course', $this->page->course->id);
61 } else if (!empty($categoryid)) {
62 $url->param('category', $this->page->category->id);
65 $this->content->footer = html_writer::div(
66 html_writer::link($url, get_string('gotocalendar', 'block_calendar_upcoming')),
67 'gotocal'
70 return $this->content;
73 /**
74 * Get the upcoming event block content.
76 * @param array $events list of events
77 * @param \moodle_url|string $linkhref link to event referer
78 * @param boolean $showcourselink whether links to courses should be shown
79 * @return string|null $content html block content
80 * @deprecated since 3.4
82 public static function get_upcoming_content($events, $linkhref = null, $showcourselink = false) {
83 debugging(
84 'get_upcoming_content() is deprecated. ' .
85 'Please see block_calendar_upcoming::get_content() for the correct API usage.',
86 DEBUG_DEVELOPER
89 $content = '';
90 $lines = count($events);
92 if (!$lines) {
93 return $content;
96 for ($i = 0; $i < $lines; ++$i) {
97 if (!isset($events[$i]->time)) {
98 continue;
100 $events[$i] = calendar_add_event_metadata($events[$i]);
101 $content .= '<div class="event"><span class="icon c0">' . $events[$i]->icon . '</span>';
102 if (!empty($events[$i]->referer)) {
103 // That's an activity event, so let's provide the hyperlink.
104 $content .= $events[$i]->referer;
105 } else {
106 if (!empty($linkhref)) {
107 $href = calendar_get_link_href(new \moodle_url(CALENDAR_URL . $linkhref), 0, 0, 0,
108 $events[$i]->timestart);
109 $href->set_anchor('event_' . $events[$i]->id);
110 $content .= \html_writer::link($href, $events[$i]->name);
111 } else {
112 $content .= $events[$i]->name;
115 $events[$i]->time = str_replace('&raquo;', '<br />&raquo;', $events[$i]->time);
116 if ($showcourselink && !empty($events[$i]->courselink)) {
117 $content .= \html_writer::div($events[$i]->courselink, 'course');
119 $content .= '<div class="date">' . $events[$i]->time . '</div></div>';
120 if ($i < $lines - 1) {
121 $content .= '<hr />';
125 return $content;