. /** * prints the forms to choose an item-typ to create items and to choose a template to use * * @author Andreas Grabs * @license http://www.gnu.org/copyleft/gpl.html GNU Public License * @package mod_feedback */ //It must be included from a Moodle page if (!defined('MOODLE_INTERNAL')) { die('Direct access to this script is forbidden.'); } require_once($CFG->libdir.'/formslib.php'); class feedback_edit_use_template_form extends moodleform { /** * Form definition */ public function definition() { $mform =& $this->_form; $course = $this->_customdata['course']; $elementgroup = array(); //headline $mform->addElement('header', 'using_templates', get_string('using_templates', 'feedback')); // hidden elements $mform->addElement('hidden', 'id'); $mform->setType('id', PARAM_INT); // visible elements $templates_options = array(); $owntemplates = feedback_get_template_list($course, 'own'); $publictemplates = feedback_get_template_list($course, 'public'); $options = array(); if ($owntemplates or $publictemplates) { $options[''] = array('' => get_string('choosedots')); if ($owntemplates) { $courseoptions = array(); foreach ($owntemplates as $template) { $courseoptions[$template->id] = format_string($template->name); } $options[get_string('course')] = $courseoptions; } if ($publictemplates) { $publicoptions = array(); foreach ($publictemplates as $template) { $publicoptions[$template->id] = format_string($template->name); } $options[get_string('public', 'feedback')] = $publicoptions; } $attributes = 'onChange="M.core_formchangechecker.set_form_submitted(); this.form.submit()"'; $elementgroup[] = $mform->createElement('selectgroups', 'templateid', get_string('using_templates', 'feedback'), $options, $attributes); $elementgroup[] = $mform->createElement('submit', 'use_template', get_string('use_this_template', 'feedback'), array('class' => 'hiddenifjs')); $mform->addGroup($elementgroup, 'elementgroup', '', array(' '), false); } else { $mform->addElement('static', 'info', get_string('no_templates_available_yet', 'feedback')); } $this->set_data(array('id' => $this->_customdata['id'])); } } class feedback_edit_create_template_form extends moodleform { /** * Form definition */ public function definition() { $mform =& $this->_form; // hidden elements $mform->addElement('hidden', 'id'); $mform->setType('id', PARAM_INT); $mform->addElement('hidden', 'do_show'); $mform->setType('do_show', PARAM_ALPHANUMEXT); $mform->setConstant('do_show', 'templates'); //headline $mform->addElement('header', 'creating_templates', get_string('creating_templates', 'feedback')); // visible elements $elementgroup = array(); $elementgroup[] = $mform->createElement('text', 'templatename', get_string('name', 'feedback'), array('size'=>'40', 'maxlength'=>'200')); if (has_capability('mod/feedback:createpublictemplate', context_system::instance())) { $elementgroup[] = $mform->createElement('checkbox', 'ispublic', '', get_string('public', 'feedback')); } $mform->addGroup($elementgroup, 'elementgroup', get_string('name', 'feedback'), array(' '), false); // Buttons. $mform->addElement('submit', 'create_template', get_string('save_as_new_template', 'feedback')); $mform->setType('templatename', PARAM_TEXT); $this->set_data(array('id' => $this->_customdata['id'])); } /** * Form validation * * @param array $data array of ("fieldname"=>value) of submitted data * @param array $files array of uploaded files "element_name"=>tmp_file_path * @return array of "element_name"=>"error_description" if there are errors, * or an empty array if everything is OK (true allowed for backwards compatibility too). */ public function validation($data, $files) { $errors = parent::validation($data, $files); if (!isset($data['templatename']) || trim(strval($data['templatename'])) === '') { $errors['elementgroup'] = get_string('name_required', 'feedback'); } return $errors; } }