1.0.0 • Published 4 years ago

react-reveal-responsive-carousel v1.0.0

Weekly downloads
17
License
ISC
Repository
github
Last release
4 years ago

React Reveal Responsive Carousel

:movie_camera: An animated and responsive carousel based on React-Reveal. It allows render any component as a slide.

Features

  • Animation on enter the viewport.
  • Render any component as slides.
  • Configure sizes of the slides.
  • Custom arrows as separated components.
  • Recalculate the number of slides per page on resize the browser, and adapt to the viewport.
  • Animation on resize.

How does it look?

alt example

Installation

npm install react-reveal-responsive-carousel --save

Usage

import Carousel from 'react-reveal-responsive-carousel'

const slides = [
  <div>Text 1</div>,
  <div>Text 2</div>,
  <div>Text 3</div>
];

const leftArrow = (
  <div>
    <LeftArrow fillColor="#000" />
  </div>
);
const rightArrow = (
  <div>
    <RightArrow fillColor="#000" />
  </div>
);

return (
  <div>
    <Carousel
      source={slides}
      leftArrow={leftArrow}
      rightArrow={rightArrow}
    />
  </div>
);

Props

proptypepurposerequired
sourceArray of ReactElementTotal of slides tha will be render in the carouselx
leftArrowReactElementComponent to represent the left arrowx
rightArrowReactElementComponent to represent the righ arrowx
  • The arrows component are expected to be SVG react components, but they can be any component. The arrows can be wrapped on a parent component for styling and positioning.
  • The carousel component can be wrapped in a container, and it will automatically adapt to the size of the container.

Peer dependencies

The component has the following peer dependencies, that need to be installed by the consumer app.

  "react": "^16.14.0",
  "react-dom": "^16.14.0",
  "react-reveal": "^1.2.2", 
  "styled-components": "^4.4.0"

Pending features

  • The carousel should provide default arrows if they are not sent as props.

Example

This application shows a working example of an implementation of the component.