<?php /** * Implements a single tab in a {@link TabSet}. * * Here is a simple implementation of a Tab. Obviously, you can include as much fields * inside as you want. A tab can contain other tabs as well. * * <code> * new Tab( * $title='Tab one', * new HeaderField("A header"), * new LiteralField("Lipsum","Lorem ipsum dolor sit amet enim.") * ) * </code> * * @package forms * @subpackage fields-structural */ class Tab extends CompositeField { protected $tabSet; /** * @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 */ 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 = 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); parent::__construct($args); } public function id() { return ($this->tabSet) ? $this->tabSet->id() . '_' . $this->id : $this->id; } public function Fields() { return $this->children; } public function setTabSet($val) { $this->tabSet = $val; return $this; } /** * Returns the named field */ public function fieldByName($name) { foreach($this->children as $child) { if($name == $child->getName()) return $child; } } public function extraClass() { return implode(' ', (array)$this->extraClasses); } public function getAttributes() { return array_merge( $this->attributes, array( 'id' => $this->id(), 'class' => 'tab ' . $this->extraClass() ) ); } }