JSPM

  • Created
  • Published
  • Downloads 415160
  • Score
    100M100P100Q246667F
  • License MIT

React Responsive Carousel

Package Exports

  • react-responsive-carousel

This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (react-responsive-carousel) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

Readme

React Responsive Carousel (WIP)

Demo

http://leandrowd.github.io/react-responsive-carousel/

Installing as a package

npm install react-responsive-carousel --save

Running locally

To run it on your local environment just:

  • git clone git@github.com:leandrowd/react-responsive-carousel.git
  • npm install
  • gulp
  • Open your favourite browser on localhost:8000

To generate the npm package run gulp package. It will transpile the jsx to js and copy the css into the lib folder.

Getting started

Slider with controls

  • Javascript / Jsx:
/** @jsx React.DOM */
var React = require('react');
var Carousel = require('./components/Carousel');

var DemoSliderControls = React.createClass({
    render() {
        return (
            <div className="demo-slider">
                <Carousel 
                    type="slider" 
                    items={ sliderImages } 
                    showControls={true} 
                    showStatus={true} />
            </div>
        );
    }
});

React.render(<DemoSliderControls />, document.querySelector('.demo-slider-controls'));
  • Css:
<link rel="stylesheet" href="carousel.css"/>
  • Props:
    • (Array) items
    • (Boolean) showControls
    • (Boolean) showStatus
    • (Function) onChange
      • Triggered when the carousel move
    • (Function) onSelectItem
      • Triggered when an item is selected
  • Javascript / Jsx:
/** @jsx React.DOM */
var React = require('react');
var Carousel = require('./components/Carousel');

var DemoCarousel = React.createClass({
    render() {
        return (
            <div className="demo-carousel">
                <Carousel items={ carouselImages } />
            </div>
        );
    }
});

React.render(<DemoCarousel />, document.querySelector('.demo-carousel'));
  • Css:
<link rel="stylesheet" href="carousel.css"/>
  • Props:
    • (Array) items
    • (Boolean) showControls
    • (Boolean) showStatus
    • (Function) onChange
      • Triggered when the carousel move
    • (Function) onSelectItem
      • Triggered when an item is selected
  • Javascript / Jsx:
/** @jsx React.DOM */
var React = require('react');
var ImageGallery = require('./components/ImageGallery');

var DemoGallery = React.createClass({
    render() {
        return (
            <div className="demo-image-gallery">
                <ImageGallery images={ galleryImages } />
            </div>
        );
    }
});

React.render(<DemoGallery />, document.querySelector('.demo-gallery'));
  • Css:
<link rel="stylesheet" href="imageGallery.css"/>
<link rel="stylesheet" href="carousel.css"/>
  • Props:
    • images

So simple, just add one carousel[type=slider]

  • Javascript / Jsx:
/** @jsx React.DOM */
var React = require('react/addons');
var Carousel = require('./Carousel');

module.exports = React.createClass({
    
    propsTypes: {
        images: React.PropTypes.array.isRequired
    },

    getInitialState () {
        return {
            currentImage: 0
        }
    },

    selectItem (selectedItem) {
        this.setState({
            currentImage: selectedItem
        });
    },

    render () {
        var { images } = this.props;
        var { current } = this.state;
        var mainImage = (images && images[current] && images[current].url);

        return (
            <div className="image-gallery">
                <Carousel 
                    type="slider" 
                    items={ images } 
                    selectedItem={this.state.currentImage} 
                    onChange={this.selectItem} 
                    onSelectItem={ this.selectItem } />

                <Carousel 
                    items={ images } 
                    selectedItem={this.state.currentImage} 
                    onSelectItem={ this.selectItem } />
            </div>
        );
    }
});

Browser Support

Although I have implemented css transformations for all the browsers and fallback to left when 3d isn't supported, I haven't had time to test in browsers other than chrome yet. I reckon than it should just work but minor issues can be found.

TODO:

  • Implement slides of content
  • Improve documentation
  • Improve tests
  • Improve swipe
  • Test cross-browser
  • ...?

Contributing

Feel free to contribute. Just Fork -> Change -> Pull request!