<?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/>.
/**
* Edit the grade options for an individual grade category
*
* @package core_grades
* @copyright 2007 Petr Skoda
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
< require_once '../../../config.php';
< require_once $CFG->dirroot.'/grade/lib.php';
< require_once $CFG->dirroot.'/grade/report/lib.php';
< require_once 'category_form.php';
> require_once('../../../config.php');
> require_once($CFG->dirroot.'/grade/lib.php');
> require_once($CFG->dirroot.'/grade/edit/tree/lib.php');
> require_once($CFG->dirroot.'/grade/report/lib.php');
> require_once('category_form.php');
$courseid = required_param('courseid', PARAM_INT);
$id = optional_param('id', 0, PARAM_INT); // grade_category->id
$url = new moodle_url('/grade/edit/tree/category.php', array('courseid'=>$courseid));
if ($id !== 0) {
$url->param('id', $id);
}
$PAGE->set_url($url);
$PAGE->set_pagelayout('admin');
navigation_node::override_active_url(new moodle_url('/grade/edit/tree/index.php',
array('id'=>$courseid)));
if (!$course = $DB->get_record('course', array('id' => $courseid))) {
< print_error('invalidcourseid');
> throw new \moodle_exception('invalidcourseid');
}
require_login($course);
$context = context_course::instance($course->id);
require_capability('moodle/grade:manage', $context);
// default return url
$gpr = new grade_plugin_return();
$returnurl = $gpr->get_return_url('index.php?id='.$course->id);
$heading = get_string('categoryedit', 'grades');
if ($id) {
if (!$grade_category = grade_category::fetch(array('id'=>$id, 'courseid'=>$course->id))) {
< print_error('invalidcategory');
> throw new \moodle_exception('invalidcategory');
}
$grade_category->apply_forced_settings();
$category = $grade_category->get_record_data();
// set parent
$category->parentcategory = $grade_category->parent;
$grade_item = $grade_category->load_grade_item();
// nomalize coef values if needed
$parent_category = $grade_category->get_parent_category();
foreach ($grade_item->get_record_data() as $key => $value) {
$category->{"grade_item_$key"} = $value;
}
$decimalpoints = $grade_item->get_decimals();
$category->grade_item_grademax = format_float($category->grade_item_grademax, $decimalpoints);
$category->grade_item_grademin = format_float($category->grade_item_grademin, $decimalpoints);
$category->grade_item_gradepass = format_float($category->grade_item_gradepass, $decimalpoints);
$category->grade_item_multfactor = format_float($category->grade_item_multfactor, 4);
$category->grade_item_plusfactor = format_float($category->grade_item_plusfactor, 4);
$category->grade_item_aggregationcoef2 = format_float($category->grade_item_aggregationcoef2 * 100.0, 4);
if (!$parent_category) {
// keep as is
} else if ($parent_category->aggregation == GRADE_AGGREGATE_SUM or $parent_category->aggregation == GRADE_AGGREGATE_WEIGHTED_MEAN2) {
$category->grade_item_aggregationcoef = $category->grade_item_aggregationcoef == 0 ? 0 : 1;
} else {
$category->grade_item_aggregationcoef = format_float($category->grade_item_aggregationcoef, 4);
}
// Check to see if the gradebook is frozen. This allows grades to not be altered at all until a user verifies that they
// wish to update the grades.
$gradebookcalculationsfreeze = get_config('core', 'gradebook_calculations_freeze_' . $courseid);
// Stick with the original code if the grade book is frozen.
if ($gradebookcalculationsfreeze && (int)$gradebookcalculationsfreeze <= 20150627) {
if ($category->aggregation == GRADE_AGGREGATE_SUM) {
// Input fields for grademin and grademax are disabled for the "Natural" category,
// this means they will be ignored if user does not change aggregation method.
// But if user does change aggregation method the default values should be used.
$category->grademax = 100;
$category->grade_item_grademax = 100;
$category->grademin = 0;
$category->grade_item_grademin = 0;
}
} else {
if ($category->aggregation == GRADE_AGGREGATE_SUM && !$grade_item->is_calculated()) {
// Input fields for grademin and grademax are disabled for the "Natural" category,
// this means they will be ignored if user does not change aggregation method.
// But if user does change aggregation method the default values should be used.
// This does not apply to calculated category totals.
$category->grademax = 100;
$category->grade_item_grademax = 100;
$category->grademin = 0;
$category->grade_item_grademin = 0;
}
}
} else {
$heading = get_string('newcategory', 'grades');
$grade_category = new grade_category(array('courseid'=>$courseid), false);
$grade_category->apply_default_settings();
$grade_category->apply_forced_settings();
$category = $grade_category->get_record_data();
$grade_item = new grade_item(array('courseid'=>$courseid, 'itemtype'=>'manual'), false);
foreach ($grade_item->get_record_data() as $key => $value) {
$category->{"grade_item_$key"} = $value;
}
}
$mform = new edit_category_form(null, array('current'=>$category, 'gpr'=>$gpr));
if ($mform->is_cancelled()) {
redirect($returnurl);
< } else if ($data = $mform->get_data(false)) {
< // If no fullname is entered for a course category, put ? in the DB
< if (!isset($data->fullname) || $data->fullname == '') {
< $data->fullname = '?';
< }
<
< if (!isset($data->aggregateonlygraded)) {
< $data->aggregateonlygraded = 0;
< }
< if (!isset($data->aggregateoutcomes)) {
< $data->aggregateoutcomes = 0;
< }
< grade_category::set_properties($grade_category, $data);
<
< /// CATEGORY
< if (empty($grade_category->id)) {
< $grade_category->insert();
<
< } else {
< $grade_category->update();
< }
<
< /// GRADE ITEM
< // grade item data saved with prefix "grade_item_"
< $itemdata = new stdClass();
< foreach ($data as $k => $v) {
< if (preg_match('/grade_item_(.*)/', $k, $matches)) {
< $itemdata->{$matches[1]} = $v;
< }
< }
<
< if (!isset($itemdata->aggregationcoef)) {
< $itemdata->aggregationcoef = 0;
< }
<
< if (!isset($itemdata->gradepass) || $itemdata->gradepass == '') {
< $itemdata->gradepass = 0;
< }
<
< if (!isset($itemdata->grademax) || $itemdata->grademax == '') {
< $itemdata->grademax = 0;
< }
<
< if (!isset($itemdata->grademin) || $itemdata->grademin == '') {
< $itemdata->grademin = 0;
< }
<
< $hidden = empty($itemdata->hidden) ? 0: $itemdata->hidden;
< $hiddenuntil = empty($itemdata->hiddenuntil) ? 0: $itemdata->hiddenuntil;
< unset($itemdata->hidden);
< unset($itemdata->hiddenuntil);
<
< $locked = empty($itemdata->locked) ? 0: $itemdata->locked;
< $locktime = empty($itemdata->locktime) ? 0: $itemdata->locktime;
< unset($itemdata->locked);
< unset($itemdata->locktime);
<
< $convert = array('grademax', 'grademin', 'gradepass', 'multfactor', 'plusfactor', 'aggregationcoef', 'aggregationcoef2');
< foreach ($convert as $param) {
< if (property_exists($itemdata, $param)) {
< $itemdata->$param = unformat_float($itemdata->$param);
< }
< }
< if (isset($itemdata->aggregationcoef2)) {
< $itemdata->aggregationcoef2 = $itemdata->aggregationcoef2 / 100.0;
< }
<
< // When creating a new category, a number of grade item fields are filled out automatically, and are required.
< // If the user leaves these fields empty during creation of a category, we let the default values take effect
< // Otherwise, we let the user-entered grade item values take effect
< $grade_item = $grade_category->load_grade_item();
< $grade_item_copy = fullclone($grade_item);
< grade_item::set_properties($grade_item, $itemdata);
<
< if (empty($grade_item->id)) {
< $grade_item->id = $grade_item_copy->id;
< }
< if (empty($grade_item->grademax) && $grade_item->grademax != '0') {
< $grade_item->grademax = $grade_item_copy->grademax;
< }
< if (empty($grade_item->grademin) && $grade_item->grademin != '0') {
< $grade_item->grademin = $grade_item_copy->grademin;
< }
< if (empty($grade_item->gradepass) && $grade_item->gradepass != '0') {
< $grade_item->gradepass = $grade_item_copy->gradepass;
< }
< if (empty($grade_item->aggregationcoef) && $grade_item->aggregationcoef != '0') {
< $grade_item->aggregationcoef = $grade_item_copy->aggregationcoef;
< }
<
< // Handle null decimals value - must be done before update!
< if (!property_exists($itemdata, 'decimals') or $itemdata->decimals < 0) {
< $grade_item->decimals = null;
< }
<
< // Change weightoverride flag. Check if the value is set, because it is not when the checkbox is not ticked.
< $itemdata->weightoverride = isset($itemdata->weightoverride) ? $itemdata->weightoverride : 0;
< if ($grade_item->weightoverride != $itemdata->weightoverride && $grade_category->aggregation == GRADE_AGGREGATE_SUM) {
< // If we are using natural weight and the weight has been un-overriden, force parent category to recalculate weights.
< $grade_category->force_regrading();
< }
< $grade_item->weightoverride = $itemdata->weightoverride;
<
< $grade_item->outcomeid = null;
<
< // This means we want to rescale overridden grades as well.
< if (!empty($data->grade_item_rescalegrades) && $data->grade_item_rescalegrades == 'yes') {
< $grade_item->markasoverriddenwhengraded = false;
< $grade_item->rescale_grades_keep_percentage($grade_item_copy->grademin, $grade_item_copy->grademax, $grade_item->grademin,
< $grade_item->grademax, 'gradebook');
< }
<
< // update hiding flag
< if ($hiddenuntil) {
< $grade_item->set_hidden($hiddenuntil, false);
< } else {
< $grade_item->set_hidden($hidden, false);
< }
<
< $grade_item->set_locktime($locktime); // locktime first - it might be removed when unlocking
< $grade_item->set_locked($locked, false, true);
<
< $grade_item->update(); // We don't need to insert it, it's already created when the category is created
<
< // set parent if needed
< if (isset($data->parentcategory)) {
< $grade_category->set_parent($data->parentcategory, 'gradebook');
< }
<
> } else if ($data = $mform->get_data()) {
> grade_edit_tree::update_gradecategory($grade_category, $data);
redirect($returnurl);
}
$PAGE->navbar->add($heading);
print_grade_page_head($courseid, 'settings', null, $heading, false, false, false);
$mform->display();
echo $OUTPUT->footer();
die;