silverstripe-framework/forms/HeaderField.php

60 lines
1.5 KiB
PHP
Raw Normal View History

<?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 {
2014-08-15 18:53:05 +12:00
/**
* @var int $headingLevel The level of the <h1> to <h6> HTML tag. Default: 2
*/
protected $headingLevel = 2;
2014-08-15 18:53:05 +12:00
public 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.
// this means i18nized fields won't be easily accessible through fieldByName()
$name = 'HeaderField' . $title;
$headingLevel = (isset($args[1])) ? $args[1] : null;
$form = (isset($args[3])) ? $args[3] : null;
2014-08-15 18:53:05 +12:00
}
if($headingLevel) $this->headingLevel = $headingLevel;
2014-08-15 18:53:05 +12:00
parent::__construct($name, $title);
}
public function getHeadingLevel() {
return $this->headingLevel;
}
2014-08-15 18:53:05 +12:00
public function setHeadingLevel($level) {
$this->headingLevel = $level;
return $this;
}
public function getAttributes() {
return array_merge(
array(
'id' => $this->ID(),
'class' => $this->extraClass()
),
$this->attributes
);
}
public function Type() {
return null;
}
}