GithubHelp home page GithubHelp logo

hrahimi270 / react-responsive-carousel Goto Github PK

View Code? Open in Web Editor NEW

This project forked from leandrowd/react-responsive-carousel

0.0 1.0 0.0 11.84 MB

React.js Responsive Carousel (with Swipe)

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

License: MIT License

CSS 12.54% HTML 3.04% JavaScript 84.42%

react-responsive-carousel's Introduction

React Responsive Carousel

Help wanted

Things here are running very slowly as I have a lot of other stuff to take care at the moment so please don't be upset if I don't answer your question or if a PR sits unreviewed for a few days or weeks. Anyone interested in helping it move faster can help by submitting or reviewing PR's and answering each other's questions. (leandrowd#160)

npm version Build Status FOSSA Status

Powerful, lightweight and fully customizable carousel component for React apps.

Features

  • Responsive
  • Mobile friendly
  • Swipe to slide
  • Mouse emulating touch
  • Server side rendering
  • Keyboard navigation
  • Custom animation duration
  • Auto play
  • Custom auto play interval
  • Infinite loop
  • Horizontal or Vertical directions
  • Supports images, videos, text content or anything you want. Each direct child represents one slide!
  • Supports any flux library (use selectedItem prop to set from the app state, and onChange callback to get the new position)
  • Show/hide anything (thumbs, indicators, arrows, status)

Important links:

Demo

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

Check it out these cool demos created using storybook. The source code for each example is available here

Customize it yourself:

Installing as a package

yarn add react-responsive-carousel

Usage

import React, { Component } from 'react';
import ReactDOM from 'react-dom';
import "react-responsive-carousel/lib/styles/carousel.min.css";
import { Carousel } from 'react-responsive-carousel';

class DemoCarousel extends Component {
    render() {
        return (
            <Carousel>
                <div>
                    <img src="assets/1.jpeg" />
                    <p className="legend">Legend 1</p>
                </div>
                <div>
                    <img src="assets/2.jpeg" />
                    <p className="legend">Legend 2</p>
                </div>
                <div>
                    <img src="assets/3.jpeg" />
                    <p className="legend">Legend 3</p>
                </div>
            </Carousel>
        );
    }
});

ReactDOM.render(<DemoCarousel />, document.querySelector('.demo-carousel'));

// Don't forget to include the css in your page

// Using webpack
// import styles from 'react-responsive-carousel/lib/styles/carousel.min.css';

// Using html tag:
// <link rel="stylesheet" href="<NODE_MODULES_FOLDER>/react-responsive-carousel/lib/styles/carousel.min.css"/>
Attributes Type Default Description
showArrows boolean true show prev and next arrows
showStatus boolean true show index of the current item. i.e: (1/8)
showIndicators boolean true show little dots at the bottom with links for changing the item
showThumbs boolean true show thumbnails of the images
thumbWidth number undefined optionally specify pixel width (as an integer) of a thumbnail (including any padding) to avoid calculating values (helps with server-side renders or page cache issues)
infiniteLoop boolean false infinite loop sliding
selectedItem number 0 selects an item though props / defines the initial selected item
axis string horizontal changes orientation - accepts horizontal and vertical
verticalSwipe string standard changes vertical swipe scroll direction - accepts standard and natural
onChange function - Fired when changing positions
onClickItem function - Fired when an item is clicked
onClickThumb function - Fired when a thumb it clicked
width string - Allows to set a fixed width
useKeyboardArrows boolean false Adds support to next and prev through keyboard arrows
autoPlay boolean false Auto play
stopOnHover boolean true Stop auto play while mouse is over the carousel
interval number 3000 Interval of auto play
transitionTime number 350 Duration of slide transitions (in miliseconds)
swipeScrollTolerance number 5 Allows scroll when the swipe movement occurs in a different direction than the carousel axis and within the tolerance - Increase for loose - Decrease for strict
swipeable boolean true Enables swiping gestures
dynamicHeight boolean false Adjusts the carousel height if required. -- Do not work with vertical axis --
emulateTouch boolean false Allows mouse to simulate swipe
statusFormatter func (current, total) => ${current} of ${total} Allows custom formatting of the status indicator
centerMode boolean false Enables centered view with partial prev/next slides. Only works with horizontal axis.
centerSlidePercentage number 80 optionally specify percentage width (as an integer) of the slides in centerMode
labels object [key: string]: string { leftArrow, rightArrow, item } optionally specify labels to be applied to controls
onSwipeStart function - Fired when a swiping gesture has started
onSwipeEnd function - Fired when a swiping gesture has ended
onSwipeMove function - Fired when a swiping gesture is happening

=======================

Contributing

The contributing guide contains details on how to create pull requests and setup your dev environment. Please read it before contributing!

=======================

Raising issues

When raising an issue, please add as much details as possible. Screenshots, video recordings, or anything else that can make it easier to reproduce the bug you are reporting.

  • A new option is to create an example with the code that causes the bug. Fork this example from codesandbox and add your code there. Don't forget to fork, save and add the link for the example to the issue.

=======================

Examples

webpack + es6 setup

https://github.com/leandrowd/demo-react-responsive-carousel-es6

Storybook

http://react-responsive-carousel.js.org/storybook/

Codesandbox

https://codesandbox.io/s/lp602ljjj7

=======================

License

FOSSA Status

react-responsive-carousel's People

Contributors

leandrowd avatar jonathanwbn avatar s0 avatar yaodingyd avatar justisb avatar deividasbakanas avatar laneysmith avatar mikeriley131 avatar willedanielsson avatar leandrooriente avatar jackyef avatar ttamminen avatar guily19 avatar driskell avatar jzeltman avatar pergy avatar wildeyes avatar visionwind avatar wenzi0github avatar jinster avatar fossabot avatar yantakus avatar flyfy1 avatar warriorpostman avatar matthew-bridgeman avatar hamidtanhaei avatar dlong500 avatar clementdubois avatar antoniocapelo avatar angorayc avatar

Watchers

James Cloos 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.