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/>.

/**
 * Block for displaying earned local badges to users
 *
 * @package    block_badges
 * @copyright  2012 onwards Totara Learning Solutions Ltd {@link http://www.totaralms.com/}
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 * @author     Yuliya Bozhko <yuliya.bozhko@totaralms.com>
 */
> class block_badges extends block_base {
< defined('MOODLE_INTERNAL') || die();
> public function init() { > global $CFG;
require_once($CFG->libdir . "/badgeslib.php");
< /** < * Displays recent badges < */ < class block_badges extends block_base { < < public function init() {
$this->title = get_string('pluginname', 'block_badges'); } public function instance_allow_multiple() { return true; } public function has_config() { return false; } public function instance_allow_config() { return true; } public function applicable_formats() { return array( 'admin' => false, 'site-index' => true, 'course-view' => true, 'mod' => false, 'my' => true ); } public function specialization() { if (empty($this->config->title)) { $this->title = get_string('pluginname', 'block_badges'); } else { $this->title = $this->config->title; } } public function get_content() { global $USER, $CFG; if ($this->content !== null) { return $this->content; } if (empty($this->config)) { $this->config = new stdClass(); } // Number of badges to display. if (!isset($this->config->numberofbadges)) { $this->config->numberofbadges = 10; } // Create empty content. $this->content = new stdClass(); $this->content->text = ''; if (empty($CFG->enablebadges)) { $this->content->text .= get_string('badgesdisabled', 'badges'); return $this->content; } $courseid = $this->page->course->id; if ($courseid == SITEID) { $courseid = null; } if ($badges = badges_get_user_badges($USER->id, $courseid, 0, $this->config->numberofbadges)) { $output = $this->page->get_renderer('core', 'badges'); $this->content->text = $output->print_badges_list($badges, $USER->id, true); } else { $this->content->text .= get_string('nothingtodisplay', 'block_badges'); } return $this->content;
> } } > } > /** > * This block shouldn't be added to a page if the badges advanced feature is disabled. > * > * @param moodle_page $page > * @return bool > */ > public function can_block_be_added(moodle_page $page): bool { > global $CFG; > > return $CFG->enablebadges;