Blame view

vendor/yiisoft/yii2-bootstrap/BaseHtml.php 3.16 KB
abf1649b   andryeyev   Чистая установка ...
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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
  <?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);
      }
  }