ae4bacd6bc9b6914ce18b61a8bbc3e72d800902e
[moodle.git] / grade / edit / outcome / edit_form.php
1 <?php
2 // This file is part of Moodle - http://moodle.org/
3 //
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.
8 //
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.
13 //
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/>.
17 /**
18  * Edit form for grade outcomes
19  *
20  * @package   core_grades
21  * @copyright 2007 Petr Skoda
22  * @license   http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
23  */
25 if (!defined('MOODLE_INTERNAL')) {
26     die('Direct access to this script is forbidden.');    ///  It must be included from a Moodle page
27 }
29 require_once $CFG->libdir.'/formslib.php';
31 class edit_outcome_form extends moodleform {
32     public function definition() {
33         global $CFG, $COURSE;
34         $mform =& $this->_form;
36         // visible elements
37         $mform->addElement('header', 'general', get_string('outcomes', 'grades'));
39         $mform->addElement('text', 'fullname', get_string('outcomefullname', 'grades'), 'size="40"');
40         $mform->addRule('fullname', get_string('required'), 'required');
41         $mform->setType('fullname', PARAM_TEXT);
43         $mform->addElement('text', 'shortname', get_string('outcomeshortname', 'grades'), 'size="20"');
44         $mform->addRule('shortname', get_string('required'), 'required');
45         $mform->setType('shortname', PARAM_NOTAGS);
47         $mform->addElement('advcheckbox', 'standard', get_string('outcomestandard', 'grades'));
48         $mform->addHelpButton('standard', 'outcomestandard', 'grades');
50         $options = array();
52         $mform->addElement('select', 'scaleid', get_string('scale'), $options);
54         $url = new moodle_url('/grade/edit/scale/edit.php', array('courseid' => $COURSE->id));
55         $label = get_string('scalescustomcreate');
56         $mform->addElement('static', 'scaleidlink', '', html_writer::link($url, $label));
58         $mform->addHelpButton('scaleid', 'typescale', 'grades');
59         $mform->addRule('scaleid', get_string('required'), 'required');
61         $mform->addElement('editor', 'description_editor', get_string('description'), null, $this->_customdata['editoroptions']);
64         // hidden params
65         $mform->addElement('hidden', 'id', 0);
66         $mform->setType('id', PARAM_INT);
68         $mform->addElement('hidden', 'courseid', 0);
69         $mform->setType('courseid', PARAM_INT);
71 /// add return tracking info
72         $gpr = $this->_customdata['gpr'];
73         $gpr->add_mform_elements($mform);
75 //-------------------------------------------------------------------------------
76         // buttons
77         $this->add_action_buttons();
78     }
81 /// tweak the form - depending on existing data
82     function definition_after_data() {
83         global $CFG;
85         $mform =& $this->_form;
87         // first load proper scales
88         if ($courseid = $mform->getElementValue('courseid')) {
89             $options = array();
90             if ($scales = grade_scale::fetch_all_local($courseid)) {
91                 $options[-1] = '--'.get_string('scalescustom');
92                 foreach($scales as $scale) {
93                     $options[$scale->id] = $scale->get_name();
94                 }
95             }
96             if ($scales = grade_scale::fetch_all_global()) {
97                 $options[-2] = '--'.get_string('scalesstandard');
98                 foreach($scales as $scale) {
99                     $options[$scale->id] = $scale->get_name();
100                 }
101             }
102             $scale_el =& $mform->getElement('scaleid');
103             $scale_el->load($options);
105         } else {
106             $options = array();
107             if ($scales = grade_scale::fetch_all_global()) {
108                 foreach($scales as $scale) {
109                     $options[$scale->id] = $scale->get_name();
110                 }
111             }
112             $scale_el =& $mform->getElement('scaleid');
113             $scale_el->load($options);
114         }
116         if ($id = $mform->getElementValue('id')) {
117             $outcome = grade_outcome::fetch(array('id'=>$id));
118             $itemcount   = $outcome->get_item_uses_count();
119             $coursecount = $outcome->get_course_uses_count();
121             if ($itemcount) {
122                 $mform->hardFreeze('scaleid');
123             }
125             if (empty($courseid)) {
126                 $mform->hardFreeze('standard');
128             } else if (!has_capability('moodle/grade:manage', context_system::instance())) {
129                 $mform->hardFreeze('standard');
131             } else if ($coursecount and empty($outcome->courseid)) {
132                 $mform->hardFreeze('standard');
133             }
136         } else {
137             if (empty($courseid) or !has_capability('moodle/grade:manage', context_system::instance())) {
138                 $mform->hardFreeze('standard');
139             }
140         }
141     }
143 /// perform extra validation before submission
144     function validation($data, $files) {
145         $errors = parent::validation($data, $files);
147         if ($data['scaleid'] < 1) {
148             $errors['scaleid'] = get_string('required');
149         }
151         if (!empty($data['standard']) and $scale = grade_scale::fetch(array('id'=>$data['scaleid']))) {
152             if (!empty($scale->courseid)) {
153                 //TODO: localize
154                 $errors['scaleid'] = 'Can not use custom scale in global outcome!';
155             }
156         }
158         return $errors;
159     }