You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
176 lines
6.9 KiB
176 lines
6.9 KiB
2 years ago
|
<?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/>.
|
||
|
|
||
|
/**
|
||
|
* Event report renderer.
|
||
|
*
|
||
|
* @package report_eventlist
|
||
|
* @copyright 2014 Adrian Greeve <adrian@moodle.com>
|
||
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
||
|
*/
|
||
|
|
||
|
defined('MOODLE_INTERNAL') || die();
|
||
|
|
||
|
/**
|
||
|
* Renderer for event report.
|
||
|
*
|
||
|
* @package report_eventlist
|
||
|
* @copyright 2014 Adrian Greeve <adrian@moodle.com>
|
||
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
||
|
*/
|
||
|
class report_eventlist_renderer extends plugin_renderer_base {
|
||
|
|
||
|
/**
|
||
|
* Renders the event list page with filter form and datatable.
|
||
|
*
|
||
|
* @param eventfilter_form $form Event filter form.
|
||
|
* @param array $tabledata An array of event data to be used by the datatable.
|
||
|
* @return string HTML to be displayed.
|
||
|
*/
|
||
|
public function render_event_list($form, $tabledata) {
|
||
|
global $PAGE;
|
||
|
|
||
|
$title = get_string('pluginname', 'report_eventlist');
|
||
|
|
||
|
// Header.
|
||
|
$html = $this->output->header();
|
||
|
$html .= $this->output->heading($title);
|
||
|
|
||
|
// Form.
|
||
|
ob_start();
|
||
|
$form->display();
|
||
|
$html .= ob_get_contents();
|
||
|
ob_end_clean();
|
||
|
|
||
|
$PAGE->requires->yui_module('moodle-report_eventlist-eventfilter', 'Y.M.report_eventlist.EventFilter.init',
|
||
|
array(array('tabledata' => $tabledata)));
|
||
|
$PAGE->requires->strings_for_js(array(
|
||
|
'eventname',
|
||
|
'component',
|
||
|
'action',
|
||
|
'crud',
|
||
|
'edulevel',
|
||
|
'affectedtable',
|
||
|
'dname',
|
||
|
'legacyevent',
|
||
|
'since'
|
||
|
), 'report_eventlist');
|
||
|
$html .= html_writer::start_div('report-eventlist-data-table', array('id' => 'report-eventlist-table'));
|
||
|
$html .= html_writer::end_div();
|
||
|
|
||
|
$html .= $this->output->footer();
|
||
|
return $html;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Event detail renderer.
|
||
|
*
|
||
|
* @param array $observerlist A list of observers that consume this event.
|
||
|
* @param array $eventinformation A list of information about the event.
|
||
|
* @return string HTML to be displayed.
|
||
|
*/
|
||
|
public function render_event_detail($observerlist, $eventinformation) {
|
||
|
global $PAGE;
|
||
|
|
||
|
$titlehtml = $this->output->header();
|
||
|
$titlehtml .= $this->output->heading($eventinformation['title']);
|
||
|
|
||
|
$html = html_writer::start_tag('dl', array('class' => 'list'));
|
||
|
|
||
|
$explanation = nl2br($eventinformation['explanation']);
|
||
|
$html .= html_writer::tag('dt', get_string('eventexplanation', 'report_eventlist'));
|
||
|
$html .= html_writer::tag('dd', $explanation);
|
||
|
|
||
|
if (isset($eventinformation['crud'])) {
|
||
|
$html .= html_writer::tag('dt', get_string('crud', 'report_eventlist'));
|
||
|
$html .= html_writer::tag('dd', $eventinformation['crud']);
|
||
|
}
|
||
|
|
||
|
if (isset($eventinformation['edulevel'])) {
|
||
|
$html .= html_writer::tag('dt', get_string('edulevel', 'report_eventlist'));
|
||
|
$html .= html_writer::tag('dd', $eventinformation['edulevel']);
|
||
|
}
|
||
|
|
||
|
if (isset($eventinformation['objecttable'])) {
|
||
|
$html .= html_writer::tag('dt', get_string('affectedtable', 'report_eventlist'));
|
||
|
$html .= html_writer::tag('dd', $eventinformation['objecttable']);
|
||
|
}
|
||
|
|
||
|
if (isset($eventinformation['legacyevent'])) {
|
||
|
$html .= html_writer::tag('dt', get_string('legacyevent', 'report_eventlist'));
|
||
|
$html .= html_writer::tag('dd', $eventinformation['legacyevent']);
|
||
|
}
|
||
|
|
||
|
if (isset($eventinformation['parentclass'])) {
|
||
|
$url = new moodle_url('eventdetail.php', array('eventname' => $eventinformation['parentclass']));
|
||
|
$html .= html_writer::tag('dt', get_string('parentevent', 'report_eventlist'));
|
||
|
$html .= html_writer::tag('dd', html_writer::link($url, $eventinformation['parentclass']));
|
||
|
}
|
||
|
|
||
|
if (isset($eventinformation['abstract'])) {
|
||
|
$html .= html_writer::tag('dt', get_string('abstractclass', 'report_eventlist'));
|
||
|
$html .= html_writer::tag('dd', get_string('yes', 'report_eventlist'));
|
||
|
}
|
||
|
|
||
|
if (isset($eventinformation['typeparameter'])) {
|
||
|
$html .= html_writer::tag('dt', get_string('typedeclaration', 'report_eventlist'));
|
||
|
foreach ($eventinformation['typeparameter'] as $typeparameter) {
|
||
|
$html .= html_writer::tag('dd', $typeparameter);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
if (isset($eventinformation['otherparameter'])) {
|
||
|
$html .= html_writer::tag('dt', get_string('othereventparameters', 'report_eventlist'));
|
||
|
foreach ($eventinformation['otherparameter'] as $otherparameter) {
|
||
|
$html .= html_writer::tag('dd', $otherparameter);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// List observers consuming this event if there are any.
|
||
|
if (!empty($observerlist)) {
|
||
|
$html .= html_writer::tag('dt', get_string('relatedobservers', 'report_eventlist'));
|
||
|
foreach ($observerlist as $observer) {
|
||
|
if ($observer->plugin == 'core') {
|
||
|
$html .= html_writer::tag('dd', $observer->plugin);
|
||
|
} else {
|
||
|
$manager = get_string_manager();
|
||
|
$pluginstring = $observer->plugintype . '_' . $observer->plugin;
|
||
|
if ($manager->string_exists('pluginname', $pluginstring)) {
|
||
|
if (!empty($observer->parentplugin)) {
|
||
|
$string = get_string('pluginname', $pluginstring) . ' (' . $observer->parentplugin
|
||
|
. ' ' . $pluginstring . ')';
|
||
|
} else {
|
||
|
$string = get_string('pluginname', $pluginstring) . ' (' . $pluginstring . ')';
|
||
|
}
|
||
|
} else {
|
||
|
$string = $observer->plugintype . ' ' . $observer->plugin;
|
||
|
}
|
||
|
$html .= html_writer::tag('dd', $string);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
$html .= html_writer::end_div();
|
||
|
$html .= html_writer::end_tag('dl');
|
||
|
|
||
|
$pagecontent = new html_table();
|
||
|
$pagecontent->data = array(array($html));
|
||
|
$pagehtml = $titlehtml . html_writer::table($pagecontent);
|
||
|
$pagehtml .= $this->output->footer();
|
||
|
|
||
|
return $pagehtml;
|
||
|
}
|
||
|
}
|