2007-07-19 12:40:28 +02:00
|
|
|
<?php
|
2013-05-10 14:01:39 +02:00
|
|
|
|
2016-08-19 00:51:35 +02:00
|
|
|
namespace SilverStripe\Forms;
|
|
|
|
|
2017-10-26 02:04:30 +02:00
|
|
|
use SilverStripe\Core\Convert;
|
2016-08-19 00:51:35 +02:00
|
|
|
use SilverStripe\ORM\ArrayLib;
|
2016-06-15 06:03:16 +02:00
|
|
|
use SilverStripe\ORM\DataObjectInterface;
|
2017-10-26 02:04:30 +02:00
|
|
|
use SilverStripe\ORM\FieldType\DBField;
|
2016-06-15 06:03:16 +02:00
|
|
|
|
2008-01-09 05:18:36 +01:00
|
|
|
/**
|
2018-04-20 00:29:45 +02:00
|
|
|
* Read-only complement of {@link MultiSelectField}.
|
2013-05-10 14:01:39 +02:00
|
|
|
*
|
2018-04-20 00:29:45 +02:00
|
|
|
* Shows the "human value" of the MultiSelectField for the currently selected
|
2013-05-10 14:01:39 +02:00
|
|
|
* value.
|
2008-01-09 05:18:36 +01:00
|
|
|
*/
|
2016-11-29 00:31:16 +01:00
|
|
|
class LookupField extends MultiSelectField
|
|
|
|
{
|
2017-07-03 02:21:27 +02:00
|
|
|
/** @skipUpgrade */
|
2016-10-05 03:30:19 +02:00
|
|
|
protected $schemaComponent = 'LookupField';
|
2007-09-15 23:39:23 +02:00
|
|
|
|
2016-11-29 00:31:16 +01:00
|
|
|
/**
|
|
|
|
* @var boolean $readonly
|
|
|
|
*/
|
|
|
|
protected $readonly = true;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns a readonly span containing the correct value.
|
|
|
|
*
|
|
|
|
* @param array $properties
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function Field($properties = array())
|
|
|
|
{
|
|
|
|
$source = ArrayLib::flatten($this->getSource());
|
|
|
|
$values = $this->getValueArray();
|
|
|
|
|
|
|
|
// Get selected values
|
2017-10-26 02:04:30 +02:00
|
|
|
$mapped = [];
|
2016-11-29 00:31:16 +01:00
|
|
|
foreach ($values as $value) {
|
|
|
|
if (isset($source[$value])) {
|
2017-10-26 02:04:30 +02:00
|
|
|
$mapped[] = Convert::raw2xml($source[$value]);
|
2016-11-29 00:31:16 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Don't check if string arguments are matching against the source,
|
|
|
|
// as they might be generated HTML diff views instead of the actual values
|
|
|
|
if ($this->value && is_string($this->value) && empty($mapped)) {
|
2017-10-26 02:04:30 +02:00
|
|
|
$mapped[] = Convert::raw2xml(trim($this->value));
|
|
|
|
$values = [];
|
2016-11-29 00:31:16 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if ($mapped) {
|
|
|
|
$attrValue = implode(', ', array_values($mapped));
|
|
|
|
$inputValue = implode(', ', array_values($values));
|
|
|
|
} else {
|
2018-01-16 19:39:30 +01:00
|
|
|
$attrValue = '<i>(' . _t('SilverStripe\\Forms\\FormField.NONE', 'none') . ')</i>';
|
2016-11-29 00:31:16 +01:00
|
|
|
$inputValue = '';
|
|
|
|
}
|
|
|
|
|
|
|
|
$properties = array_merge($properties, array(
|
|
|
|
'AttrValue' => DBField::create_field('HTMLFragment', $attrValue),
|
|
|
|
'InputValue' => $inputValue
|
|
|
|
));
|
|
|
|
|
|
|
|
return parent::Field($properties);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Ignore validation as the field is readonly
|
|
|
|
*
|
|
|
|
* @param Validator $validator
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function validate($validator)
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Stubbed so invalid data doesn't save into the DB
|
|
|
|
*
|
|
|
|
* @param DataObjectInterface $record DataObject to save data into
|
|
|
|
*/
|
|
|
|
public function saveInto(DataObjectInterface $record)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return LookupField
|
|
|
|
*/
|
|
|
|
public function performReadonlyTransformation()
|
|
|
|
{
|
|
|
|
$clone = clone $this;
|
|
|
|
return $clone;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getHasEmptyDefault()
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function Type()
|
|
|
|
{
|
|
|
|
return "lookup readonly";
|
|
|
|
}
|
2007-07-19 12:40:28 +02:00
|
|
|
}
|