2007-07-19 10:40:28 +00:00
|
|
|
<?php
|
|
|
|
/**
|
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.
|
2014-08-15 18:53:05 +12:00
|
|
|
*
|
2008-01-09 04:18:36 +00:00
|
|
|
* @package forms
|
|
|
|
* @subpackage fields-basic
|
2007-07-19 10:40:28 +00:00
|
|
|
*/
|
|
|
|
class ReadonlyField extends FormField {
|
|
|
|
|
2008-08-12 02:58:48 +00:00
|
|
|
protected $readonly = true;
|
|
|
|
|
2013-01-07 18:44:01 +13:00
|
|
|
/**
|
|
|
|
* Include a hidden field in the HTML for the readonly field
|
|
|
|
* @var boolean
|
|
|
|
*/
|
|
|
|
protected $includeHiddenField = false;
|
|
|
|
|
2016-04-21 14:38:02 +12:00
|
|
|
protected $schemaDataType = FormField::SCHEMA_DATA_TYPE_TEXT;
|
|
|
|
|
2013-01-07 18:44:01 +13:00
|
|
|
/**
|
|
|
|
* If true, a hidden field will be included in the HTML for the readonly field.
|
2014-08-15 18:53:05 +12:00
|
|
|
*
|
2013-01-07 18:44:01 +13:00
|
|
|
* 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.
|
2014-08-15 18:53:05 +12:00
|
|
|
*
|
2013-01-07 18:44:01 +13:00
|
|
|
* @param boolean $includeHiddenField
|
|
|
|
*/
|
|
|
|
public function setIncludeHiddenField($includeHiddenField) {
|
|
|
|
$this->includeHiddenField = $includeHiddenField;
|
|
|
|
}
|
|
|
|
|
2012-09-19 12:07:39 +02:00
|
|
|
public function performReadonlyTransformation() {
|
2008-12-04 22:38:32 +00:00
|
|
|
return clone $this;
|
2007-07-19 10:40:28 +00:00
|
|
|
}
|
2011-12-22 13:10:57 +01:00
|
|
|
|
2015-06-20 11:11:08 +01:00
|
|
|
/**
|
|
|
|
* @param array $properties
|
|
|
|
* @return HTMLText
|
|
|
|
*/
|
2013-01-07 18:44:01 +13:00
|
|
|
public function Field($properties = array()) {
|
|
|
|
// Include a hidden field in the HTML
|
|
|
|
if($this->includeHiddenField && $this->readonly) {
|
|
|
|
$hidden = clone $this;
|
|
|
|
$hidden->setReadonly(false);
|
|
|
|
return parent::Field($properties) . $hidden->Field($properties);
|
|
|
|
|
|
|
|
} else {
|
|
|
|
return parent::Field($properties);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-04-21 14:38:02 +12:00
|
|
|
/**
|
|
|
|
* If $dontEscape is true the returned value will be plain text
|
|
|
|
* and should be escaped in templates via .XML
|
|
|
|
*
|
|
|
|
* If $dontEscape is false the returned value will be safely encoded,
|
|
|
|
* but should not be escaped by the frontend.
|
|
|
|
*
|
|
|
|
* @return mixed|string
|
|
|
|
*/
|
2012-09-19 12:07:39 +02:00
|
|
|
public function Value() {
|
2016-04-21 14:38:02 +12:00
|
|
|
if($this->value) {
|
|
|
|
if($this->dontEscape) {
|
|
|
|
return $this->value;
|
|
|
|
} else {
|
2016-04-26 16:57:07 +12:00
|
|
|
return Convert::raw2xml($this->value);
|
2016-04-21 14:38:02 +12:00
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$value = '(' . _t('FormField.NONE', 'none') . ')';
|
|
|
|
if($this->dontEscape) {
|
|
|
|
return $value;
|
|
|
|
} else {
|
|
|
|
return '<i>'.Convert::raw2xml($value).'</i>';
|
|
|
|
}
|
|
|
|
}
|
2011-12-22 13:10:57 +01:00
|
|
|
}
|
|
|
|
|
2012-09-19 12:07:39 +02:00
|
|
|
public function getAttributes() {
|
2011-12-22 13:10:57 +01:00
|
|
|
return array_merge(
|
|
|
|
parent::getAttributes(),
|
|
|
|
array(
|
|
|
|
'type' => 'hidden',
|
2013-01-07 18:44:01 +13:00
|
|
|
'value' => $this->readonly ? null : $this->value,
|
2011-12-22 13:10:57 +01:00
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2012-09-19 12:07:39 +02:00
|
|
|
public function Type() {
|
2011-12-22 13:10:57 +01:00
|
|
|
return 'readonly';
|
|
|
|
}
|
2014-11-12 15:19:12 +13:00
|
|
|
|
2012-03-24 16:04:52 +13:00
|
|
|
}
|