🚀 DAY 5 OF LAUNCH WEEK:Introducing Webhook Events for Alert Changes.Learn more →
Socket
Book a DemoInstallSign in
Socket

jquery-heaven-scroll

Package Overview
Dependencies
Maintainers
3
Versions
16
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

jquery-heaven-scroll

Heaven scroll provides an InfiniteScroll with amazing performance and experiance improvements

latest
Source
npmnpm
Version
3.5.0
Version published
Weekly downloads
2
Maintainers
3
Weekly downloads
 
Created
Source

HeavenScroll

Heaven scroll provides an InfiniteScroll with amazing performance and experience improvements

Pre-requisites

Install the package dependencies by running the following command

npm install

Development

npm run start

Then view this project at http://localhost:8080

Demo

To create a packagable demo, use the following command.

npm run build

This will create a demo project in the dist folder

Publishing

NODE_ENV=production npm run build
npm publish

How to use

Install plugin

npm install jquery-heaven-scroll

This plugin requires some information to be passed to it in order to work.

Option 1 using arguments values (will overwrite option 2 values)

One way to send this information is passing an array as argument to the method, like:

/**
 * Returns html to be written inside .pageSingle
 * -
 * div that holds .pageSingle must have a data atrribuite of data-page-number that has value of options.pageNumber
 * - 
 * function deals with receiving a single page, or an array of pages to add 
 * -
 * @param {object} options
 * @param {string} options.pageClassName
 * @param {integer|array} options.pageNumber
 * @param {function} cb
 */
function productTileFetcher(options, cb) {
	// (...)
}

var $pagesContainer = $('.your-selector-classname');

$pagesContainer.heavenScroll({
		fadeInValue: 1500, // page fade in duration
		maxPagesNumber: 3, // maximum number of pages shown
		pageHeight: 1584, // page height
		startPage: 1, // page to start (gets overwritten if url has query parameter)
		endPage: 10,
		pageClassName: 'pageSingle', // page class
		urlQueryParamName: 'startPage', // page to start url query parameter name
		loadPageFunction: productTileFetcher,  // function that returns the html to be shown
		spinnerClassName: 'Spinner', // default class name 'Spinner'
		debugMode: true // enable debugMode for loading a page information, it's default value is `false`,
        eraseMode: 'hide' // enable `hide` mode or `erase` mode regarding previous loaded pages in the infinity scroll
    });

NOTE: the loadPageFunction value must be passed in option 1.

Option 2 using data attributes values

Another way to send this information is by using data-attributes in the $pagesContainer element, like:

<div class="pagesContainer"
	 data-max-pages="3"
	 data-page-height="1584"
	 data-start-page="1"
	 data-end-page="10"
	 data-page-class-name="pageSingle"
	 data-url-query-param-name="startPage"
	 data-erase-mode="hide">
</div>

NOTE: For an example check the demo folder

Keywords

jquery

FAQs

Package last updated on 18 Oct 2017

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts