2007-07-19 10:40:28 +00:00
|
|
|
<?php
|
|
|
|
/**
|
2012-06-26 15:03:11 +02:00
|
|
|
* SelectionGroup represents a number of fields which are selectable by a radio
|
2012-04-14 17:32:29 +12:00
|
|
|
* button that appears at the beginning of each item. Using CSS, you can
|
|
|
|
* configure the field to only display its contents if the corresponding radio
|
|
|
|
* button is selected.
|
|
|
|
*
|
2008-01-09 04:18:36 +00:00
|
|
|
* @package forms
|
|
|
|
* @subpackage fields-structural
|
2007-07-19 10:40:28 +00:00
|
|
|
*/
|
|
|
|
class SelectionGroup extends CompositeField {
|
2011-04-16 15:09:30 +12:00
|
|
|
|
2007-07-19 10:40:28 +00:00
|
|
|
/**
|
|
|
|
* Create a new selection group.
|
|
|
|
* @param name The field name of the selection group.
|
|
|
|
* @param items The list of items to show. This should be a map. The keys will be the radio
|
|
|
|
* button option names, and the values should be the associated field to display. If you want,
|
|
|
|
* you can make this field a composite field.
|
|
|
|
*
|
|
|
|
* If you want to a have a title that is different from the value of the key, you can express it
|
|
|
|
* as "InternalVal//This is the Title"
|
|
|
|
*/
|
2012-09-19 12:07:39 +02:00
|
|
|
public function __construct($name, $items) {
|
2007-07-19 10:40:28 +00:00
|
|
|
$this->name = $name;
|
2007-09-27 20:56:55 +00:00
|
|
|
|
2007-07-19 10:40:28 +00:00
|
|
|
parent::__construct($items);
|
2007-09-27 20:56:55 +00:00
|
|
|
|
2012-03-24 16:38:57 +13:00
|
|
|
Requirements::css(FRAMEWORK_DIR . '/css/SelectionGroup.css');
|
2007-07-19 10:40:28 +00:00
|
|
|
}
|
2011-12-22 12:38:51 +01:00
|
|
|
|
2012-09-19 12:07:39 +02:00
|
|
|
public function FieldSet() {
|
2011-12-22 12:38:51 +01:00
|
|
|
return $this->FieldList();
|
|
|
|
}
|
|
|
|
|
2012-09-19 12:07:39 +02:00
|
|
|
public function FieldList() {
|
2011-12-22 12:38:51 +01:00
|
|
|
$items = parent::FieldList()->toArray();
|
2008-01-22 03:51:24 +00:00
|
|
|
|
2007-07-19 10:40:28 +00:00
|
|
|
$count = 0;
|
2008-01-22 03:51:24 +00:00
|
|
|
$firstSelected = $checked ="";
|
2012-08-10 18:53:33 +12:00
|
|
|
$newItems = array();
|
|
|
|
|
2007-07-19 10:40:28 +00:00
|
|
|
foreach($items as $key => $item) {
|
|
|
|
if(strpos($key,'//') !== false) {
|
|
|
|
list($key,$title) = explode('//', $key,2);
|
|
|
|
} else {
|
|
|
|
$title = $key;
|
|
|
|
}
|
|
|
|
if($this->value == $key) {
|
|
|
|
$firstSelected = " class=\"selected\"";
|
|
|
|
$checked = " checked=\"checked\"";
|
|
|
|
}
|
|
|
|
|
|
|
|
$itemID = $this->ID() . '_' . (++$count);
|
|
|
|
$extra = array(
|
2012-09-27 09:34:00 +12:00
|
|
|
"RadioButton" => "<input class=\"selector\" type=\"radio\" id=\"$itemID\" name=\"$this->name\""
|
|
|
|
. " value=\"$key\"$checked />",
|
2007-07-19 10:40:28 +00:00
|
|
|
"RadioLabel" => "<label for=\"$itemID\">$title</label>",
|
|
|
|
"Selected" => $firstSelected,
|
|
|
|
);
|
|
|
|
if(is_object($item)) $newItems[] = $item->customise($extra);
|
|
|
|
else $newItems[] = new ArrayData($extra);
|
|
|
|
|
2012-04-12 12:24:06 +12:00
|
|
|
$firstSelected = $checked ="";
|
2007-07-19 10:40:28 +00:00
|
|
|
}
|
2012-04-14 17:32:29 +12:00
|
|
|
|
2011-05-05 20:40:24 +10:00
|
|
|
return new ArrayList($newItems);
|
2007-07-19 10:40:28 +00:00
|
|
|
}
|
|
|
|
|
2012-09-19 12:07:39 +02:00
|
|
|
public function hasData() {
|
2007-07-19 10:40:28 +00:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2012-09-19 12:07:39 +02:00
|
|
|
public function FieldHolder($properties = array()) {
|
2009-12-13 05:22:31 +00:00
|
|
|
Requirements::javascript(THIRDPARTY_DIR .'/jquery/jquery.js');
|
2012-03-24 16:38:57 +13:00
|
|
|
Requirements::javascript(FRAMEWORK_DIR . '/javascript/SelectionGroup.js');
|
|
|
|
Requirements::css(FRAMEWORK_DIR . '/css/SelectionGroup.css');
|
2012-04-11 18:07:55 +12:00
|
|
|
|
|
|
|
$obj = $properties ? $this->customise($properties) : $this;
|
2012-04-14 22:08:00 +12:00
|
|
|
|
|
|
|
return $obj->renderWith($this->getTemplates());
|
2007-07-19 10:40:28 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|