Skip to content

ibreathebsb/pulltorefresh.js

 
 

Repository files navigation

PulltoRefresh.js

Build Status NPM version CDNJS

PulltoRefresh.jsDemos

A small, but powerful Javascript library crafted to power your webapp's pull to refresh feature. No markup needed, highly customizable and dependency-free!


Install

Include the JS file in your webapp and initialize it:

PullToRefresh.init({
  mainElement: 'body',
  onRefresh: function(){ window.location.reload(); }
});

API

distThreshold (integer, default: 60)

Minimum distance required to trigger the refresh.

distMax (integer, default: 80)

Maximum distance possible for the element.

distReload (integer, default: 50)

After the distThreshold is reached and released, the element will have this height.

mainElement (string, default: body)

Before which element the pull to refresh elements will be?

triggerElement (string, default: body)

Which element should trigger the pull to refresh?

ptrElement (string, default: .ptr)

Which class will the main element have?

classPrefix (string, default: ptr--)

Which class prefix for the elements?

cssProp (string, default: min-height)

Which property will be used to calculate the element's proportions?

iconArrow (string, default: ⇣)

The icon for both instructionsPullToRefresh and instructionsReleaseToRefresh

iconRefreshing (string, default: …)

The icon when the refresh is in progress.

instructionsPullToRefresh (string, default: Pull down to refresh)

The initial instructions string.

instructionsReleaseToRefresh (string, default: Release to refresh)

The instructions string when the distThreshold has been reached.

instructionsRefreshing (string, default: Refreshing)

The refreshing text.

refreshTimeout (integer, default: 500)

The delay, in milliseconds before the onRefresh is triggered.

onInit (function)

The initialize function.

onRefresh (function)

What will the pull to refresh trigger? You can return a promise. Defaults to window.location.reload()

resistanceFunction (function)

The resistance function, accepts one parameter, must return a number, capping at 1. Defaults to t => Math.min(1, t / 2.5)

shouldPullToRefresh (function)

Which condition should be met for pullToRefresh to trigger? Defaults to !window.scrollY

passive (boolean)

This value will be passed as { passive: true|false } to touchmove listeners if passive-handlers are supported. Defaults to false

Contribute

  1. Install NodeJS (NVM)
  2. Run nvm use 4 && npm install
  3. Then npm run dev

Roadmap

  • More events: onPullStart, onPullDown(direction, willRefresh), onRelease(willRefresh)
  • Fully customizable CSS
  • Gallery of use cases
  • Advanced demos
  • Tests - WIP
  • Minified releases

About

A quick and powerful plugin for your pull-to-refresh needs in your webapp.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 59.7%
  • HTML 28.9%
  • CSS 11.4%