2007-07-19 10:40:28 +00:00
|
|
|
<?php
|
2016-08-19 10:51:35 +12:00
|
|
|
|
|
|
|
namespace SilverStripe\Forms;
|
|
|
|
|
2007-07-19 10:40:28 +00:00
|
|
|
/**
|
2009-03-10 15:03:34 +00:00
|
|
|
* Read-only field to display a non-editable value with a label.
|
|
|
|
* Consider using an {@link LabelField} if you just need a label-less
|
|
|
|
* value display.
|
2007-07-19 10:40:28 +00:00
|
|
|
*/
|
2016-11-29 12:31:16 +13:00
|
|
|
class ReadonlyField extends FormField
|
|
|
|
{
|
|
|
|
|
|
|
|
protected $readonly = true;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Include a hidden field in the HTML for the readonly field
|
|
|
|
* @var boolean
|
|
|
|
*/
|
|
|
|
protected $includeHiddenField = false;
|
|
|
|
|
|
|
|
protected $schemaDataType = FormField::SCHEMA_DATA_TYPE_TEXT;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* If true, a hidden field will be included in the HTML for the readonly field.
|
|
|
|
*
|
|
|
|
* This can be useful if you need to pass the data through on the form submission, as
|
|
|
|
* long as it's okay than an attacker could change the data before it's submitted.
|
|
|
|
*
|
|
|
|
* This is disabled by default as it can introduce security holes if the data is not
|
|
|
|
* allowed to be modified by the user.
|
|
|
|
*
|
|
|
|
* @param boolean $includeHiddenField
|
|
|
|
* @return $this
|
|
|
|
*/
|
|
|
|
public function setIncludeHiddenField($includeHiddenField)
|
|
|
|
{
|
|
|
|
$this->includeHiddenField = $includeHiddenField;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function getIncludeHiddenField()
|
|
|
|
{
|
|
|
|
return $this->includeHiddenField;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function performReadonlyTransformation()
|
|
|
|
{
|
|
|
|
return clone $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function Type()
|
|
|
|
{
|
|
|
|
return 'readonly';
|
|
|
|
}
|
|
|
|
|
|
|
|
public function castingHelper($field)
|
|
|
|
{
|
|
|
|
// Get dynamic cast for 'Value' field
|
|
|
|
if (strcasecmp($field, 'Value') === 0) {
|
|
|
|
return $this->getValueCast();
|
|
|
|
}
|
|
|
|
|
|
|
|
// Fall back to default casting
|
|
|
|
return parent::castingHelper($field);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getSchemaStateDefaults()
|
|
|
|
{
|
|
|
|
$state = parent::getSchemaStateDefaults();
|
|
|
|
$state['value'] = $this->dataValue();
|
|
|
|
|
|
|
|
return $state;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return mixed|string
|
|
|
|
*/
|
|
|
|
public function Value()
|
|
|
|
{
|
|
|
|
// Get raw value
|
|
|
|
$value = $this->dataValue();
|
|
|
|
if ($value) {
|
|
|
|
return $value;
|
|
|
|
}
|
|
|
|
|
|
|
|
// "none" text
|
2017-04-20 13:15:24 +12:00
|
|
|
$label = _t('SilverStripe\\Forms\\FormField.NONE', 'none');
|
2016-11-29 12:31:16 +13:00
|
|
|
return "<i>('{$label}')</i>";
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get custom cating helper for Value() field
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getValueCast()
|
|
|
|
{
|
|
|
|
// Casting class for 'none' text
|
|
|
|
$value = $this->dataValue();
|
|
|
|
if (empty($value)) {
|
|
|
|
return 'HTMLFragment';
|
|
|
|
}
|
|
|
|
|
|
|
|
// Use default casting
|
2017-02-22 16:14:53 +13:00
|
|
|
$casting = $this->config()->get('casting');
|
|
|
|
return $casting['Value'];
|
2016-11-29 12:31:16 +13:00
|
|
|
}
|
2012-03-24 16:04:52 +13:00
|
|
|
}
|