silverstripe-framework/forms/NullableField.php

185 lines
3.9 KiB
PHP
Raw Normal View History

<?php
2015-04-27 14:50:40 +12:00
use SilverStripe\ORM\FieldType\DBField;
/**
2015-04-27 14:50:40 +12:00
* 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.
2014-08-15 18:53:05 +12:00
*
* $a = new NullableField(new TextField("Field1", "Field 1", "abc"));
2014-08-15 18:53:05 +12:00
*
2015-04-27 14:50:40 +12:00
* 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()
2014-08-15 18:53:05 +12:00
*
2015-04-27 14:50:40 +12:00
* 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:
2014-08-15 18:53:05 +12:00
*
2015-04-27 14:50:40 +12:00
* $field->setIsNullLabel(_T(SOME_MODULE_ISNULL_LABEL, "Is Null"));
2014-08-15 18:53:05 +12:00
*
* @author Pete Bacon Darwin
2015-04-27 14:50:40 +12:00
*
* @package forms
* @subpackage fields-basic
*/
class NullableField extends FormField {
/**
* The field that holds the value of this field
2015-04-27 14:50:40 +12:00
*
* @var FormField
*/
protected $valueField;
2014-08-15 18:53:05 +12:00
/**
* The label to show next to the is null check box.
2015-04-27 14:50:40 +12:00
*
* @var string
*/
protected $isNullLabel;
2014-08-15 18:53:05 +12:00
/**
* Create a new nullable field
2015-04-27 14:50:40 +12:00
*
* @param FormField $valueField
* @param null|string $isNullLabel
*/
public function __construct(FormField $valueField, $isNullLabel = null) {
$this->valueField = $valueField;
2015-04-27 14:50:40 +12:00
if(isset($isNullLabel)) {
$this->setIsNullLabel($isNullLabel);
} else {
$this->isNullLabel = _t('NullableField.IsNullLabel', 'Is Null');
}
2015-04-27 14:50:40 +12:00
parent::__construct(
$valueField->getName(),
$valueField->Title(),
$valueField->Value()
);
$this->setForm($valueField->getForm());
$this->setRightTitle($valueField->RightTitle());
$this->setReadonly($valueField->isReadonly());
}
2014-08-15 18:53:05 +12:00
/**
* Get the label used for the Is Null checkbox.
2015-04-27 14:50:40 +12:00
*
* @return string
*/
public function getIsNullLabel() {
return $this->isNullLabel;
}
2015-04-27 14:50:40 +12:00
/**
* Set the label used for the Is Null checkbox.
2015-04-27 14:50:40 +12:00
*
* @param $isNulLabel string
2015-04-27 14:50:40 +12:00
*
* @return $this
*/
2015-04-27 14:50:40 +12:00
public function setIsNullLabel($isNulLabel) {
$this->isNullLabel = $isNulLabel;
2015-04-27 14:50:40 +12:00
return $this;
}
2014-08-15 18:53:05 +12:00
/**
* Get the id used for the Is Null check box.
2015-04-27 14:50:40 +12:00
*
* @return string
*/
public function getIsNullId() {
return $this->getName() . "_IsNull";
}
/**
2015-04-27 14:50:40 +12:00
* @param array $properties
*
2015-06-20 11:11:08 +01:00
* @return HTMLText
*/
public function Field($properties = array()) {
2015-04-27 14:50:40 +12:00
if($this->isReadonly()) {
$nullableCheckbox = new CheckboxField_Readonly($this->getIsNullId());
} else {
$nullableCheckbox = new CheckboxField($this->getIsNullId());
}
2015-04-27 14:50:40 +12:00
$nullableCheckbox->setValue(is_null($this->dataValue()));
2015-06-20 11:11:08 +01:00
return DBField::create_field('HTMLText', sprintf(
2015-04-27 14:50:40 +12:00
'%s %s&nbsp;<span>%s</span>',
$this->valueField->Field(),
$nullableCheckbox->Field(),
$this->getIsNullLabel()
2015-06-20 11:11:08 +01:00
));
}
/**
* Value is sometimes an array, and sometimes a single value, so we need to handle both cases
2015-04-27 14:50:40 +12:00
*
* @param mixed $value
* @param null|array $data
*
* @return $this
*/
public function setValue($value, $data = null) {
2015-04-27 14:50:40 +12:00
$id = $this->getIsNullId();
if(is_array($data) && array_key_exists($id, $data) && $data[$id]) {
$value = null;
}
2015-04-27 14:50:40 +12:00
$this->valueField->setValue($value);
2015-04-27 14:50:40 +12:00
parent::setValue($value);
return $this;
}
2014-08-15 18:53:05 +12:00
/**
2015-04-27 14:50:40 +12:00
* @param string $name
*
* @return $this
*/
public function setName($name) {
$this->valueField->setName($name);
2015-04-27 14:50:40 +12:00
parent::setName($name);
return $this;
}
/**
2015-04-27 14:50:40 +12:00
* @return string
*/
public function debug() {
2015-04-27 14:50:40 +12:00
$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;
}
}