2007-07-19 10:40:28 +00:00
|
|
|
<?php
|
2016-08-19 10:51:35 +12:00
|
|
|
|
|
|
|
namespace SilverStripe\Forms;
|
|
|
|
|
|
|
|
use InvalidArgumentException;
|
2016-11-23 18:09:10 +13:00
|
|
|
use SilverStripe\ORM\ValidationResult;
|
2016-08-19 10:51:35 +12:00
|
|
|
|
2007-07-19 10:40:28 +00:00
|
|
|
/**
|
|
|
|
* Lets you include a nested group of fields inside a template.
|
|
|
|
* This control gives you more flexibility over form layout.
|
2014-08-15 18:53:05 +12:00
|
|
|
*
|
2009-06-27 07:00:01 +00:00
|
|
|
* Note: the child fields within a field group aren't rendered using FieldHolder(). Instead,
|
2007-07-19 10:40:28 +00:00
|
|
|
* SmallFieldHolder() is called, which just prefixes $Field with a <label> tag, if the Title is set.
|
2014-08-15 18:53:05 +12:00
|
|
|
*
|
2010-10-15 03:55:22 +00:00
|
|
|
* <b>Usage</b>
|
2014-08-15 18:53:05 +12:00
|
|
|
*
|
2010-10-15 03:55:22 +00:00
|
|
|
* <code>
|
2013-07-26 16:01:24 +02:00
|
|
|
* FieldGroup::create(
|
2016-11-29 12:31:16 +13:00
|
|
|
* FieldGroup::create(
|
|
|
|
* HeaderField::create('FieldGroup 1'),
|
|
|
|
* TextField::create('Firstname')
|
|
|
|
* ),
|
|
|
|
* FieldGroup::create(
|
|
|
|
* HeaderField::create('FieldGroup 2'),
|
|
|
|
* TextField::create('Surname')
|
|
|
|
* )
|
2010-10-15 03:55:22 +00:00
|
|
|
* )
|
|
|
|
* </code>
|
2014-08-15 18:53:05 +12:00
|
|
|
*
|
2010-10-15 03:55:22 +00:00
|
|
|
* <b>Adding to existing FieldGroup instances</b>
|
2014-08-15 18:53:05 +12:00
|
|
|
*
|
2010-10-15 03:55:22 +00:00
|
|
|
* <code>
|
|
|
|
* function getCMSFields() {
|
2016-11-29 12:31:16 +13:00
|
|
|
* $fields = parent::getCMSFields();
|
2014-08-15 18:53:05 +12:00
|
|
|
*
|
2016-11-29 12:31:16 +13:00
|
|
|
* $fields->addFieldToTab(
|
|
|
|
* 'Root.Main',
|
|
|
|
* FieldGroup::create(
|
|
|
|
* TimeField::create("StartTime","What's the start time?"),
|
|
|
|
* TimeField::create("EndTime","What's the end time?")
|
|
|
|
* ),
|
|
|
|
* 'Content'
|
|
|
|
* );
|
2014-08-15 18:53:05 +12:00
|
|
|
*
|
2016-11-29 12:31:16 +13:00
|
|
|
* return $fields;
|
2014-08-15 18:53:05 +12:00
|
|
|
*
|
2010-10-15 03:55:22 +00:00
|
|
|
* }
|
|
|
|
* </code>
|
2013-07-26 16:01:24 +02:00
|
|
|
*
|
|
|
|
* <b>Setting a title to a FieldGroup</b>
|
2014-08-15 18:53:05 +12:00
|
|
|
*
|
2013-07-26 16:01:24 +02:00
|
|
|
* <code>
|
|
|
|
* $fields->addFieldToTab("Root.Main",
|
2016-11-29 12:31:16 +13:00
|
|
|
* FieldGroup::create(
|
|
|
|
* TimeField::create('StartTime','What's the start time?'),
|
|
|
|
* TimeField::create('EndTime', 'What's the end time?')
|
|
|
|
* )->setTitle('Time')
|
2013-07-26 16:01:24 +02:00
|
|
|
* );
|
|
|
|
* </code>
|
2007-07-19 10:40:28 +00:00
|
|
|
*/
|
2016-11-29 12:31:16 +13:00
|
|
|
class FieldGroup extends CompositeField
|
|
|
|
{
|
2017-07-03 12:21:27 +12:00
|
|
|
/** @skipUpgrade */
|
2016-12-12 15:25:18 +13:00
|
|
|
protected $schemaComponent = 'FieldGroup';
|
|
|
|
|
2016-11-29 12:31:16 +13:00
|
|
|
protected $zebra;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Create a new field group.
|
|
|
|
*
|
|
|
|
* Accepts any number of arguments.
|
|
|
|
*
|
|
|
|
* @param mixed $titleOrField Either the field title, list of fields, or first field
|
|
|
|
* @param mixed ...$otherFields Subsequent fields or field list (if passing in title to $titleOrField)
|
|
|
|
*/
|
|
|
|
public function __construct($titleOrField = null, $otherFields = null)
|
|
|
|
{
|
|
|
|
$title = null;
|
|
|
|
if (is_array($titleOrField) || $titleOrField instanceof FieldList) {
|
|
|
|
$fields = $titleOrField;
|
|
|
|
|
|
|
|
// This would be discarded otherwise
|
|
|
|
if ($otherFields) {
|
|
|
|
throw new InvalidArgumentException(
|
|
|
|
'$otherFields is not accepted if passing in field list to $titleOrField'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
} elseif (is_array($otherFields) || $otherFields instanceof FieldList) {
|
|
|
|
$title = $titleOrField;
|
|
|
|
$fields = $otherFields;
|
|
|
|
} else {
|
|
|
|
$fields = func_get_args();
|
|
|
|
if (!is_object(reset($fields))) {
|
|
|
|
$title = array_shift($fields);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
parent::__construct($fields);
|
|
|
|
|
|
|
|
if ($title) {
|
|
|
|
$this->setTitle($title);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the name (ID) for the element.
|
|
|
|
* In some cases the FieldGroup doesn't have a title, but we still want
|
|
|
|
* the ID / name to be set. This code, generates the ID from the nested children
|
|
|
|
*
|
|
|
|
* TODO this is temporary, and should be removed when FormTemplateHelper is updated to handle ID
|
|
|
|
* for CompositeFields with no name
|
|
|
|
*/
|
|
|
|
public function getName()
|
|
|
|
{
|
|
|
|
if ($this->name) {
|
|
|
|
return $this->name;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!$this->title) {
|
|
|
|
return parent::getName();
|
|
|
|
}
|
|
|
|
|
|
|
|
return preg_replace("/[^a-zA-Z0-9]+/", "", $this->title);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set an odd/even class
|
|
|
|
*
|
|
|
|
* @param string $zebra one of odd or even.
|
|
|
|
* @return $this
|
|
|
|
*/
|
|
|
|
public function setZebra($zebra)
|
|
|
|
{
|
|
|
|
if ($zebra == 'odd' || $zebra == 'even') {
|
|
|
|
$this->zebra = $zebra;
|
|
|
|
} else {
|
|
|
|
user_error("setZebra passed '$zebra'. It should be passed 'odd' or 'even'", E_USER_WARNING);
|
|
|
|
}
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getZebra()
|
|
|
|
{
|
|
|
|
return $this->zebra;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
2016-11-23 18:09:10 +13:00
|
|
|
public function getMessage()
|
2016-11-29 12:31:16 +13:00
|
|
|
{
|
2016-11-23 18:09:10 +13:00
|
|
|
$dataFields = array();
|
|
|
|
$this->collateDataFields($dataFields);
|
|
|
|
|
|
|
|
/** @var FormField $subfield */
|
|
|
|
$messages = [];
|
|
|
|
foreach ($dataFields as $subfield) {
|
|
|
|
$message = $subfield->obj('Message')->forTemplate();
|
|
|
|
if ($message) {
|
|
|
|
$messages[] = rtrim($message, ".");
|
2016-11-29 12:31:16 +13:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-11-23 18:09:10 +13:00
|
|
|
if (!$messages) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
return implode(", ", $messages) . ".";
|
2016-11-29 12:31:16 +13:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
2016-11-23 18:09:10 +13:00
|
|
|
public function getMessageType()
|
2016-11-29 12:31:16 +13:00
|
|
|
{
|
2016-11-23 18:09:10 +13:00
|
|
|
$dataFields = array();
|
|
|
|
$this->collateDataFields($dataFields);
|
|
|
|
|
|
|
|
/** @var FormField $subfield */
|
|
|
|
foreach ($dataFields as $subfield) {
|
|
|
|
$type = $subfield->getMessageType();
|
|
|
|
if ($type) {
|
|
|
|
return $type;
|
2016-11-29 12:31:16 +13:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-11-23 18:09:10 +13:00
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getMessageCast()
|
|
|
|
{
|
|
|
|
return ValidationResult::CAST_HTML;
|
2016-11-29 12:31:16 +13:00
|
|
|
}
|
2012-12-09 00:20:20 +13:00
|
|
|
}
|