<?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/>.
/**
* Class that represents the exclude checkbox on a grade_grade.
*
* @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;
defined('MOODLE_INTERNAL') || die;
use grade_grade;
/**
* Class that represents the exclude checkbox on a grade_grade.
*
* @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 exclude extends grade_attribute_format implements be_checked, be_disabled {
> class exclude extends grade_attribute_format implements be_checked, be_disabled, be_readonly {
< /** @var string $name The name of the input */
> /**
> * The name of the input
> * @var string $name
> */
public $name = 'exclude';
< /** @var bool $disabled Is the checkbox disabled? */
> /**
> * Is the checkbox disabled?
> * @var bool $disabled
> */
public $disabled = false;
/**
* Is it checked?
*
* @return bool
*/
< public function is_checked() {
> public function is_checked(): bool {
return $this->grade->is_excluded();
}
/**
* Is it disabled?
*
* @return bool
*/
< public function is_disabled() {
> public function is_disabled(): bool {
return $this->disabled;
}
/**
> * Return true if this is read-only.
* Generate the element used to render the UI
> *
*
> * @return bool
* @return element
> */
*/
> public function is_readonly(): bool {
public function determine_format() {
> global $USER;
return new checkbox_attribute(
> return empty($USER->editing);
$this->get_name(),
> }
$this->get_label(),
>
$this->is_checked(),
> /**
< public function determine_format() {
> public function determine_format(): element {
< $this->is_disabled()
> $this->is_disabled(),
> $this->is_readonly()
}
/**
* Get the label for the form input
*
* @return string
*/
< public function get_label() {
> public function get_label(): string {
if (!isset($this->grade->label)) {
$this->grade->label = '';
}
return $this->grade->label;
}
/**
* Set the value that was changed in the form.
*
* @param string $value The value to set.
* @return mixed string|bool An error message or false.
*/
public function set($value) {
if (empty($this->grade->id)) {
if (empty($value)) {
return false;
}
$gradeitem = $this->grade->grade_item;
// Fill in arbitrary grade to be excluded.
$gradeitem->update_final_grade(
$this->grade->userid, null, 'singleview', null, FORMAT_MOODLE
);
< $gradeparams = array(
> $gradeparams = [
'userid' => $this->grade->userid,
'itemid' => $this->grade->itemid
< );
> ];
$this->grade = grade_grade::fetch($gradeparams);
$this->grade->grade_item = $gradeitem;
}
< $state = $value == 0 ? false : true;
> $state = !($value == 0);
$this->grade->set_excluded($state);
$this->grade->grade_item->get_parent_category()->force_regrading();
return false;
}
}