[ Index ]

PHP Cross Reference of moodle-2.8

title

Body

[close]

/mod/assign/ -> gradeform.php (source)

   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/>.
  16  
  17  /**
  18   * This file contains the forms to create and edit an instance of this module
  19   *
  20   * @package   mod_assign
  21   * @copyright 2012 NetSpot {@link http://www.netspot.com.au}
  22   * @license   http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
  23   */
  24  
  25  defined('MOODLE_INTERNAL') || die('Direct access to this script is forbidden.');
  26  
  27  
  28  require_once($CFG->libdir.'/formslib.php');
  29  require_once($CFG->dirroot . '/mod/assign/locallib.php');
  30  require_once('HTML/QuickForm/input.php');
  31  
  32  /**
  33   * Assignment grade form
  34   *
  35   * @package   mod_assign
  36   * @copyright 2012 NetSpot {@link http://www.netspot.com.au}
  37   * @license   http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
  38   */
  39  class mod_assign_grade_form extends moodleform {
  40      /** @var assignment $assignment */
  41      private $assignment;
  42  
  43      /**
  44       * Define the form - called by parent constructor.
  45       */
  46      public function definition() {
  47          $mform = $this->_form;
  48  
  49          list($assignment, $data, $params) = $this->_customdata;
  50          // Visible elements.
  51          $this->assignment = $assignment;
  52          $assignment->add_grade_form_elements($mform, $data, $params);
  53  
  54          if ($data) {
  55              $this->set_data($data);
  56          }
  57      }
  58  
  59      /**
  60       * This is required so when using "Save and next", each form is not defaulted to the previous form.
  61       * Giving each form a unique identitifer is enough to prevent this
  62       * (include the rownum in the form name).
  63       *
  64       * @return string - The unique identifier for this form.
  65       */
  66      protected function get_form_identifier() {
  67          $params = $this->_customdata[2];
  68          return get_class($this) . '_' . $params['rownum'];
  69      }
  70  
  71      /**
  72       * Perform minimal validation on the grade form
  73       * @param array $data
  74       * @param array $files
  75       */
  76      public function validation($data, $files) {
  77          global $DB;
  78          $errors = parent::validation($data, $files);
  79          $instance = $this->assignment->get_instance();
  80          // Advanced grading.
  81          if (!array_key_exists('grade', $data)) {
  82              return $errors;
  83          }
  84  
  85          if ($instance->grade > 0) {
  86              if (unformat_float($data['grade']) === null && (!empty($data['grade']))) {
  87                  $errors['grade'] = get_string('invalidfloatforgrade', 'assign', $data['grade']);
  88              } else if (unformat_float($data['grade']) > $instance->grade) {
  89                  $errors['grade'] = get_string('gradeabovemaximum', 'assign', $instance->grade);
  90              } else if (unformat_float($data['grade']) < 0) {
  91                  $errors['grade'] = get_string('gradebelowzero', 'assign');
  92              }
  93          } else {
  94              // This is a scale.
  95              if ($scale = $DB->get_record('scale', array('id'=>-($instance->grade)))) {
  96                  $scaleoptions = make_menu_from_list($scale->scale);
  97                  if ((int)$data['grade'] !== -1 && !array_key_exists((int)$data['grade'], $scaleoptions)) {
  98                      $errors['grade'] = get_string('invalidgradeforscale', 'assign');
  99                  }
 100              }
 101          }
 102          return $errors;
 103      }
 104  }


Generated: Fri Nov 28 20:29:05 2014 Cross-referenced by PHPXref 0.7.1