/
BootBadge.php
70 lines (62 loc) · 1.66 KB
/
BootBadge.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
<?php
/**
* BootBadge class file.
* @author Christoffer Niska <ChristofferNiska@gmail.com>
* @copyright Copyright © Christoffer Niska 2011-
* @license http://www.opensource.org/licenses/bsd-license.php New BSD License
* @package bootstrap.widgets
*/
/**
* Bootstrap badge widget.
*/
class BootBadge extends CWidget
{
// Badge types.
const TYPE_DEFAULT = '';
const TYPE_SUCCESS = 'success';
const TYPE_WARNING = 'warning';
const TYPE_ERROR = 'error';
const TYPE_INFO = 'info';
const TYPE_INVERSE = 'inverse';
/**
* @var string the badge type (defaults to '').
* Valid types are '', 'success', 'warning', 'error', 'info' and 'inverse'.
*/
public $type = self::TYPE_DEFAULT;
/**
* @var string the badge text.
*/
public $label;
/**
* @var boolean whether to encode the label.
*/
public $encodeLabel = true;
/**
* @var array the HTML attributes for the widget container.
*/
public $htmlOptions = array();
/**
* Initializes the widget.
*/
public function init()
{
$classes = array('badge');
$validTypes = array(self::TYPE_SUCCESS, self::TYPE_WARNING, self::TYPE_ERROR, self::TYPE_INFO, self::TYPE_INVERSE);
if (in_array($this->type, $validTypes))
$classes[] = 'badge-'.$this->type;
$classes = implode(' ', $classes);
if (isset($this->htmlOptions['class']))
$this->htmlOptions['class'] .= ' '.$classes;
else
$this->htmlOptions['class'] = $classes;
if ($this->encodeLabel === true)
$this->label = CHtml::encode($this->label);
}
/**
* Runs the widget.
*/
public function run()
{
echo CHtml::tag('span', $this->htmlOptions, $this->label);
}
}