<?php
/**
 * Field that generates a heading tag.
 *
 * This can be used to add extra text in your forms.
 *
 * @package forms
 * @subpackage fields-dataless
 */
class HeaderField extends DatalessField {
	
	/**
	 * @var int $headingLevel The level of the <h1> to <h6> HTML tag. Default: 2
	 */
	protected $headingLevel = 2;
	
	function __construct($name, $title = null, $headingLevel = 2) {
		// legacy handling for old parameters: $title, $heading, ...
		// instead of new handling: $name, $title, $heading, ...
		$args = func_get_args();
		if(!isset($args[1]) || is_numeric($args[1])) {
			$title = (isset($args[0])) ? $args[0] : null;
			// Use "HeaderField(title)" as the default field name for a HeaderField; if it's just set to title then we risk
			// causing accidental duplicate-field creation.
			$name = 'HeaderField' . $title; // this means i18nized fields won't be easily accessible through fieldByName()
			$headingLevel = (isset($args[1])) ? $args[1] : null;
			$form = (isset($args[3])) ? $args[3] : null;
		} 
		
		if($headingLevel) $this->headingLevel = $headingLevel;
		
		parent::__construct($name, $title);
	}

	public function getHeadingLevel() {
		return $this->headingLevel;
	}
	
	public function setHeadingLevel($level) {
		$this->headingLevel = $level;
	}

	function getAttributes() {
		return array_merge(
			array(
				'id' => $this->ID(),
				'class' => $this->extraClass()
			),
			$this->attributes
		);
	}

	function Type() {
		return null;
	}

}