silverstripe-framework/Forms/LookupField.php

107 lines
2.2 KiB
PHP
Raw Normal View History

<?php
namespace SilverStripe\Forms;
use SilverStripe\ORM\ArrayLib;
use SilverStripe\ORM\FieldType\DBField;
use SilverStripe\ORM\DataObjectInterface;
use SilverStripe\Core\Convert;
/**
* Read-only complement of {@link DropdownField}.
*
2014-08-15 08:53:05 +02:00
* Shows the "human value" of the dropdown field for the currently selected
* value.
*/
class LookupField extends MultiSelectField {
protected $schemaComponent = 'LookupField';
/**
* @var boolean $readonly
*/
protected $readonly = true;
2014-08-15 08:53:05 +02:00
/**
* 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
$mapped = array();
foreach($values as $value) {
if(isset($source[$value])) {
$mapped[] = $source[$value];
}
}
// 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)) {
$mapped = array(trim($this->value));
$values = array();
}
2014-08-15 08:53:05 +02:00
if($mapped) {
$attrValue = implode(', ', array_values($mapped));
2014-08-15 08:53:05 +02:00
$attrValue = Convert::raw2xml($attrValue);
2014-08-15 08:53:05 +02:00
$inputValue = implode(', ', array_values($values));
} else {
$attrValue = '<i>('._t('FormField.NONE', 'none').')</i>';
$inputValue = '';
}
$properties = array_merge($properties, array(
'AttrValue' => DBField::create_field('HTMLFragment', $attrValue),
'InputValue' => $inputValue
));
return parent::Field($properties);
}
2014-08-15 08:53:05 +02:00
/**
* 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";
}
}