Search moodle.org's
Developer Documentation

See Release Notes
Long Term Support Release

  • Bug fixes for general core bugs in 4.1.x will end 13 November 2023 (12 months).
  • Bug fixes for security issues in 4.1.x will end 10 November 2025 (36 months).
  • PHP version: minimum PHP 7.4.0 Note: minimum PHP version has increased since Moodle 4.0. PHP 8.0.x is supported too.
<?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/>.

/**
 * Log report renderer.
 *
 * @package    report_log
 * @copyright  2014 Rajesh Taneja <rajesh.taneja@gmail.com>
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */
defined('MOODLE_INTERNAL') || die;

/**
 * Report log renderer's for printing reports.
 *
 * @package    report_log
 * @copyright  2014 Rajesh Taneja <rajesh.taneja@gmail.com>
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */
class report_log_renderer extends plugin_renderer_base {

    /**
     * This method should never be manually called, it should only be called by process.
     *
     * @deprecated since 2.8, to be removed in 2.9
     * @param report_log_renderable $reportlog
     * @return string
     */
    public function render_report_log_renderable(report_log_renderable $reportlog) {
        debugging('Do not call this method. Please call $renderer->render($reportlog) instead.', DEBUG_DEVELOPER);
        return $this->render($reportlog);
    }

    /**
     * Render log report page.
     *
     * @param report_log_renderable $reportlog object of report_log.
     */
    protected function render_report_log(report_log_renderable $reportlog) {
        if (empty($reportlog->selectedlogreader)) {
            echo $this->output->notification(get_string('nologreaderenabled', 'report_log'), 'notifyproblem');
            return;
        }
        if ($reportlog->showselectorform) {
            $this->report_selector_form($reportlog);
        }

        if ($reportlog->showreport) {
            $reportlog->tablelog->out($reportlog->perpage, true);
        }
    }

    /**
     * Prints/return reader selector
     *
     * @param report_log_renderable $reportlog log report.
     */
    public function reader_selector(report_log_renderable $reportlog) {
        $readers = $reportlog->get_readers(true);
        if (empty($readers)) {
            $readers = array(get_string('nologreaderenabled', 'report_log'));
        }
        $url = fullclone ($reportlog->url);
        $url->remove_params(array('logreader'));
        $select = new single_select($url, 'logreader', $readers, $reportlog->selectedlogreader, null);
        $select->set_label(get_string('selectlogreader', 'report_log'));
        echo $this->output->render($select);
    }

    /**
     * This function is used to generate and display selector form
     *
     * @param report_log_renderable $reportlog log report.
     */
    public function report_selector_form(report_log_renderable $reportlog) {
        echo html_writer::start_tag('form', array('class' => 'logselecform', 'action' => $reportlog->url, 'method' => 'get'));
        echo html_writer::start_div();
        echo html_writer::empty_tag('input', array('type' => 'hidden', 'name' => 'chooselog', 'value' => '1'));
        echo html_writer::empty_tag('input', array('type' => 'hidden', 'name' => 'showusers', 'value' => $reportlog->showusers));
        echo html_writer::empty_tag('input', array('type' => 'hidden', 'name' => 'showcourses',
            'value' => $reportlog->showcourses));

        $selectedcourseid = empty($reportlog->course) ? 0 : $reportlog->course->id;

        // Add course selector.
        $sitecontext = context_system::instance();
        $courses = $reportlog->get_course_list();
        if (!empty($courses) && $reportlog->showcourses) {
            echo html_writer::label(get_string('selectacourse'), 'menuid', false, array('class' => 'accesshide'));
< echo html_writer::select($courses, "id", $selectedcourseid, null);
> echo html_writer::select($courses, "id", $selectedcourseid, null, ['class' => 'mr-2 mb-2']);
} else { $courses = array(); $courses[$selectedcourseid] = get_course_display_name_for_list($reportlog->course) . (($selectedcourseid == SITEID) ? ' (' . get_string('site') . ') ' : ''); echo html_writer::label(get_string('selectacourse'), 'menuid', false, array('class' => 'accesshide'));
< echo html_writer::select($courses, "id", $selectedcourseid, false);
> echo html_writer::select($courses, "id", $selectedcourseid, false, ['class' => 'mr-2 mb-2']);
// Check if user is admin and this came because of limitation on number of courses to show in dropdown. if (has_capability('report/log:view', $sitecontext)) { $a = new stdClass(); $a->url = new moodle_url('/report/log/index.php', array('chooselog' => 0, 'group' => $reportlog->get_selected_group(), 'user' => $reportlog->userid, 'id' => $selectedcourseid, 'date' => $reportlog->date, 'modid' => $reportlog->modid, 'showcourses' => 1, 'showusers' => $reportlog->showusers)); $a->url = $a->url->out(false); print_string('logtoomanycourses', 'moodle', $a); } } // Add group selector. $groups = $reportlog->get_group_list(); if (!empty($groups)) { echo html_writer::label(get_string('selectagroup'), 'menugroup', false, array('class' => 'accesshide'));
< echo html_writer::select($groups, "group", $reportlog->groupid, get_string("allgroups"));
> echo html_writer::select($groups, "group", $reportlog->groupid, get_string("allgroups"), > ['class' => 'mr-2 mb-2']);
} // Add user selector. $users = $reportlog->get_user_list(); if ($reportlog->showusers) { echo html_writer::label(get_string('selctauser'), 'menuuser', false, array('class' => 'accesshide'));
< echo html_writer::select($users, "user", $reportlog->userid, get_string("allparticipants"));
> echo html_writer::select($users, "user", $reportlog->userid, get_string("allparticipants"), > ['class' => 'mr-2 mb-2']);
} else { $users = array(); if (!empty($reportlog->userid)) { $users[$reportlog->userid] = $reportlog->get_selected_user_fullname(); } else { $users[0] = get_string('allparticipants'); } echo html_writer::label(get_string('selctauser'), 'menuuser', false, array('class' => 'accesshide'));
< echo html_writer::select($users, "user", $reportlog->userid, false);
> echo html_writer::select($users, "user", $reportlog->userid, false, ['class' => 'mr-2 mb-2']);
$a = new stdClass(); $a->url = new moodle_url('/report/log/index.php', array('chooselog' => 0, 'group' => $reportlog->get_selected_group(), 'user' => $reportlog->userid, 'id' => $selectedcourseid, 'date' => $reportlog->date, 'modid' => $reportlog->modid, 'showusers' => 1, 'showcourses' => $reportlog->showcourses)); $a->url = $a->url->out(false); echo html_writer::start_span('mx-1'); print_string('logtoomanyusers', 'moodle', $a); echo html_writer::end_span(); } // Add date selector. $dates = $reportlog->get_date_options(); echo html_writer::label(get_string('date'), 'menudate', false, array('class' => 'accesshide'));
< echo html_writer::select($dates, "date", $reportlog->date, get_string("alldays"));
> echo html_writer::select($dates, "date", $reportlog->date, get_string("alldays"), > ['class' => 'mr-2 mb-2']);
// Add activity selector. $activities = $reportlog->get_activities_list(); echo html_writer::label(get_string('activities'), 'menumodid', false, array('class' => 'accesshide'));
< echo html_writer::select($activities, "modid", $reportlog->modid, get_string("allactivities"));
> echo html_writer::select($activities, "modid", $reportlog->modid, get_string("allactivities"), > ['class' => 'mr-2 mb-2']);
// Add actions selector. echo html_writer::label(get_string('actions'), 'menumodaction', false, array('class' => 'accesshide'));
< echo html_writer::select($reportlog->get_actions(), 'modaction', $reportlog->action, get_string("allactions"));
> echo html_writer::select($reportlog->get_actions(), 'modaction', $reportlog->action, > get_string("allactions"), ['class' => 'mr-2 mb-2']);
// Add origin. $origin = $reportlog->get_origin_options(); echo html_writer::label(get_string('origin', 'report_log'), 'menuorigin', false, array('class' => 'accesshide'));
< echo html_writer::select($origin, 'origin', $reportlog->origin, false);
> echo html_writer::select($origin, 'origin', $reportlog->origin, false, ['class' => 'mr-2 mb-2']);
// Add edulevel. $edulevel = $reportlog->get_edulevel_options(); echo html_writer::label(get_string('edulevel'), 'menuedulevel', false, array('class' => 'accesshide'));
< echo html_writer::select($edulevel, 'edulevel', $reportlog->edulevel, false).$this->help_icon('edulevel');
> echo html_writer::select($edulevel, 'edulevel', $reportlog->edulevel, false, > ['class' => 'mr-2 mb-2']) .$this->help_icon('edulevel');
// Add reader option. // If there is some reader available then only show submit button. $readers = $reportlog->get_readers(true); if (!empty($readers)) { if (count($readers) == 1) { $attributes = array('type' => 'hidden', 'name' => 'logreader', 'value' => key($readers)); echo html_writer::empty_tag('input', $attributes); } else { echo html_writer::label(get_string('selectlogreader', 'report_log'), 'menureader', false, array('class' => 'accesshide'));
< echo html_writer::select($readers, 'logreader', $reportlog->selectedlogreader, false);
> echo html_writer::select($readers, 'logreader', $reportlog->selectedlogreader, false, > ['class' => 'mr-2 mb-2']);
}
< echo html_writer::empty_tag('input', array('type' => 'submit', 'value' => get_string('gettheselogs'), < 'class' => 'btn btn-secondary'));
> echo html_writer::start_div('mt-1'); > echo html_writer::empty_tag('input', array('type' => 'submit', > 'value' => get_string('gettheselogs'), 'class' => 'btn btn-primary')); > echo html_writer::end_div();
} echo html_writer::end_div(); echo html_writer::end_tag('form'); } }