Giter Site home page Giter Site logo

yinyang / yii2-scroll-pager Goto Github PK

View Code? Open in Web Editor NEW

This project forked from kop/yii2-scroll-pager

1.0 2.0 0.0 468 KB

Infinite AJAX scrolling for Yii2 ListView widget

Home Page: http://kop.github.io/yii2-scroll-pager

License: MIT License

PHP 100.00%

yii2-scroll-pager's Introduction

Yii2 Scroll Pager

Yii2 Scroll Pager (Y2SP) turns your regular paginated page into an infinite scrolling page using AJAX.

Y2SP works with a 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.

Latest Stable Version Build Status Code Climate Scrutinizer Code Quality Version Eye License

Requirements

  • Yii 2.0
  • PHP 5.4

Installation

The preferred way to install this extension is through Composer.

Either run

php composer.phar require kop/yii2-scroll-pager "dev-master"

or add

"kop/yii2-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.

echo ListView::widget([
     'dataProvider' => $dataProvider,
     'itemOptions' => ['class' => 'item'],
     'itemView' => '_item_view',
     'pager' => ['class' => \kop\y2sp\ScrollPager::className()]
]);

Configuration

General Options

container

Default: ".list-view"

Enter the selector of the element containing your items that you want to paginate.

item

Default: ".item"

Enter the selector of the element that each item has. Make sure the elements are inside the container element.

delay

Default: 600

Minimal number of milliseconds to stay in a loading state.

negativeMargin

Default: 10

On default IAS starts loading new items when you scroll to the latest .item element. The negativeMargin will 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).

For example:

Setting a negativeMargin of 250 means that IAS will start loading 250 pixel before the last item has scrolled into view.

Extensions

enabledExtensions

Default: Array( ScrollPager::EXTENSION_TRIGGER, ScrollPager::EXTENSION_SPINNER, ScrollPager::EXTENSION_NONE_LEFT, ScrollPager::EXTENSION_PAGING, ScrollPager::EXTENSION_HISTORY )

The list of the enabled plugin extensions.

Extension Options

triggerText

Default: "Load more items"

Text of trigger the link.

triggerTemplate

Default: "<div class="ias-trigger" style="text-align: center; cursor: pointer;"><a>{text}</a></div>"

Allows you to override the trigger html template.

triggerOffset

Default: 0

The number of pages which should load automatically. After that the trigger is shown for every subsequent page.

For example: if you set the offset to 2, the pages 2 and 3 (page 1 is always shown) would load automatically and for every subsequent page the user has to press the trigger to load it.

spinnerSrc

Default: Spinner Image

The src attribute of the spinner image.

spinnerTemplate

Default: "<div class="ias-spinner" style="text-align: center;"><img src="{src}"/></div>"

Allows you to override the spinner html template.

noneLeftText

Default: "You reached the end"

Text of the "nothing left" message.

noneLeftTemplate

Default: "<div class="ias-noneleft" style="text-align: center;">{text}</div>"

Allows you to override the "nothing left" message html template.

historyPrev

Default: ".previous"

Enter the selector of the link element that links to the previous page.

The href attribute of this element will be used to get the items from the previous page.

Make sure there is only one element that matches the selector.

overflowContainer

Default: null

A selector for div HTML element to use as an overflow container.

Plugin Events

eventOnScroll

Default: null

Triggered when the visitors scrolls.

eventOnLoad

Default: null

Triggered when a new url will be loaded from the server.

eventOnLoaded

Default: null

Triggered after a new page was loaded from the server.

eventOnRender

Default: null

Triggered before new items will be rendered.

eventOnRendered

Default: null

Triggered after new items have rendered.

eventOnNoneLeft

Default: null

Triggered when there are no more pages left.

eventOnNext

Default: null

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.

eventOnReady

Default: null

Triggered when IAS and all the extensions have been initialized.

eventOnPageChange

Default: null

Triggered when a used scroll to another page.

Report

License

yii2-scroll-pager is released under the MIT License. See the bundled LICENSE.md for details.

Resources

yii2-scroll-pager's People

Contributors

kop avatar slacki avatar

Stargazers

 avatar

Watchers

 avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.