You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
88 lines
3.2 KiB
88 lines
3.2 KiB
<?php |
|
/** |
|
* @link http://www.yiiframework.com/ |
|
* @copyright Copyright (c) 2008 Yii Software LLC |
|
* @license http://www.yiiframework.com/license/ |
|
*/ |
|
|
|
namespace yii\bootstrap; |
|
|
|
use yii\helpers\ArrayHelper; |
|
|
|
/** |
|
* BaseHtml provides concrete implementation for [[Html]]. |
|
* |
|
* Do not use BaseHtml. Use [[Html]] instead. |
|
* |
|
* @author Paul Klimov <klimov.paul@gmail.com> |
|
* @since 2.0.5 |
|
*/ |
|
class BaseHtml extends \yii\helpers\Html |
|
{ |
|
/** |
|
* Composes icon HTML for bootstrap Glyphicons. |
|
* @param string $name icon short name, for example: 'star' |
|
* @param array $options the tag options in terms of name-value pairs. These will be rendered as |
|
* the attributes of the resulting tag. There are also a special options: |
|
* |
|
* - tag: string, tag to be rendered, by default 'span' is used. |
|
* - prefix: string, prefix which should be used to compose tag class, by default 'glyphicon glyphicon-' is used. |
|
* |
|
* @return string icon HTML. |
|
* @see http://getbootstrap.com/components/#glyphicons |
|
*/ |
|
public static function icon($name, $options = []) |
|
{ |
|
$tag = ArrayHelper::remove($options, 'tag', 'span'); |
|
$classPrefix = ArrayHelper::remove($options, 'prefix', 'glyphicon glyphicon-'); |
|
static::addCssClass($options, $classPrefix . $name); |
|
return static::tag($tag, '', $options); |
|
} |
|
|
|
/** |
|
* Renders Bootstrap static form control. |
|
* |
|
* By default value will be HTML-encoded using [[encode()]], you may control this behavior |
|
* via 'encode' option. |
|
* @param string $value static control value. |
|
* @param array $options the tag options in terms of name-value pairs. These will be rendered as |
|
* the attributes of the resulting tag. There are also a special options: |
|
* |
|
* - encode: boolean, whether value should be HTML-encoded or not. |
|
* |
|
* @return string generated HTML |
|
* @see http://getbootstrap.com/css/#forms-controls-static |
|
*/ |
|
public static function staticControl($value, $options = []) |
|
{ |
|
static::addCssClass($options, 'form-control-static'); |
|
$value = (string) $value; |
|
if (isset($options['encode'])) { |
|
$encode = $options['encode']; |
|
unset($options['encode']); |
|
} else { |
|
$encode = true; |
|
} |
|
return static::tag('p', $encode ? static::encode($value) : $value, $options); |
|
} |
|
|
|
/** |
|
* Generates a Bootstrap static form control for the given model attribute. |
|
* @param \yii\base\Model $model the model object. |
|
* @param string $attribute the attribute name or expression. See [[getAttributeName()]] for the format |
|
* about attribute expression. |
|
* @param array $options the tag options in terms of name-value pairs. See [[staticControl()]] for details. |
|
* @return string generated HTML |
|
* @see staticControl() |
|
*/ |
|
public static function activeStaticControl($model, $attribute, $options = []) |
|
{ |
|
if (isset($options['value'])) { |
|
$value = $options['value']; |
|
unset($options['value']); |
|
} else { |
|
$value = static::getAttributeValue($model, $attribute); |
|
} |
|
return static::staticControl($value, $options); |
|
} |
|
}
|
|
|