2007-07-19 10:40:28 +00:00
|
|
|
<?php
|
|
|
|
/**
|
2008-01-09 04:18:36 +00:00
|
|
|
* Implements a single tab in a {@link TabSet}.
|
|
|
|
* @package forms
|
|
|
|
* @subpackage fields-structural
|
2007-07-19 10:40:28 +00:00
|
|
|
*/
|
|
|
|
class Tab extends CompositeField {
|
|
|
|
protected $tabSet;
|
|
|
|
|
2008-10-10 16:00:50 +00:00
|
|
|
/**
|
|
|
|
* @uses FormField::name_to_label()
|
|
|
|
*
|
|
|
|
* @param string $name Identifier of the tab, without characters like dots or spaces
|
|
|
|
* @param string $title Natural language title of the tab. If its left out,
|
|
|
|
* the class uses {@link FormField::name_to_label()} to produce a title from the {@link $name} parameter.
|
|
|
|
* @param FormField All following parameters are inserted as children to this tab
|
|
|
|
*/
|
2008-08-09 05:57:44 +00:00
|
|
|
public function __construct($name) {
|
2007-07-19 10:40:28 +00:00
|
|
|
$args = func_get_args();
|
2008-10-10 16:00:50 +00:00
|
|
|
|
2008-08-09 05:57:44 +00:00
|
|
|
$name = array_shift($args);
|
2008-10-10 16:00:50 +00:00
|
|
|
if(!is_string($name)) user_error('TabSet::__construct(): $name parameter to a valid string', E_USER_ERROR);
|
2008-08-09 05:57:44 +00:00
|
|
|
$this->name = $name;
|
2007-07-19 10:40:28 +00:00
|
|
|
|
2008-10-10 16:00:50 +00:00
|
|
|
$this->id = preg_replace('/[^0-9A-Za-z]+/', '', $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
|
|
|
parent::__construct($args);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function id() {
|
|
|
|
return $this->tabSet->id() . '_' . $this->id;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function Fields() {
|
|
|
|
return $this->children;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function setTabSet($val) {
|
|
|
|
$this->tabSet = $val;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the named field
|
|
|
|
*/
|
|
|
|
public function fieldByName($name) {
|
|
|
|
foreach($this->children as $child) {
|
2008-06-13 01:56:29 +00:00
|
|
|
if($name == $child->Name()) return $child;
|
2007-07-19 10:40:28 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
?>
|