/report/eventlist/classes/renderer.php

https://github.com/markn86/moodle · PHP · 173 lines · 104 code · 24 blank · 45 comment · 17 complexity · a25024d1cfcf30a112065fc0cd62527c MD5 · raw file

  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.
  13. //
  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/>.
  16. /**
  17. * Event report renderer.
  18. *
  19. * @package report_eventlist
  20. * @copyright 2014 Adrian Greeve <adrian@moodle.com>
  21. * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
  22. */
  23. defined('MOODLE_INTERNAL') || die();
  24. /**
  25. * Renderer for event report.
  26. *
  27. * @package report_eventlist
  28. * @copyright 2014 Adrian Greeve <adrian@moodle.com>
  29. * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
  30. */
  31. class report_eventlist_renderer extends plugin_renderer_base {
  32. /**
  33. * Renders the event list page with filter form and datatable.
  34. *
  35. * @param eventfilter_form $form Event filter form.
  36. * @param array $tabledata An array of event data to be used by the datatable.
  37. * @return string HTML to be displayed.
  38. */
  39. public function render_event_list($form, $tabledata) {
  40. $title = get_string('pluginname', 'report_eventlist');
  41. // Header.
  42. $html = $this->output->header();
  43. $html .= $this->output->heading($title);
  44. // Form.
  45. ob_start();
  46. $form->display();
  47. $html .= ob_get_contents();
  48. ob_end_clean();
  49. $this->page->requires->yui_module('moodle-report_eventlist-eventfilter', 'Y.M.report_eventlist.EventFilter.init',
  50. array(array('tabledata' => $tabledata)));
  51. $this->page->requires->strings_for_js(array(
  52. 'eventname',
  53. 'component',
  54. 'action',
  55. 'crud',
  56. 'edulevel',
  57. 'affectedtable',
  58. 'dname',
  59. 'legacyevent',
  60. 'since'
  61. ), 'report_eventlist');
  62. $html .= html_writer::start_div('report-eventlist-data-table', array('id' => 'report-eventlist-table'));
  63. $html .= html_writer::end_div();
  64. $html .= $this->output->footer();
  65. return $html;
  66. }
  67. /**
  68. * Event detail renderer.
  69. *
  70. * @param array $observerlist A list of observers that consume this event.
  71. * @param array $eventinformation A list of information about the event.
  72. * @return string HTML to be displayed.
  73. */
  74. public function render_event_detail($observerlist, $eventinformation) {
  75. $titlehtml = $this->output->header();
  76. $titlehtml .= $this->output->heading($eventinformation['title']);
  77. $html = html_writer::start_tag('dl', array('class' => 'list'));
  78. $explanation = nl2br($eventinformation['explanation']);
  79. $html .= html_writer::tag('dt', get_string('eventexplanation', 'report_eventlist'));
  80. $html .= html_writer::tag('dd', $explanation);
  81. if (isset($eventinformation['crud'])) {
  82. $html .= html_writer::tag('dt', get_string('crud', 'report_eventlist'));
  83. $html .= html_writer::tag('dd', $eventinformation['crud']);
  84. }
  85. if (isset($eventinformation['edulevel'])) {
  86. $html .= html_writer::tag('dt', get_string('edulevel', 'report_eventlist'));
  87. $html .= html_writer::tag('dd', $eventinformation['edulevel']);
  88. }
  89. if (isset($eventinformation['objecttable'])) {
  90. $html .= html_writer::tag('dt', get_string('affectedtable', 'report_eventlist'));
  91. $html .= html_writer::tag('dd', $eventinformation['objecttable']);
  92. }
  93. if (isset($eventinformation['legacyevent'])) {
  94. $html .= html_writer::tag('dt', get_string('legacyevent', 'report_eventlist'));
  95. $html .= html_writer::tag('dd', $eventinformation['legacyevent']);
  96. }
  97. if (isset($eventinformation['parentclass'])) {
  98. $url = new moodle_url('eventdetail.php', array('eventname' => $eventinformation['parentclass']));
  99. $html .= html_writer::tag('dt', get_string('parentevent', 'report_eventlist'));
  100. $html .= html_writer::tag('dd', html_writer::link($url, $eventinformation['parentclass']));
  101. }
  102. if (isset($eventinformation['abstract'])) {
  103. $html .= html_writer::tag('dt', get_string('abstractclass', 'report_eventlist'));
  104. $html .= html_writer::tag('dd', get_string('yes', 'report_eventlist'));
  105. }
  106. if (isset($eventinformation['typeparameter'])) {
  107. $html .= html_writer::tag('dt', get_string('typedeclaration', 'report_eventlist'));
  108. foreach ($eventinformation['typeparameter'] as $typeparameter) {
  109. $html .= html_writer::tag('dd', $typeparameter);
  110. }
  111. }
  112. if (isset($eventinformation['otherparameter'])) {
  113. $html .= html_writer::tag('dt', get_string('othereventparameters', 'report_eventlist'));
  114. foreach ($eventinformation['otherparameter'] as $otherparameter) {
  115. $html .= html_writer::tag('dd', $otherparameter);
  116. }
  117. }
  118. // List observers consuming this event if there are any.
  119. if (!empty($observerlist)) {
  120. $html .= html_writer::tag('dt', get_string('relatedobservers', 'report_eventlist'));
  121. foreach ($observerlist as $observer) {
  122. if ($observer->plugin == 'core') {
  123. $html .= html_writer::tag('dd', $observer->plugin);
  124. } else {
  125. $manager = get_string_manager();
  126. $pluginstring = $observer->plugintype . '_' . $observer->plugin;
  127. if ($manager->string_exists('pluginname', $pluginstring)) {
  128. if (!empty($observer->parentplugin)) {
  129. $string = get_string('pluginname', $pluginstring) . ' (' . $observer->parentplugin
  130. . ' ' . $pluginstring . ')';
  131. } else {
  132. $string = get_string('pluginname', $pluginstring) . ' (' . $pluginstring . ')';
  133. }
  134. } else {
  135. $string = $observer->plugintype . ' ' . $observer->plugin;
  136. }
  137. $html .= html_writer::tag('dd', $string);
  138. }
  139. }
  140. }
  141. $html .= html_writer::end_div();
  142. $html .= html_writer::end_tag('dl');
  143. $pagecontent = new html_table();
  144. $pagecontent->data = array(array($html));
  145. $pagehtml = $titlehtml . html_writer::table($pagecontent);
  146. $pagehtml .= $this->output->footer();
  147. return $pagehtml;
  148. }
  149. }