2007-07-19 10:40:28 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Lets you include a nested group of fields inside a template.
|
|
|
|
* This control gives you more flexibility over form layout.
|
|
|
|
*
|
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.
|
2010-10-15 03:55:22 +00:00
|
|
|
*
|
|
|
|
* <b>Usage</b>
|
|
|
|
*
|
|
|
|
* <code>
|
|
|
|
* new FieldGroup(
|
|
|
|
* new FieldGroup(
|
|
|
|
* new HeaderField('FieldGroup 1'),
|
|
|
|
* new TextField('Firstname')
|
|
|
|
* ),
|
|
|
|
* new FieldGroup(
|
|
|
|
* new HeaderField('FieldGroup 2'),
|
|
|
|
* new TextField('Surname')
|
|
|
|
* )
|
|
|
|
* )
|
|
|
|
* </code>
|
|
|
|
*
|
|
|
|
* <b>Adding to existing FieldGroup instances</b>
|
|
|
|
*
|
|
|
|
* <code>
|
|
|
|
* function getCMSFields() {
|
|
|
|
* $fields = parent::getCMSFields();
|
|
|
|
*
|
|
|
|
* $fields->addFieldToTab(
|
2011-04-15 16:36:22 +12:00
|
|
|
* 'Root.Content',
|
2010-10-15 03:55:22 +00:00
|
|
|
* new FieldGroup(
|
|
|
|
* new TimeField("StartTime","What's the start time?"),
|
|
|
|
* new TimeField("EndTime","What's the end time?")
|
|
|
|
* ),
|
|
|
|
* 'Content'
|
|
|
|
* );
|
|
|
|
*
|
|
|
|
* return $fields;
|
|
|
|
*
|
|
|
|
* }
|
|
|
|
* </code>
|
|
|
|
*
|
2008-01-09 04:18:36 +00:00
|
|
|
* @package forms
|
|
|
|
* @subpackage fields-structural
|
2007-07-19 10:40:28 +00:00
|
|
|
*/
|
|
|
|
class FieldGroup extends CompositeField {
|
2012-04-14 09:47:17 +12:00
|
|
|
|
2007-07-19 10:40:28 +00:00
|
|
|
protected $zebra;
|
|
|
|
|
2012-09-19 12:07:39 +02:00
|
|
|
public function __construct($arg1 = null, $arg2 = null) {
|
2007-07-19 10:40:28 +00:00
|
|
|
if(is_array($arg1) || is_a($arg1, 'FieldSet')) {
|
|
|
|
$fields = $arg1;
|
|
|
|
|
2011-10-28 14:37:27 +13:00
|
|
|
} else if(is_array($arg2) || is_a($arg2, 'FieldList')) {
|
2007-07-19 10:40:28 +00:00
|
|
|
$this->title = $arg1;
|
|
|
|
$fields = $arg2;
|
|
|
|
|
|
|
|
} else {
|
|
|
|
$fields = func_get_args();
|
|
|
|
if(!is_object(reset($fields))) $this->title = array_shift($fields);
|
|
|
|
}
|
|
|
|
|
|
|
|
parent::__construct($fields);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 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
|
|
|
|
*/
|
2012-09-19 12:07:39 +02:00
|
|
|
public function Name(){
|
2007-07-19 10:40:28 +00:00
|
|
|
if(!$this->title) {
|
2011-10-29 17:09:12 +13:00
|
|
|
$fs = $this->FieldList();
|
2007-07-19 10:40:28 +00:00
|
|
|
$compositeTitle = '';
|
|
|
|
$count = 0;
|
|
|
|
foreach($fs as $subfield){
|
2011-10-29 13:07:40 +02:00
|
|
|
$compositeTitle .= $subfield->getName();
|
|
|
|
if($subfield->getName()) $count++;
|
2007-07-19 10:40:28 +00:00
|
|
|
}
|
|
|
|
if($count == 1) $compositeTitle .= 'Group';
|
2012-02-27 22:14:02 +01:00
|
|
|
return preg_replace("/[^a-zA-Z0-9]+/", "", $compositeTitle);
|
2007-07-19 10:40:28 +00:00
|
|
|
}
|
|
|
|
|
2012-02-27 22:14:02 +01:00
|
|
|
return preg_replace("/[^a-zA-Z0-9]+/", "", $this->title);
|
2007-07-19 10:40:28 +00:00
|
|
|
}
|
2012-02-27 22:14:02 +01:00
|
|
|
|
2007-07-19 10:40:28 +00:00
|
|
|
/**
|
|
|
|
* Set an odd/even class
|
2012-04-14 09:47:17 +12:00
|
|
|
*
|
|
|
|
* @param string $zebra one of odd or even.
|
2007-07-19 10:40:28 +00:00
|
|
|
*/
|
2012-12-09 00:20:20 +13:00
|
|
|
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;
|
|
|
|
}
|
|
|
|
|
2012-04-14 09:47:17 +12:00
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
2012-09-19 12:07:39 +02:00
|
|
|
public function getZebra() {
|
2012-04-14 09:47:17 +12:00
|
|
|
return $this->zebra;
|
2007-07-19 10:40:28 +00:00
|
|
|
}
|
|
|
|
|
2012-04-14 09:47:17 +12:00
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
2012-09-19 12:07:39 +02:00
|
|
|
public function Message() {
|
2011-10-29 17:09:12 +13:00
|
|
|
$fs = $this->FieldList();
|
2012-04-14 09:47:17 +12:00
|
|
|
|
2007-07-19 10:40:28 +00:00
|
|
|
foreach($fs as $subfield) {
|
|
|
|
if($m = $subfield->Message()) $message[] = $m;
|
|
|
|
}
|
2012-04-14 09:47:17 +12:00
|
|
|
|
|
|
|
return (isset($message)) ? implode(", ", $message) . ". " : "";
|
2007-07-19 10:40:28 +00:00
|
|
|
}
|
|
|
|
|
2012-04-14 09:47:17 +12:00
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
2012-09-19 12:07:39 +02:00
|
|
|
public function MessageType() {
|
2011-10-29 17:09:12 +13:00
|
|
|
$fs = $this->FieldList();
|
2012-04-14 09:47:17 +12:00
|
|
|
|
2007-07-19 10:40:28 +00:00
|
|
|
foreach($fs as $subfield) {
|
|
|
|
if($m = $subfield->MessageType()) $MessageType[] = $m;
|
|
|
|
}
|
2012-04-14 09:47:17 +12:00
|
|
|
|
|
|
|
return (isset($MessageType)) ? implode(". ", $MessageType) : "";
|
2007-07-19 10:40:28 +00:00
|
|
|
}
|
|
|
|
|
2012-09-19 12:07:39 +02:00
|
|
|
public function php($data) {
|
2007-07-19 10:40:28 +00:00
|
|
|
return;
|
2012-04-14 09:47:17 +12:00
|
|
|
}
|
2012-12-09 00:20:20 +13:00
|
|
|
}
|