* @author Bertrand Mansion
* @copyright 2001-2009 The PHP Group
* @license http://www.php.net/license/3_01.txt PHP License 3.01
* @version CVS: $Id: textarea.php,v 1.13 2009/04/04 21:34:04 avb Exp $
* @link http://pear.php.net/package/HTML_QuickForm
* @version Release: 3.2.11
* @since 1.0
*/
class HTML_QuickForm_textarea extends HTML_QuickForm_element
{
/**
* Field value
* @var string
*/
public $_value;
/**
* @param string $elementName Input field name attribute
* @param string|array $label Label(s) for a field
* @param mixed $attributes Either a typical HTML attribute string or an associative array
*/
public function __construct(
$elementName = null,
$label = null,
$attributes = null
) {
$columnsSize = $attributes['cols-size'] ?? null;
$this->setColumnsSize($columnsSize);
parent::__construct($elementName, $label, $attributes);
$id = $this->getAttribute('id');
if (empty($id)) {
$name = $this->getAttribute('name');
$this->setAttribute('id', uniqid($name.'_', false));
}
$this->_persistantFreeze = true;
$this->_type = 'textarea';
$this->_value = null;
}
/**
* Sets the input field name
*
* @param string $name Input field name attribute
*
* @return void
* @since 1.0
*/
public function setName($name)
{
$this->updateAttributes(['name' => $name]);
}
/**
* Returns the element name
*
* @return string
* @since 1.0
*/
public function getName()
{
return $this->getAttribute('name');
}
/**
* Returns the value of the form element
*
* @return string
* @since 1.0
*/
public function getValue()
{
return $this->_value;
}
/**
* Sets value for textarea element
*
* @param string $value Value for textarea element
*
* @return void
* @since 1.0
*/
public function setValue($value)
{
$this->_value = $value;
}
/**
* Sets height in rows for textarea element
*
* @param string $rows Height expressed in rows
*
* @return void
* @since 1.0
*/
public function setRows($rows)
{
$this->updateAttributes(['rows' => $rows]);
}
/**
* Sets width in cols for textarea element
*
* @param string $cols Width expressed in cols
*
* @return void
* @since 1.0
*/
public function setCols($cols)
{
$this->updateAttributes(['cols' => $cols]);
}
public function getTemplate(string $layout): string
{
if (FormValidator::LAYOUT_HORIZONTAL === $layout) {
return '
{element}
{icon}
{label_2}
{label_3}
{error}
';
}
return parent::getTemplate($layout);
}
public function toHtml()
{
if ($this->_flagFrozen) {
return $this->getFrozenHtml();
}
if (!isset($this->_attributes['class'])) {
$this->_attributes['class'] = '';
}
if (FormValidator::LAYOUT_HORIZONTAL === $this->getLayout()) {
$this->_attributes['class'] .= 'p-inputtextarea p-inputtext p-component p-filled';
}
return $this->_getTabs().
'';
}
/**
* Returns the value of field without HTML tags (in this case, value is changed to a mask)
*/
public function getFrozenHtml()
{
$value = $this->getCleanValue();
if ($this->getAttribute('wrap') === 'off') {
$html = $this->_getTabs().'