<?php
if (!defined('MOODLE_INTERNAL')) {
die('Direct access to this script is forbidden.'); /// It must be included from a Moodle page
}
require_once ($CFG->dirroot.'/course/moodleform_mod.php');
class mod_survey_mod_form extends moodleform_mod {
function definition() {
global $CFG, $DB;
$mform =& $this->_form;
$strrequired = get_string('required');
//-------------------------------------------------------------------------------
$mform->addElement('header', 'general', get_string('general', 'form'));
$mform->addElement('text', 'name', get_string('name'), array('size'=>'64'));
if (!empty($CFG->formatstringstriptags)) {
$mform->setType('name', PARAM_TEXT);
} else {
$mform->setType('name', PARAM_CLEANHTML);
}
$mform->addRule('name', null, 'required', null, 'client');
if (!$options = $DB->get_records_menu("survey", array("template"=>0), "name", "id, name")) {
< print_error('cannotfindsurveytmpt', 'survey');
> throw new \moodle_exception('cannotfindsurveytmpt', 'survey');
}
foreach ($options as $id => $name) {
$options[$id] = get_string($name, "survey");
}
$options = array(''=>get_string('choose').'...') + $options;
$mform->addElement('select', 'template', get_string("surveytype", "survey"), $options);
$mform->addRule('template', $strrequired, 'required', null, 'client');
$mform->addHelpButton('template', 'surveytype', 'survey');
$this->standard_intro_elements(get_string('customintro', 'survey'));
$this->standard_coursemodule_elements();
//-------------------------------------------------------------------------------
// buttons
$this->add_action_buttons();
}
/**
* Allows module to modify the data returned by form get_data().
* This method is also called in the bulk activity completion form.
*
* Only available on moodleform_mod.
*
* @param stdClass $data the form data to be modified.
*/
public function data_postprocessing($data) {
parent::data_postprocessing($data);
if (!empty($data->completionunlocked)) {
// Turn off completion settings if the checkboxes aren't ticked.
< $autocompletion = !empty($data->completion) &&
< $data->completion == COMPLETION_TRACKING_AUTOMATIC;
< if (!$autocompletion || empty($data->completionsubmit)) {
< $data->completionsubmit = 0;
> $suffix = $this->get_suffix();
> $completion = $data->{'completion' . $suffix};
> $autocompletion = !empty($completion) && $completion == COMPLETION_TRACKING_AUTOMATIC;
> if (!$autocompletion || empty($data->{'completionsubmit' . $suffix})) {
> $data->{'completionsubmit' . $suffix} = 0;
}
}
}
/**
* Add completion rules to form.
* @return array
*/
public function add_completion_rules() {
$mform =& $this->_form;
< $mform->addElement('checkbox', 'completionsubmit', '', get_string('completionsubmit', 'survey'));
> $suffix = $this->get_suffix();
> $completionsubmitel = 'completionsubmit' . $suffix;
> $mform->addElement('checkbox', $completionsubmitel, '', get_string('completionsubmit', 'survey'));
// Enable this completion rule by default.
< $mform->setDefault('completionsubmit', 1);
< return array('completionsubmit');
> $mform->setDefault($completionsubmitel, 1);
> return [$completionsubmitel];
}
/**
* Enable completion rules
< * @param stdclass $data
< * @return array
> * @param array $data
> * @return bool
*/
public function completion_rule_enabled($data) {
< return !empty($data['completionsubmit']);
> $suffix = $this->get_suffix();
> return !empty($data['completionsubmit' . $suffix]);
}
}
<