2007-07-19 10:40:28 +00:00
|
|
|
<?php
|
|
|
|
|
2008-01-09 04:18:36 +00:00
|
|
|
/**
|
|
|
|
* @package forms
|
|
|
|
* @subpackage fields-structural
|
|
|
|
*/
|
|
|
|
|
2007-07-19 10:40:28 +00:00
|
|
|
/**
|
|
|
|
* SelectionGroup represents a number of fields that are selectable by a radio 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 {
|
|
|
|
/**
|
|
|
|
* 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"
|
|
|
|
*/
|
|
|
|
function __construct($name, $items) {
|
|
|
|
$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
|
|
|
|
|
|
|
Requirements::css('sapphire/css/SelectionGroup.css');
|
2007-07-19 10:40:28 +00:00
|
|
|
}
|
|
|
|
|
2007-11-23 01:10:19 +00:00
|
|
|
/**
|
|
|
|
* Return a readonly version of this field. Keeps the composition but returns readonly
|
|
|
|
* versions of all the children
|
|
|
|
*/
|
|
|
|
public function performDisabledTransformation($trans) {
|
|
|
|
$newChildren = array();
|
|
|
|
if($this->children) foreach($this->children as $idx => $child) {
|
|
|
|
if(is_object($child)) {
|
|
|
|
$child = $child->transform($trans);
|
|
|
|
}
|
|
|
|
$newChildren[$idx] = $child;
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->children = new FieldSet($newChildren);
|
|
|
|
$this->readonly = true;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2007-07-19 10:40:28 +00:00
|
|
|
function FieldSet() {
|
|
|
|
$items = parent::FieldSet()->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 ="";
|
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(
|
|
|
|
"RadioButton" => "<input class=\"selector\" type=\"radio\" id=\"$itemID\" name=\"$this->name\" value=\"$key\"$checked />",
|
|
|
|
"RadioLabel" => "<label for=\"$itemID\">$title</label>",
|
|
|
|
"Selected" => $firstSelected,
|
|
|
|
);
|
|
|
|
if(is_object($item)) $newItems[] = $item->customise($extra);
|
|
|
|
else $newItems[] = new ArrayData($extra);
|
|
|
|
|
|
|
|
$firstSelected = $checked ="";
|
|
|
|
}
|
|
|
|
return new DataObjectSet($newItems);
|
|
|
|
}
|
|
|
|
|
|
|
|
function hasData() {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
function FieldHolder() {
|
|
|
|
Requirements::javascript('jsparty/prototype.js');
|
|
|
|
Requirements::javascript('jsparty/behaviour.js');
|
|
|
|
Requirements::javascript('jsparty/prototype_improvements.js');
|
|
|
|
Requirements::javascript('sapphire/javascript/SelectionGroup.js');
|
|
|
|
|
|
|
|
|
|
|
|
return $this->renderWith("SelectionGroup");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
?>
|