antonyz89 / yii2-pagesize
dynamic page size for gridview
Installs: 837
Dependents: 2
Suggesters: 0
Security: 0
Stars: 0
Watchers: 3
Forks: 0
Type:yii2-extension
Requires
- php: >=7
- yiisoft/yii2: ^2.0.5
This package is auto-updated.
Last update: 2025-01-13 03:02:52 UTC
README
--
Installation
The preferred way to install this extension is through composer.
Either run
php composer.phar require --prefer-dist antonyz89/yii2-pagesize dev-master
or add
"antonyz89/yii2-pagesize": "dev-master"
to the require section of your composer.json
file.
USAGE
1 - Add the translation:
common/config/main.php
return [ ... 'components' => [ 'i18n' => [ 'translations' => [ 'pagesize' => [ 'class' => \yii\i18n\PhpMessageSource::class, 'basePath' => '@antonyz89/pagesize/messages', ] ] ] ], ... ];
2 - Add panel -> footer
to your GridView:
use antonyz89\pagesize\PageSize; $pageSize = PageSize::widget([ 'options' => [ 'id' => 'per-page' // without # ] ]); GridView::widget([ ... 'panelFooterTemplate' => '{footer}<div class="clearfix"></div>', 'filterSelector' => '#per-page', // with # 'panel' => [ 'footer' => " {pager} {summary} <div class='float-right'> $pageSize </div> " ], ... ]);
Optional
1 - In your common/config/bootstrap.php
, you can override default values:
use antonyz89\pagesize\PageSize; PageSize::$defaultPageSize = 10; PageSize::$values = [10, 20, 30, 40, 50]; /* `PageSize::$renderItem` to being used in `$renderSelect` */ PageSize::$renderItem = static function ($value, $key, $page) { return [$key, $value]; }; /* * `PageSize::$renderSelect`, use for render a custom select. * If needed override $renderItem to return `$items` as you want */ PageSize::$renderSelect = static function (array $options, array $items, string $pageSize) { $items = array_combine( array_map(static function ($value) { return $value[0]; }, $items), array_map(static function ($value) { return $value[1]; }, $items) ); return Select2::widget([ 'name' => $options['name'], 'id' => $options['id'], 'data' => $items, 'value' => $pageSize, 'hideSearch' => true, 'theme' => Select2::THEME_MATERIAL ]); };
2 - Create a GridView for you! Avoid duplicate code.
Tip: Create your new component in common/components
<?php namespace common\components; use antonyz89\pagesize\PageSize; class GridView extends \yii\grid\GridView { public $panelFooterTemplate = '{footer}<div class="clearfix"></div>'; public $filterSelector = '#pagesize'; protected function initPanel() { $pageSize = PageSize::widget([ 'options' => [ 'id' => str_replace('#', '', $this->filterSelector) // without # ] ]); $this->panel['footer'] = " {pager} {summary} <div class='float-right'> $pageSize </div> "; parent::initPanel(); } }
Use custom pagesize ID
1 - Update your ActiveDataProvider on SearchModel:
use antonyz89\pagesize\PageSizeTrait; public class ExampleSearch extends Example { use PageSizeTrait; // add PageSizeTrait public $pageSizeId = 'custom-pagesize'; // custom ID public function search($params) { ... $dataProvider = new ActiveDataProvider([ ... 'pagination' => $this->pagination, // add `$this->pagination` ]); ... } }
2 - Add panel -> footer
to your GridView:
use antonyz89\pagesize\PageSize; $pageSize = PageSize::widget([ 'options' => [ 'id' => 'custom-pagesize' // without # ] ]); GridView::widget([ ... 'panelFooterTemplate' => '{footer}<div class="clearfix"></div>', 'filterSelector' => '#custom-pagesize', // with # 'panel' => [ 'footer' => " {pager} {summary} <div class='float-right'> $pageSize </div> " ], ... ]);
2.1 - If you created your own GridView
, you just need to override filterSelector
:
use my\own\GridView; GridView::widget([ ... 'filterSelector' => '#custom-pagesize', // with # ... ]);