Search moodle.org's
Developer Documentation

See Release Notes

  • Bug fixes for general core bugs in 3.11.x will end 14 Nov 2022 (12 months plus 6 months extension).
  • Bug fixes for security issues in 3.11.x will end 13 Nov 2023 (18 months plus 12 months extension).
  • PHP version: minimum PHP 7.3.0 Note: minimum PHP version has increased since Moodle 3.10. PHP 7.4.x is supported too.
/user/ -> renderer.php (source)
<?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/>.

/**
 * Provides user rendering functionality such as printing private files tree and displaying a search utility
 *
 * @package    core_user
 * @copyright  2010 Dongsheng Cai <dongsheng@moodle.com>
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */

defined('MOODLE_INTERNAL') || die();

/**
 * Provides user rendering functionality such as printing private files tree and displaying a search utility
 * @copyright  2010 Dongsheng Cai <dongsheng@moodle.com>
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */
class core_user_renderer extends plugin_renderer_base {

    /**
     * Prints user search utility that can search user by first initial of firstname and/or first initial of lastname
     * Prints a header with a title and the number of users found within that subset
     * @param string $url the url to return to, complete with any parameters needed for the return
     * @param string $firstinitial the first initial of the firstname
     * @param string $lastinitial the first initial of the lastname
     * @param int $usercount the amount of users meeting the search criteria
     * @param int $totalcount the amount of users of the set/subset being searched
     * @param string $heading heading of the subset being searched, default is All Participants
     * @return string html output
     */
    public function user_search($url, $firstinitial, $lastinitial, $usercount, $totalcount, $heading = null) {

        if ($firstinitial !== 'all') {
            set_user_preference('ifirst', $firstinitial);
        }
        if ($lastinitial !== 'all') {
            set_user_preference('ilast', $lastinitial);
        }

        if (!isset($heading)) {
            $heading = get_string('allparticipants');
        }

        $content = html_writer::start_tag('form', array('action' => new moodle_url($url)));
        $content .= html_writer::start_tag('div');

        // Search utility heading.
        $content .= $this->output->heading($heading.get_string('labelsep', 'langconfig').$usercount.'/'.$totalcount, 3);

        // Initials bar.
        $prefixfirst = 'sifirst';
        $prefixlast = 'silast';
        $content .= $this->output->initials_bar($firstinitial, 'firstinitial', get_string('firstname'), $prefixfirst, $url);
        $content .= $this->output->initials_bar($lastinitial, 'lastinitial', get_string('lastname'), $prefixlast, $url);

        $content .= html_writer::end_tag('div');
        $content .= html_writer::tag('div', '&nbsp;');
        $content .= html_writer::end_tag('form');

        return $content;
    }

    /**
> * Construct a partial user search that'll require form handling implemented by the caller. * Displays the list of tagged users > * This allows the developer to have an initials bar setup that does not automatically redirect. * > * * @param array $userlist > * @param string $url the url to return to, complete with any parameters needed for the return * @param bool $exclusivemode if set to true it means that no other entities tagged with this tag > * @param string $firstinitial the first initial of the firstname * are displayed on the page and the per-page limit may be bigger > * @param string $lastinitial the first initial of the lastname * @return string > * @param bool $minirender Return a trimmed down view of the initials bar. */ > * @return string html output public function user_list($userlist, $exclusivemode) { > * @throws coding_exception $tagfeed = new core_tag\output\tagfeed(); > */ foreach ($userlist as $user) { > public function partial_user_search(String $url, String $firstinitial, String $lastinitial, Bool $minirender = false): String { $userpicture = $this->output->user_picture($user, array('size' => $exclusivemode ? 100 : 35)); > $fullname = fullname($user); > $content = ''; if (user_can_view_profile($user)) { > $profilelink = new moodle_url('/user/view.php', array('id' => $user->id)); > if ($firstinitial !== 'all') { $fullname = html_writer::link($profilelink, $fullname); > set_user_preference('ifirst', $firstinitial); } > } $tagfeed->add($userpicture, $fullname); > if ($lastinitial !== 'all') { } > set_user_preference('ilast', $lastinitial); > } $items = $tagfeed->export_for_template($this->output); > > // Initials bar. if ($exclusivemode) { > $prefixfirst = 'sifirst'; $output = '<div><ul class="inline-list">'; > $prefixlast = 'silast'; foreach ($items['items'] as $item) { > $content .= $this->output->initials_bar( $output .= '<li><div class="user-box">'. $item['img'] . $item['heading'] ."</div></li>\n"; > $firstinitial, } > 'firstinitial', $output .= "</ul></div>\n"; > get_string('firstname'), return $output; > $prefixfirst, } > $url, > null, return $this->output->render_from_template('core_tag/tagfeed', $items); > $minirender } > ); > $content .= $this->output->initials_bar( /** > $lastinitial, * Renders the unified filter element for the course participants page. > 'lastinitial', * @deprecated since Moodle 3.9 MDL-68612 - Please use participants_filter() instead. > get_string('lastname'), * > $prefixlast, * @param stdClass $course The course object. > $url, * @param context $context The context object. > null, * @param array $filtersapplied Array of currently applied filters. > $minirender * @param string|moodle_url $baseurl The url with params needed to call up this page. > ); * @return bool|string > */ > return $content; public function unified_filter($course, $context, $filtersapplied, $baseurl = null) { > } global $CFG, $DB, $USER; > > /**
< * @deprecated since Moodle 3.9 MDL-68612 - Please use participants_filter() instead. < * < * @param stdClass $course The course object. < * @param context $context The context object. < * @param array $filtersapplied Array of currently applied filters. < * @param string|moodle_url $baseurl The url with params needed to call up this page. < * @return bool|string
> * @deprecated since 3.9 > * @throws coding_exception
< public function unified_filter($course, $context, $filtersapplied, $baseurl = null) { < global $CFG, $DB, $USER; < < debugging('core_user_renderer->unified_filter() is deprecated. Please use participants_filter() instead.', DEBUG_DEVELOPER); < < require_once($CFG->dirroot . '/enrol/locallib.php'); < require_once($CFG->dirroot . '/lib/grouplib.php'); < $manager = new course_enrolment_manager($this->page, $course); < < $filteroptions = []; < < // Filter options for role. < $roleseditable = has_capability('moodle/role:assign', $context); < $roles = get_viewable_roles($context); < if ($roleseditable) { < $roles += get_assignable_roles($context, ROLENAME_ALIAS); < } < < $criteria = get_string('role'); < $roleoptions = $this->format_filter_option(USER_FILTER_ROLE, $criteria, -1, get_string('noroles', 'role')); < foreach ($roles as $id => $role) { < $roleoptions += $this->format_filter_option(USER_FILTER_ROLE, $criteria, $id, $role); < } < $filteroptions += $roleoptions; < < // Filter options for groups, if available. < if (has_capability('moodle/site:accessallgroups', $context) || $course->groupmode != SEPARATEGROUPS) { < // List all groups if the user can access all groups, or we are in visible group mode or no groups mode. < $groups = $manager->get_all_groups(); < if (!empty($groups)) { < // Add 'No group' option, to enable filtering users without any group. < $nogroup[USERSWITHOUTGROUP] = (object)['name' => get_string('nogroup', 'group')]; < $groups = $nogroup + $groups; < } < } else { < // Otherwise, just list the groups the user belongs to. < $groups = groups_get_all_groups($course->id, $USER->id); < } < $criteria = get_string('group'); < $groupoptions = []; < foreach ($groups as $id => $group) { < $groupoptions += $this->format_filter_option(USER_FILTER_GROUP, $criteria, $id, $group->name); < } < $filteroptions += $groupoptions; < < $canreviewenrol = has_capability('moodle/course:enrolreview', $context); < < // Filter options for status. < if ($canreviewenrol) { < $criteria = get_string('status'); < // Add statuses. < $filteroptions += $this->format_filter_option(USER_FILTER_STATUS, $criteria, ENROL_USER_ACTIVE, get_string('active')); < $filteroptions += $this->format_filter_option(USER_FILTER_STATUS, $criteria, ENROL_USER_SUSPENDED, < get_string('inactive')); < } < < // Filter options for enrolment methods. < if ($canreviewenrol && $enrolmentmethods = $manager->get_enrolment_instance_names(true)) { < $criteria = get_string('enrolmentinstances', 'enrol'); < $enroloptions = []; < foreach ($enrolmentmethods as $id => $enrolname) { < $enroloptions += $this->format_filter_option(USER_FILTER_ENROLMENT, $criteria, $id, $enrolname); < } < $filteroptions += $enroloptions; < } < < $isfrontpage = ($course->id == SITEID); < < // Get the list of fields we have to hide. < $hiddenfields = array(); < if (!has_capability('moodle/course:viewhiddenuserfields', $context)) { < $hiddenfields = array_flip(explode(',', $CFG->hiddenuserfields)); < } < $haslastaccess = !isset($hiddenfields['lastaccess']); < // Filter options for last access. < if ($haslastaccess) { < // Get minimum lastaccess for this course and display a dropbox to filter by lastaccess going back this far. < // We need to make it diferently for normal courses and site course. < if (!$isfrontpage) { < $params = ['courseid' => $course->id, 'timeaccess' => 0]; < $select = 'courseid = :courseid AND timeaccess != :timeaccess'; < $minlastaccess = $DB->get_field_select('user_lastaccess', 'MIN(timeaccess)', $select, $params); < $lastaccess0exists = $DB->record_exists('user_lastaccess', $params); < } else { < $params = ['lastaccess' => 0]; < $select = 'lastaccess != :lastaccess'; < $minlastaccess = $DB->get_field_select('user', 'MIN(lastaccess)', $select, $params); < $lastaccess0exists = $DB->record_exists('user', $params); < } < $now = usergetmidnight(time()); < $timeoptions = []; < $criteria = get_string('usersnoaccesssince'); < < // Days. < for ($i = 1; $i < 7; $i++) { < $timestamp = strtotime('-' . $i . ' days', $now); < if ($timestamp < $minlastaccess) { < break; < } < $value = get_string('numdays', 'moodle', $i); < $timeoptions += $this->format_filter_option(USER_FILTER_LAST_ACCESS, $criteria, $timestamp, $value); < } < // Weeks. < for ($i = 1; $i < 10; $i++) { < $timestamp = strtotime('-'.$i.' weeks', $now); < if ($timestamp < $minlastaccess) { < break; < } < $value = get_string('numweeks', 'moodle', $i); < $timeoptions += $this->format_filter_option(USER_FILTER_LAST_ACCESS, $criteria, $timestamp, $value); < } < // Months. < for ($i = 2; $i < 12; $i++) { < $timestamp = strtotime('-'.$i.' months', $now); < if ($timestamp < $minlastaccess) { < break; < } < $value = get_string('nummonths', 'moodle', $i); < $timeoptions += $this->format_filter_option(USER_FILTER_LAST_ACCESS, $criteria, $timestamp, $value); < } < // Try a year. < $timestamp = strtotime('-1 year', $now); < if ($timestamp >= $minlastaccess) { < $value = get_string('numyear', 'moodle', 1); < $timeoptions += $this->format_filter_option(USER_FILTER_LAST_ACCESS, $criteria, $timestamp, $value); < } < if (!empty($lastaccess0exists)) { < $value = get_string('never', 'moodle'); < $timeoptions += $this->format_filter_option(USER_FILTER_LAST_ACCESS, $criteria, $timestamp, $value); < } < if (count($timeoptions) > 1) { < $filteroptions += $timeoptions; < } < } < < // Add missing applied filters to the filter options. < $filteroptions = $this->handle_missing_applied_filters($filtersapplied, $filteroptions); < < $indexpage = new \core_user\output\unified_filter($filteroptions, $filtersapplied, $baseurl); < $context = $indexpage->export_for_template($this->output);
> public function unified_filter() { > throw new coding_exception('unified_filter cannot be used any more, please use participants_filter instead');
< return $this->output->render_from_template('core_user/unified_filter', $context);
< * @param string $tableregionid The table to be updated by this filter
> * @param string $tableregionid Container of the table to be updated by this filter, is used to retrieve the table
$renderable = new \core_user\output\participants_filter($context, $tableregionid); $templatecontext = $renderable->export_for_template($this->output); return $this->output->render_from_template('core_user/participantsfilter', $templatecontext); } /** * Returns a formatted filter option. * * @param int $filtertype The filter type (e.g. status, role, group, enrolment, last access). * @param string $criteria The string label of the filter type. * @param int $value The value for the filter option. * @param string $label The string representation of the filter option's value. * @return array The formatted option with the ['filtertype:value' => 'criteria: label'] format. */ protected function format_filter_option($filtertype, $criteria, $value, $label) { $optionlabel = get_string('filteroption', 'moodle', (object)['criteria' => $criteria, 'value' => $label]); $optionvalue = "$filtertype:$value"; return [$optionvalue => $optionlabel]; } /** * Handles cases when after reloading the applied filters are missing in the filter options. * * @param array $filtersapplied The applied filters. * @param array $filteroptions The filter options. * @return array The formatted options with the ['filtertype:value' => 'criteria: label'] format. */ private function handle_missing_applied_filters($filtersapplied, $filteroptions) { global $DB; foreach ($filtersapplied as $filter) { if (!array_key_exists($filter, $filteroptions)) { $filtervalue = explode(':', $filter); if (count($filtervalue) !== 2) { continue; } $key = $filtervalue[0]; $value = $filtervalue[1]; switch($key) { case USER_FILTER_LAST_ACCESS: $now = usergetmidnight(time()); $criteria = get_string('usersnoaccesssince'); // Days. for ($i = 1; $i < 7; $i++) { $timestamp = strtotime('-' . $i . ' days', $now); if ($timestamp < $value) { break; } $val = get_string('numdays', 'moodle', $i); $filteroptions += $this->format_filter_option(USER_FILTER_LAST_ACCESS, $criteria, $timestamp, $val); } // Weeks. for ($i = 1; $i < 10; $i++) { $timestamp = strtotime('-'.$i.' weeks', $now); if ($timestamp < $value) { break; } $val = get_string('numweeks', 'moodle', $i); $filteroptions += $this->format_filter_option(USER_FILTER_LAST_ACCESS, $criteria, $timestamp, $val); } // Months. for ($i = 2; $i < 12; $i++) { $timestamp = strtotime('-'.$i.' months', $now); if ($timestamp < $value) { break; } $val = get_string('nummonths', 'moodle', $i); $filteroptions += $this->format_filter_option(USER_FILTER_LAST_ACCESS, $criteria, $timestamp, $val); } // Try a year. $timestamp = strtotime('-1 year', $now); if ($timestamp >= $value) { $val = get_string('numyear', 'moodle', 1); $filteroptions += $this->format_filter_option(USER_FILTER_LAST_ACCESS, $criteria, $timestamp, $val); } break; case USER_FILTER_ROLE: $criteria = get_string('role'); if ($role = $DB->get_record('role', array('id' => $value))) { $role = role_get_name($role); $filteroptions += $this->format_filter_option(USER_FILTER_ROLE, $criteria, $value, $role); } break; } } } return $filteroptions; } }