2009-07-07 02:26:36 +00:00
|
|
|
<?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/>.
|
2007-10-10 06:34:20 +00:00
|
|
|
|
2012-01-06 11:52:46 +07:00
|
|
|
/**
|
|
|
|
* Edit form for grade scales
|
|
|
|
*
|
|
|
|
* @package core_grades
|
|
|
|
* @copyright 2007 Petr Skoda
|
|
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|
|
|
*/
|
|
|
|
|
2010-05-13 02:02:05 +00:00
|
|
|
if (!defined('MOODLE_INTERNAL')) {
|
|
|
|
die('Direct access to this script is forbidden.'); /// It must be included from a Moodle page
|
|
|
|
}
|
|
|
|
|
2007-07-29 23:02:03 +00:00
|
|
|
require_once $CFG->libdir.'/formslib.php';
|
|
|
|
|
|
|
|
class edit_scale_form extends moodleform {
|
|
|
|
function definition() {
|
|
|
|
global $CFG;
|
|
|
|
$mform =& $this->_form;
|
|
|
|
|
|
|
|
// visible elements
|
|
|
|
$mform->addElement('header', 'general', get_string('scale'));
|
|
|
|
|
2007-07-31 21:10:20 +00:00
|
|
|
$mform->addElement('text', 'name', get_string('name'), 'size="40"');
|
2007-07-29 23:02:03 +00:00
|
|
|
$mform->addRule('name', get_string('required'), 'required', null, 'client');
|
|
|
|
$mform->setType('name', PARAM_TEXT);
|
|
|
|
|
2007-07-30 22:56:45 +00:00
|
|
|
$mform->addElement('advcheckbox', 'standard', get_string('scalestandard'));
|
2010-06-18 16:13:20 +00:00
|
|
|
$mform->addHelpButton('standard', 'scalestandard');
|
2007-07-29 23:02:03 +00:00
|
|
|
|
2007-09-18 18:37:58 +00:00
|
|
|
$mform->addElement('static', 'used', get_string('used'));
|
2007-07-29 23:02:03 +00:00
|
|
|
|
|
|
|
$mform->addElement('textarea', 'scale', get_string('scale'), array('cols'=>50, 'rows'=>2));
|
2010-06-27 21:30:44 +00:00
|
|
|
$mform->addHelpButton('scale', 'scale');
|
2007-07-29 23:02:03 +00:00
|
|
|
$mform->addRule('scale', get_string('required'), 'required', null, 'client');
|
|
|
|
$mform->setType('scale', PARAM_TEXT);
|
|
|
|
|
2009-11-04 06:14:06 +00:00
|
|
|
$mform->addElement('editor', 'description_editor', get_string('description'), null, $this->_customdata['editoroptions']);
|
2007-07-29 23:02:03 +00:00
|
|
|
|
|
|
|
// hidden params
|
|
|
|
$mform->addElement('hidden', 'id', 0);
|
|
|
|
$mform->setType('id', PARAM_INT);
|
|
|
|
|
|
|
|
$mform->addElement('hidden', 'courseid', 0);
|
|
|
|
$mform->setType('courseid', PARAM_INT);
|
|
|
|
|
|
|
|
/// add return tracking info
|
|
|
|
$gpr = $this->_customdata['gpr'];
|
|
|
|
$gpr->add_mform_elements($mform);
|
|
|
|
|
|
|
|
//-------------------------------------------------------------------------------
|
|
|
|
// buttons
|
|
|
|
$this->add_action_buttons();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// tweak the form - depending on existing data
|
|
|
|
function definition_after_data() {
|
|
|
|
global $CFG;
|
|
|
|
|
|
|
|
$mform =& $this->_form;
|
|
|
|
|
2007-07-30 22:56:45 +00:00
|
|
|
$courseid = $mform->getElementValue('courseid');
|
|
|
|
|
2007-07-29 23:02:03 +00:00
|
|
|
if ($id = $mform->getElementValue('id')) {
|
|
|
|
$scale = grade_scale::fetch(array('id'=>$id));
|
2007-09-18 18:37:58 +00:00
|
|
|
$used = $scale->is_used();
|
2007-07-30 22:56:45 +00:00
|
|
|
|
2007-09-18 18:37:58 +00:00
|
|
|
if ($used) {
|
2007-07-29 23:02:03 +00:00
|
|
|
$mform->hardFreeze('scale');
|
|
|
|
}
|
2007-07-30 22:56:45 +00:00
|
|
|
|
|
|
|
if (empty($courseid)) {
|
|
|
|
$mform->hardFreeze('standard');
|
|
|
|
|
2012-07-24 14:04:40 +08:00
|
|
|
} else if (!has_capability('moodle/course:managescales', context_system::instance())) {
|
2010-10-15 02:56:28 +00:00
|
|
|
//if they dont have managescales at system level the shouldnt be allowed to make scales standard (or not standard)
|
2007-07-30 22:56:45 +00:00
|
|
|
$mform->hardFreeze('standard');
|
|
|
|
|
2007-09-18 18:37:58 +00:00
|
|
|
} else if ($used and !empty($scale->courseid)) {
|
2007-07-30 22:56:45 +00:00
|
|
|
$mform->hardFreeze('standard');
|
|
|
|
}
|
|
|
|
|
2007-09-18 18:37:58 +00:00
|
|
|
$usedstr = $scale->is_used() ? get_string('yes') : get_string('no');
|
|
|
|
$used_el =& $mform->getElement('used');
|
|
|
|
$used_el->setValue($usedstr);
|
2007-07-29 23:02:03 +00:00
|
|
|
|
|
|
|
} else {
|
2007-09-18 18:37:58 +00:00
|
|
|
$mform->removeElement('used');
|
2012-07-24 14:04:40 +08:00
|
|
|
if (empty($courseid) or !has_capability('moodle/course:managescales', context_system::instance())) {
|
2007-07-30 22:56:45 +00:00
|
|
|
$mform->hardFreeze('standard');
|
2007-07-29 23:02:03 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/// perform extra validation before submission
|
2007-11-23 22:15:07 +00:00
|
|
|
function validation($data, $files) {
|
2008-06-01 17:53:25 +00:00
|
|
|
global $CFG, $COURSE, $DB;
|
2007-08-01 21:48:10 +00:00
|
|
|
|
2007-11-23 22:15:07 +00:00
|
|
|
$errors = parent::validation($data, $files);
|
2007-08-01 21:48:10 +00:00
|
|
|
|
2007-08-01 07:40:40 +00:00
|
|
|
// we can not allow 2 scales with the same exact scale as this creates
|
|
|
|
// problems for backup/restore
|
2007-09-15 21:17:11 +00:00
|
|
|
|
|
|
|
$old = grade_scale::fetch(array('id'=>$data['id']));
|
|
|
|
|
|
|
|
if (array_key_exists('standard', $data)) {
|
|
|
|
if (empty($data['standard'])) {
|
|
|
|
$courseid = $COURSE->id;
|
|
|
|
} else {
|
|
|
|
$courseid = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
} else {
|
|
|
|
$courseid = $old->courseid;
|
2007-08-01 21:48:10 +00:00
|
|
|
}
|
2007-07-29 23:02:03 +00:00
|
|
|
|
2007-09-15 21:17:11 +00:00
|
|
|
if (array_key_exists('scale', $data)) {
|
2010-11-22 05:52:13 +00:00
|
|
|
$scalearray = explode(',', $data['scale']);
|
|
|
|
$scalearray = array_map('trim', $scalearray);
|
|
|
|
$scaleoptioncount = count($scalearray);
|
2007-09-15 21:17:11 +00:00
|
|
|
|
2014-06-30 10:15:12 +08:00
|
|
|
if (count($scalearray) < 1) {
|
2010-11-22 05:52:13 +00:00
|
|
|
$errors['scale'] = get_string('badlyformattedscale', 'grades');
|
|
|
|
} else {
|
2012-03-01 02:04:45 +01:00
|
|
|
$thescale = implode(',',$scalearray);
|
2007-09-15 21:17:11 +00:00
|
|
|
|
2010-11-22 05:52:13 +00:00
|
|
|
//this check strips out whitespace from the scale we're validating but not from those already in the DB
|
2013-08-06 20:58:28 +02:00
|
|
|
$count = $DB->count_records_select('scale', "courseid=:courseid AND ".$DB->sql_compare_text('scale', core_text::strlen($thescale)).'=:scale',
|
2012-03-01 02:04:45 +01:00
|
|
|
array('courseid'=>$courseid, 'scale'=>$thescale));
|
2007-09-15 21:17:11 +00:00
|
|
|
|
2010-11-22 05:52:13 +00:00
|
|
|
if ($count) {
|
|
|
|
//if this is a new scale but we found a duplice in the DB
|
|
|
|
//or we found a duplicate in another course report the error
|
|
|
|
if (empty($old->id) or $old->courseid != $courseid) {
|
2012-03-01 02:04:45 +01:00
|
|
|
$errors['scale'] = get_string('duplicatescale', 'grades');
|
2010-11-22 05:52:13 +00:00
|
|
|
} else if ($old->scale !== $thescale and $old->scale !== $data['scale']) {
|
|
|
|
//if the old scale from DB is different but we found a duplicate then we're trying to modify a scale to be a duplicate
|
2012-03-01 02:04:45 +01:00
|
|
|
$errors['scale'] = get_string('duplicatescale', 'grades');
|
|
|
|
}
|
|
|
|
}
|
2007-09-15 21:17:11 +00:00
|
|
|
}
|
2007-07-29 23:02:03 +00:00
|
|
|
}
|
|
|
|
|
2007-11-23 22:15:07 +00:00
|
|
|
return $errors;
|
2007-07-29 23:02:03 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2009-11-01 12:11:29 +00:00
|
|
|
|