. /** * htmleditor type form element * * Contains HTML class for htmleditor type element * * @package core_form * @copyright 2006 Jamie Pratt * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ global $CFG; require_once("$CFG->libdir/form/textarea.php"); /** * htmleditor type form element * * HTML class for htmleditor type element * * @package core_form * @category form * @copyright 2006 Jamie Pratt * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ class MoodleQuickForm_htmleditor extends MoodleQuickForm_textarea{ /** @var string defines the type of editor */ var $_type; /** @var array default options for html editor, which can be overridden */ var $_options=array('rows'=>10, 'cols'=>45, 'width'=>0,'height'=>0); /** * Constructor * * @param string $elementName (optional) name of the html editor * @param string $elementLabel (optional) editor label * @param array $options set of options to create html editor * @param array $attributes (optional) Either a typical HTML attribute string * or an associative array */ public function __construct($elementName=null, $elementLabel=null, $options=array(), $attributes=null){ parent::__construct($elementName, $elementLabel, $attributes); // set the options, do not bother setting bogus ones if (is_array($options)) { foreach ($options as $name => $value) { if (array_key_exists($name, $this->_options)) { if (is_array($value) && is_array($this->_options[$name])) { $this->_options[$name] = @array_merge($this->_options[$name], $value); } else { $this->_options[$name] = $value; } } } } $this->_type='htmleditor'; editors_head_setup(); } /** * Old syntax of class constructor. Deprecated in PHP7. * * @deprecated since Moodle 3.1 */ public function MoodleQuickForm_htmleditor($elementName=null, $elementLabel=null, $options=array(), $attributes=null) { debugging('Use of class name as constructor is deprecated', DEBUG_DEVELOPER); self::__construct($elementName, $elementLabel, $options, $attributes); } /** * Returns the input field in HTML * * @return string */ function toHtml(){ if ($this->_flagFrozen) { return $this->getFrozenHtml(); } else { return $this->_getTabs() . print_textarea(true, $this->_options['rows'], $this->_options['cols'], $this->_options['width'], $this->_options['height'], $this->getName(), preg_replace("/(\r\n|\n|\r)/", ' ',$this->getValue()), 0, // unused anymore true, $this->getAttribute('id')); } } /** * What to display when element is frozen. * * @return string */ function getFrozenHtml() { $html = format_text($this->getValue()); return $html . $this->_getPersistantData(); } }