I have a gridview which contains a checkbox column and also uses pagination. When I check some checkboxes in the first page and navigate to the second page and check another one in the second page, the options I checked in the first page is not retained there. Is it posssible to retain the checkbox values during pagination?
Code for Gridview is
$widget = $this->widget('zii.widgets.grid.CGridView', array(
'dataProvider' => $model->search(),
'cssFile' => Yii::app()->baseUrl . '/media/js/admin/css/admingridview.css',
//'filter' => $model,
'ajaxUpdate' => true,
'enablePagination' => true,
'columns' => array(
array(
'name' => 'id',
'header' => '#',
'value' => '$this->grid->dataProvider->pagination->currentPage * $this->grid->dataProvider->pagination->pageSize + ($row+1)',
),
array(
'class' => 'CCheckBoxColumn',
'selectableRows' => '2',
'header' => 'Selected',
),
array(
'name' => 'fb_user_id',
'header' => 'FaceBook Id',
'value' => 'CHtml::encode($data->fb_user_id)',
),
array(
'name' => 'first_name',
'header' => 'Name',
'value' => 'CHtml::encode($data->first_name)',
),
array(
'name' => 'email_id',
'header' => 'Email',
'value' => 'CHtml::encode($data->email_id)',
),
array(
'name' => 'demo',
'type' => 'raw',
'header' => "Select",
'value' => 'CHtml::checkBox("email[]","",array("class"=>"check","value"=>$data->email_id))',
),
),
));
Edit:
Extension for remembering the selected options in gridview,check this link Selgridview
Thanks to bool.dev
You could use sessions/cookies to store the checked values. I’m not very sure how to make cookies work, so i’ll tell you how to do it with sessions. Specifically the user session that yii creates.
Now to use sessions we need to pass the checked (and unchecked) ids to the controller, therefore we’ll modify the data being sent to the controller on every ajax update(i.e between paginations), to do this we exploit the
beforeAjaxUpdateoption of CGridView.I’m also using CCheckBoxColumn instead of the following in your code(of course you can modify the solution to suit your own needs):
GridView Changes:
Pay special attention to the code for
beforeAjaxUpdateand CCheckBoxColumn, in beforeAjaxUpdate we are passingcheckedIdsas a csv string of all the ids(in this case email_ids) that have been checked anduncheckedIdsas a csv string of all the unchecked ids, we get the unchecked boxes by calling a functiongetUncheckeds(), which follows shortly. Please take note here, that when i was testing i had used an integer id field (of my table) as the unique field, and not an email field.The
getUncheckeds()function can be registered like this anywhere in the view file for gridview:In the above function pay attention to the selectors and
eachandpushfunction.With that done, we need to modify the controller/action for this view.
That’s it, it should work now.