thrieu / yii2-grid-view-state
Save filters from GridView to session, keep the filter state between pages.
Installs: 10 555
Dependents: 1
Suggesters: 0
Security: 0
Stars: 13
Watchers: 5
Forks: 9
Open Issues: 2
Type:yii2-extension
Requires
- yiisoft/yii2: *
This package is not auto-updated.
Last update: 2024-11-13 21:17:20 UTC
README
Save filters from GridView to session, keep filter state between pages.
Features
- Very flexible. Separate setting and getting.
- Setting via behavior.
- Determines uniqueness by action's route and a customizable ID.
Installation
To install, either run
php composer.phar require --prefer-dist thrieu/yii2-grid-view-state "dev-master"
or add
"thrieu/yii2-grid-view-state": "dev-master"
to the require section of your composer.json
file and then run composer update
.
Usage
Step 1
Create \app\widgets\Gridview.php
Extend GridView
class, simply implement FilterStateInterface
and FilterStateTrait
.
namespace \app\widgets; use thrieu\grid\FilterStateInterface; use thrieu\grid\FilterStateTrait; class GridView extends \yii\grid\GridView implements FilterStateInterface { use FilterStateTrait; }
Step 2
Attach the filter behavior to your GridView
widget.
use \app\widgets\Gridview; ... GridView::widget([ ... 'as filterBehavior' => \thrieu\grid\FilterStateBehavior::className(), ... ]);
Step 3
Update \app\models\xxxSearch.php
To get the params which is merged with GridView state params and GET query params, and then set it to filter model and DataProvider
.
// DataProvider $dataProvider = new ActiveDataProvider([ 'query' => $query, 'pagination' => [ 'params' => \app\widgets\GridView::getMergedFilterStateParams(), ], 'sort' => [ 'params' => \app\widgets\GridView::getMergedFilterStateParams(), ], ]); // Filter model $this->load(\app\widgets\GridView::getMergedFilterStateParams());
Enjoy it.
Clear state
Update \app\controllers\xxxController.php
Add ClearFilterStateBehavior
to behaviors()
of your controller.
public function behaviors() { return [ ... 'clearFilterState' => \thrieu\grid\ClearFilterStateBehavior::className(), ... ]; }
And then add a form to your frontend page.
$form = Html::beginForm(); $form .= Html::hiddenInput('clear-state', '1'); $form .= Html::hiddenInput('redirect-to', ''); $form .= Button::widget([ 'label' => Yii::t('app', 'Reset filter'), ]); $form .= Html::endForm(); echo $form;
get filter settings by route
$filterData = GridView::getMergedFilterStateParams(null, null, 'delivery/cmd-delivery/index'); $model->load($filterData);
Prev Next model for view screens
for gridview set usepreview = true
use \app\widgets\Gridview; ... GridView::widget([ ... 'as filterBehavior' => \thrieu\grid\FilterStateBehavior::class, 'usePrevNext' => true, ... ]);
for prev next buttons easy get previousa nd next model keys values
$prevNext = new PrevNextPage('cars/in-way/index'); if ($prevId = $prevNext->getPrevPage($model->id)) { echo ThButton::widget([ 'tooltip' => Yii::t('blankonthema', 'Previous record'), 'link' => [ 'view', 'id' => $prevId, ], 'icon' => 'arrow-left', 'type' => ThButton::TYPE_DEFAULT ]); } if ($nextId = $prevNext->getNextPage($this->id)) { echo ThButton::widget([ 'tooltip' => Yii::t('blankonthema', 'Next record'), 'link' => [ 'view', 'id' => $nextId, ], 'icon' => 'arrow-right', 'type' => ThButton::TYPE_DEFAULT ]); }