2006-12-18 04:38:53 +00:00
< ? php // $Id$
2006-09-24 17:04:51 +00:00
/**
* formslib . php - library of classes for creating forms in Moodle , based on PEAR QuickForms .
2006-11-12 07:28:13 +00:00
*
* To use formslib then you will want to create a new file purpose_form . php eg . edit_form . php
* and you want to name your class something like { modulename } _ { purpose } _form . Your class will
* extend moodleform overriding abstract classes definition and optionally defintion_after_data
* and validation .
*
* See examples of use of this library in course / edit . php and course / edit_form . php
*
* A few notes :
* form defintion is used for both printing of form and processing and should be the same
* for both or you may lose some submitted data which won ' t be let through .
* you should be using setType for every form element except select , radio or checkbox
* elements , these elements clean themselves .
*
*
2006-09-24 17:04:51 +00:00
* @ author Jamie Pratt
* @ version $Id $
* @ license http :// www . gnu . org / copyleft / gpl . html GNU Public License
*/
//point pear include path to moodles lib/pear so that includes and requires will search there for files before anywhere else.
if ( FALSE === strstr ( ini_get ( 'include_path' ), $CFG -> libdir . '/pear' )){
ini_set ( 'include_path' , $CFG -> libdir . '/pear' . PATH_SEPARATOR . ini_get ( 'include_path' ));
}
require_once 'HTML/QuickForm.php' ;
require_once 'HTML/QuickForm/DHTMLRulesTableless.php' ;
require_once 'HTML/QuickForm/Renderer/Tableless.php' ;
2006-11-09 08:38:40 +00:00
require_once $CFG -> libdir . '/uploadlib.php' ;
2007-01-13 04:24:15 +00:00
define ( 'FORM_ADVANCEDIMAGEURL' , $CFG -> pixpath . '/adv.gif' );
define ( 'FORM_REQIMAGEURL' , $CFG -> pixpath . '/req.gif' );
2006-12-14 12:44:10 +00:00
2006-12-19 07:03:08 +00:00
/**
* Callback called when PEAR throws an error
*
* @ param PEAR_Error $error
*/
function pear_handle_error ( $error ){
echo '<strong>' . $error -> GetMessage () . '</strong> ' . $error -> getUserInfo ();
echo '<br /> <strong>Backtrace </strong>:' ;
print_object ( $error -> backtrace );
}
2006-09-25 11:08:44 +00:00
if ( $CFG -> debug >= DEBUG_ALL ){
2006-12-19 07:03:08 +00:00
PEAR :: setErrorHandling ( PEAR_ERROR_CALLBACK , 'pear_handle_error' );
2006-09-25 11:08:44 +00:00
}
2006-12-28 09:32:45 +00:00
2006-11-09 10:42:44 +00:00
/**
2006-11-12 07:28:13 +00:00
* Moodle specific wrapper that separates quickforms syntax from moodle code . You won ' t directly
* use this class you should write a class defintion which extends this class or a more specific
* subclass such a moodleform_mod for each form you want to display and / or process with formslib .
*
* You will write your own definition () method which performs the form set up .
2006-11-09 10:42:44 +00:00
*/
2006-10-12 07:33:57 +00:00
class moodleform {
2006-11-09 08:38:40 +00:00
var $_formname ; // form name
2006-11-15 07:40:49 +00:00
/**
* quickform object definition
*
* @ var MoodleQuickForm
*/
var $_form ;
/**
* globals workaround
*
* @ var array
*/
var $_customdata ;
/**
* file upload manager
*
* @ var upload_manager
*/
var $_upload_manager ; //
2006-10-12 07:33:57 +00:00
2006-12-04 09:36:30 +00:00
2006-11-24 12:20:26 +00:00
2006-11-12 07:28:13 +00:00
/**
* The constructor function calls the abstract function definition () and it will then
* process and clean and attempt to validate incoming data .
*
* It will call your custom validate method to validate data and will also check any rules
* you have specified in definition using addRule
*
* The name of the form ( id attribute of the form ) is automatically generated depending on
* the name you gave the class extending moodleform . You should call your class something
* like
*
2006-12-19 07:03:08 +00:00
* @ param string $action the action attribute for the form . If empty defaults to auto detect the
* current url .
2006-11-12 07:28:13 +00:00
* @ param array $customdata if your form defintion method needs access to data such as $course
* $cm , etc . to construct the form definition then pass it in this array . You can
* use globals for somethings .
* @ param string $method if you set this to anything other than 'post' then _GET and _POST will
* be merged and used as incoming data to the form .
* @ param string $target target frame for form submission . You will rarely use this . Don ' t use
* it if you don ' t need to as the target attribute is deprecated in xhtml
* strict .
* @ param mixed $attributes you can pass a string of html attributes here or an array .
* @ return moodleform
*/
2006-12-19 07:03:08 +00:00
function moodleform ( $action = null , $customdata = null , $method = 'post' , $target = '' , $attributes = null ) {
if ( empty ( $action )){
$action = strip_querystring ( qualified_me ());
}
2006-12-28 09:32:45 +00:00
2007-01-06 20:31:06 +00:00
$this -> _formname = get_class ( $this ); // '_form' suffix kept in order to prevent collisions of form id and other element
2006-10-12 07:33:57 +00:00
$this -> _customdata = $customdata ;
2006-10-14 12:32:31 +00:00
$this -> _form =& new MoodleQuickForm ( $this -> _formname , $method , $action , $target , $attributes );
2006-12-28 21:21:44 +00:00
$this -> set_upload_manager ( new upload_manager ());
2006-10-12 07:33:57 +00:00
$this -> definition ();
$this -> _form -> addElement ( 'hidden' , 'sesskey' , null ); // automatic sesskey protection
$this -> _form -> setDefault ( 'sesskey' , sesskey ());
2006-10-14 12:32:31 +00:00
$this -> _form -> addElement ( 'hidden' , '_qf__' . $this -> _formname , null ); // form submission marker
$this -> _form -> setDefault ( '_qf__' . $this -> _formname , 1 );
$this -> _form -> _setDefaultRuleMessages ();
2006-10-12 07:33:57 +00:00
// we have to know all input types before processing submission ;-)
$this -> _process_submission ( $method );
2006-11-09 10:42:44 +00:00
// update form definition based on final data
$this -> definition_after_data ();
2006-10-12 07:33:57 +00:00
}
2006-11-09 10:42:44 +00:00
2006-10-24 11:05:50 +00:00
/**
2006-11-12 07:28:13 +00:00
* To autofocus on first form element or first element with error .
2006-10-24 11:05:50 +00:00
*
* @ return string javascript to select form element with first error or
2006-11-12 07:28:13 +00:00
* first element if no errors . Use this as a parameter
* when calling print_header
2006-10-24 11:05:50 +00:00
*/
function focus (){
2006-11-22 15:58:07 +00:00
$form =& $this -> _form ;
2006-10-30 06:27:15 +00:00
$elkeys = array_keys ( $form -> _elementIndex );
2006-11-22 15:58:07 +00:00
if ( isset ( $form -> _errors ) && 0 != count ( $form -> _errors )){
$errorkeys = array_keys ( $form -> _errors );
$elkeys = array_intersect ( $elkeys , $errorkeys );
2006-10-24 11:05:50 +00:00
}
2006-11-22 15:58:07 +00:00
$names = null ;
while ( ! $names ){
$el = array_shift ( $elkeys );
2007-01-21 09:23:19 +00:00
$names = $form -> _getElNamesRecursive ( $el );
2006-11-22 15:58:07 +00:00
}
$name = array_shift ( $names );
$focus = 'forms[\'' . $this -> _form -> getAttribute ( 'id' ) . '\'].elements[\'' . $name . '\']' ;
return $focus ;
}
2006-10-12 07:33:57 +00:00
2006-11-09 10:42:44 +00:00
/**
* Internal method . Alters submitted data to be suitable for quickforms processing .
* Must be called when the form is fully set up .
*/
2006-10-12 07:33:57 +00:00
function _process_submission ( $method ) {
$submission = array ();
if ( $method == 'post' ) {
if ( ! empty ( $_POST )) {
$submission = $_POST ;
}
} else {
$submission = array_merge_recursive ( $_GET , $_POST ); // emulate handling of parameters in xxxx_param()
}
// following trick is needed to enable proper sesskey checks when using GET forms
2006-10-14 12:32:31 +00:00
// the _qf__.$this->_formname serves as a marker that form was actually submitted
if ( array_key_exists ( '_qf__' . $this -> _formname , $submission ) and $submission [ '_qf__' . $this -> _formname ] == 1 ) {
2006-10-12 07:33:57 +00:00
if ( ! confirm_sesskey ()) {
error ( 'Incorrect sesskey submitted, form not accepted!' );
}
2006-11-09 10:42:44 +00:00
$files = $_FILES ;
2006-10-12 07:33:57 +00:00
} else {
$submission = array ();
2006-11-09 10:42:44 +00:00
$files = array ();
2006-10-12 07:33:57 +00:00
}
2006-11-09 10:42:44 +00:00
$this -> _form -> updateSubmission ( $submission , $files );
2006-10-12 07:33:57 +00:00
}
2006-11-09 10:42:44 +00:00
/**
* Internal method . Validates all uploaded files .
*/
2006-11-09 08:38:40 +00:00
function _validate_files () {
if ( empty ( $_FILES )) {
// we do not need to do any checks because no files were submitted
// TODO: find out why server side required rule does not work for uploaded files;
// testing is easily done by always returning true from this function and adding
// $mform->addRule('soubor', get_string('required'), 'required', null, 'server');
// and submitting form without selected file
return true ;
}
$errors = array ();
$mform =& $this -> _form ;
// check the files
$status = $this -> _upload_manager -> preprocess_files ();
// now check that we really want each file
foreach ( $_FILES as $elname => $file ) {
if ( $mform -> elementExists ( $elname ) and $mform -> getElementType ( $elname ) == 'file' ) {
$required = $mform -> isElementRequired ( $elname );
if ( ! empty ( $this -> _upload_manager -> files [ $elname ][ 'uploadlog' ]) and empty ( $this -> _upload_manager -> files [ $elname ][ 'clear' ])) {
if ( ! $required and $file [ 'error' ] == UPLOAD_ERR_NO_FILE ) {
// file not uploaded and not required - ignore it
continue ;
}
$errors [ $elname ] = $this -> _upload_manager -> files [ $elname ][ 'uploadlog' ];
}
} else {
2006-12-28 21:21:44 +00:00
error ( 'Incorrect upload attempt!' );
2006-11-09 08:38:40 +00:00
}
}
// return errors if found
if ( $status and 0 == count ( $errors )){
return true ;
} else {
return $errors ;
}
}
2006-11-09 10:42:44 +00:00
/**
2006-11-12 07:28:13 +00:00
* Load in existing data as form defaults . Usually new entry defaults are stored directly in
* form definition ( new entry form ); this function is used to load in data where values
* already exist and data is being edited ( edit entry form ) .
2006-11-09 10:42:44 +00:00
*
* @ param mixed $default_values object or array of default values
* @ param bool $slased true if magic quotes applied to data values
*/
2007-01-12 18:52:09 +00:00
function set_data ( $default_values , $slashed = false ) {
2006-10-12 07:33:57 +00:00
if ( is_object ( $default_values )) {
$default_values = ( array ) $default_values ;
}
$filter = $slashed ? 'stripslashes' : NULL ;
$this -> _form -> setDefaults ( $default_values , $filter );
2006-11-09 10:43:26 +00:00
//update form definition when data changed
2006-11-09 10:42:44 +00:00
$this -> definition_after_data ();
2006-10-12 07:33:57 +00:00
}
2006-11-23 08:24:58 +00:00
/**
2006-12-28 21:21:44 +00:00
* Set custom upload manager .
2006-11-23 08:24:58 +00:00
* Must be used BEFORE creating of file element !
*
2006-12-28 21:21:44 +00:00
* @ param object $um - custom upload manager
2006-11-23 08:24:58 +00:00
*/
2006-12-28 21:21:44 +00:00
function set_upload_manager ( $um = false ) {
if ( $um === false ) {
$um = new upload_manager ();
2006-11-23 08:24:58 +00:00
}
2006-12-28 21:21:44 +00:00
$this -> _upload_manager = $um ;
2006-11-23 08:24:58 +00:00
2006-12-28 21:21:44 +00:00
$this -> _form -> setMaxFileSize ( $um -> config -> maxbytes );
2006-11-23 08:24:58 +00:00
}
2006-11-09 10:42:44 +00:00
/**
* Check that form was submitted . Does not check validity of submitted data .
*
* @ return bool true if form properly submitted
*/
2006-10-12 07:33:57 +00:00
function is_submitted () {
return $this -> _form -> isSubmitted ();
}
2006-12-19 07:03:08 +00:00
function no_submit_button_pressed (){
static $nosubmit = null ; // one check is enough
if ( ! is_null ( $nosubmit )){
return $nosubmit ;
}
$mform =& $this -> _form ;
$nosubmit = false ;
2006-12-28 09:32:45 +00:00
if ( ! $this -> is_submitted ()){
return false ;
}
2006-12-19 07:03:08 +00:00
foreach ( $mform -> _noSubmitButtons as $nosubmitbutton ){
if ( optional_param ( $nosubmitbutton , 0 , PARAM_RAW )){
$nosubmit = true ;
break ;
}
}
return $nosubmit ;
}
2006-11-09 10:42:44 +00:00
/**
* Check that form data is valid .
*
* @ return bool true if form data valid
*/
2006-10-12 07:33:57 +00:00
function is_validated () {
2006-11-09 08:38:40 +00:00
static $validated = null ; // one validation is enough
2006-12-04 10:55:50 +00:00
$mform =& $this -> _form ;
2006-12-28 09:32:45 +00:00
2007-01-10 05:05:26 +00:00
if ( $this -> no_submit_button_pressed ()){
return false ;
} elseif ( $validated === null ) {
2006-12-04 10:55:50 +00:00
$internal_val = $mform -> validate ();
$moodle_val = $this -> validation ( $mform -> exportValues ( null , true ));
2006-10-12 07:33:57 +00:00
if ( $moodle_val !== true ) {
2006-12-19 07:03:08 +00:00
if (( is_array ( $moodle_val ) && count ( $moodle_val ) !== 0 )) {
2006-10-12 07:33:57 +00:00
foreach ( $moodle_val as $element => $msg ) {
2006-12-04 10:55:50 +00:00
$mform -> setElementError ( $element , $msg );
2006-10-12 07:33:57 +00:00
}
2006-12-19 07:03:08 +00:00
$moodle_val = false ;
} else {
$moodle_val = true ;
2006-10-12 07:33:57 +00:00
}
}
2006-11-09 08:38:40 +00:00
$file_val = $this -> _validate_files ();
if ( $file_val !== true ) {
if ( ! empty ( $file_val )) {
foreach ( $file_val as $element => $msg ) {
2006-12-04 10:55:50 +00:00
$mform -> setElementError ( $element , $msg );
2006-11-09 08:38:40 +00:00
}
}
$file_val = false ;
}
$validated = ( $internal_val and $moodle_val and $file_val );
2006-10-12 07:33:57 +00:00
}
2007-01-10 05:05:26 +00:00
return $validated ;
2006-10-12 07:33:57 +00:00
}
2006-12-04 09:36:30 +00:00
/**
* Return true if a cancel button has been pressed resulting in the form being submitted .
*
* @ return boolean true if a cancel button has been pressed
*/
function is_cancelled (){
$mform =& $this -> _form ;
2006-12-19 07:03:08 +00:00
if ( $mform -> isSubmitted ()){
foreach ( $mform -> _cancelButtons as $cancelbutton ){
if ( optional_param ( $cancelbutton , 0 , PARAM_RAW )){
return true ;
}
2006-12-04 09:36:30 +00:00
}
}
return false ;
}
2006-11-09 10:42:44 +00:00
/**
2006-11-12 07:28:13 +00:00
* Return submitted data if properly submitted or returns NULL if validation fails or
* if there is no submitted data .
2006-11-09 10:42:44 +00:00
*
* @ param bool $slashed true means return data with addslashes applied
* @ return object submitted data ; NULL if not valid or not submitted
*/
2007-01-12 18:52:09 +00:00
function get_data ( $slashed = true ) {
2006-12-04 09:36:30 +00:00
$mform =& $this -> _form ;
2006-12-04 10:55:50 +00:00
2006-10-12 07:33:57 +00:00
if ( $this -> is_submitted () and $this -> is_validated ()) {
2006-12-04 09:36:30 +00:00
$data = $mform -> exportValues ( null , $slashed );
2006-10-14 12:32:31 +00:00
unset ( $data [ 'sesskey' ]); // we do not need to return sesskey
unset ( $data [ '_qf__' . $this -> _formname ]); // we do not need the submission marker too
2006-10-12 07:33:57 +00:00
if ( empty ( $data )) {
return NULL ;
} else {
return ( object ) $data ;
}
} else {
return NULL ;
}
}
2006-11-09 10:42:44 +00:00
/**
* Save verified uploaded files into directory . Upload process can be customised from definition ()
2006-11-09 10:43:26 +00:00
* method by creating instance of upload manager and storing it in $this -> _upload_form
2006-11-09 10:42:44 +00:00
*
* @ param string $destination where to store uploaded files
* @ return bool success
*/
2006-11-09 08:38:40 +00:00
function save_files ( $destination ) {
if ( $this -> is_submitted () and $this -> is_validated ()) {
return $this -> _upload_manager -> save_files ( $destination );
}
return false ;
}
2006-11-07 08:48:18 +00:00
2006-12-28 21:21:44 +00:00
/**
* If we ' re only handling one file ( if inputname was given in the constructor )
* this will return the ( possibly changed ) filename of the file .
* @ return mixed false in case of failure , string if ok
*/
function get_new_filename () {
return $this -> _upload_manager -> get_new_filename ();
}
2006-11-09 10:42:44 +00:00
/**
* Print html form .
*/
2006-10-12 07:33:57 +00:00
function display () {
$this -> _form -> display ();
}
2006-11-09 08:38:40 +00:00
/**
2006-11-09 10:42:44 +00:00
* Abstract method - always override !
2006-11-09 08:38:40 +00:00
*
* If you need special handling of uploaded files , create instance of $this -> _upload_manager here .
*/
2006-10-12 07:33:57 +00:00
function definition () {
error ( 'Abstract form_definition() method in class ' . get_class ( $this ) . ' must be overriden, please fix the code.' );
}
2006-10-24 11:05:50 +00:00
2006-10-16 12:07:44 +00:00
/**
2006-11-09 10:42:44 +00:00
* Dummy stub method - override if you need to setup the form depending on current
2007-01-12 18:52:09 +00:00
* values . This method is called after definition (), data submission and set_data () .
2006-11-09 10:42:44 +00:00
* All form setup that is dependent on form values should go in here .
2006-10-16 12:07:44 +00:00
*/
function definition_after_data (){
}
2006-10-12 07:33:57 +00:00
2006-11-09 10:42:44 +00:00
/**
* Dummy stub method - override if you needed to perform some extra validation .
* If there are errors return array of errors ( " fieldname " => " error message " ),
* otherwise true if ok .
2006-11-09 10:43:26 +00:00
*
2006-11-09 10:42:44 +00:00
* @ param array $data array of ( " fieldname " => value ) of submitted data
2006-11-09 10:43:26 +00:00
* @ return bool array of errors or true if ok
2006-11-09 10:42:44 +00:00
*/
2006-10-12 07:33:57 +00:00
function validation ( $data ) {
return true ;
}
2006-11-24 12:20:26 +00:00
2006-12-04 09:36:30 +00:00
2006-11-24 12:20:26 +00:00
2006-12-14 12:44:10 +00:00
2006-12-19 07:03:08 +00:00
2006-11-24 12:33:53 +00:00
/**
* Method to add a repeating group of elements to a form .
*
* @ param array $elementobjs Array of elements or groups of elements that are to be repeated
* @ param integer $repeats no of times to repeat elements initially
* @ param array $options Array of options to apply to elements . Array keys are element names .
* This is an array of arrays . The second sets of keys are the option types
* for the elements :
* 'default' - default value is value
* 'type' - PARAM_ * constant is value
* 'helpbutton' - helpbutton params array is value
* 'disabledif' - last three moodleform :: disabledIf ()
* params are value as an array
* @ param string $repeathiddenname name for hidden element storing no of repeats in this form
* @ param string $addfieldsname name for button to add more fields
* @ param int $addfieldsno how many fields to add at a time
2007-01-07 12:46:47 +00:00
* @ param string $addstring name of button , { no } is replaced by no of blanks that will be added .
2006-12-19 07:03:08 +00:00
* @ return int no of repeats of element in this page
2006-11-24 12:33:53 +00:00
*/
2007-01-07 12:46:47 +00:00
function repeat_elements ( $elementobjs , $repeats , $options , $repeathiddenname , $addfieldsname , $addfieldsno = 5 , $addstring = null ){
if ( $addstring === null ){
$addstring = get_string ( 'addfields' , 'form' , $addfieldsno );
} else {
$addstring = str_ireplace ( '{no}' , $addfieldsno , $addstring );
}
2006-11-24 12:20:26 +00:00
$repeats = optional_param ( $repeathiddenname , $repeats , PARAM_INT );
$addfields = optional_param ( $addfieldsname , '' , PARAM_TEXT );
if ( ! empty ( $addfields )){
$repeats += $addfieldsno ;
}
$mform =& $this -> _form ;
2006-12-19 07:03:08 +00:00
$mform -> registerNoSubmitButton ( $addfieldsname );
2006-11-24 12:20:26 +00:00
$mform -> addElement ( 'hidden' , $repeathiddenname , $repeats );
//value not to be overridden by submitted value
$mform -> setConstants ( array ( $repeathiddenname => $repeats ));
for ( $i = 0 ; $i < $repeats ; $i ++ ) {
foreach ( $elementobjs as $elementobj ){
2007-01-07 12:46:47 +00:00
$elementclone = clone ( $elementobj );
2007-01-18 11:21:10 +00:00
$name = $elementclone -> getName ();
2007-01-08 15:53:17 +00:00
if ( ! empty ( $name )){
$elementclone -> setName ( $name . " [ $i ] " );
}
2006-11-24 12:20:26 +00:00
if ( is_a ( $elementclone , 'HTML_QuickForm_header' )){
$value = $elementclone -> _text ;
2007-01-07 12:46:47 +00:00
$elementclone -> setValue ( str_replace ( '{no}' , ( $i + 1 ), $value ));
} else {
$value = $elementclone -> getLabel ();
$elementclone -> setLabel ( str_replace ( '{no}' , ( $i + 1 ), $value ));
2006-11-24 12:20:26 +00:00
}
2007-01-18 11:21:10 +00:00
2006-11-24 12:20:26 +00:00
$mform -> addElement ( $elementclone );
}
}
for ( $i = 0 ; $i < $repeats ; $i ++ ) {
foreach ( $options as $elementname => $elementoptions ){
$pos = strpos ( $elementname , '[' );
if ( $pos !== FALSE ){
$realelementname = substr ( $elementname , 0 , $pos + 1 ) . " [ $i ] " ;
$realelementname .= substr ( $elementname , $pos + 1 );
} else {
$realelementname = $elementname . " [ $i ] " ;
}
foreach ( $elementoptions as $option => $params ){
switch ( $option ){
case 'default' :
$mform -> setDefault ( $realelementname , $params );
break ;
case 'helpbutton' :
$mform -> setHelpButton ( $realelementname , $params );
break ;
case 'disabledif' :
2007-01-10 05:05:26 +00:00
$params = array_merge ( array ( $realelementname ), $params );
call_user_func_array ( array ( & $mform , 'disabledIf' ), $params );
break ;
case 'rule' :
if ( is_string ( $params )){
$params = array ( null , $params , null , 'client' );
}
$params = array_merge ( array ( $realelementname ), $params );
call_user_func_array ( array ( & $mform , 'addRule' ), $params );
2006-11-24 12:20:26 +00:00
break ;
}
}
}
}
2007-01-07 12:46:47 +00:00
$mform -> addElement ( 'submit' , $addfieldsname , $addstring );
2006-12-19 07:03:08 +00:00
$mform -> closeHeaderBefore ( $addfieldsname );
2006-11-24 12:20:26 +00:00
2006-12-14 12:44:10 +00:00
return $repeats ;
2006-11-24 12:20:26 +00:00
}
2006-12-19 07:03:08 +00:00
/**
2006-12-28 15:43:47 +00:00
* Use this method to a cancel and submit button to the end of your form . Pass a param of false
2006-12-19 07:03:08 +00:00
* if you don ' t want a cancel button in your form . If you have a cancel button make sure you
* check for it being pressed using is_cancelled () and redirecting if it is true before trying to
2007-01-12 18:52:09 +00:00
* get data with get_data () .
2006-12-19 07:03:08 +00:00
*
* @ param boolean $cancel whether to show cancel button , default true
* @ param boolean $revert whether to show revert button , default true
* @ param string $submitlabel label for submit button , defaults to get_string ( 'savechanges' )
*/
2006-12-28 15:43:47 +00:00
function add_action_buttons ( $cancel = true , $submitlabel = null ){
2006-12-19 07:03:08 +00:00
if ( is_null ( $submitlabel )){
$submitlabel = get_string ( 'savechanges' );
}
$mform =& $this -> _form ;
2006-12-28 15:43:47 +00:00
if ( $cancel ){
//when two elements we need a group
2006-12-19 07:03:08 +00:00
$buttonarray = array ();
$buttonarray [] = & $mform -> createElement ( 'submit' , 'submitbutton' , $submitlabel );
2006-12-28 15:43:47 +00:00
$buttonarray [] = & $mform -> createElement ( 'cancel' );
2006-12-19 07:03:08 +00:00
$mform -> addGroup ( $buttonarray , 'buttonar' , '' , array ( ' ' ), false );
$mform -> closeHeaderBefore ( 'buttonar' );
} else {
//no group needed
$mform -> addElement ( 'submit' , 'submitbutton' , $submitlabel );
$mform -> closeHeaderBefore ( 'submitbutton' );
}
}
2006-10-12 07:33:57 +00:00
}
2006-11-12 07:28:13 +00:00
/**
* You never extend this class directly . The class methods of this class are available from
* the private $this -> _form property on moodleform and it ' s children . You generally only
* call methods on this class from within abstract methods that you override on moodleform such
* as definition and definition_after_data
*
*/
2006-10-12 07:33:57 +00:00
class MoodleQuickForm extends HTML_QuickForm_DHTMLRulesTableless {
var $_types = array ();
2006-11-21 09:17:46 +00:00
var $_dependencies = array ();
2006-12-04 09:36:30 +00:00
/**
* Array of buttons that if pressed do not result in the processing of the form .
*
* @ var array
*/
var $_noSubmitButtons = array ();
/**
* Array of buttons that if pressed do not result in the processing of the form .
*
* @ var array
*/
var $_cancelButtons = array ();
2006-10-12 07:33:57 +00:00
2006-12-14 12:44:10 +00:00
/**
* Array whose keys are element names . If the key exists this is a advanced element
*
* @ var array
*/
var $_advancedElements = array ();
/**
* Whether to display advanced elements ( on page load )
*
* @ var boolean
*/
var $_showAdvanced = null ;
2006-12-28 09:32:45 +00:00
/**
* The form name is derrived from the class name of the wrapper minus the trailing form
* It is a name with words joined by underscores whereas the id attribute is words joined by
* underscores .
*
* @ var unknown_type
*/
var $_formName = '' ;
2006-09-24 17:04:51 +00:00
/**
* Class constructor - same parameters as HTML_QuickForm_DHTMLRulesTableless
* @ param string $formName Form ' s name .
* @ param string $method ( optional ) Form 's method defaults to ' POST '
* @ param string $action ( optional ) Form ' s action
* @ param string $target ( optional ) Form ' s target defaults to none
* @ param mixed $attributes ( optional ) Extra attributes for < form > tag
* @ param bool $trackSubmit ( optional ) Whether to track if the form was submitted by adding a special hidden field
* @ access public
*/
2006-10-12 07:33:57 +00:00
function MoodleQuickForm ( $formName , $method , $action , $target = '' , $attributes = null ){
2007-01-07 12:46:47 +00:00
static $formcounter = 1 ;
2006-10-12 07:33:57 +00:00
2006-09-24 17:04:51 +00:00
HTML_Common :: HTML_Common ( $attributes );
$target = empty ( $target ) ? array () : array ( 'target' => $target );
2006-12-28 09:32:45 +00:00
$this -> _formName = $formName ;
2006-09-24 17:04:51 +00:00
//no 'name' atttribute for form in xhtml strict :
2007-01-07 12:46:47 +00:00
$attributes = array ( 'action' => $action , 'method' => $method , 'id' => 'mform' . $formcounter ) + $target ;
$formcounter ++ ;
2006-09-24 17:04:51 +00:00
$this -> updateAttributes ( $attributes );
2006-10-12 07:33:57 +00:00
//this is custom stuff for Moodle :
2006-09-24 17:04:51 +00:00
$oldclass = $this -> getAttribute ( 'class' );
if ( ! empty ( $oldclass )){
$this -> updateAttributes ( array ( 'class' => $oldclass . ' mform' ));
} else {
2006-09-26 09:42:42 +00:00
$this -> updateAttributes ( array ( 'class' => 'mform' ));
2006-09-24 17:04:51 +00:00
}
2007-01-13 04:54:44 +00:00
$this -> _reqHTML = '<img class="req" alt="' . get_string ( 'requiredelement' , 'form' ) . '" src="' . FORM_REQIMAGEURL . '" />' ;
$this -> _advancedHTML = '<img class="adv" alt="' . get_string ( 'advancedelement' , 'form' ) . '" src="' . FORM_ADVANCEDIMAGEURL . '" />' ;
$this -> setRequiredNote ( get_string ( 'somefieldsrequired' , 'form' ) .
helpbutton ( 'requiredelement' , get_string ( 'requiredelement' , 'form' ), 'moodle' , true , false , '' , true ));
2006-12-14 12:44:10 +00:00
}
2006-12-19 07:03:08 +00:00
/**
* Use this method to indicate an element in a form is an advanced field . If items in a form
* are marked as advanced then 'Hide/Show Advanced' buttons will automatically be displayed in the
* form so the user can decide whether to display advanced form controls .
*
* If you set a header element to advanced then all elements it contains will also be set as advanced .
*
* @ param string $elementName group or element name ( not the element name of something inside a group ) .
* @ param boolean $advanced default true sets the element to advanced . False removes advanced mark .
*/
function setAdvanced ( $elementName , $advanced = true ){
if ( $advanced ){
$this -> _advancedElements [ $elementName ] = '' ;
} elseif ( isset ( $this -> _advancedElements [ $elementName ])) {
unset ( $this -> _advancedElements [ $elementName ]);
}
if ( $advanced && $this -> getElementType ( 'mform_showadvanced_last' ) === false ){
$this -> setShowAdvanced ();
$this -> registerNoSubmitButton ( 'mform_showadvanced' );
$this -> addElement ( 'hidden' , 'mform_showadvanced_last' );
}
}
/**
* Set whether to show advanced elements in the form on first displaying form . Default is not to
* display advanced elements in the form until 'Show Advanced' is pressed .
*
* You can get the last state of the form and possibly save it for this user by using
* value 'mform_showadvanced_last' in submitted data .
*
* @ param boolean $showadvancedNow
*/
function setShowAdvanced ( $showadvancedNow = null ){
if ( $showadvancedNow === null ){
if ( $this -> _showAdvanced !== null ){
return ;
} else { //if setShowAdvanced is called without any preference
//make the default to not show advanced elements.
2006-12-28 09:32:45 +00:00
$showadvancedNow = get_user_preferences (
moodle_strtolower ( $this -> _formName . '_showadvanced' , 0 ));
2006-12-19 07:03:08 +00:00
}
}
//value of hidden element
$hiddenLast = optional_param ( 'mform_showadvanced_last' , - 1 , PARAM_INT );
//value of button
$buttonPressed = optional_param ( 'mform_showadvanced' , 0 , PARAM_RAW );
//toggle if button pressed or else stay the same
if ( $hiddenLast == - 1 ) {
$next = $showadvancedNow ;
} elseif ( $buttonPressed ) { //toggle on button press
$next = ! $hiddenLast ;
} else {
$next = $hiddenLast ;
}
$this -> _showAdvanced = $next ;
2006-12-28 09:32:45 +00:00
if ( $showadvancedNow != $next ){
set_user_preference ( $this -> _formName . '_showadvanced' , $next );
}
2006-12-19 07:03:08 +00:00
$this -> setConstants ( array ( 'mform_showadvanced_last' => $next ));
2006-12-14 12:44:10 +00:00
}
function getShowAdvanced (){
return $this -> _showAdvanced ;
}
/**
* Accepts a renderer
*
* @ param HTML_QuickForm_Renderer An HTML_QuickForm_Renderer object
* @ since 3.0
* @ access public
* @ return void
*/
function accept ( & $renderer )
{
if ( method_exists ( $renderer , 'setAdvancedElements' )){
//check for visible fieldsets where all elements are advanced
//and mark these headers as advanced as well.
//And mark all elements in a advanced header as advanced
$stopFields = $renderer -> getStopFieldSetElements ();
$lastHeader = null ;
$lastHeaderAdvanced = false ;
$anyAdvanced = false ;
foreach ( array_keys ( $this -> _elements ) as $elementIndex ){
$element =& $this -> _elements [ $elementIndex ];
if ( $element -> getType () == 'header' || in_array ( $element -> getName (), $stopFields )){
if ( $anyAdvanced && ( $lastHeader !== null )){
$this -> setAdvanced ( $lastHeader -> getName ());
}
$lastHeaderAdvanced = false ;
} elseif ( $lastHeaderAdvanced ) {
$this -> setAdvanced ( $element -> getName ());
}
if ( $element -> getType () == 'header' ){
$lastHeader =& $element ;
$anyAdvanced = false ;
$lastHeaderAdvanced = isset ( $this -> _advancedElements [ $element -> getName ()]);
} elseif ( isset ( $this -> _advancedElements [ $element -> getName ()])){
$anyAdvanced = true ;
}
}
$renderer -> setAdvancedElements ( $this -> _advancedElements );
}
parent :: accept ( $renderer );
}
function closeHeaderBefore ( $elementName ){
$renderer =& $this -> defaultRenderer ();
$renderer -> addStopFieldsetElements ( $elementName );
2006-09-24 17:04:51 +00:00
}
2006-11-08 06:22:58 +00:00
2006-11-12 07:28:13 +00:00
/**
* Should be used for all elements of a form except for select , radio and checkboxes which
* clean their own data .
*
* @ param string $elementname
* @ param integer $paramtype use the constants PARAM_ *.
* * PARAM_CLEAN is deprecated and you should try to use a more specific type .
* * PARAM_TEXT should be used for cleaning data that is expected to be plain text .
* It will strip all html tags . But will still let tags for multilang support
* through .
* * PARAM_RAW means no cleaning whatsoever , it is used mostly for data from the
* html editor . Data from the editor is later cleaned before display using
* format_text () function . PARAM_RAW can also be used for data that is validated
* by some other way or printed by p () or s () .
* * PARAM_INT should be used for integers .
* * PARAM_ACTION is an alias of PARAM_ALPHA and is used for hidden fields specifying
* form actions .
*/
2006-10-12 07:33:57 +00:00
function setType ( $elementname , $paramtype ) {
$this -> _types [ $elementname ] = $paramtype ;
}
2006-11-09 08:38:40 +00:00
2006-11-12 07:28:13 +00:00
/**
* See description of setType above . This can be used to set several types at once .
*
* @ param array $paramtypes
*/
2006-10-12 14:15:59 +00:00
function setTypes ( $paramtypes ) {
$this -> _types = $paramtypes + $this -> _types ;
}
2006-11-09 08:38:40 +00:00
function updateSubmission ( $submission , $files ) {
$this -> _flagSubmitted = false ;
2006-10-12 07:33:57 +00:00
if ( empty ( $submission )) {
$this -> _submitValues = array ();
} else {
foreach ( $submission as $key => $s ) {
if ( array_key_exists ( $key , $this -> _types )) {
$submission [ $key ] = clean_param ( $s , $this -> _types [ $key ]);
}
}
$this -> _submitValues = $this -> _recursiveFilter ( 'stripslashes' , $submission );
$this -> _flagSubmitted = true ;
}
2006-11-09 08:38:40 +00:00
if ( empty ( $files )) {
$this -> _submitFiles = array ();
} else {
if ( 1 == get_magic_quotes_gpc ()) {
2007-01-21 10:32:42 +00:00
foreach ( array_keys ( $files ) as $elname ) {
2006-11-09 08:38:40 +00:00
// dangerous characters in filenames are cleaned later in upload_manager
$files [ $elname ][ 'name' ] = stripslashes ( $files [ $elname ][ 'name' ]);
}
}
$this -> _submitFiles = $files ;
$this -> _flagSubmitted = true ;
}
2006-10-24 11:05:50 +00:00
// need to tell all elements that they need to update their value attribute.
foreach ( array_keys ( $this -> _elements ) as $key ) {
$this -> _elements [ $key ] -> onQuickFormEvent ( 'updateValue' , null , $this );
}
2006-10-12 07:33:57 +00:00
}
2006-09-24 17:04:51 +00:00
function getReqHTML (){
return $this -> _reqHTML ;
}
2006-10-12 07:33:57 +00:00
2006-12-14 12:44:10 +00:00
function getAdvancedHTML (){
return $this -> _advancedHTML ;
}
2006-10-12 07:33:57 +00:00
/**
2006-11-12 07:28:13 +00:00
* Initializes a default form value . Used to specify the default for a new entry where
2007-01-12 18:52:09 +00:00
* no data is loaded in using moodleform :: set_data ()
2006-10-12 07:33:57 +00:00
*
* @ param string $elementname element name
* @ param mixed $values values for that element name
* @ param bool $slashed the default value is slashed
* @ access public
* @ return void
*/
function setDefault ( $elementName , $defaultValue , $slashed = false ){
$filter = $slashed ? 'stripslashes' : NULL ;
$this -> setDefaults ( array ( $elementName => $defaultValue ), $filter );
} // end func setDefault
2006-09-24 17:04:51 +00:00
/**
2006-10-12 14:15:59 +00:00
* Add an array of buttons to the form
2006-10-12 07:33:57 +00:00
* @ param array $buttons An associative array representing help button to attach to
2006-09-24 17:04:51 +00:00
* to the form . keys of array correspond to names of elements in form .
2006-10-12 07:33:57 +00:00
*
2006-09-24 17:04:51 +00:00
* @ access public
*/
2006-11-13 07:43:22 +00:00
function setHelpButtons ( $buttons , $suppresscheck = false , $function = 'helpbutton' ){
2006-10-12 07:33:57 +00:00
2006-10-12 14:15:59 +00:00
foreach ( $buttons as $elementname => $button ){
2006-11-13 07:43:22 +00:00
$this -> setHelpButton ( $elementname , $button , $suppresscheck , $function );
2006-09-24 17:04:51 +00:00
}
}
2006-10-12 14:15:59 +00:00
/**
2006-11-12 07:28:13 +00:00
* Add a single button .
2006-10-12 14:15:59 +00:00
*
* @ param string $elementname name of the element to add the item to
2006-11-13 07:43:22 +00:00
* @ param array $button - arguments to pass to function $function
2006-10-12 14:15:59 +00:00
* @ param boolean $suppresscheck - whether to throw an error if the element
* doesn ' t exist .
2006-11-13 07:43:22 +00:00
* @ param string $function - function to generate html from the arguments in $button
2006-10-12 14:15:59 +00:00
*/
2006-11-13 07:43:22 +00:00
function setHelpButton ( $elementname , $button , $suppresscheck = false , $function = 'helpbutton' ){
2006-10-12 14:15:59 +00:00
if ( array_key_exists ( $elementname , $this -> _elementIndex )){
//_elements has a numeric index, this code accesses the elements by name
$element =& $this -> _elements [ $this -> _elementIndex [ $elementname ]];
if ( method_exists ( $element , 'setHelpButton' )){
2006-11-13 07:43:22 +00:00
$element -> setHelpButton ( $button , $function );
2006-10-12 14:15:59 +00:00
} else {
$a = new object ();
$a -> name = $element -> getName ();
$a -> classname = get_class ( $element );
print_error ( 'nomethodforaddinghelpbutton' , 'form' , '' , $a );
}
} elseif ( ! $suppresscheck ){
print_error ( 'nonexistentformelements' , 'form' , '' , $elementname );
2006-10-24 11:05:50 +00:00
}
2006-10-12 14:15:59 +00:00
}
2006-10-12 07:33:57 +00:00
2006-09-27 16:00:19 +00:00
function exportValues ( $elementList = null , $addslashes = true ){
2007-01-12 04:36:02 +00:00
$unfiltered = array ();
if ( null === $elementList ) {
// iterate over all elements, calling their exportValue() methods
2007-01-12 08:36:24 +00:00
$emptyarray = array ();
2007-01-12 04:36:02 +00:00
foreach ( array_keys ( $this -> _elements ) as $key ) {
if ( $this -> _elements [ $key ] -> isFrozen () && ! $this -> _elements [ $key ] -> _persistantFreeze ){
2007-01-12 08:36:24 +00:00
$value = $this -> _elements [ $key ] -> exportValue ( $emptyarray , true );
2007-01-12 04:36:02 +00:00
} else {
$value = $this -> _elements [ $key ] -> exportValue ( $this -> _submitValues , true );
}
if ( is_array ( $value )) {
// This shit throws a bogus warning in PHP 4.3.x
$unfiltered = HTML_QuickForm :: arrayMerge ( $unfiltered , $value );
}
}
} else {
if ( ! is_array ( $elementList )) {
$elementList = array_map ( 'trim' , explode ( ',' , $elementList ));
}
foreach ( $elementList as $elementName ) {
$value = $this -> exportValue ( $elementName );
if ( PEAR :: isError ( $value )) {
return $value ;
}
$unfiltered [ $elementName ] = $value ;
}
}
2006-10-12 07:33:57 +00:00
2006-09-24 17:04:51 +00:00
if ( $addslashes ){
2007-01-12 04:36:02 +00:00
return $this -> _recursiveFilter ( 'addslashes' , $unfiltered );
2006-09-24 17:04:51 +00:00
} else {
return $unfiltered ;
}
}
2006-12-28 09:32:45 +00:00
/**
* Adds a validation rule for the given field
*
* If the element is in fact a group , it will be considered as a whole .
* To validate grouped elements as separated entities ,
* use addGroupRule instead of addRule .
*
* @ param string $element Form element name
* @ param string $message Message to display for invalid data
* @ param string $type Rule type , use getRegisteredRules () to get types
* @ param string $format ( optional ) Required for extra rule data
* @ param string $validation ( optional ) Where to perform validation : " server " , " client "
* @ param boolean $reset Client - side validation : reset the form element to its original value if there is an error ?
* @ param boolean $force Force the rule to be applied , even if the target form element does not exist
* @ since 1.0
* @ access public
* @ throws HTML_QuickForm_Error
*/
function addRule ( $element , $message , $type , $format = null , $validation = 'server' , $reset = false , $force = false )
{
parent :: addRule ( $element , $message , $type , $format , $validation , $reset , $force );
if ( $validation == 'client' ) {
$this -> updateAttributes ( array ( 'onsubmit' => 'try { var myValidator = validate_' . $this -> _formName . '; } catch(e) { return true; } return myValidator(this);' ));
}
} // end func addRule
/**
* Adds a validation rule for the given group of elements
*
* Only groups with a name can be assigned a validation rule
* Use addGroupRule when you need to validate elements inside the group .
* Use addRule if you need to validate the group as a whole . In this case ,
* the same rule will be applied to all elements in the group .
* Use addRule if you need to validate the group against a function .
*
* @ param string $group Form group name
* @ param mixed $arg1 Array for multiple elements or error message string for one element
* @ param string $type ( optional ) Rule type use getRegisteredRules () to get types
* @ param string $format ( optional ) Required for extra rule data
* @ param int $howmany ( optional ) How many valid elements should be in the group
* @ param string $validation ( optional ) Where to perform validation : " server " , " client "
* @ param bool $reset Client - side : whether to reset the element ' s value to its original state if validation failed .
* @ since 2.5
* @ access public
* @ throws HTML_QuickForm_Error
*/
function addGroupRule ( $group , $arg1 , $type = '' , $format = null , $howmany = 0 , $validation = 'server' , $reset = false )
{
parent :: addGroupRule ( $group , $arg1 , $type , $format , $howmany , $validation , $reset );
if ( is_array ( $arg1 )) {
2007-01-21 10:32:42 +00:00
foreach ( $arg1 as $rules ) {
2006-12-28 09:32:45 +00:00
foreach ( $rules as $rule ) {
$validation = ( isset ( $rule [ 3 ]) && 'client' == $rule [ 3 ]) ? 'client' : 'server' ;
if ( 'client' == $validation ) {
$this -> updateAttributes ( array ( 'onsubmit' => 'try { var myValidator = validate_' . $this -> _formName . '; } catch(e) { return true; } return myValidator(this);' ));
}
}
}
} elseif ( is_string ( $arg1 )) {
if ( $validation == 'client' ) {
2007-01-21 10:32:42 +00:00
$this -> updateAttributes ( array ( 'onsubmit' => 'try { var myValidator = validate_' . $this -> _formName . '; } catch(e) { return true; } return myValidator(this);' ));
2006-12-28 09:32:45 +00:00
}
}
} // end func addGroupRule
// }}}
2006-10-14 12:32:31 +00:00
/**
* Returns the client side validation script
*
* The code here was copied from HTML_QuickForm_DHTMLRulesTableless who copied it from HTML_QuickForm
* and slightly modified to run rules per - element
* Needed to override this because of an error with client side validation of grouped elements .
*
* @ access public
* @ return string Javascript to perform validation , empty string if no 'client' rules were added
*/
function getValidationScript ()
{
if ( empty ( $this -> _rules ) || empty ( $this -> _attributes [ 'onsubmit' ])) {
return '' ;
}
include_once ( 'HTML/QuickForm/RuleRegistry.php' );
$registry =& HTML_QuickForm_RuleRegistry :: singleton ();
$test = array ();
$js_escape = array (
" \r " => '\r' ,
" \n " => '\n' ,
" \t " => '\t' ,
" ' " => " \\ ' " ,
'"' => '\"' ,
'\\' => '\\\\'
);
foreach ( $this -> _rules as $elementName => $rules ) {
foreach ( $rules as $rule ) {
if ( 'client' == $rule [ 'validation' ]) {
2006-11-12 07:28:13 +00:00
unset ( $element ); //TODO: find out how to properly initialize it
2006-10-14 12:32:31 +00:00
$dependent = isset ( $rule [ 'dependent' ]) && is_array ( $rule [ 'dependent' ]);
$rule [ 'message' ] = strtr ( $rule [ 'message' ], $js_escape );
if ( isset ( $rule [ 'group' ])) {
$group =& $this -> getElement ( $rule [ 'group' ]);
// No JavaScript validation for frozen elements
if ( $group -> isFrozen ()) {
continue 2 ;
}
$elements =& $group -> getElements ();
foreach ( array_keys ( $elements ) as $key ) {
if ( $elementName == $group -> getElementName ( $key )) {
$element =& $elements [ $key ];
break ;
}
}
} elseif ( $dependent ) {
$element = array ();
$element [] =& $this -> getElement ( $elementName );
2007-01-21 10:32:42 +00:00
foreach ( $rule [ 'dependent' ] as $elName ) {
2006-10-14 12:32:31 +00:00
$element [] =& $this -> getElement ( $elName );
}
} else {
$element =& $this -> getElement ( $elementName );
}
// No JavaScript validation for frozen elements
if ( is_object ( $element ) && $element -> isFrozen ()) {
continue 2 ;
} elseif ( is_array ( $element )) {
foreach ( array_keys ( $element ) as $key ) {
if ( $element [ $key ] -> isFrozen ()) {
continue 3 ;
}
}
}
// Fix for bug displaying errors for elements in a group
//$test[$elementName][] = $registry->getValidationScript($element, $elementName, $rule);
$test [ $elementName ][ 0 ][] = $registry -> getValidationScript ( $element , $elementName , $rule );
$test [ $elementName ][ 1 ] = $element ;
//end of fix
}
}
}
$js = '
< script type = " text/javascript " >
//<![CDATA[
2006-12-04 22:00:47 +00:00
var skipClientValidation = false ;
2006-10-14 12:32:31 +00:00
function qf_errorHandler ( element , _qfMsg ) {
div = element . parentNode ;
if ( _qfMsg != \ ' \ ' ) {
2006-12-05 21:43:33 +00:00
var errorSpan = document . getElementById ( \ ' id_error_\ ' + element . name );
2006-12-05 14:27:24 +00:00
if ( ! errorSpan ) {
errorSpan = document . createElement ( " span " );
2006-12-05 21:43:33 +00:00
errorSpan . id = \ ' id_error_\ ' + element . name ;
errorSpan . className = " error " ;
2006-12-05 21:48:44 +00:00
element . parentNode . insertBefore ( errorSpan , element . parentNode . firstChild );
2006-10-14 12:32:31 +00:00
}
2006-12-05 21:48:44 +00:00
2006-12-05 14:27:24 +00:00
while ( errorSpan . firstChild ) {
errorSpan . removeChild ( errorSpan . firstChild );
2006-10-14 12:32:31 +00:00
}
2006-10-24 11:05:50 +00:00
2006-12-05 14:27:24 +00:00
errorSpan . appendChild ( document . createTextNode ( _qfMsg . substring ( 3 )));
2006-12-05 21:43:33 +00:00
errorSpan . appendChild ( document . createElement ( " br " ));
2006-10-14 12:32:31 +00:00
if ( div . className . substr ( div . className . length - 6 , 6 ) != " error "
&& div . className != " error " ) {
div . className += " error " ;
}
return false ;
} else {
2006-12-05 21:43:33 +00:00
var errorSpan = document . getElementById ( \ ' id_error_\ ' + element . name );
2006-12-05 14:27:24 +00:00
if ( errorSpan ) {
errorSpan . parentNode . removeChild ( errorSpan );
2006-10-14 12:32:31 +00:00
}
if ( div . className . substr ( div . className . length - 6 , 6 ) == " error " ) {
div . className = div . className . substr ( 0 , div . className . length - 6 );
} else if ( div . className == " error " ) {
div . className = " " ;
}
return true ;
}
} ' ;
$validateJS = '' ;
foreach ( $test as $elementName => $jsandelement ) {
// Fix for bug displaying errors for elements in a group
//unset($element);
list ( $jsArr , $element ) = $jsandelement ;
//end of fix
$js .= '
2006-12-28 09:32:45 +00:00
function validate_ ' . $this->_formName . ' _ ' . $elementName . ' ( element ) {
2006-10-14 12:32:31 +00:00
var value = \ ' \ ' ;
var errFlag = new Array ();
var _qfGroups = {};
var _qfMsg = \ ' \ ' ;
var frm = element . parentNode ;
while ( frm && frm . nodeName != " FORM " ) {
frm = frm . parentNode ;
}
' . join("\n", $jsArr) . '
return qf_errorHandler ( element , _qfMsg );
}
' ;
$validateJS .= '
2006-12-28 09:32:45 +00:00
ret = validate_ ' . $this->_formName . ' _ ' . $elementName.' ( frm . elements [ \ '' . $elementName . '\']) && ret;' ;
2006-10-14 12:32:31 +00:00
// Fix for bug displaying errors for elements in a group
//unset($element);
//$element =& $this->getElement($elementName);
//end of fix
2006-12-28 09:32:45 +00:00
$valFunc = 'validate_' . $this -> _formName . '_' . $elementName . '(this)' ;
2006-10-14 12:32:31 +00:00
$onBlur = $element -> getAttribute ( 'onBlur' );
$onChange = $element -> getAttribute ( 'onChange' );
$element -> updateAttributes ( array ( 'onBlur' => $onBlur . $valFunc ,
'onChange' => $onChange . $valFunc ));
}
2006-12-05 14:27:24 +00:00
// do not rely on frm function parameter, because htmlarea breaks it when overloading the onsubmit method
2006-10-14 12:32:31 +00:00
$js .= '
2006-12-28 09:32:45 +00:00
function validate_ ' . $this->_formName . ' ( frm ) {
2006-12-04 22:00:47 +00:00
if ( skipClientValidation ) {
return true ;
}
2006-10-14 12:32:31 +00:00
var ret = true ;
2006-12-05 13:21:40 +00:00
var frm = document . getElementById ( \ '' . $this -> _attributes [ 'id' ] . ' \ ' )
2006-10-14 12:32:31 +00:00
' . $validateJS . ' ;
return ret ;
}
//]]>
</ script > ' ;
return $js ;
} // end func getValidationScript
function _setDefaultRuleMessages (){
foreach ( $this -> _rules as $field => $rulesarr ){
foreach ( $rulesarr as $key => $rule ){
if ( $rule [ 'message' ] === null ){
$a = new object ();
$a -> format = $rule [ 'format' ];
$str = get_string ( 'err_' . $rule [ 'type' ], 'form' , $a );
if ( strpos ( $str , '[[' ) !== 0 ){
$this -> _rules [ $field ][ $key ][ 'message' ] = $str ;
2006-10-24 11:05:50 +00:00
}
2006-10-14 12:32:31 +00:00
}
}
}
}
2006-11-08 06:22:58 +00:00
2006-11-22 08:53:35 +00:00
function getLockOptionEndScript (){
2007-01-12 09:38:02 +00:00
$iname = $this -> getAttribute ( 'id' ) . 'items' ;
2007-01-03 14:44:17 +00:00
$js = '<script type="text/javascript">' . " \n " ;
2006-12-22 04:52:13 +00:00
$js .= '//<![CDATA[' . " \n " ;
2007-01-12 09:38:02 +00:00
$js .= " var $iname = Array(); \n " ;
foreach ( $this -> _dependencies as $dependentOn => $conditions ){
$js .= " { $iname } [' $dependentOn '] = Array(); \n " ;
foreach ( $conditions as $condition => $values ) {
$js .= " { $iname } [' $dependentOn '][' $condition '] = Array(); \n " ;
foreach ( $values as $value => $dependents ) {
$js .= " { $iname } [' $dependentOn '][' $condition '][' $value '] = Array(); \n " ;
$i = 0 ;
foreach ( $dependents as $dependent ) {
$elements = $this -> _getElNamesRecursive ( $dependent );
foreach ( $elements as $element ) {
if ( $element == $dependentOn ) {
continue ;
}
$js .= " { $iname } [' $dependentOn '][' $condition '][' $value '][ $i ]=' $element '; \n " ;
$i ++ ;
}
2006-12-09 11:42:57 +00:00
}
}
2006-11-21 09:17:46 +00:00
}
2007-01-12 09:38:02 +00:00
}
2006-11-22 08:53:35 +00:00
$js .= " lockoptionsallsetup(' " . $this -> getAttribute ( 'id' ) . " '); \n " ;
2006-12-22 04:52:13 +00:00
$js .= '//]]>' . " \n " ;
2006-11-21 09:17:46 +00:00
$js .= '</script>' . " \n " ;
return $js ;
2006-11-08 06:22:58 +00:00
}
2006-11-22 08:53:35 +00:00
2007-01-12 09:38:02 +00:00
function _getElNamesRecursive ( $element , $group = null ){
2006-11-22 08:53:35 +00:00
if ( $group == null ){
2006-11-22 15:58:07 +00:00
$el = $this -> getElement ( $element );
2006-11-22 08:53:35 +00:00
} else {
2006-11-22 15:58:07 +00:00
$el = & $element ;
2006-11-22 08:53:35 +00:00
}
if ( is_a ( $el , 'HTML_QuickForm_group' )){
2006-11-22 15:58:07 +00:00
$group = $el ;
$elsInGroup = $group -> getElements ();
$elNames = array ();
2006-11-22 08:53:35 +00:00
foreach ( $elsInGroup as $elInGroup ){
$elNames = array_merge ( $elNames , $this -> _getElNamesRecursive ( $elInGroup , $group ));
}
} else {
2006-11-22 15:58:07 +00:00
if ( $group != null ){
$elNames = array ( $group -> getElementName ( $el -> getName ()));
} elseif ( is_a ( $el , 'HTML_QuickForm_header' )) {
return null ;
2007-01-21 09:23:19 +00:00
} elseif ( is_a ( $el , 'HTML_QuickForm_hidden' )) {
return null ;
2006-11-28 08:04:00 +00:00
} elseif ( method_exists ( $el , 'getPrivateName' )) {
return array ( $el -> getPrivateName ());
2006-11-22 08:53:35 +00:00
} else {
2006-11-22 15:58:07 +00:00
$elNames = array ( $el -> getName ());
2006-11-22 08:53:35 +00:00
}
}
return $elNames ;
2006-11-21 09:17:46 +00:00
}
2006-11-21 09:33:48 +00:00
/**
* Adds a dependency for $elementName which will be disabled if $condition is met .
2006-11-22 15:58:07 +00:00
* If $condition = 'notchecked' ( default ) then the condition is that the $dependentOn element
* is not checked . If $condition = 'checked' then the condition is that the $dependentOn element
2006-11-21 09:33:48 +00:00
* is checked . If $condition is something else then it is checked to see if the value
* of the $dependentOn element is equal to $condition .
*
* @ param string $elementName the name of the element which will be disabled
* @ param string $dependentOn the name of the element whose state will be checked for
* condition
* @ param string $condition the condition to check
2006-12-04 09:36:30 +00:00
* @ param mixed $value used in conjunction with condition .
2006-11-21 09:33:48 +00:00
*/
2007-01-12 09:38:02 +00:00
function disabledIf ( $elementName , $dependentOn , $condition = 'notchecked' , $value = '1' ){
if ( ! array_key_exists ( $dependentOn , $this -> _dependencies )) {
$this -> _dependencies [ $dependentOn ] = array ();
}
if ( ! array_key_exists ( $condition , $this -> _dependencies [ $dependentOn ])) {
$this -> _dependencies [ $dependentOn ][ $condition ] = array ();
}
if ( ! array_key_exists ( $value , $this -> _dependencies [ $dependentOn ][ $condition ])) {
$this -> _dependencies [ $dependentOn ][ $condition ][ $value ] = array ();
}
$this -> _dependencies [ $dependentOn ][ $condition ][ $value ][] = $elementName ;
2006-11-08 06:22:58 +00:00
}
2007-01-12 09:38:02 +00:00
2006-12-19 07:03:08 +00:00
function registerNoSubmitButton ( $buttonname ){
$this -> _noSubmitButtons [] = $buttonname ;
}
2007-01-12 09:38:02 +00:00
2006-12-19 07:03:08 +00:00
function isNoSubmitButton ( $buttonname ){
return ( array_search ( $buttonname , $this -> _noSubmitButtons ) !== FALSE );
2006-12-04 09:36:30 +00:00
}
2007-01-12 09:38:02 +00:00
2006-12-04 09:36:30 +00:00
function _registerCancelButton ( $addfieldsname ){
$this -> _cancelButtons [] = $addfieldsname ;
}
2007-01-12 06:19:39 +00:00
/**
* Displays elements without HTML input tags .
* This method is different to freeze () in that it makes sure no hidden
* elements are included in the form . And a 'hardFrozen' element ' s submitted value is
* ignored .
*
* @ param mixed $elementList array or string of element ( s ) to be frozen
* @ since 1.0
* @ access public
* @ throws HTML_QuickForm_Error
*/
function hardFreeze ( $elementList = null )
{
if ( ! isset ( $elementList )) {
$this -> _freezeAll = true ;
$elementList = array ();
} else {
if ( ! is_array ( $elementList )) {
$elementList = preg_split ( '/[ ]*,[ ]*/' , $elementList );
}
$elementList = array_flip ( $elementList );
}
foreach ( array_keys ( $this -> _elements ) as $key ) {
$name = $this -> _elements [ $key ] -> getName ();
if ( $this -> _freezeAll || isset ( $elementList [ $name ])) {
$this -> _elements [ $key ] -> freeze ();
$this -> _elements [ $key ] -> setPersistantFreeze ( false );
unset ( $elementList [ $name ]);
}
}
if ( ! empty ( $elementList )) {
return PEAR :: raiseError ( null , QUICKFORM_NONEXIST_ELEMENT , null , E_USER_WARNING , " Nonexistant element(s): ' " . implode ( " ', ' " , array_keys ( $elementList )) . " ' in HTML_QuickForm::freeze() " , 'HTML_QuickForm_Error' , true );
}
return true ;
} // end func hardFreeze
// }}}
2006-09-24 17:04:51 +00:00
}
2006-11-24 06:39:15 +00:00
2006-09-24 17:04:51 +00:00
/**
2006-10-12 07:33:57 +00:00
* A renderer for MoodleQuickForm that only uses XHTML and CSS and no
2006-09-24 17:04:51 +00:00
* table tags , extends PEAR class HTML_QuickForm_Renderer_Tableless
2006-10-12 07:33:57 +00:00
*
2006-09-24 17:04:51 +00:00
* Stylesheet is part of standard theme and should be automatically included .
*
* @ author Jamie Pratt < me @ jamiep . org >
* @ license gpl license
*/
2006-10-12 07:33:57 +00:00
class MoodleQuickForm_Renderer extends HTML_QuickForm_Renderer_Tableless {
2006-09-24 17:04:51 +00:00
/**
* Element template array
* @ var array
* @ access private
*/
var $_elementTemplates ;
2006-09-27 19:12:52 +00:00
/**
* Template used when opening a hidden fieldset
* ( i . e . a fieldset that is opened when there is no header element )
* @ var string
* @ access private
*/
var $_openHiddenFieldsetTemplate = " \n \t <fieldset class= \" hidden \" > " ;
2006-12-14 12:44:10 +00:00
/**
* Header Template string
* @ var string
* @ access private
*/
var $_headerTemplate =
2006-12-19 07:03:08 +00:00
" \n \t \t <legend> { header}</legend> \n \t \t <div class= \" advancedbutton \" > { advancedimg} { button}</div> \n \t \t " ;
2006-10-12 07:33:57 +00:00
2006-09-27 19:12:52 +00:00
/**
* Template used when closing a fieldset
* @ var string
* @ access private
*/
var $_closeFieldsetTemplate = " \n \t \t </fieldset> " ;
2006-09-27 16:00:19 +00:00
2006-09-27 19:12:52 +00:00
/**
* Required Note template string
* @ var string
* @ access private
*/
2006-10-12 07:33:57 +00:00
var $_requiredNoteTemplate =
2007-01-13 04:54:44 +00:00
" \n \t \t <div class= \" fdescription required \" > { requiredNote}</div> " ;
2006-10-12 07:33:57 +00:00
2006-12-14 12:44:10 +00:00
var $_advancedElements = array ();
/**
* Whether to display advanced elements ( on page load )
*
* @ var integer 1 means show 0 means hide
*/
var $_showAdvanced ;
2006-10-12 07:33:57 +00:00
function MoodleQuickForm_Renderer (){
2006-09-27 16:00:19 +00:00
// switch next two lines for ol li containers for form items.
2007-01-13 04:24:15 +00:00
// $this->_elementTemplates=array('default'=>"\n\t\t".'<li class="fitem"><label>{label}{help}<!-- BEGIN required -->{req}<!-- END required --></label><div class="qfelement<!-- BEGIN error --> error<!-- END error --> {type}"><!-- BEGIN error --><span class="error">{error}</span><br /><!-- END error -->{element}</div></li>');
2007-01-10 05:05:26 +00:00
$this -> _elementTemplates = array (
2007-01-13 04:24:15 +00:00
'default' => " \n \t \t " . '<div class="fitem {advanced}<!-- BEGIN required --> required<!-- END required -->"><div class="fitemtitle"><label>{label}<!-- BEGIN required -->{req} <!-- END required -->{advancedimg}</label>{help}</div><div class="felement {type}<!-- BEGIN error --> error<!-- END error -->"><!-- BEGIN error --><span class="error">{error}</span><br /><!-- END error -->{element}</div></div>' ,
'fieldset' => " \n \t \t " . '<div class="fitem {advanced}<!-- BEGIN required --> required<!-- END required -->"><div class="fitemtitle"><div class="fgrouplabel">{label}<!-- BEGIN required -->{req} <!-- END required -->{advancedimg}</div>{help}</div><fieldset class="felement {type}<!-- BEGIN error --> error<!-- END error -->"><!-- BEGIN error --><span class="error">{error}</span><br /><!-- END error -->{element}</fieldset></div>' ,
'static' => " \n \t \t " . '<div class="fitem {advanced}<!-- BEGIN required --> required<!-- END required -->"><div class="fitemtitle"><div class="fstaticlabel">{label}<!-- BEGIN required -->{req} <!-- END required -->{advancedimg}</div>{help}</div><div class="felement {type}<!-- BEGIN error --> error<!-- END error -->"><!-- BEGIN error --><span class="error">{error}</span><br /><!-- END error -->{element}</div></div>' );
2006-09-24 17:04:51 +00:00
parent :: HTML_QuickForm_Renderer_Tableless ();
}
2006-10-12 07:33:57 +00:00
2006-12-14 12:44:10 +00:00
function setAdvancedElements ( $elements ){
$this -> _advancedElements = $elements ;
}
/**
* What to do when starting the form
*
* @ param MoodleQuickForm $form
*/
2006-09-24 17:04:51 +00:00
function startForm ( & $form ){
2006-11-22 15:58:07 +00:00
$this -> _reqHTML = $form -> getReqHTML ();
$this -> _elementTemplates = str_replace ( '{req}' , $this -> _reqHTML , $this -> _elementTemplates );
2006-12-14 12:44:10 +00:00
$this -> _advancedHTML = $form -> getAdvancedHTML ();
$this -> _showAdvanced = $form -> getShowAdvanced ();
2006-09-24 17:04:51 +00:00
parent :: startForm ( $form );
}
2006-10-12 07:33:57 +00:00
2006-09-24 17:04:51 +00:00
function startGroup ( & $group , $required , $error ){
if ( method_exists ( $group , 'getElementTemplateType' )){
2006-09-27 16:07:37 +00:00
$html = $this -> _elementTemplates [ $group -> getElementTemplateType ()];
2006-09-24 17:04:51 +00:00
} else {
$html = $this -> _elementTemplates [ 'default' ];
2006-10-12 07:33:57 +00:00
2006-09-24 17:04:51 +00:00
}
2006-12-14 12:44:10 +00:00
if ( $this -> _showAdvanced ){
$advclass = ' advanced' ;
} else {
$advclass = ' advanced hide' ;
}
if ( isset ( $this -> _advancedElements [ $group -> getName ()])){
$html = str_replace ( ' {advanced}' , $advclass , $html );
$html = str_replace ( '{advancedimg}' , $this -> _advancedHTML , $html );
} else {
$html = str_replace ( ' {advanced}' , '' , $html );
$html = str_replace ( '{advancedimg}' , '' , $html );
}
2006-09-24 17:04:51 +00:00
if ( method_exists ( $group , 'getHelpButton' )){
$html = str_replace ( '{help}' , $group -> getHelpButton (), $html );
} else {
$html = str_replace ( '{help}' , '' , $html );
}
2006-12-05 14:27:24 +00:00
$html = str_replace ( '{name}' , $group -> getName (), $html );
2006-09-27 19:12:52 +00:00
$html = str_replace ( '{type}' , 'fgroup' , $html );
2006-10-12 07:33:57 +00:00
2006-09-24 17:04:51 +00:00
$this -> _templates [ $group -> getName ()] = $html ;
// Fix for bug in tableless quickforms that didn't allow you to stop a
// fieldset before a group of elements.
// if the element name indicates the end of a fieldset, close the fieldset
if ( in_array ( $group -> getName (), $this -> _stopFieldsetElements )
&& $this -> _fieldsetsOpen > 0
) {
$this -> _html .= $this -> _closeFieldsetTemplate ;
$this -> _fieldsetsOpen -- ;
}
parent :: startGroup ( $group , $required , $error );
}
2006-10-12 07:33:57 +00:00
2006-09-24 17:04:51 +00:00
function renderElement ( & $element , $required , $error ){
2007-01-08 15:53:17 +00:00
//manipulate id of all elements before rendering
if ( ! is_null ( $element -> getAttribute ( 'id' ))) {
$id = $element -> getAttribute ( 'id' );
} else {
$id = $element -> getName ();
}
//strip qf_ prefix and replace '[' with '_' and strip ']'
$id = preg_replace ( array ( '/^qf_|\]/' , '/\[/' ), array ( '' , '_' ), $id );
if ( strpos ( $id , 'id_' ) !== 0 ){
$element -> updateAttributes ( array ( 'id' => 'id_' . $id ));
}
//adding stuff to place holders in template
2006-09-24 17:04:51 +00:00
if ( method_exists ( $element , 'getElementTemplateType' )){
$html = $this -> _elementTemplates [ $element -> getElementTemplateType ()];
} else {
$html = $this -> _elementTemplates [ 'default' ];
2006-12-14 12:44:10 +00:00
}
if ( $this -> _showAdvanced ){
$advclass = ' advanced' ;
} else {
$advclass = ' advanced hide' ;
}
if ( isset ( $this -> _advancedElements [ $element -> getName ()])){
$html = str_replace ( ' {advanced}' , $advclass , $html );
} else {
$html = str_replace ( ' {advanced}' , '' , $html );
}
if ( isset ( $this -> _advancedElements [ $element -> getName ()]) || $element -> getName () == 'mform_showadvanced' ){
$html = str_replace ( '{advancedimg}' , $this -> _advancedHTML , $html );
} else {
$html = str_replace ( '{advancedimg}' , '' , $html );
2006-09-24 17:04:51 +00:00
}
2006-09-27 19:12:52 +00:00
$html = str_replace ( '{type}' , 'f' . $element -> getType (), $html );
2006-12-05 14:27:24 +00:00
$html = str_replace ( '{name}' , $element -> getName (), $html );
2006-09-24 17:04:51 +00:00
if ( method_exists ( $element , 'getHelpButton' )){
2006-11-22 15:58:07 +00:00
$html = str_replace ( '{help}' , $element -> getHelpButton (), $html );
2006-09-24 17:04:51 +00:00
} else {
2006-11-22 15:58:07 +00:00
$html = str_replace ( '{help}' , '' , $html );
2006-10-12 07:33:57 +00:00
2006-09-24 17:04:51 +00:00
}
2007-01-08 15:53:17 +00:00
2006-11-22 15:58:07 +00:00
$this -> _templates [ $element -> getName ()] = $html ;
2007-01-08 15:53:17 +00:00
2006-09-24 17:04:51 +00:00
parent :: renderElement ( $element , $required , $error );
}
2006-12-14 12:44:10 +00:00
2006-11-08 06:22:58 +00:00
function finishForm ( & $form ){
parent :: finishForm ( $form );
2006-11-22 08:53:35 +00:00
// add a lockoptions script
2006-11-08 06:22:58 +00:00
if ( '' != ( $script = $form -> getLockOptionEndScript ())) {
$this -> _html = $this -> _html . " \n " . $script ;
}
}
2006-12-14 12:44:10 +00:00
/**
* Called when visiting a header element
*
* @ param object An HTML_QuickForm_header element being visited
* @ access public
* @ return void
*/
function renderHeader ( & $header ) {
$name = $header -> getName ();
$id = empty ( $name ) ? '' : ' id="' . $name . '"' ;
2007-01-10 06:17:45 +00:00
$id = preg_replace ( array ( '/\]/' , '/\[/' ), array ( '' , '_' ), $id );
2006-12-14 12:44:10 +00:00
if ( is_null ( $header -> _text )) {
$header_html = '' ;
} elseif ( ! empty ( $name ) && isset ( $this -> _templates [ $name ])) {
$header_html = str_replace ( '{header}' , $header -> toHtml (), $this -> _templates [ $name ]);
} else {
$header_html = str_replace ( '{header}' , $header -> toHtml (), $this -> _headerTemplate );
}
if ( isset ( $this -> _advancedElements [ $name ])){
$header_html = str_replace ( '{advancedimg}' , $this -> _advancedHTML , $header_html );
} else {
$header_html = str_replace ( '{advancedimg}' , '' , $header_html );
}
$elementName = 'mform_showadvanced' ;
if ( $this -> _showAdvanced == 0 ){
$buttonlabel = get_string ( 'showadvanced' , 'form' );
} else {
$buttonlabel = get_string ( 'hideadvanced' , 'form' );
}
if ( isset ( $this -> _advancedElements [ $name ])){
$showtext = " ' " . get_string ( 'showadvanced' , 'form' ) . " ' " ;
$hidetext = " ' " . get_string ( 'hideadvanced' , 'form' ) . " ' " ;
//onclick returns false so if js is on then page is not submitted.
$onclick = 'return showAdvancedOnClick(this, ' . $hidetext . ', ' . $showtext . ');' ;
$button = '<input name="' . $elementName . '" value="' . $buttonlabel . '" type="submit" onclick="' . $onclick . '" />' ;
$header_html = str_replace ( '{button}' , $button , $header_html );
} else {
$header_html = str_replace ( '{button}' , '' , $header_html );
}
if ( $this -> _fieldsetsOpen > 0 ) {
$this -> _html .= $this -> _closeFieldsetTemplate ;
$this -> _fieldsetsOpen -- ;
}
$openFieldsetTemplate = str_replace ( '{id}' , $id , $this -> _openFieldsetTemplate );
if ( $this -> _showAdvanced ){
$advclass = ' class="advanced"' ;
} else {
$advclass = ' class="advanced hide"' ;
}
if ( isset ( $this -> _advancedElements [ $name ])){
$openFieldsetTemplate = str_replace ( '{advancedclass}' , $advclass , $openFieldsetTemplate );
} else {
$openFieldsetTemplate = str_replace ( '{advancedclass}' , '' , $openFieldsetTemplate );
}
$this -> _html .= $openFieldsetTemplate . $header_html ;
$this -> _fieldsetsOpen ++ ;
} // end func renderHeader
function getStopFieldsetElements (){
return $this -> _stopFieldsetElements ;
}
2006-09-24 17:04:51 +00:00
}
2006-11-22 15:58:07 +00:00
$GLOBALS [ '_HTML_QuickForm_default_renderer' ] =& new MoodleQuickForm_Renderer ();
2006-09-24 17:04:51 +00:00
2006-10-12 07:33:57 +00:00
MoodleQuickForm :: registerElementType ( 'checkbox' , " $CFG->libdir /form/checkbox.php " , 'MoodleQuickForm_checkbox' );
MoodleQuickForm :: registerElementType ( 'file' , " $CFG->libdir /form/file.php " , 'MoodleQuickForm_file' );
MoodleQuickForm :: registerElementType ( 'group' , " $CFG->libdir /form/group.php " , 'MoodleQuickForm_group' );
MoodleQuickForm :: registerElementType ( 'password' , " $CFG->libdir /form/password.php " , 'MoodleQuickForm_password' );
MoodleQuickForm :: registerElementType ( 'radio' , " $CFG->libdir /form/radio.php " , 'MoodleQuickForm_radio' );
MoodleQuickForm :: registerElementType ( 'select' , " $CFG->libdir /form/select.php " , 'MoodleQuickForm_select' );
MoodleQuickForm :: registerElementType ( 'text' , " $CFG->libdir /form/text.php " , 'MoodleQuickForm_text' );
MoodleQuickForm :: registerElementType ( 'textarea' , " $CFG->libdir /form/textarea.php " , 'MoodleQuickForm_textarea' );
MoodleQuickForm :: registerElementType ( 'date_selector' , " $CFG->libdir /form/dateselector.php " , 'MoodleQuickForm_date_selector' );
MoodleQuickForm :: registerElementType ( 'date_time_selector' , " $CFG->libdir /form/datetimeselector.php " , 'MoodleQuickForm_date_time_selector' );
MoodleQuickForm :: registerElementType ( 'htmleditor' , " $CFG->libdir /form/htmleditor.php " , 'MoodleQuickForm_htmleditor' );
2006-10-26 07:02:20 +00:00
MoodleQuickForm :: registerElementType ( 'format' , " $CFG->libdir /form/format.php " , 'MoodleQuickForm_format' );
2006-10-12 07:33:57 +00:00
MoodleQuickForm :: registerElementType ( 'static' , " $CFG->libdir /form/static.php " , 'MoodleQuickForm_static' );
MoodleQuickForm :: registerElementType ( 'hidden' , " $CFG->libdir /form/hidden.php " , 'MoodleQuickForm_hidden' );
2006-11-09 18:08:34 +00:00
MoodleQuickForm :: registerElementType ( 'modvisible' , " $CFG->libdir /form/modvisible.php " , 'MoodleQuickForm_modvisible' );
MoodleQuickForm :: registerElementType ( 'modgroupmode' , " $CFG->libdir /form/modgroupmode.php " , 'MoodleQuickForm_modgroupmode' );
2006-11-12 11:30:12 +00:00
MoodleQuickForm :: registerElementType ( 'selectyesno' , " $CFG->libdir /form/selectyesno.php " , 'MoodleQuickForm_selectyesno' );
2006-11-13 07:43:22 +00:00
MoodleQuickForm :: registerElementType ( 'modgrade' , " $CFG->libdir /form/modgrade.php " , 'MoodleQuickForm_modgrade' );
2006-12-04 09:36:30 +00:00
MoodleQuickForm :: registerElementType ( 'cancel' , " $CFG->libdir /form/cancel.php " , 'MoodleQuickForm_cancel' );
2006-11-15 07:40:49 +00:00
MoodleQuickForm :: registerElementType ( 'button' , " $CFG->libdir /form/button.php " , 'MoodleQuickForm_button' );
MoodleQuickForm :: registerElementType ( 'choosecoursefile' , " $CFG->libdir /form/choosecoursefile.php " , 'MoodleQuickForm_choosecoursefile' );
2006-12-19 07:03:08 +00:00
MoodleQuickForm :: registerElementType ( 'header' , " $CFG->libdir /form/header.php " , 'MoodleQuickForm_header' );
MoodleQuickForm :: registerElementType ( 'submit' , " $CFG->libdir /form/submit.php " , 'MoodleQuickForm_submit' );
2007-01-05 16:46:28 +00:00
MoodleQuickForm :: registerElementType ( 'questioncategory' , " $CFG->libdir /form/questioncategory.php " , 'MoodleQuickForm_questioncategory' );
2007-01-07 16:41:06 +00:00
MoodleQuickForm :: registerElementType ( 'advcheckbox' , " $CFG->libdir /form/advcheckbox.php " , 'MoodleQuickForm_advcheckbox' );
2007-01-13 04:24:15 +00:00
?>