panix / wgt-scroll-pager
Infinite AJAX scrolling
Installs: 233
Dependents: 1
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
Language:JavaScript
Type:pixelion-component
pkg:composer/panix/wgt-scroll-pager
Requires
- php: >=5.4.0
This package is auto-updated.
Last update: 2025-10-10 16:23:43 UTC
README
infinite scrolling page using AJAX.
Y2SP works with a yii\data\Pagination object which specifies the totally number of pages and the current page number.
Pager is build with help of jQuery Infinite Ajax Scroll plugin.
Requirements
- Yii 2.0
- PHP 5.4
Installation
The preferred way to install this extension is through Composer.
Either run
php composer require panix/wgt-scroll-pager "dev-master"
or add
 "panix/wgt-scroll-pager": "dev-master"
to the require section of your composer.json file.
Usage
Just pass the ScrollPager class name to the ListView pager configuration.
Make sure that items in your list have some classes that can be used as JavaScript selectors.
ListView
echo ListView::widget([ 'dataProvider' => $dataProvider, 'itemOptions' => ['class' => 'item'], 'itemView' => '_item_view', 'pager' => ['class' => \panix\wgt\scrollpager\ScrollPager::className()] ]);
GridView
echo GridView::widget([ 'dataProvider' => $dataProvider, 'pager' => [ 'class' => \panix\wgt\scrollpager\ScrollPager::class, 'container' => '.grid-view tbody', 'item' => 'tr', 'paginationSelector' => '.grid-view .pagination', 'triggerTemplate' => '<tr class="ias-trigger"><td colspan="100%" style="text-align: center"><a style="cursor: pointer">{text}</a></td></tr>', ], ]);
Configuration
General Options
| Option name | Description | Default value | 
|---|---|---|
| container | The selector of the element containing your items that you want to paginate. | .list-view | 
| item | The selector of the element that each item has.<br Make sure the elements are inside the container element. | .item | 
| paginationSelector | The selector of the element containing the pagination. | .list-view .pagination | 
| next | The selector of the link element that links to the next page. The href attribute of this element will be used to get the items from the next page. Make sure there is only one(1) element that matches the selector. | .next a | 
| delay | Minimal number of milliseconds to stay in a loading state. | 600 | 
| negativeMargin | By default IAS starts loading new items when you scroll to the latest .itemelement.The negativeMarginwill be added to the items offset, giving you the ability to load new items earlier (please note that the margin is always transformed to a negative integer).Example: Setting a negativeMargin of 250 means that IAS will start loading 250 pixel before the last item has scrolled into view. | 10 | 
Extensions
| Option name | Description | Default value | 
|---|---|---|
| enabledExtensions | The list of the enabled plugin extensions. | [ ScrollPager::EXTENSION_TRIGGER,ScrollPager::EXTENSION_SPINNER,ScrollPager::EXTENSION_NONE_LEFT,ScrollPager::EXTENSION_PAGING,ScrollPager::EXTENSION_HISTORY] | 
Extension Options
Plugin Events
| Option name | Description | Default value | 
|---|---|---|
| eventOnScroll | Triggered when the visitors scrolls. | null | 
| eventOnLoad | Triggered when a new url will be loaded from the server. | null | 
| eventOnLoaded | Triggered after a new page was loaded from the server. | null | 
| eventOnRender | Triggered before new items will be rendered. | null | 
| eventOnRendered | Triggered after new items have rendered. | null | 
| eventOnNoneLeft | Triggered when there are no more pages left. | null | 
| eventOnNext | Triggered when the next page should be loaded. Happens before loading of the next page starts. With this event it is possible to cancel the loading of the next page. You can do this by returning false from your callback. | null | 
| eventOnReady | Triggered when IAS and all the extensions have been initialized. | null | 
| eventOnPageChange | Triggered when a used scroll to another page. | null | 
Report
- Report any issues on the GitHub.
License
wgt-scroll-pager is released under the MIT License. See the bundled LICENSE.md for details.
