mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-09-21 00:46:07 +02:00
a24ccecb69
FEATURE Added FormScaffolder for more flexible scaffolding of FieldSets from DataObject metadata API CHANGE Removed DataObject->addScaffoldRelationFields(), now in separate class FormScaffolder API CHANGE Changed parameters for DataObject->scaffoldSearchFields() to unify them with scaffoldFormFields() API CHANGE Added optional $params parameter to DataObject->getCMSFields() to be passed on to scaffoldFormFields() API CHANGE Renamed DataObject->getFormFields() to getFrontEndFields() ENHANCEMENT Added $params parameter to all DBField->scaffoldFormField() subclasses API CHANGE Added third optional parameter $object to DBField::create() to comply with ForeignKey and PrimaryKey constructors git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/sapphire/trunk@64157 467b73ca-7a2a-4603-9d3b-597d59a354a9
63 lines
1.3 KiB
PHP
63 lines
1.3 KiB
PHP
<?php
|
|
/**
|
|
* Represents a boolean field.
|
|
* @package sapphire
|
|
* @subpackage model
|
|
*/
|
|
class Boolean extends DBField {
|
|
|
|
function __construct($name, $defaultVal = 0) {
|
|
$this->defaultVal = ($defaultVal) ? 1 : 0;
|
|
|
|
parent::__construct($name);
|
|
}
|
|
|
|
function requireField() {
|
|
DB::requireField($this->tableName, $this->name, "tinyint(1) unsigned not null default '{$this->defaultVal}'");
|
|
}
|
|
|
|
function nullValue() {
|
|
return 0;
|
|
}
|
|
|
|
function Nice() {
|
|
return ($this->value) ? "yes" : "no";
|
|
}
|
|
|
|
function NiceAsBoolean() {
|
|
return ($this->value) ? "true" : "false";
|
|
}
|
|
|
|
/**
|
|
* Saves this field to the given data object.
|
|
*/
|
|
function saveInto($dataObject) {
|
|
$fieldName = $this->name;
|
|
if($fieldName) {
|
|
$dataObject->$fieldName = $this->value ? 1 : 0;
|
|
} else {
|
|
user_error("DBField::saveInto() Called on a nameless '$this->class' object", E_USER_ERROR);
|
|
}
|
|
}
|
|
|
|
public function scaffoldFormField($title = null, $params = null) {
|
|
return new CheckboxField($this->name, $title);
|
|
}
|
|
|
|
/**
|
|
* Return an encoding of the given value suitable for inclusion in a SQL statement.
|
|
* If necessary, this should include quotes.
|
|
*/
|
|
function prepValueForDB($value) {
|
|
if($value === true) {
|
|
return 1;
|
|
} if(!$value || !is_numeric($value)) {
|
|
return "0";
|
|
} else {
|
|
return addslashes($value);
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
?>
|