[ Index ]

PHP Cross Reference of moodle-2.8

title

Body

[close]

/report/log/classes/ -> renderer.php (source)

   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  /**
  18   * Log report renderer.
  19   *
  20   * @package    report_log
  21   * @copyright  2014 Rajesh Taneja <[email protected]>
  22   * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
  23   */
  24  defined('MOODLE_INTERNAL') || die;
  25  
  26  /**
  27   * Report log renderer's for printing reports.
  28   *
  29   * @package    report_log
  30   * @copyright  2014 Rajesh Taneja <[email protected]>
  31   * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
  32   */
  33  class report_log_renderer extends plugin_renderer_base {
  34  
  35      /**
  36       * This method should never be manually called, it should only be called by process.
  37       *
  38       * @deprecated since 2.8, to be removed in 2.9
  39       * @param report_log_renderable $reportlog
  40       * @return string
  41       */
  42      public function render_report_log_renderable(report_log_renderable $reportlog) {
  43          debugging('Do not call this method. Please call $renderer->render($reportlog) instead.', DEBUG_DEVELOPER);
  44          return $this->render($reportlog);
  45      }
  46  
  47      /**
  48       * Render log report page.
  49       *
  50       * @param report_log_renderable $reportlog object of report_log.
  51       */
  52      protected function render_report_log(report_log_renderable $reportlog) {
  53          if (empty($reportlog->selectedlogreader)) {
  54              echo $this->output->notification(get_string('nologreaderenabled', 'report_log'), 'notifyproblem');
  55              return;
  56          }
  57          if ($reportlog->showselectorform) {
  58              $this->report_selector_form($reportlog);
  59          }
  60  
  61          if ($reportlog->showreport) {
  62              $reportlog->tablelog->out($reportlog->perpage, true);
  63          }
  64      }
  65  
  66      /**
  67       * Prints/return reader selector
  68       *
  69       * @param report_log_renderable $reportlog log report.
  70       */
  71      public function reader_selector(report_log_renderable $reportlog) {
  72          $readers = $reportlog->get_readers(true);
  73          if (empty($readers)) {
  74              $readers = array(get_string('nologreaderenabled', 'report_log'));
  75          }
  76          $select = new single_select($reportlog->url, 'logreader', $readers, $reportlog->selectedlogreader, null);
  77          $select->set_label(get_string('selectlogreader', 'report_log'));
  78          echo $this->output->render($select);
  79      }
  80  
  81      /**
  82       * This function is used to generate and display selector form
  83       *
  84       * @param report_log_renderable $reportlog log report.
  85       */
  86      public function report_selector_form(report_log_renderable $reportlog) {
  87          echo html_writer::start_tag('form', array('class' => 'logselecform', 'action' => $reportlog->url, 'method' => 'get'));
  88          echo html_writer::start_div();
  89          echo html_writer::empty_tag('input', array('type' => 'hidden', 'name' => 'chooselog', 'value' => '1'));
  90          echo html_writer::empty_tag('input', array('type' => 'hidden', 'name' => 'showusers', 'value' => $reportlog->showusers));
  91          echo html_writer::empty_tag('input', array('type' => 'hidden', 'name' => 'showcourses',
  92              'value' => $reportlog->showcourses));
  93  
  94          $selectedcourseid = empty($reportlog->course) ? 0 : $reportlog->course->id;
  95  
  96          // Add course selector.
  97          $sitecontext = context_system::instance();
  98          $courses = $reportlog->get_course_list();
  99          if (!empty($courses) && $reportlog->showcourses) {
 100              echo html_writer::label(get_string('selectacourse'), 'menuid', false, array('class' => 'accesshide'));
 101              echo html_writer::select($courses, "id", $selectedcourseid, null);
 102          } else {
 103              $courses = array();
 104              $courses[$selectedcourseid] = get_course_display_name_for_list($reportlog->course) . (($selectedcourseid == SITEID) ?
 105                  ' (' . get_string('site') . ') ' : '');
 106              echo html_writer::label(get_string('selectacourse'), 'menuid', false, array('class' => 'accesshide'));
 107              echo html_writer::select($courses, "id", $selectedcourseid, false);
 108              // Check if user is admin and this came because of limitation on number of courses to show in dropdown.
 109              if (has_capability('report/log:view', $sitecontext)) {
 110                  $a = new stdClass();
 111                  $a->url = new moodle_url('/report/log/index.php', array('chooselog' => 0,
 112                      'group' => $reportlog->get_selected_group(), 'user' => $reportlog->userid,
 113                      'id' => $selectedcourseid, 'date' => $reportlog->date, 'modid' => $reportlog->modid,
 114                      'showcourses' => 1, 'showusers' => $reportlog->showusers));
 115                  $a->url = $a->url->out(false);
 116                  print_string('logtoomanycourses', 'moodle', $a);
 117              }
 118          }
 119  
 120          // Add group selector.
 121          $groups = $reportlog->get_group_list();
 122          if (!empty($groups)) {
 123              echo html_writer::label(get_string('selectagroup'), 'menugroup', false, array('class' => 'accesshide'));
 124              echo html_writer::select($groups, "group", $reportlog->groupid, get_string("allgroups"));
 125          }
 126  
 127          // Add user selector.
 128          $users = $reportlog->get_user_list();
 129  
 130          if ($reportlog->showusers) {
 131              echo html_writer::label(get_string('selctauser'), 'menuuser', false, array('class' => 'accesshide'));
 132              echo html_writer::select($users, "user", $reportlog->userid, get_string("allparticipants"));
 133          } else {
 134              $users = array();
 135              if (!empty($reportlog->userid)) {
 136                  $users[$reportlog->userid] = $reportlog->get_selected_user_fullname();
 137              } else {
 138                  $users[0] = get_string('allparticipants');
 139              }
 140              echo html_writer::label(get_string('selctauser'), 'menuuser', false, array('class' => 'accesshide'));
 141              echo html_writer::select($users, "user", $reportlog->userid, false);
 142              $a = new stdClass();
 143              $a->url = new moodle_url('/report/log/index.php', array('chooselog' => 0,
 144                  'group' => $reportlog->get_selected_group(), 'user' => $reportlog->userid,
 145                  'id' => $selectedcourseid, 'date' => $reportlog->date, 'modid' => $reportlog->modid,
 146                  'showusers' => 1, 'showcourses' => $reportlog->showcourses));
 147              $a->url = $a->url->out(false);
 148              print_string('logtoomanyusers', 'moodle', $a);
 149          }
 150  
 151          // Add date selector.
 152          $dates = $reportlog->get_date_options();
 153          echo html_writer::label(get_string('date'), 'menudate', false, array('class' => 'accesshide'));
 154          echo html_writer::select($dates, "date", $reportlog->date, get_string("alldays"));
 155  
 156          // Add activity selector.
 157          $activities = $reportlog->get_activities_list();
 158          echo html_writer::label(get_string('activities'), 'menumodid', false, array('class' => 'accesshide'));
 159          echo html_writer::select($activities, "modid", $reportlog->modid, get_string("allactivities"));
 160  
 161          // Add actions selector.
 162          echo html_writer::label(get_string('actions'), 'menumodaction', false, array('class' => 'accesshide'));
 163          echo html_writer::select($reportlog->get_actions(), 'modaction', $reportlog->action, get_string("allactions"));
 164  
 165          // Add edulevel.
 166          $edulevel = $reportlog->get_edulevel_options();
 167          echo html_writer::label(get_string('edulevel'), 'menuedulevel', false, array('class' => 'accesshide'));
 168          echo html_writer::select($edulevel, 'edulevel', $reportlog->edulevel, false);
 169  
 170          // Add reader option.
 171          // If there is some reader available then only show submit button.
 172          $readers = $reportlog->get_readers(true);
 173          if (!empty($readers)) {
 174              if (count($readers) == 1) {
 175                  $attributes = array('type' => 'hidden', 'name' => 'logreader', 'value' => key($readers));
 176                  echo html_writer::empty_tag('input', $attributes);
 177              } else {
 178                  echo html_writer::label(get_string('selectlogreader', 'report_log'), 'menureader', false,
 179                          array('class' => 'accesshide'));
 180                  echo html_writer::select($readers, 'logreader', $reportlog->selectedlogreader, false);
 181              }
 182              echo html_writer::empty_tag('input', array('type' => 'submit', 'value' => get_string('gettheselogs')));
 183          }
 184          echo html_writer::end_div();
 185          echo html_writer::end_tag('form');
 186      }
 187  }
 188  


Generated: Fri Nov 28 20:29:05 2014 Cross-referenced by PHPXref 0.7.1