| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172 | 
							- <?php
 
- /**
 
-  * @link http://www.yiiframework.com/
 
-  * @copyright Copyright (c) 2008 Yii Software LLC
 
-  * @license http://www.yiiframework.com/license/
 
-  */
 
- namespace yii\grid;
 
- use Closure;
 
- use yii\base\InvalidConfigException;
 
- use yii\helpers\Html;
 
- use yii\helpers\Json;
 
- /**
 
-  * CheckboxColumn displays a column of checkboxes in a grid view.
 
-  *
 
-  * To add a CheckboxColumn to the [[GridView]], add it to the [[GridView::columns|columns]] configuration as follows:
 
-  *
 
-  * ```php
 
-  * 'columns' => [
 
-  *     // ...
 
-  *     [
 
-  *         'class' => 'yii\grid\CheckboxColumn',
 
-  *         // you may configure additional properties here
 
-  *     ],
 
-  * ]
 
-  * ```
 
-  *
 
-  * Users may click on the checkboxes to select rows of the grid. The selected rows may be
 
-  * obtained by calling the following JavaScript code:
 
-  *
 
-  * ```javascript
 
-  * var keys = $('#grid').yiiGridView('getSelectedRows');
 
-  * // keys is an array consisting of the keys associated with the selected rows
 
-  * ```
 
-  *
 
-  * For more details and usage information on CheckboxColumn, see the [guide article on data widgets](guide:output-data-widgets).
 
-  *
 
-  * @author Qiang Xue <qiang.xue@gmail.com>
 
-  * @since 2.0
 
-  */
 
- class CheckboxColumn extends Column
 
- {
 
-     /**
 
-      * @var string the name of the input checkbox input fields. This will be appended with `[]` to ensure it is an array.
 
-      */
 
-     public $name = 'selection';
 
-     /**
 
-      * @var array|\Closure the HTML attributes for checkboxes. This can either be an array of
 
-      * attributes or an anonymous function ([[Closure]]) that returns such an array.
 
-      * The signature of the function should be the following: `function ($model, $key, $index, $column)`.
 
-      * Where `$model`, `$key`, and `$index` refer to the model, key and index of the row currently being rendered
 
-      * and `$column` is a reference to the [[CheckboxColumn]] object.
 
-      * A function may be used to assign different attributes to different rows based on the data in that row.
 
-      * Specifically if you want to set a different value for the checkbox
 
-      * you can use this option in the following way (in this example using the `name` attribute of the model):
 
-      *
 
-      * ```php
 
-      * 'checkboxOptions' => function ($model, $key, $index, $column) {
 
-      *     return ['value' => $model->name];
 
-      * }
 
-      * ```
 
-      *
 
-      * @see \yii\helpers\Html::renderTagAttributes() for details on how attributes are being rendered.
 
-      */
 
-     public $checkboxOptions = [];
 
-     /**
 
-      * @var bool whether it is possible to select multiple rows. Defaults to `true`.
 
-      */
 
-     public $multiple = true;
 
-     /**
 
-      * @var string the css class that will be used to find the checkboxes.
 
-      * @since 2.0.9
 
-      */
 
-     public $cssClass;
 
-     /**
 
-      * {@inheritdoc}
 
-      * @throws \yii\base\InvalidConfigException if [[name]] is not set.
 
-      */
 
-     public function init()
 
-     {
 
-         parent::init();
 
-         if (empty($this->name)) {
 
-             throw new InvalidConfigException('The "name" property must be set.');
 
-         }
 
-         if (substr_compare($this->name, '[]', -2, 2)) {
 
-             $this->name .= '[]';
 
-         }
 
-         $this->registerClientScript();
 
-     }
 
-     /**
 
-      * Renders the header cell content.
 
-      * The default implementation simply renders [[header]].
 
-      * This method may be overridden to customize the rendering of the header cell.
 
-      * @return string the rendering result
 
-      */
 
-     protected function renderHeaderCellContent()
 
-     {
 
-         if ($this->header !== null || !$this->multiple) {
 
-             return parent::renderHeaderCellContent();
 
-         }
 
-         return Html::checkbox($this->getHeaderCheckBoxName(), false, ['class' => 'select-on-check-all']);
 
-     }
 
-     /**
 
-      * {@inheritdoc}
 
-      */
 
-     protected function renderDataCellContent($model, $key, $index)
 
-     {
 
-         if ($this->content !== null) {
 
-             return parent::renderDataCellContent($model, $key, $index);
 
-         }
 
-         if ($this->checkboxOptions instanceof Closure) {
 
-             $options = call_user_func($this->checkboxOptions, $model, $key, $index, $this);
 
-         } else {
 
-             $options = $this->checkboxOptions;
 
-         }
 
-         if (!isset($options['value'])) {
 
-             $options['value'] = is_array($key) ? Json::encode($key) : $key;
 
-         }
 
-         if ($this->cssClass !== null) {
 
-             Html::addCssClass($options, $this->cssClass);
 
-         }
 
-         return Html::checkbox($this->name, !empty($options['checked']), $options);
 
-     }
 
-     /**
 
-      * Returns header checkbox name.
 
-      * @return string header checkbox name
 
-      * @since 2.0.8
 
-      */
 
-     protected function getHeaderCheckBoxName()
 
-     {
 
-         $name = $this->name;
 
-         if (substr_compare($name, '[]', -2, 2) === 0) {
 
-             $name = substr($name, 0, -2);
 
-         }
 
-         if (substr_compare($name, ']', -1, 1) === 0) {
 
-             $name = substr($name, 0, -1) . '_all]';
 
-         } else {
 
-             $name .= '_all';
 
-         }
 
-         return $name;
 
-     }
 
-     /**
 
-      * Registers the needed JavaScript.
 
-      * @since 2.0.8
 
-      */
 
-     public function registerClientScript()
 
-     {
 
-         $id = $this->grid->options['id'];
 
-         $options = Json::encode([
 
-             'name' => $this->name,
 
-             'class' => $this->cssClass,
 
-             'multiple' => $this->multiple,
 
-             'checkAll' => $this->grid->showHeader ? $this->getHeaderCheckBoxName() : null,
 
-         ]);
 
-         $this->grid->getView()->registerJs("jQuery('#$id').yiiGridView('setSelectionColumn', $options);");
 
-     }
 
- }
 
 
  |