mirror of
https://github.com/moodle/moodle.git
synced 2025-04-15 05:25:08 +02:00
MDL-67351 quiz: Move quiz form defaults logic out of form.
By including the mod_form:apply_admin_defaults() method in the quiz moodle_form, each element does not need to set default and advanced states individually.
This commit is contained in:
parent
948a951a4e
commit
b5d1151574
@ -94,15 +94,11 @@ class mod_quiz_mod_form extends moodleform_mod {
|
||||
$mform->addElement('duration', 'timelimit', get_string('timelimit', 'quiz'),
|
||||
array('optional' => true));
|
||||
$mform->addHelpButton('timelimit', 'timelimit', 'quiz');
|
||||
$mform->setAdvanced('timelimit', $quizconfig->timelimit_adv);
|
||||
$mform->setDefault('timelimit', $quizconfig->timelimit);
|
||||
|
||||
// What to do with overdue attempts.
|
||||
$mform->addElement('select', 'overduehandling', get_string('overduehandling', 'quiz'),
|
||||
quiz_get_overdue_handling_options());
|
||||
$mform->addHelpButton('overduehandling', 'overduehandling', 'quiz');
|
||||
$mform->setAdvanced('overduehandling', $quizconfig->overduehandling_adv);
|
||||
$mform->setDefault('overduehandling', $quizconfig->overduehandling);
|
||||
// TODO Formslib does OR logic on disableif, and we need AND logic here.
|
||||
// $mform->disabledIf('overduehandling', 'timelimit', 'eq', 0);
|
||||
// $mform->disabledIf('overduehandling', 'timeclose', 'eq', 0);
|
||||
@ -111,8 +107,6 @@ class mod_quiz_mod_form extends moodleform_mod {
|
||||
$mform->addElement('duration', 'graceperiod', get_string('graceperiod', 'quiz'),
|
||||
array('optional' => true));
|
||||
$mform->addHelpButton('graceperiod', 'graceperiod', 'quiz');
|
||||
$mform->setAdvanced('graceperiod', $quizconfig->graceperiod_adv);
|
||||
$mform->setDefault('graceperiod', $quizconfig->graceperiod);
|
||||
$mform->hideIf('graceperiod', 'overduehandling', 'neq', 'graceperiod');
|
||||
|
||||
// -------------------------------------------------------------------------------
|
||||
@ -135,15 +129,11 @@ class mod_quiz_mod_form extends moodleform_mod {
|
||||
}
|
||||
$mform->addElement('select', 'attempts', get_string('attemptsallowed', 'quiz'),
|
||||
$attemptoptions);
|
||||
$mform->setAdvanced('attempts', $quizconfig->attempts_adv);
|
||||
$mform->setDefault('attempts', $quizconfig->attempts);
|
||||
|
||||
// Grading method.
|
||||
$mform->addElement('select', 'grademethod', get_string('grademethod', 'quiz'),
|
||||
quiz_get_grading_options());
|
||||
$mform->addHelpButton('grademethod', 'grademethod', 'quiz');
|
||||
$mform->setAdvanced('grademethod', $quizconfig->grademethod_adv);
|
||||
$mform->setDefault('grademethod', $quizconfig->grademethod);
|
||||
if ($this->get_max_attempts_for_any_override() < 2) {
|
||||
$mform->hideIf('grademethod', 'attempts', 'eq', 1);
|
||||
}
|
||||
@ -154,7 +144,6 @@ class mod_quiz_mod_form extends moodleform_mod {
|
||||
$pagegroup = array();
|
||||
$pagegroup[] = $mform->createElement('select', 'questionsperpage',
|
||||
get_string('newpage', 'quiz'), quiz_questions_per_page_options(), array('id' => 'id_questionsperpage'));
|
||||
$mform->setDefault('questionsperpage', $quizconfig->questionsperpage);
|
||||
|
||||
if (!empty($this->_cm)) {
|
||||
$pagegroup[] = $mform->createElement('checkbox', 'repaginatenow', '',
|
||||
@ -164,14 +153,11 @@ class mod_quiz_mod_form extends moodleform_mod {
|
||||
$mform->addGroup($pagegroup, 'questionsperpagegrp',
|
||||
get_string('newpage', 'quiz'), null, false);
|
||||
$mform->addHelpButton('questionsperpagegrp', 'newpage', 'quiz');
|
||||
$mform->setAdvanced('questionsperpagegrp', $quizconfig->questionsperpage_adv);
|
||||
|
||||
// Navigation method.
|
||||
$mform->addElement('select', 'navmethod', get_string('navmethod', 'quiz'),
|
||||
quiz_get_navigation_options());
|
||||
$mform->addHelpButton('navmethod', 'navmethod', 'quiz');
|
||||
$mform->setAdvanced('navmethod', $quizconfig->navmethod_adv);
|
||||
$mform->setDefault('navmethod', $quizconfig->navmethod);
|
||||
|
||||
// -------------------------------------------------------------------------------
|
||||
$mform->addElement('header', 'interactionhdr', get_string('questionbehaviour', 'quiz'));
|
||||
@ -179,8 +165,6 @@ class mod_quiz_mod_form extends moodleform_mod {
|
||||
// Shuffle within questions.
|
||||
$mform->addElement('selectyesno', 'shuffleanswers', get_string('shufflewithin', 'quiz'));
|
||||
$mform->addHelpButton('shuffleanswers', 'shufflewithin', 'quiz');
|
||||
$mform->setAdvanced('shuffleanswers', $quizconfig->shuffleanswers_adv);
|
||||
$mform->setDefault('shuffleanswers', $quizconfig->shuffleanswers);
|
||||
|
||||
// How questions behave (question behaviour).
|
||||
if (!empty($this->current->preferredbehaviour)) {
|
||||
@ -192,14 +176,11 @@ class mod_quiz_mod_form extends moodleform_mod {
|
||||
$mform->addElement('select', 'preferredbehaviour',
|
||||
get_string('howquestionsbehave', 'question'), $behaviours);
|
||||
$mform->addHelpButton('preferredbehaviour', 'howquestionsbehave', 'question');
|
||||
$mform->setDefault('preferredbehaviour', $quizconfig->preferredbehaviour);
|
||||
|
||||
// Can redo completed questions.
|
||||
$redochoices = array(0 => get_string('no'), 1 => get_string('canredoquestionsyes', 'quiz'));
|
||||
$mform->addElement('select', 'canredoquestions', get_string('canredoquestions', 'quiz'), $redochoices);
|
||||
$mform->addHelpButton('canredoquestions', 'canredoquestions', 'quiz');
|
||||
$mform->setAdvanced('canredoquestions', $quizconfig->canredoquestions_adv);
|
||||
$mform->setDefault('canredoquestions', $quizconfig->canredoquestions);
|
||||
foreach ($behaviours as $behaviour => $notused) {
|
||||
if (!question_engine::can_questions_finish_during_the_attempt($behaviour)) {
|
||||
$mform->hideIf('canredoquestions', 'preferredbehaviour', 'eq', $behaviour);
|
||||
@ -210,8 +191,6 @@ class mod_quiz_mod_form extends moodleform_mod {
|
||||
$mform->addElement('selectyesno', 'attemptonlast',
|
||||
get_string('eachattemptbuildsonthelast', 'quiz'));
|
||||
$mform->addHelpButton('attemptonlast', 'eachattemptbuildsonthelast', 'quiz');
|
||||
$mform->setAdvanced('attemptonlast', $quizconfig->attemptonlast_adv);
|
||||
$mform->setDefault('attemptonlast', $quizconfig->attemptonlast);
|
||||
if ($this->get_max_attempts_for_any_override() < 2) {
|
||||
$mform->hideIf('attemptonlast', 'attempts', 'eq', 1);
|
||||
}
|
||||
@ -253,8 +232,6 @@ class mod_quiz_mod_form extends moodleform_mod {
|
||||
$mform->addElement('select', 'showuserpicture', get_string('showuserpicture', 'quiz'),
|
||||
quiz_get_user_image_options());
|
||||
$mform->addHelpButton('showuserpicture', 'showuserpicture', 'quiz');
|
||||
$mform->setAdvanced('showuserpicture', $quizconfig->showuserpicture_adv);
|
||||
$mform->setDefault('showuserpicture', $quizconfig->showuserpicture);
|
||||
|
||||
// Overall decimal points.
|
||||
$options = array();
|
||||
@ -264,8 +241,6 @@ class mod_quiz_mod_form extends moodleform_mod {
|
||||
$mform->addElement('select', 'decimalpoints', get_string('decimalplaces', 'quiz'),
|
||||
$options);
|
||||
$mform->addHelpButton('decimalpoints', 'decimalplaces', 'quiz');
|
||||
$mform->setAdvanced('decimalpoints', $quizconfig->decimalpoints_adv);
|
||||
$mform->setDefault('decimalpoints', $quizconfig->decimalpoints);
|
||||
|
||||
// Question decimal points.
|
||||
$options = array(-1 => get_string('sameasoverall', 'quiz'));
|
||||
@ -275,14 +250,10 @@ class mod_quiz_mod_form extends moodleform_mod {
|
||||
$mform->addElement('select', 'questiondecimalpoints',
|
||||
get_string('decimalplacesquestion', 'quiz'), $options);
|
||||
$mform->addHelpButton('questiondecimalpoints', 'decimalplacesquestion', 'quiz');
|
||||
$mform->setAdvanced('questiondecimalpoints', $quizconfig->questiondecimalpoints_adv);
|
||||
$mform->setDefault('questiondecimalpoints', $quizconfig->questiondecimalpoints);
|
||||
|
||||
// Show blocks during quiz attempt.
|
||||
$mform->addElement('selectyesno', 'showblocks', get_string('showblocks', 'quiz'));
|
||||
$mform->addHelpButton('showblocks', 'showblocks', 'quiz');
|
||||
$mform->setAdvanced('showblocks', $quizconfig->showblocks_adv);
|
||||
$mform->setDefault('showblocks', $quizconfig->showblocks);
|
||||
|
||||
// -------------------------------------------------------------------------------
|
||||
$mform->addElement('header', 'security', get_string('extraattemptrestrictions', 'quiz'));
|
||||
@ -291,22 +262,16 @@ class mod_quiz_mod_form extends moodleform_mod {
|
||||
$mform->addElement('passwordunmask', 'quizpassword', get_string('requirepassword', 'quiz'));
|
||||
$mform->setType('quizpassword', PARAM_TEXT);
|
||||
$mform->addHelpButton('quizpassword', 'requirepassword', 'quiz');
|
||||
$mform->setAdvanced('quizpassword', $quizconfig->password_adv);
|
||||
$mform->setDefault('quizpassword', $quizconfig->password);
|
||||
|
||||
// IP address.
|
||||
$mform->addElement('text', 'subnet', get_string('requiresubnet', 'quiz'));
|
||||
$mform->setType('subnet', PARAM_TEXT);
|
||||
$mform->addHelpButton('subnet', 'requiresubnet', 'quiz');
|
||||
$mform->setAdvanced('subnet', $quizconfig->subnet_adv);
|
||||
$mform->setDefault('subnet', $quizconfig->subnet);
|
||||
|
||||
// Enforced time delay between quiz attempts.
|
||||
$mform->addElement('duration', 'delay1', get_string('delay1st2nd', 'quiz'),
|
||||
array('optional' => true));
|
||||
$mform->addHelpButton('delay1', 'delay1st2nd', 'quiz');
|
||||
$mform->setAdvanced('delay1', $quizconfig->delay1_adv);
|
||||
$mform->setDefault('delay1', $quizconfig->delay1);
|
||||
if ($this->get_max_attempts_for_any_override() < 2) {
|
||||
$mform->hideIf('delay1', 'attempts', 'eq', 1);
|
||||
}
|
||||
@ -314,8 +279,6 @@ class mod_quiz_mod_form extends moodleform_mod {
|
||||
$mform->addElement('duration', 'delay2', get_string('delaylater', 'quiz'),
|
||||
array('optional' => true));
|
||||
$mform->addHelpButton('delay2', 'delaylater', 'quiz');
|
||||
$mform->setAdvanced('delay2', $quizconfig->delay2_adv);
|
||||
$mform->setDefault('delay2', $quizconfig->delay2);
|
||||
if ($this->get_max_attempts_for_any_override() < 3) {
|
||||
$mform->hideIf('delay2', 'attempts', 'eq', 1);
|
||||
$mform->hideIf('delay2', 'attempts', 'eq', 2);
|
||||
@ -325,8 +288,6 @@ class mod_quiz_mod_form extends moodleform_mod {
|
||||
$mform->addElement('select', 'browsersecurity', get_string('browsersecurity', 'quiz'),
|
||||
quiz_access_manager::get_browser_security_choices());
|
||||
$mform->addHelpButton('browsersecurity', 'browsersecurity', 'quiz');
|
||||
$mform->setAdvanced('browsersecurity', $quizconfig->browsersecurity_adv);
|
||||
$mform->setDefault('browsersecurity', $quizconfig->browsersecurity);
|
||||
|
||||
// Any other rule plugins.
|
||||
quiz_access_manager::add_settings_form_fields($this, $mform);
|
||||
@ -400,6 +361,7 @@ class mod_quiz_mod_form extends moodleform_mod {
|
||||
$mform->setDefault('grade', $quizconfig->maximumgrade);
|
||||
|
||||
// -------------------------------------------------------------------------------
|
||||
$this->apply_admin_defaults();
|
||||
$this->add_action_buttons();
|
||||
|
||||
$PAGE->requires->yui_module('moodle-mod_quiz-modform', 'M.mod_quiz.modform.init');
|
||||
|
Loading…
x
Reference in New Issue
Block a user