86 lines
2.1 KiB
PHP
Raw Permalink Normal View History

<?php
/**
* Implements a single tab in a {@link TabSet}.
2014-08-15 18:53:05 +12:00
*
* 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.
2014-08-15 18:53:05 +12:00
*
* <code>
* new Tab(
* $title='Tab one',
* new HeaderField("A header"),
* new LiteralField("Lipsum","Lorem ipsum dolor sit amet enim.")
* )
* </code>
2014-08-15 18:53:05 +12:00
*
* @package forms
* @subpackage fields-structural
*/
class Tab extends CompositeField {
protected $tabSet;
2014-08-15 18:53:05 +12:00
/**
* @uses FormField::name_to_label()
2014-08-15 18:53:05 +12:00
*
* @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();
2014-08-15 18:53:05 +12:00
$name = array_shift($args);
if(!is_string($name)) user_error('TabSet::__construct(): $name parameter to a valid string', E_USER_ERROR);
$this->name = $name;
2014-08-15 18:53:05 +12:00
$this->id = preg_replace('/[^0-9A-Za-z]+/', '', $name);
2014-08-15 18:53:05 +12:00
// 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);
2014-08-15 18:53:05 +12:00
parent::__construct($args);
}
2014-08-15 18:53:05 +12:00
public function id() {
return ($this->tabSet) ? $this->tabSet->id() . '_' . $this->id : $this->id;
}
2014-08-15 18:53:05 +12:00
public function Fields() {
return $this->children;
}
2014-08-15 18:53:05 +12:00
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()
)
);
}
}