Fixed determination of right-to-left MDL-10768
[moodle.git] / grade / edit / tree / grade.php
CommitLineData
20544755 1<?php //$Id$
739196ba 2
78ad5f3f 3require_once '../../../config.php';
3af29899 4require_once $CFG->dirroot.'/grade/lib.php';
6fb39a98 5require_once 'grade_form.php';
20544755 6
7$courseid = required_param('courseid', PARAM_INT);
23207a1a 8$id = optional_param('id', 0, PARAM_INT);
9$itemid = optional_param('itemid', 0, PARAM_INT);
10$userid = optional_param('userid', 0, PARAM_INT);
20544755 11
12if (!$course = get_record('course', 'id', $courseid)) {
13 print_error('nocourseid');
14}
15
20544755 16require_login($course);
17$context = get_context_instance(CONTEXT_COURSE, $course->id);
27b1735b 18if (!has_capability('moodle/grade:manage', $context)) {
19 require_capability('moodle/grade:override', $context);
20}
20544755 21
22// default return url
3af29899 23$gpr = new grade_plugin_return();
24$returnurl = $gpr->get_return_url($CFG->wwwroot.'/grade/report.php?id='.$course->id);
20544755 25
23207a1a 26// security checks!
27if (!empty($id)) {
28 if (!$grade = get_record('grade_grades', 'id', $id)) {
29 error('Incorrect grade id');
30 }
31
32 if (!empty($itemid) and $itemid != $grade->itemid) {
33 error('Incorrect itemid');
34 }
35 $itemid = $grade->itemid;
36
37 if (!empty($userid) and $userid != $grade->userid) {
38 error('Incorrect userid');
39 }
40 $userid = $grade->userid;
79eabc2a 41
23207a1a 42 unset($grade);
9c25957a 43
23207a1a 44} else if (empty($userid) or empty($itemid)) {
45 error('Missing userid and itemid');
46}
47
48if (!$grade_item = grade_item::fetch(array('id'=>$itemid, 'courseid'=>$courseid))) {
49 error('Can not find grade_item');
50}
51
dc3ca94c 52// now verify grading user has access to all groups or is member of the same group when separate groups used in course
53if (groupmode($COURSE) == SEPARATEGROUPS and !has_capability('moodle/site:accessallgroups', $context)) {
54 if ($groups = user_group($COURSE->id, $userid)) {
55 $ok = false;
56 foreach ($groups as $group) {
57 if (groups_is_member($group->id, $USER->id)) {
58 $ok = true;
59 }
60 }
61 if (!$ok) {
62 error('Can not grade this user');
63 }
64 } else {
65 error('Can not grade this user');
66 }
67}
23207a1a 68
69$mform = new edit_grade_form(null, array('grade_item'=>$grade_item, 'gpr'=>$gpr));
70
15a51159 71if ($grade = get_record('grade_grades', 'itemid', $grade_item->id, 'userid', $userid)) {
23207a1a 72 if ($grade_text = get_record('grade_grades_text', 'gradeid', $grade->id)) {
73 // always clean existing feedback - grading should not have XSS risk
79eabc2a 74 if (can_use_html_editor()) {
75 $options = new object();
23207a1a 76 $options->smiley = false;
77 $options->filter = false;
78 $options->noclean = false;
79 $grade->feedback = format_text($grade_text->feedback, $grade_text->feedbackformat, $options);
80 $grade->feedbackformat = FORMAT_HTML;
81 } else {
82 $grade->feedback = clean_text($grade_text->feedback, $grade_text->feedbackformat);
83 $grade->feedbackformat = $grade_text->feedbackformat;
79eabc2a 84 }
920a0fb2 85 }
86
15a51159 87 $grade->locked = $grade->locked > 0 ? 1:0;
88 $grade->overridden = $grade->overridden > 0 ? 1:0;
89 $grade->excluded = $grade->excluded > 0 ? 1:0;
90
91 if ($grade->hidden > 1) {
92 $grade->hiddenuntil = $grade->hidden;
93 $grade->hidden = 0;
94 } else {
95 $grade->hiddenuntil = 0;
96 }
23207a1a 97
98 $mform->set_data($grade);
9c25957a 99
20544755 100} else {
27b1735b 101 $mform->set_data(array('itemid'=>$itemid, 'userid'=>$userid, 'locked'=>$grade_item->locked, 'locktime'=>$grade_item->locktime));
20544755 102}
103
104if ($mform->is_cancelled()) {
105 redirect($returnurl);
23207a1a 106
20544755 107// form processing
41486d1c 108} else if ($data = $mform->get_data(false)) {
23207a1a 109 $old_grade_grade = new grade_grade(array('userid'=>$data->userid, 'itemid'=>$grade_item->id), true); //might not exist yet
920a0fb2 110
0658afc9 111 // fix no grade for scales
112 if ($grade_item->gradetype == GRADE_TYPE_SCALE and $data->finalgrade < 1) {
113 $data->finalgrade = NULL;
114 }
115
23207a1a 116 // update final grade or feedback
117 $grade_item->update_final_grade($data->userid, $data->finalgrade, NULL, 'editgrade', $data->feedback, $data->feedbackformat);
8c4d80f1 118
23207a1a 119 $grade_grade = grade_grade::fetch(array('userid'=>$data->userid, 'itemid'=>$grade_item->id));
8c4d80f1 120
27b1735b 121 if (has_capability('moodle/grade:manage', $context) or has_capability('moodle/grade:hide', $context)) {
122 if (empty($data->hidden)) {
123 if (empty($data->hiddenuntil)) {
124 $grade_grade->set_hidden(0);
125 } else {
126 $grade_grade->set_hidden($data->hiddenuntil);
127 }
15a51159 128 } else {
27b1735b 129 $grade_grade->set_hidden(1);
15a51159 130 }
15a51159 131 }
23207a1a 132
0658afc9 133 if (has_capability('moodle/grade:manage', $context) or has_capability('moodle/grade:override', $context)) {
27b1735b 134 // ignore overridden flag when changing final grade
135 if ($old_grade_grade->finalgrade == $grade_grade->finalgrade) {
136 if ($grade_grade->set_overridden($data->overridden) and empty($data->overridden)) {
137 $grade_item->force_regrading(); // force regrading only when clearing the flag
138 }
23207a1a 139 }
140 }
141
27b1735b 142 if (has_capability('moodle/grade:manage', $context)) {
143 if ($grade_grade->set_excluded($data->excluded)) {
144 $grade_item->force_regrading();
145 }
23207a1a 146 }
920a0fb2 147
27b1735b 148 if (($old_grade_grade->locked or $old_grade_grade->locktime)
149 and (!has_capability('moodle/grade:manage', $context) and !has_capability('moodle/grade:unlock', $context))) {
150 //ignore data
20544755 151
27b1735b 152 } else if ((!$old_grade_grade->locked and !$old_grade_grade->locktime)
153 and (!has_capability('moodle/grade:manage', $context) and !has_capability('moodle/grade:lock', $context))) {
154 //ignore data
155
156 } else {
157 $grade_grade->set_locked($data->locked);
158 $grade_grade->set_locktime($data->locktime);
159 }
160
ffe6eb27 161 redirect($returnurl);
20544755 162}
163
20544755 164$strgrades = get_string('grades');
20544755 165$strgraderreport = get_string('graderreport', 'grades');
23207a1a 166$strgradeedit = get_string('editgrade', 'grades');
167$struser = get_string('user');
20544755 168
826c5f86 169$navigation = grade_build_nav(__FILE__, $strgradeedit, array('courseid' => $courseid));
20544755 170
171/*********** BEGIN OUTPUT *************/
172
23207a1a 173print_header_simple($strgrades . ': ' . $strgraderreport . ': ' . $strgradeedit,
174 ': ' . $strgradeedit , $navigation, '', '', true, '', navmenu($course));
20544755 175
23207a1a 176print_heading($strgradeedit);
20544755 177
178print_simple_box_start("center");
179
20544755 180// Form if in edit or add modes
181$mform->display();
20544755 182
183print_simple_box_end();
184
185print_footer($course);
186die;