2 // This file is part of Moodle - http://moodle.org/
4 // Moodle is free software: you can redistribute it and/or modify
5 // it under the terms of the GNU General Public License as published by
6 // the Free Software Foundation, either version 3 of the License, or
7 // (at your option) any later version.
9 // Moodle is distributed in the hope that it will be useful,
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 // GNU General Public License for more details.
14 // You should have received a copy of the GNU General Public License
15 // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
18 * A moodleform to allow the editing of a user's grade for a particular activity
20 * @package core_grades
21 * @copyright 2007 Petr Skoda
22 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
25 if (!defined('MOODLE_INTERNAL')) {
26 die('Direct access to this script is forbidden.'); /// It must be included from a Moodle page
29 require_once $CFG->libdir.'/formslib.php';
31 class edit_grade_form extends moodleform {
33 function definition() {
34 global $CFG, $COURSE, $DB;
36 $mform =& $this->_form;
38 $grade_item = $this->_customdata['grade_item'];
39 $gpr = $this->_customdata['gpr'];
41 if ($grade_item->is_course_item()) {
42 $grade_category = null;
43 } else if ($grade_item->is_category_item()) {
44 $grade_category = $grade_item->get_item_category();
45 $grade_category = $grade_category->get_parent_category();
47 $grade_category = $grade_item->get_parent_category();
50 /// information fields
51 $mform->addElement('static', 'user', get_string('user'));
52 $mform->addElement('static', 'itemname', get_string('itemname', 'grades'));
54 $mform->addElement('checkbox', 'overridden', get_string('overridden', 'grades'));
55 $mform->addHelpButton('overridden', 'overridden', 'grades');
57 /// actual grade - numeric or scale
58 if ($grade_item->gradetype == GRADE_TYPE_VALUE) {
60 $mform->addElement('text', 'finalgrade', get_string('finalgrade', 'grades'));
61 $mform->addHelpButton('finalgrade', 'finalgrade', 'grades');
62 $mform->disabledIf('finalgrade', 'overridden', 'notchecked');
64 } else if ($grade_item->gradetype == GRADE_TYPE_SCALE) {
68 if (empty($grade_item->outcomeid)) {
69 $scaleopt[-1] = get_string('nograde');
71 $scaleopt[-1] = get_string('nooutcome', 'grades');
75 if ($scale = $DB->get_record('scale', array('id' => $grade_item->scaleid))) {
76 foreach (explode(",", $scale->scale) as $option) {
77 $scaleopt[$i] = $option;
82 $mform->addElement('select', 'finalgrade', get_string('finalgrade', 'grades'), $scaleopt);
83 $mform->addHelpButton('finalgrade', 'finalgrade', 'finalgrade');
84 $mform->disabledIf('finalgrade', 'overridden', 'notchecked');
87 if ($grade_category and $grade_category->aggregation == GRADE_AGGREGATE_SUM) {
88 $mform->addElement('advcheckbox', 'excluded', get_string('excluded', 'grades'), '<small>('.get_string('warningexcludedsum', 'grades').')</small>');
90 $mform->addElement('advcheckbox', 'excluded', get_string('excluded', 'grades'));
92 $mform->addHelpButton('excluded', 'excluded', 'grades');
95 /// advcheckbox is not compatible with disabledIf !!
96 $mform->addElement('checkbox', 'hidden', get_string('hidden', 'grades'));
97 $mform->addHelpButton('hidden', 'hidden', 'grades');
98 $mform->addElement('date_time_selector', 'hiddenuntil', get_string('hiddenuntil', 'grades'), array('optional'=>true));
99 $mform->disabledIf('hidden', 'hiddenuntil[off]', 'notchecked');
102 $mform->addElement('advcheckbox', 'locked', get_string('locked', 'grades'));
103 $mform->addHelpButton('locked', 'locked', 'grades');
104 $mform->addElement('date_time_selector', 'locktime', get_string('locktime', 'grades'), array('optional'=>true));
105 $mform->disabledIf('locktime', 'gradetype', 'eq', GRADE_TYPE_NONE);
107 // Feedback format is automatically converted to html if user has enabled editor
108 $feedbackoptions = array('maxfiles'=>0, 'maxbytes'=>0); //TODO: no files here for now, if ever gets implemented use component 'grade' and filearea 'feedback'
109 $mform->addElement('editor', 'feedback', get_string('feedback', 'grades'), null, $feedbackoptions);
110 $mform->addHelpButton('feedback', 'feedback', 'grades');
111 $mform->setType('text', PARAM_RAW); // to be cleaned before display, no XSS risk
114 $mform->addElement('hidden', 'oldgrade');
115 $mform->setType('oldgrade', PARAM_RAW);
116 $mform->addElement('hidden', 'oldfeedback');
117 $mform->setType('oldfeedback', PARAM_RAW);
119 $mform->addElement('hidden', 'id', 0);
120 $mform->setType('id', PARAM_INT);
122 $mform->addElement('hidden', 'itemid', 0);
123 $mform->setType('itemid', PARAM_INT);
125 $mform->addElement('hidden', 'userid', 0);
126 $mform->setType('userid', PARAM_INT);
128 $mform->addElement('hidden', 'courseid', $COURSE->id);
129 $mform->setType('courseid', PARAM_INT);
131 /// add return tracking info
132 $gpr->add_mform_elements($mform);
134 //-------------------------------------------------------------------------------
136 $this->add_action_buttons();
139 function definition_after_data() {
140 global $CFG, $COURSE, $DB;
142 $context = get_context_instance(CONTEXT_COURSE, $COURSE->id);
144 $mform =& $this->_form;
145 $grade_item = $this->_customdata['grade_item'];
147 // fill in user name if user still exists
148 $userid = $mform->getElementValue('userid');
149 if ($user = $DB->get_record('user', array('id' => $userid))) {
150 $username = '<a href="'.$CFG->wwwroot.'/user/view.php?id='.$userid.'">'.fullname($user).'</a>';
151 $user_el =& $mform->getElement('user');
152 $user_el->setValue($username);
155 // add activity name + link
156 if ($grade_item->itemtype == 'mod') {
157 $cm = get_coursemodule_from_instance($grade_item->itemmodule, $grade_item->iteminstance, $grade_item->courseid);
158 $itemname = '<a href="'.$CFG->wwwroot.'/mod/'.$grade_item->itemmodule.'/view.php?id='.$cm->id.'">'.$grade_item->get_name().'</a>';
160 $itemname = $grade_item->get_name();
162 $itemname_el =& $mform->getElement('itemname');
163 $itemname_el->setValue($itemname);
165 // access control - disable not allowed elements
166 if (!has_capability('moodle/grade:manage', $context)) {
167 $mform->hardFreeze('excluded');
170 if (!has_capability('moodle/grade:manage', $context) and !has_capability('moodle/grade:hide', $context)) {
171 $mform->hardFreeze('hidden');
172 $mform->hardFreeze('hiddenuntil');
175 $old_grade_grade = new grade_grade(array('itemid'=>$grade_item->id, 'userid'=>$userid));
177 if (!$grade_item->is_overridable_item()) {
178 $mform->removeElement('overridden');
181 if ($grade_item->is_hidden()) {
182 $mform->hardFreeze('hidden');
185 if ($old_grade_grade->is_locked()) {
186 if ($grade_item->is_locked()) {
187 $mform->hardFreeze('locked');
188 $mform->hardFreeze('locktime');
191 $mform->hardFreeze('overridden');
192 $mform->hardFreeze('finalgrade');
193 $mform->hardFreeze('feedback');
196 if (empty($old_grade_grade->id)) {
197 $old_grade_grade->locked = $grade_item->locked;
198 $old_grade_grade->locktime = $grade_item->locktime;
201 if (($old_grade_grade->locked or $old_grade_grade->locktime)
202 and (!has_capability('moodle/grade:manage', $context) and !has_capability('moodle/grade:unlock', $context))) {
203 $mform->hardFreeze('locked');
204 $mform->hardFreeze('locktime');
206 } else if ((!$old_grade_grade->locked and !$old_grade_grade->locktime)
207 and (!has_capability('moodle/grade:manage', $context) and !has_capability('moodle/grade:lock', $context))) {
208 $mform->hardFreeze('locked');
209 $mform->hardFreeze('locktime');