9413d65ee0
The images were not loading in the filemanager. This meant that when the element was saved the images would be deleted for that course, affecting existing image elements as well.
78 lines
2.7 KiB
PHP
78 lines
2.7 KiB
PHP
<?php
|
|
// This file is part of the customcert module for Moodle - http://moodle.org/
|
|
//
|
|
// Moodle is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
//
|
|
// Moodle is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
defined('MOODLE_INTERNAL') || die('Direct access to this script is forbidden.');
|
|
|
|
require_once($CFG->dirroot . '/course/moodleform_mod.php');
|
|
require_once($CFG->dirroot.'/mod/customcert/locallib.php');
|
|
require_once($CFG->dirroot . '/mod/customcert/includes/colourpicker.php');
|
|
|
|
MoodleQuickForm::registerElementType('customcert_colourpicker',
|
|
$CFG->dirroot . '/mod/customcert/includes/colourpicker.php', 'MoodleQuickForm_customcert_colourpicker');
|
|
|
|
/**
|
|
* The form for handling editing a customcert element.
|
|
*
|
|
* @package mod_customcert
|
|
* @copyright 2013 Mark Nelson <markn@moodle.com>
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|
*/
|
|
class mod_customcert_edit_element_form extends moodleform {
|
|
|
|
/**
|
|
* The element object.
|
|
*/
|
|
private $element;
|
|
|
|
/**
|
|
* Form definition.
|
|
*/
|
|
public function definition() {
|
|
$mform =& $this->_form;
|
|
|
|
$element = $this->_customdata['element'];
|
|
|
|
// Add the field for the name of the element, this is required for all elements.
|
|
$mform->addElement('text', 'name', get_string('elementname', 'customcert'));
|
|
$mform->setType('name', PARAM_TEXT);
|
|
$mform->setDefault('name', get_string('pluginname', 'customcertelement_' . $element->element));
|
|
$mform->addRule('name', get_string('required'), 'required', null, 'client');
|
|
$mform->addHelpButton('name', 'elementname', 'customcert');
|
|
|
|
$this->element = customcert_get_element_instance($element);
|
|
$this->element->render_form_elements($mform);
|
|
|
|
$this->add_action_buttons(true);
|
|
}
|
|
|
|
/**
|
|
* Fill in the current page data for this customcert.
|
|
*/
|
|
public function definition_after_data() {
|
|
$this->element->definition_after_data($this->_form);
|
|
}
|
|
|
|
/**
|
|
* Validation.
|
|
*
|
|
* @param array $data
|
|
* @param array $files
|
|
* @return array the errors that were found
|
|
*/
|
|
public function validation($data, $files) {
|
|
return $this->element->validate_form_elements($data, $files);
|
|
}
|
|
}
|