2007-07-19 10:40:28 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Defines a set of tabs in a form.
|
2010-10-15 03:55:22 +00:00
|
|
|
* The tabs are build with our standard tabstrip javascript library.
|
|
|
|
* By default, the HTML is generated using FieldHolder.
|
|
|
|
*
|
|
|
|
* <b>Usage</b>
|
|
|
|
*
|
|
|
|
* <code>
|
|
|
|
* new TabSet(
|
|
|
|
* $name = "TheTabSetName",
|
|
|
|
* new Tab(
|
|
|
|
* $title='Tab one',
|
|
|
|
* new HeaderField("A header"),
|
|
|
|
* new LiteralField("Lipsum","Lorem ipsum dolor sit amet enim.")
|
|
|
|
* ),
|
|
|
|
* new Tab(
|
|
|
|
* $title='Tab two',
|
|
|
|
* new HeaderField("A second header"),
|
|
|
|
* new LiteralField("Lipsum","Ipsum dolor sit amet enim.")
|
|
|
|
* )
|
|
|
|
* )
|
|
|
|
* </code>
|
|
|
|
*
|
2008-01-09 04:18:36 +00:00
|
|
|
* @package forms
|
|
|
|
* @subpackage fields-structural
|
2007-07-19 10:40:28 +00:00
|
|
|
*/
|
|
|
|
class TabSet extends CompositeField {
|
2008-10-10 16:00:50 +00:00
|
|
|
|
2011-04-16 15:09:30 +12:00
|
|
|
protected $template = "TabSetFieldHolder";
|
|
|
|
|
2008-10-10 16:00:50 +00:00
|
|
|
/**
|
|
|
|
* @param string $name Identifier
|
|
|
|
* @param string $title (Optional) Natural language title of the tabset
|
|
|
|
* @param Tab|TabSet $unknown All further parameters are inserted as children into the TabSet
|
|
|
|
*/
|
|
|
|
public function __construct($name) {
|
|
|
|
$args = func_get_args();
|
|
|
|
|
|
|
|
$name = array_shift($args);
|
|
|
|
if(!is_string($name)) user_error('TabSet::__construct(): $name parameter to a valid string', E_USER_ERROR);
|
|
|
|
$this->name = $name;
|
|
|
|
|
|
|
|
$this->id = $name;
|
|
|
|
|
|
|
|
// Legacy handling: only assume second parameter as title if its a string,
|
|
|
|
// otherwise it might be a formfield instance
|
|
|
|
if(isset($args[0]) && is_string($args[0])) {
|
|
|
|
$title = array_shift($args);
|
|
|
|
}
|
|
|
|
$this->title = (isset($title)) ? $title : FormField::name_to_label($name);
|
2007-07-19 10:40:28 +00:00
|
|
|
|
2008-10-10 16:00:50 +00:00
|
|
|
if($args) foreach($args as $tab) {
|
|
|
|
$isValidArg = (is_object($tab) && (!($tab instanceof Tab) || !($tab instanceof TabSet)));
|
|
|
|
if(!$isValidArg) user_error('TabSet::__construct(): Parameter not a valid Tab instance', E_USER_ERROR);
|
|
|
|
|
|
|
|
$tab->setTabSet($this);
|
|
|
|
}
|
2007-07-19 10:40:28 +00:00
|
|
|
|
2008-10-10 16:00:50 +00:00
|
|
|
parent::__construct($args);
|
2007-07-19 10:40:28 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public function id() {
|
|
|
|
if($this->tabSet) return $this->tabSet->id() . '_' . $this->id . '_set';
|
|
|
|
else return $this->id;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns a tab-strip and the associated tabs.
|
|
|
|
* The HTML is a standardised format, containing a <ul;
|
|
|
|
*/
|
2012-04-11 18:07:55 +12:00
|
|
|
public function FieldHolder($properties = array()) {
|
2009-11-21 02:29:59 +00:00
|
|
|
Requirements::javascript(SAPPHIRE_DIR . '/thirdparty/jquery/jquery.js');
|
2011-02-24 17:07:24 +13:00
|
|
|
Requirements::javascript(SAPPHIRE_DIR . '/thirdparty/jquery-ui/jquery-ui.js');
|
2009-11-21 02:30:21 +00:00
|
|
|
Requirements::javascript(SAPPHIRE_DIR . '/thirdparty/jquery-cookie/jquery.cookie.js');
|
2009-11-21 02:22:49 +00:00
|
|
|
|
2011-04-25 21:24:55 +12:00
|
|
|
Requirements::css(SAPPHIRE_DIR . '/thirdparty/jquery-ui-themes/smoothness/jquery.ui.css');
|
2007-07-19 10:40:28 +00:00
|
|
|
|
2010-04-13 05:45:29 +00:00
|
|
|
Requirements::javascript(SAPPHIRE_DIR . '/thirdparty/jquery-entwine/dist/jquery.entwine-dist.js');
|
2009-11-21 02:22:52 +00:00
|
|
|
|
2009-11-21 02:22:49 +00:00
|
|
|
Requirements::javascript(SAPPHIRE_DIR . '/javascript/TabSet.js');
|
|
|
|
|
2012-04-11 18:07:55 +12:00
|
|
|
$obj = $properties ? $this->customise($properties) : $this;
|
|
|
|
return $obj->renderWith($this->template);
|
2007-07-19 10:40:28 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return a dataobject set of all this classes tabs
|
|
|
|
*/
|
|
|
|
public function Tabs() {
|
|
|
|
return $this->children;
|
|
|
|
}
|
|
|
|
public function setTabs($children){
|
|
|
|
$this->children = $children;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function setTabSet($val) {
|
|
|
|
$this->tabSet = $val;
|
2012-02-17 13:35:26 +01:00
|
|
|
return $this;
|
2007-07-19 10:40:28 +00:00
|
|
|
}
|
2012-02-17 13:35:26 +01:00
|
|
|
|
2007-07-19 10:40:28 +00:00
|
|
|
public function getTabSet() {
|
2008-04-01 01:50:34 +00:00
|
|
|
if(isset($this->tabSet)) return $this->tabSet;
|
2007-07-19 10:40:28 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the named tab
|
|
|
|
*/
|
|
|
|
public function fieldByName($name) {
|
2009-07-06 21:53:50 +00:00
|
|
|
if(strpos($name,'.') !== false) list($name, $remainder) = explode('.',$name,2);
|
|
|
|
else $remainder = null;
|
|
|
|
|
2007-07-19 10:40:28 +00:00
|
|
|
foreach($this->children as $child) {
|
2009-07-06 21:53:50 +00:00
|
|
|
if(trim($name) == trim($child->Name) || $name == $child->id) {
|
|
|
|
if($remainder) {
|
|
|
|
if($child->isComposite()) {
|
|
|
|
return $child->fieldByName($remainder);
|
|
|
|
} else {
|
|
|
|
user_error("Trying to get field '$remainder' from non-composite field $child->class.$name", E_USER_WARNING);
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
return $child;
|
|
|
|
}
|
|
|
|
}
|
2007-07-19 10:40:28 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add a new child field to the end of the set.
|
|
|
|
*/
|
2012-04-12 12:11:53 +12:00
|
|
|
public function push(FormField $field) {
|
2007-07-19 10:40:28 +00:00
|
|
|
parent::push($field);
|
|
|
|
$field->setTabSet($this);
|
|
|
|
}
|
2008-11-11 02:35:54 +00:00
|
|
|
|
|
|
|
/**
|
2011-10-28 14:37:27 +13:00
|
|
|
* Inserts a field before a particular field in a FieldList.
|
2008-11-11 02:35:54 +00:00
|
|
|
*
|
|
|
|
* @param FormField $item The form field to insert
|
|
|
|
* @param string $name Name of the field to insert before
|
|
|
|
*/
|
2007-07-19 10:40:28 +00:00
|
|
|
public function insertBefore($field, $insertBefore) {
|
|
|
|
parent::insertBefore($field, $insertBefore);
|
2008-11-11 02:35:54 +00:00
|
|
|
if($field instanceof Tab) $field->setTabSet($this);
|
|
|
|
$this->sequentialSet = null;
|
2007-07-19 10:40:28 +00:00
|
|
|
}
|
|
|
|
|
2008-11-11 02:35:54 +00:00
|
|
|
public function insertAfter($field, $insertAfter) {
|
|
|
|
parent::insertAfter($field, $insertAfter);
|
|
|
|
if($field instanceof Tab) $field->setTabSet($this);
|
|
|
|
$this->sequentialSet = null;
|
2007-09-16 16:05:59 +00:00
|
|
|
}
|
|
|
|
|
2008-09-12 04:42:24 +00:00
|
|
|
public function removeByName( $tabName, $dataFieldOnly = false ) {
|
|
|
|
parent::removeByName( $tabName, $dataFieldOnly );
|
2007-07-19 10:40:28 +00:00
|
|
|
}
|
2012-04-12 12:11:53 +12:00
|
|
|
}
|