diff --git a/grade/export/grade_export_form.php b/grade/export/grade_export_form.php index 03dff894854..9c3f935009d 100755 --- a/grade/export/grade_export_form.php +++ b/grade/export/grade_export_form.php @@ -6,10 +6,10 @@ class grade_export_form extends moodleform { global $CFG, $COURSE, $USER; $mform =& $this->_form; - if (isset($this->_customdata['plugin'])) { // hardcoding plugin names here is hacky - $plugin = $this->_customdata['plugin']; + if (isset($this->_customdata)) { // hardcoding plugin names here is hacky + $features = $this->_customdata; } else { - $plugin = 'unknown'; + $features = array(); } $mform->addElement('header', 'options', get_string('options', 'grades')); @@ -19,50 +19,59 @@ class grade_export_form extends moodleform { $mform->setHelpButton('export_letters', array(false, get_string('exportletters', 'grades'), false, true, false, get_string("exportlettershelp", 'grades'))); - $mform->addElement('header', 'publishing', get_string('publishing', 'grades')); - $options = array(get_string('nopublish', 'grades'), get_string('createnewkey', 'userkey')); - if ($keys = get_records_select('user_private_key', "script='grade/export' AND instance={$COURSE->id} AND userid={$USER->id}")) { - foreach ($keys as $key) { - $options[$key->value] = $key->value; // TODO: add ip, date, etc.?? - } + $options = array('10'=>10, '20'=>20, '100'=>100, '1000'=>1000, '100000'=>100000); + $mform->addElement('select', 'previewrows', 'Preview rows', $options); // TODO: localize + + if (!empty($features['includeseparator'])) { + $radio = array(); + $radio[] = &MoodleQuickForm::createElement('radio', 'separator', null, get_string('septab', 'grades'), 'tab'); + $radio[] = &MoodleQuickForm::createElement('radio', 'separator', null, get_string('sepcomma', 'grades'), 'comma'); + $mform->addGroup($radio, 'separator', get_string('separator', 'grades'), ' ', false); + $mform->setDefault('separator', 'comma'); } - $mform->addElement('select', 'key', get_string('userkey', 'userkey'), $options); - $mform->setHelpButton('key', array(false, get_string('userkey', 'userkey'), - false, true, false, get_string("userkeyhelp", 'grades'))); - $mform->addElement('static', 'keymanagerlink', get_string('keymanager', 'userkey'), - ''.get_string('keymanager', 'userkey').''); - $mform->addElement('text', 'iprestriction', get_string('keyiprestriction', 'userkey'), array('size'=>80)); - $mform->setHelpButton('iprestriction', array(false, get_string('keyiprestriction', 'userkey'), - false, true, false, get_string("keyiprestrictionhelp", 'userkey'))); + if (!empty($features['publishing'])) { + $mform->addElement('header', 'publishing', get_string('publishing', 'grades')); + $options = array(get_string('nopublish', 'grades'), get_string('createnewkey', 'userkey')); + if ($keys = get_records_select('user_private_key', "script='grade/export' AND instance={$COURSE->id} AND userid={$USER->id}")) { + foreach ($keys as $key) { + $options[$key->value] = $key->value; // TODO: add more details - ip restriction, valid until ?? + } + } + $mform->addElement('select', 'key', get_string('userkey', 'userkey'), $options); + $mform->setHelpButton('key', array(false, get_string('userkey', 'userkey'), + false, true, false, get_string("userkeyhelp", 'grades'))); + $mform->addElement('static', 'keymanagerlink', get_string('keymanager', 'userkey'), + ''.get_string('keymanager', 'userkey').''); + + $mform->addElement('text', 'iprestriction', get_string('keyiprestriction', 'userkey'), array('size'=>80)); + $mform->setHelpButton('iprestriction', array(false, get_string('keyiprestriction', 'userkey'), + false, true, false, get_string("keyiprestrictionhelp", 'userkey'))); + + $mform->addElement('date_time_selector', 'validuntil', get_string('keyvaliduntil', 'userkey'), array('optional'=>true)); + $mform->setHelpButton('validuntil', array(false, get_string('keyvaliduntil', 'userkey'), + false, true, false, get_string("keyvaliduntilhelp", 'userkey'))); + $mform->disabledIf('iprestriction', 'key', get_string('createnewkey', 'userkey')); + $mform->disabledIf('validuntil', 'key', get_string('createnewkey', 'userkey')); + } - $mform->addElement('date_time_selector', 'validuntil', get_string('keyvaliduntil', 'userkey'), array('optional'=>true)); - $mform->setHelpButton('validuntil', array(false, get_string('keyvaliduntil', 'userkey'), - false, true, false, get_string("keyvaliduntilhelp", 'userkey'))); - $mform->disabledIf('iprestriction', 'key', get_string('createnewkey', 'userkey')); - $mform->disabledIf('validuntil', 'key', get_string('createnewkey', 'userkey')); - - $mform->addElement('header', 'general', get_string('gradeitemsinc', 'grades')); // TODO: localize - - $mform->addElement('hidden', 'id', $COURSE->id); + $mform->addElement('header', 'gradeitems', get_string('gradeitemsinc', 'grades')); // TODO: localize if ($grade_items = grade_item::fetch_all(array('courseid'=>$COURSE->id))) { foreach ($grade_items as $grade_item) { - if ($plugin != 'xmlexport' || $grade_item->idnumber) { - $mform->addElement('advcheckbox', 'itemids['.$grade_item->id.']', $grade_item->get_name()); - $mform->setDefault('itemids['.$grade_item->id.']', 1); - - } else { + if (!empty($features['idnumberrequired']) and empty($grade_item->idnumber)) { $mform->addElement('advcheckbox', 'itemids['.$grade_item->id.']', $grade_item->get_name(), get_string('noidnumber')); $mform->hardFreeze('itemids['.$grade_item->id.']'); - $noidnumber = true; + + } else { + $mform->addElement('advcheckbox', 'itemids['.$grade_item->id.']', $grade_item->get_name()); + $mform->setDefault('itemids['.$grade_item->id.']', 1); } } } - $options = array('10'=>10, '20'=>20, '100'=>100, '1000'=>1000, '100000'=>100000); - $mform->addElement('select', 'previewrows', 'Preview rows', $options); // TODO: localize - $mform->setType('previewrows', PARAM_INT); + $mform->addElement('hidden', 'id', $COURSE->id); + $this->add_action_buttons(false, get_string('submit')); } } diff --git a/grade/export/txt/grade_export_txt_form.php b/grade/export/txt/grade_export_txt_form.php deleted file mode 100755 index c4795560e46..00000000000 --- a/grade/export/txt/grade_export_txt_form.php +++ /dev/null @@ -1,35 +0,0 @@ -libdir.'/formslib.php'; - -class grade_export_txt_form extends moodleform { - function definition (){ - global $CFG, $COURSE; - - $mform =& $this->_form; - - $mform->addElement('advcheckbox', 'export_letters', get_string('exportletters', 'grades')); - $mform->setDefault('export_letters', 0); - $mform->setHelpButton('export_letters', array(false, get_string('exportletters', 'grades'), - false, true, false, get_string("exportlettershelp", 'grades'))); - - $mform->addElement('header', 'general', 'Gradeitems to be included'); // TODO: localize - $mform->addElement('hidden', 'id', $COURSE->id); - if ($grade_items = grade_item::fetch_all(array('courseid'=>$COURSE->id))) { - foreach ($grade_items as $grade_item) { - $mform->addElement('advcheckbox', 'itemids['.$grade_item->id.']', $grade_item->get_name()); - $mform->setDefault('itemids['.$grade_item->id.']', 1); - } - } - $options = array('10'=>10, '20'=>20, '100'=>100, '1000'=>1000, '100000'=>100000); - $mform->addElement('select', 'previewrows', 'Preview rows', $options); // TODO: localize - $mform->setType('previewrows', PARAM_INT); - $radio = array(); - $radio[] = &MoodleQuickForm::createElement('radio', 'separator', null, get_string('septab', 'grades'), 'tab'); - $radio[] = &MoodleQuickForm::createElement('radio', 'separator', null, get_string('sepcomma', 'grades'), 'comma'); - $mform->addGroup($radio, 'separator', get_string('separator', 'grades'), ' ', false); - $mform->setDefault('separator', 'comma'); - - $this->add_action_buttons(false, get_string('submit')); - } -} -?> diff --git a/grade/export/txt/index.php b/grade/export/txt/index.php index f65ff7694d4..ea9d909ada9 100755 --- a/grade/export/txt/index.php +++ b/grade/export/txt/index.php @@ -26,7 +26,6 @@ require_once '../../../config.php'; require_once $CFG->dirroot.'/grade/export/lib.php'; require_once 'grade_export_txt.php'; -require_once 'grade_export_txt_form.php'; $id = required_param('id', PARAM_INT); // course id $feedback = optional_param('feedback', '', PARAM_ALPHA); @@ -49,7 +48,7 @@ $navigation = grade_build_nav(__FILE__, $actionstr, array('courseid' => $course- print_header($course->shortname.': '.get_string('grades'), $course->fullname, $navigation); print_grade_plugin_selector($id, 'export', 'txt'); -$mform = new grade_export_txt_form(); +$mform = new grade_export_form(null, array('includeseparator'=>true)); // process post information if ($data = $mform->get_data()) { diff --git a/grade/export/xml/index.php b/grade/export/xml/index.php index d4bdcdd7376..999ebb49e6e 100755 --- a/grade/export/xml/index.php +++ b/grade/export/xml/index.php @@ -48,7 +48,7 @@ $navigation = grade_build_nav(__FILE__, $actionstr, array('courseid' => $course- print_header($course->shortname.': '.get_string('grades'), $course->fullname, $navigation); print_grade_plugin_selector($id, 'export', 'xml'); -$mform = new grade_export_form(null, array('plugin'=>'xmlexport')); +$mform = new grade_export_form(null, array('idnumberrequired'=>true, 'publishing'=>true)); // process post information if ($data = $mform->get_data()) {