2007-07-19 10:40:28 +00:00
|
|
|
<?php
|
2015-04-27 16:00:53 +12:00
|
|
|
|
2016-08-19 10:51:35 +12:00
|
|
|
namespace SilverStripe\Forms;
|
|
|
|
|
|
|
|
use SilverStripe\View\ViewableData;
|
|
|
|
|
2007-07-19 10:40:28 +00:00
|
|
|
/**
|
|
|
|
* This field lets you put an arbitrary piece of HTML into your forms.
|
2015-04-27 16:00:53 +12:00
|
|
|
*
|
2010-10-15 03:55:22 +00:00
|
|
|
* <code>
|
|
|
|
* new LiteralField (
|
|
|
|
* $name = "literalfield",
|
|
|
|
* $content = '<b>some bold text</b> and <a href="http://silverstripe.com">a link</a>'
|
|
|
|
* )
|
|
|
|
* </code>
|
2007-07-19 10:40:28 +00:00
|
|
|
*/
|
2016-11-29 12:31:16 +13:00
|
|
|
class LiteralField extends DatalessField
|
|
|
|
{
|
|
|
|
|
|
|
|
private static $casting = [
|
|
|
|
'Value' => 'HTMLFragment',
|
|
|
|
];
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var string|FormField
|
|
|
|
*/
|
|
|
|
protected $content;
|
|
|
|
|
|
|
|
protected $schemaDataType = self::SCHEMA_DATA_TYPE_STRUCTURAL;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @skipUpgrade
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $schemaComponent = 'LiteralField';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param string $name
|
|
|
|
* @param string|FormField $content
|
|
|
|
*/
|
|
|
|
public function __construct($name, $content)
|
|
|
|
{
|
|
|
|
$this->setContent($content);
|
|
|
|
|
|
|
|
parent::__construct($name);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param array $properties
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
2020-04-20 18:58:09 +01:00
|
|
|
public function FieldHolder($properties = [])
|
2016-11-29 12:31:16 +13:00
|
|
|
{
|
|
|
|
if ($this->content instanceof ViewableData) {
|
|
|
|
$context = $this->content;
|
|
|
|
|
|
|
|
if ($properties) {
|
|
|
|
$context = $context->customise($properties);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $context->forTemplate();
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this->content;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param array $properties
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
2020-04-20 18:58:09 +01:00
|
|
|
public function Field($properties = [])
|
2016-11-29 12:31:16 +13:00
|
|
|
{
|
|
|
|
return $this->FieldHolder($properties);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the content of this field to a new value.
|
|
|
|
*
|
|
|
|
* @param string|FormField $content
|
|
|
|
*
|
|
|
|
* @return $this
|
|
|
|
*/
|
|
|
|
public function setContent($content)
|
|
|
|
{
|
|
|
|
$this->content = $content;
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getContent()
|
|
|
|
{
|
|
|
|
return $this->content;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Synonym of {@link setContent()} so that LiteralField is more compatible with other field types.
|
|
|
|
*
|
|
|
|
* @param string|FormField $content
|
2017-01-26 17:20:08 +13:00
|
|
|
* @param mixed $data
|
2016-11-29 12:31:16 +13:00
|
|
|
* @return $this
|
|
|
|
*/
|
2017-01-26 17:20:08 +13:00
|
|
|
public function setValue($content, $data = null)
|
2016-11-29 12:31:16 +13:00
|
|
|
{
|
|
|
|
$this->setContent($content);
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return static
|
|
|
|
*/
|
|
|
|
public function performReadonlyTransformation()
|
|
|
|
{
|
|
|
|
$clone = clone $this;
|
|
|
|
|
|
|
|
$clone->setReadonly(true);
|
|
|
|
|
|
|
|
return $clone;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Header fields support dynamic titles via schema state
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function getSchemaStateDefaults()
|
|
|
|
{
|
|
|
|
$state = parent::getSchemaStateDefaults();
|
|
|
|
$state['value'] = $this->FieldHolder();
|
|
|
|
|
|
|
|
return $state;
|
|
|
|
}
|
2012-03-24 16:04:52 +13:00
|
|
|
}
|