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

/**
 * Drop down list (select list) element
 *
 * @package   gradereport_singleview
 * @copyright 2014 Moodle Pty Ltd (http://moodle.com)
 * @license   http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */

namespace gradereport_singleview\local\ui;

< use html_writer; <
defined('MOODLE_INTERNAL') || die; /** * Drop down list (select list) element * * @package gradereport_singleview * @copyright 2014 Moodle Pty Ltd (http://moodle.com) * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ class dropdown_attribute extends element {
< /** @var string $selected Who is selected ? */
> /** > * Who is selected? > * @var string $selected > */
private $selected;
< /** @var array $options List of options ? */
> /** > * List of options > * @var array $options > */
private $options;
< /** @var bool $isdisabled Is this input disabled. */
> /** > * Is this input disabled. > * @var bool $isdisabled > */
private $isdisabled;
> /** @var bool If this is a read-only input. */ /** > private bool $isreadonly; * Constructor >
* * @param string $name The first bit of the name of this input. * @param array $options The options list for this select. * @param string $label The form label for this input. * @param string $selected The name of the selected item in this input. * @param bool $isdisabled Are we disabled?
> * @param bool $isreadonly If this is a read-only input.
*/
< public function __construct($name, $options, $label, $selected = '', $isdisabled = false) {
> public function __construct( > string $name, > array $options, > string $label, > string $selected = '', > bool $isdisabled = false, > bool $isreadonly = false > ) {
$this->selected = $selected; $this->options = $options; $this->isdisabled = $isdisabled;
> $this->isreadonly = $isreadonly;
parent::__construct($name, $selected, $label); } /** * Nasty function spreading dropdown logic around. * * @return bool */
< public function is_dropdown() {
> public function is_dropdown(): bool {
return true; } /** * Render this element as html. * * @return string */
< public function html() {
> public function html(): string {
global $OUTPUT; $options = $this->options; $selected = $this->selected;
< $context = array(
> $context = [
'name' => $this->name, 'value' => $this->selected,
< 'tabindex' => 1,
> 'text' => $options[$selected],
'disabled' => !empty($this->isdisabled),
> 'readonly' => $this->isreadonly,
'options' => array_map(function($option) use ($options, $selected) { return [ 'name' => $options[$option], 'value' => $option, 'selected' => $selected == $option ]; }, array_keys($options)), 'label' => get_string('gradefor', 'gradereport_singleview', $this->label),
< );
> ];
return $OUTPUT->render_from_template('gradereport_singleview/dropdown_attribute', $context); } }