#react-photostory
A lightweight carousel made in React and optimized for mobile
Demo is available here. Make sure devtools is
open and mobile emulation is selected as this library currently only supports touch events.
##Features
- lazy-loading by default
- AutoPlay
- Drag and swipe
Installation
npm install --save react-photostory
Basic Usage
import { Slide, Swipe } from 'react-photostory';
<Swipe className="photostory">
<Slide image="a.jpg" defaultImage="default1.jpg">Text 1</Slide>
<Slide image="b.jpg" defaultimage="default2.jpg">Text 2</Slide>
</Swipe>
Options
<Swipe/> Component
prop | default | description |
---|
className | '' | Custom classname |
initialIndex | 0 | initially visible slide index |
autoPlay | false | whether to display slide show or not |
overScan | 0 | Number of Slide offsets to load excluding the current slide.If its 1 it will load current, current+-1 |
onSwipe | ({initialIndex, currentIndex}) | function executed whenever the current slide changes |
onClick | {index} | function executed when a slide is clicked |
prev | | React element to replace the PREV button |
next | | React element to replace the NEXT button |
threshold | 0.5 | Ratio of carousel width one should drag to make successful swipe |
responsive | false | Should the gallery be responsive |
To manually go to a particular slide you can use gotoSlide(i)
method
const x = (
<Swipe className="photostory">
<Slide image="a.jpg" defaultImage="default1.jpg">Text 1</Slide>
<Slide image="b.jpg" defaultimage="default2.jpg">Text 2</Slide>
<Slide image="c.jpg" defaultimage="default3.jpg">Text 2</Slide>
</Swipe>
)
x.gotoSlide(2)
<Slide/> Component
prop | default | description |
---|
image | string | final image to be loaded |
defaultImage | string | pre-loader image to be shown |
autoLoad | false | should the component automatically lazyLoad the image |
attributes | {} | Additional attributes for component root |
title | '' | serves like alt attribute for img tag |
lazyLoad | true | enable/disable lazy load |
If autoload
is set to false the you have to manually call .load()
to load the image
const a = <Slide image="a.jpg" defaultImage="default1.jpg">Text 1</Slide>
a.load()
<Slide image="a.jpg" defaultImage="default1.jpg" autoLoad={true}>Text 1</Slide>
Development
git clone https://github.com/housinghq/react-photostory
cd react-photostory
npm install
npm run storybook
Make sure you develop in emulation mode (open devtools and select mobile emulation). Currently this only supports touch events.
Make sure you open issue before opening a PR. This package is optimised for mobile so not many features may be implemented.
License @ MIT