silverstripe-framework/src/Forms/TextareaField.php

214 lines
4.3 KiB
PHP
Raw Normal View History

<?php
2015-04-27 15:15:32 +12:00
namespace SilverStripe\Forms;
/**
* TextareaField creates a multi-line text field,
* allowing more data to be entered than a standard
* text field. It creates the `<textarea>` tag in the
* form HTML.
2014-08-15 18:53:05 +12:00
*
* <code>
* new TextareaField(
* $name = "description",
* $title = "Description",
* $value = "This is the default description"
* );
* </code>
*/
2016-11-29 12:31:16 +13:00
class TextareaField extends FormField
{
/**
* Value should be XML
*
* @var array
*/
private static $casting = [
2016-11-29 12:31:16 +13:00
'Value' => 'Text',
'ValueEntities' => 'HTMLFragment([\'shortcodes\' => false])',
];
2017-12-04 16:40:40 +13:00
protected $schemaDataType = FormField::SCHEMA_DATA_TYPE_TEXT;
2017-12-04 16:40:40 +13:00
/**
2016-11-29 12:31:16 +13:00
* Visible number of text lines.
*
* @var int
*/
protected $rows = 5;
/**
* Visible number of text columns.
*
* @var int
*/
protected $cols = 20;
2017-12-04 16:40:40 +13:00
/**
* @var int
*/
protected $maxLength;
2016-11-29 12:31:16 +13:00
/**
* Set textarea specific schema data
*/
public function getSchemaDataDefaults()
{
$data = parent::getSchemaDataDefaults();
$data['data']['rows'] = $this->getRows();
$data['data']['columns'] = $this->getColumns();
2017-12-04 16:40:40 +13:00
$data['data']['maxlength'] = $this->getMaxLength();
return $data;
}
2017-12-04 16:40:40 +13:00
/**
* Set the number of rows in the textarea
2016-11-29 12:31:16 +13:00
*
* @param int $rows
*
* @return $this
*/
public function setRows($rows)
{
$this->rows = $rows;
return $this;
}
/**
* Gets number of rows
*
* @return int
*/
public function getRows()
{
return $this->rows;
}
/**
* Set the number of columns in the textarea
*
* @param int $cols
*
* @return $this
*/
public function setColumns($cols)
{
$this->cols = $cols;
return $this;
}
/**
* Gets the number of columns in this textarea
*
* @return int
*/
public function getColumns()
{
return $this->cols;
}
2017-12-04 16:40:40 +13:00
/**
* @param int $maxLength
* @return $this
*/
public function setMaxLength($maxLength)
{
$this->maxLength = $maxLength;
return $this;
}
/**
* @return null|int
*/
public function getMaxLength()
{
return $this->maxLength;
}
2016-11-29 12:31:16 +13:00
/**
* {@inheritdoc}
*/
public function getAttributes()
{
2017-12-08 09:58:52 +13:00
$attributes = array_merge(
2016-11-29 12:31:16 +13:00
parent::getAttributes(),
[
2016-11-29 12:31:16 +13:00
'rows' => $this->getRows(),
'cols' => $this->getColumns(),
'value' => null,
2017-12-04 16:40:40 +13:00
'type' => null,
]
2016-11-29 12:31:16 +13:00
);
2017-12-08 09:58:52 +13:00
$maxLength = $this->getMaxLength();
2017-12-11 09:00:04 +13:00
if ($maxLength) {
2017-12-08 09:58:52 +13:00
$attributes['maxlength'] = $maxLength;
}
return $attributes;
2016-11-29 12:31:16 +13:00
}
/**
* {@inheritdoc}
*/
public function Type()
{
$parent = parent::Type();
if ($this->readonly) {
return $parent . ' readonly';
}
return $parent;
}
2023-08-28 10:51:43 +02:00
/**
* Validate this field
*
* @param Validator $validator
* @return bool
*/
public function validate($validator)
{
if (!is_null($this->maxLength) && mb_strlen($this->value ?? '') > $this->maxLength) {
$name = strip_tags($this->Title() ? $this->Title() : $this->getName());
$validator->validationError(
$this->name,
_t(
'SilverStripe\\Forms\\TextField.VALIDATEMAXLENGTH',
'The value for {name} must not exceed {maxLength} characters in length',
['name' => $name, 'maxLength' => $this->maxLength]
),
"validation"
);
return false;
}
return true;
}
public function getSchemaValidation()
{
$rules = parent::getSchemaValidation();
if ($this->getMaxLength()) {
$rules['max'] = [
'length' => $this->getMaxLength(),
];
}
return $rules;
}
2016-11-29 12:31:16 +13:00
/**
* Return value with all values encoded in html entities
*
* @return string Raw HTML
*/
public function ValueEntities()
{
2022-04-14 13:12:59 +12:00
return htmlentities($this->Value() ?? '', ENT_COMPAT, 'UTF-8');
2016-11-29 12:31:16 +13:00
}
}