. /** * Editor input element * * Contains class to create preffered editor form element * * @package core_form * @copyright 2009 Petr Skoda {@link http://skodak.org} * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ global $CFG; require_once('HTML/QuickForm/element.php'); require_once($CFG->dirroot.'/lib/filelib.php'); require_once($CFG->dirroot.'/repository/lib.php'); require_once('templatable_form_element.php'); /** * Editor element * * It creates preffered editor (textbox/TinyMce) form element for the format (Text/HTML) selected. * * @package core_form * @category form * @copyright 2009 Petr Skoda {@link http://skodak.org} * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later * @todo MDL-29421 element Freezing * @todo MDL-29426 ajax format conversion */ class MoodleQuickForm_editor extends HTML_QuickForm_element implements templatable { use templatable_form_element { export_for_template as export_for_template_base; } /** @var string html for help button, if empty then no help will icon will be dispalyed. */ public $_helpbutton = ''; /** @var string defines the type of editor */ public $_type = 'editor'; /** @var array options provided to initalize filepicker */ protected $_options = array('subdirs' => 0, 'maxbytes' => 0, 'maxfiles' => 0, 'changeformat' => 0, 'areamaxbytes' => FILE_AREA_MAX_BYTES_UNLIMITED, 'context' => null, 'noclean' => 0, 'trusttext' => 0, 'return_types' => 15, 'enable_filemanagement' => true, 'removeorphaneddrafts' => false, 'autosave' => true); // 15 is $_options['return_types'] = FILE_INTERNAL | FILE_EXTERNAL | FILE_REFERENCE | FILE_CONTROLLED_LINK. /** @var array values for editor */ protected $_values = array('text'=>null, 'format'=>null, 'itemid'=>null); /** * Constructor * * @param string $elementName (optional) name of the editor * @param string $elementLabel (optional) editor label * @param array $attributes (optional) Either a typical HTML attribute string * or an associative array * @param array $options set of options to initalize filepicker */ public function __construct($elementName=null, $elementLabel=null, $attributes=null, $options=null) { global $CFG, $PAGE; $options = (array)$options; foreach ($options as $name=>$value) { if (array_key_exists($name, $this->_options)) { $this->_options[$name] = $value; } } if (!empty($options['maxbytes'])) { $this->_options['maxbytes'] = get_max_upload_file_size($CFG->maxbytes, $options['maxbytes']); } if (!$this->_options['context']) { // trying to set context to the current page context to make legacy files show in filepicker (e.g. forum post) if (!empty($PAGE->context->id)) { $this->_options['context'] = $PAGE->context; } else { $this->_options['context'] = context_system::instance(); } } $this->_options['trusted'] = trusttext_trusted($this->_options['context']); parent::__construct($elementName, $elementLabel, $attributes); // Note: for some reason the code using this setting does not like bools. $this->_options['subdirs'] = (int)($this->_options['subdirs'] == 1); editors_head_setup(); } /** * Old syntax of class constructor. Deprecated in PHP7. * * @deprecated since Moodle 3.1 */ public function MoodleQuickForm_editor($elementName=null, $elementLabel=null, $attributes=null, $options=null) { debugging('Use of class name as constructor is deprecated', DEBUG_DEVELOPER); self::__construct($elementName, $elementLabel, $attributes, $options); } /** * Called by HTML_QuickForm whenever form event is made on this element * * @param string $event Name of event * @param mixed $arg event arguments * @param object $caller calling object * @return bool */ function onQuickFormEvent($event, $arg, &$caller) { switch ($event) { case 'createElement': $caller->setType($arg[0] . '[format]', PARAM_ALPHANUM); $caller->setType($arg[0] . '[itemid]', PARAM_INT); break; } return parent::onQuickFormEvent($event, $arg, $caller); } /** * Sets name of editor * * @param string $name name of the editor */ function setName($name) { $this->updateAttributes(array('name'=>$name)); } /** * Returns name of element * * @return string */ function getName() { return $this->getAttribute('name'); } /** * Updates editor values, if part of $_values * * @param array $values associative array of values to set */ function setValue($values) { $values = (array)$values; foreach ($values as $name=>$value) { if (array_key_exists($name, $this->_values)) { $this->_values[$name] = $value; } } } /** * Returns editor values * * @return array */ function getValue() { return $this->_values; } /** * Returns maximum file size which can be uploaded * * @return int */ function getMaxbytes() { return $this->_options['maxbytes']; } /** * Sets maximum file size which can be uploaded * * @param int $maxbytes file size */ function setMaxbytes($maxbytes) { global $CFG; $this->_options['maxbytes'] = get_max_upload_file_size($CFG->maxbytes, $maxbytes); } /** * Returns the maximum size of the area. * * @return int */ function getAreamaxbytes() { return $this->_options['areamaxbytes']; } /** * Sets the maximum size of the area. * * @param int $areamaxbytes size limit */ function setAreamaxbytes($areamaxbytes) { $this->_options['areamaxbytes'] = $areamaxbytes; } /** * Returns maximum number of files which can be uploaded * * @return int */ function getMaxfiles() { return $this->_options['maxfiles']; } /** * Sets maximum number of files which can be uploaded. * * @param int $num number of files */ function setMaxfiles($num) { $this->_options['maxfiles'] = $num; } /** * Returns true if subdirectoy can be created, else false * * @return bool */ function getSubdirs() { return $this->_options['subdirs']; } /** * Set option to create sub directory, while uploading file * * @param bool $allow true if sub directory can be created. */ function setSubdirs($allow) { $this->_options['subdirs'] = (int)($allow == 1); } /** * Returns editor format * * @return int. */ function getFormat() { return $this->_values['format']; } /** * Checks if editor used is a required field * * @return bool true if required field. */ function isRequired() { return (isset($this->_options['required']) && $this->_options['required']); } /** * @deprecated since Moodle 2.0 */ function setHelpButton($_helpbuttonargs, $function='_helpbutton') { throw new coding_exception('setHelpButton() can not be used any more, please see MoodleQuickForm::addHelpButton().'); } /** * Returns html for help button. * * @return string html for help button */ function getHelpButton() { return $this->_helpbutton; } /** * Returns type of editor element * * @return string */ function getElementTemplateType() { if ($this->_flagFrozen){ return 'nodisplay'; } else { return 'default'; } } /** * Returns HTML for editor form element. * * @return string */ function toHtml() { global $CFG, $PAGE, $OUTPUT; require_once($CFG->dirroot.'/repository/lib.php'); if ($this->_flagFrozen) { return $this->getFrozenHtml(); } $ctx = $this->_options['context']; $id = $this->_attributes['id']; $elname = $this->_attributes['name']; $subdirs = $this->_options['subdirs']; $maxbytes = $this->_options['maxbytes']; $areamaxbytes = $this->_options['areamaxbytes']; $maxfiles = $this->_options['maxfiles']; $changeformat = $this->_options['changeformat']; // TO DO: implement as ajax calls $text = $this->_values['text']; $format = $this->_values['format']; $draftitemid = $this->_values['itemid']; // security - never ever allow guest/not logged in user to upload anything if (isguestuser() or !isloggedin()) { $maxfiles = 0; } $str = $this->_getTabs(); $str .= '