123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173 |
- <?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);");
- }
- }
|