mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
5c9044a007
API Introduce HTMLFragment as casting helper for HTMLText with shortcodes disabled API Introduce DBField::CDATA for XML file value encoding API RSSFeed now casts from the underlying model rather than by override API Introduce CustomMethods::getExtraMethodConfig() to allow metadata to be queried BUG Remove _call hack from VirtualPage API Remove FormField::$dontEscape API Introduce HTMLReadonlyField for non-editable readonly HTML API FormField::Field() now returns string in many cases rather than DBField instance. API Remove redundant *_val methods from ViewableData API ViewableData::obj() no longer has a $forceReturnObject parameter as it always returns an object BUG Fix issue with ViewableData caching incorrect field values after being modified. API Remove deprecated DB class methods API Enforce plain text left/right formfield titles
185 lines
3.9 KiB
PHP
185 lines
3.9 KiB
PHP
<?php
|
|
|
|
|
|
use SilverStripe\ORM\FieldType\DBField;
|
|
|
|
|
|
/**
|
|
* NullableField is a field that wraps other fields when you want to allow the user to specify
|
|
* whether the value of the field is null or not.
|
|
*
|
|
* The classic case is to wrap a TextField so that the user can distinguish between an empty string
|
|
* and a null string.
|
|
*
|
|
* $a = new NullableField(new TextField("Field1", "Field 1", "abc"));
|
|
*
|
|
* It displays the field that is wrapped followed by a checkbox that is used to specify if the
|
|
* value is null or not. It uses the Title of the wrapped field for its title.
|
|
*
|
|
* When a form is submitted the field tests the value of the "is null" checkbox and sets its value
|
|
* accordingly. You can retrieve the value of the wrapped field from the NullableField as follows:
|
|
*
|
|
* $field->Value() or $field->dataValue()
|
|
*
|
|
* You can specify the label to use for the "is null" checkbox. If you want to use i18n for this
|
|
* label then specify it like this:
|
|
*
|
|
* $field->setIsNullLabel(_T(SOME_MODULE_ISNULL_LABEL, "Is Null"));
|
|
*
|
|
* @author Pete Bacon Darwin
|
|
*
|
|
* @package forms
|
|
* @subpackage fields-basic
|
|
*/
|
|
class NullableField extends FormField {
|
|
/**
|
|
* The field that holds the value of this field
|
|
*
|
|
* @var FormField
|
|
*/
|
|
protected $valueField;
|
|
|
|
/**
|
|
* The label to show next to the is null check box.
|
|
*
|
|
* @var string
|
|
*/
|
|
protected $isNullLabel;
|
|
|
|
/**
|
|
* Create a new nullable field
|
|
*
|
|
* @param FormField $valueField
|
|
* @param null|string $isNullLabel
|
|
*/
|
|
public function __construct(FormField $valueField, $isNullLabel = null) {
|
|
$this->valueField = $valueField;
|
|
|
|
if(isset($isNullLabel)) {
|
|
$this->setIsNullLabel($isNullLabel);
|
|
} else {
|
|
$this->isNullLabel = _t('NullableField.IsNullLabel', 'Is Null');
|
|
}
|
|
|
|
parent::__construct(
|
|
$valueField->getName(),
|
|
$valueField->Title(),
|
|
$valueField->Value()
|
|
);
|
|
|
|
$this->setForm($valueField->getForm());
|
|
$this->setRightTitle($valueField->RightTitle());
|
|
$this->setReadonly($valueField->isReadonly());
|
|
}
|
|
|
|
/**
|
|
* Get the label used for the Is Null checkbox.
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getIsNullLabel() {
|
|
return $this->isNullLabel;
|
|
}
|
|
|
|
/**
|
|
* Set the label used for the Is Null checkbox.
|
|
*
|
|
* @param $isNulLabel string
|
|
*
|
|
* @return $this
|
|
*/
|
|
public function setIsNullLabel($isNulLabel) {
|
|
$this->isNullLabel = $isNulLabel;
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Get the id used for the Is Null check box.
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getIsNullId() {
|
|
return $this->getName() . "_IsNull";
|
|
}
|
|
|
|
/**
|
|
* @param array $properties
|
|
*
|
|
* @return string
|
|
*/
|
|
public function Field($properties = array()) {
|
|
if($this->isReadonly()) {
|
|
$nullableCheckbox = new CheckboxField_Readonly($this->getIsNullId());
|
|
} else {
|
|
$nullableCheckbox = new CheckboxField($this->getIsNullId());
|
|
}
|
|
|
|
$nullableCheckbox->setValue(is_null($this->dataValue()));
|
|
|
|
return sprintf(
|
|
'%s %s <span>%s</span>',
|
|
$this->valueField->Field(),
|
|
$nullableCheckbox->Field(),
|
|
$this->getIsNullLabel()
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Value is sometimes an array, and sometimes a single value, so we need to handle both cases
|
|
*
|
|
* @param mixed $value
|
|
* @param null|array $data
|
|
*
|
|
* @return $this
|
|
*/
|
|
public function setValue($value, $data = null) {
|
|
$id = $this->getIsNullId();
|
|
|
|
if(is_array($data) && array_key_exists($id, $data) && $data[$id]) {
|
|
$value = null;
|
|
}
|
|
|
|
$this->valueField->setValue($value);
|
|
|
|
parent::setValue($value);
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* @param string $name
|
|
*
|
|
* @return $this
|
|
*/
|
|
public function setName($name) {
|
|
$this->valueField->setName($name);
|
|
|
|
parent::setName($name);
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* @return string
|
|
*/
|
|
public function debug() {
|
|
$result = sprintf(
|
|
'%s (%s: $s : <span style="color: red">%s</span>) = ',
|
|
$this->class,
|
|
$this->name,
|
|
$this->title,
|
|
$this->message
|
|
);
|
|
|
|
if($this->value === null) {
|
|
$result .= "<<null>>";
|
|
} else {
|
|
$result .= (string) $this->value;
|
|
}
|
|
|
|
return $result;
|
|
}
|
|
|
|
}
|