-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
fix documentation and dev dependencies
- Loading branch information
1 parent
4f7018e
commit af6398c
Showing
5 changed files
with
1,685 additions
and
133 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,34 +1,160 @@ | ||
# react-carousel | ||
|
||
> react carousel slider | ||
data:image/s3,"s3://crabby-images/8d45a/8d45a0aeb8d36d94675dfab254d44a1226fc534a" alt="npm" data:image/s3,"s3://crabby-images/b58c6/b58c6c35137e4123713b5924cdf967e2bb32439f" alt="GitHub top language" [data:image/s3,"s3://crabby-images/432d6/432d695915e1b608030587a7ba48baa6280c643d" alt="JavaScript Style Guide"](https://standardjs.com) data:image/s3,"s3://crabby-images/ad547/ad547c6c55039cd226bc8f29ca3ed23722526e00" alt="npm bundle size" data:image/s3,"s3://crabby-images/0dff6/0dff6fb37b3f2a918a8fad16d812ef3ed2457617" alt="npm" | ||
|
||
Horizontal infinite scroll container | ||
|
||
## Table of Contents | ||
---------- | ||
- [Features](#-features) | ||
- [Install](#-install) | ||
- [Example](#-example) | ||
- [API](#-api) | ||
- [License](#license) | ||
|
||
## Features | ||
---------- | ||
|
||
- Display element in an horizontal carousel | ||
- Use custom buttons to slide the elements | ||
- Mobile support for scroll | ||
- Use predefined themes for side buttons | ||
|
||
[data:image/s3,"s3://crabby-images/eee4a/eee4ad7562ccdf574fe1f86448955236d98fc36d" alt="NPM"](https://www.npmjs.com/package/react-carousel) [data:image/s3,"s3://crabby-images/432d6/432d695915e1b608030587a7ba48baa6280c643d" alt="JavaScript Style Guide"](https://standardjs.com) | ||
|
||
## Install | ||
---------- | ||
|
||
Using npm : | ||
```bash | ||
npm install @marchintosh94/react-carousel | ||
``` | ||
Using yarn : | ||
```bash | ||
npm install --save react-carousel | ||
yarn add @marchintosh94/react-carousel | ||
``` | ||
|
||
## Usage | ||
```ts | ||
import { ReactCarouselSlider } from "@marchintosh94/react-carousel" | ||
import "@marchintosh94/react-carousel/dist/index.css" | ||
``` | ||
|
||
|
||
## Example | ||
---------- | ||
|
||
See a complete **[Demo](https://crkn6.csb.app/)**. | ||
|
||
#### Display 5 boxes in **react carosel** | ||
|
||
In this example we are going to use [fontawesome](https://fontawesome.com/)) icons for the "previous" and "next" buttons, but you can use your favourite icon sets: | ||
|
||
```tsx | ||
const prevIcon = ( | ||
<i className="far fa-chevron-left"></i> | ||
) | ||
|
||
const nextIcon = ( | ||
<i className="far fa-chevron-right"></i> | ||
) | ||
``` | ||
|
||
Then define the boxes that will be displayed in **react carousel** | ||
```tsx | ||
const boxesStyle: React.CSSProperties = { | ||
height: "250px", | ||
width: "400px", | ||
border: ".5px solid rgba(0, 0, 0, .4)", | ||
borderRadius: "5px" | ||
} | ||
|
||
const boxes: React.ReactNode = ( | ||
<div style={boxesStyle}></div> | ||
<div style={boxesStyle}></div> | ||
<div style={boxesStyle}></div> | ||
<div style={boxesStyle}></div> | ||
<div style={boxesStyle}></div> | ||
) | ||
``` | ||
Display **react carousel** | ||
|
||
```tsx | ||
return ( | ||
|
||
<ReactCarouselSlider | ||
itemsHeight={boxesStyle.height} | ||
itemsWidth={boxesStyle.width} | ||
elementsMargin={10} //in px | ||
prevIcon={prevIcon} | ||
nextIcon={nextIcon}> | ||
|
||
{boxes} | ||
|
||
</ReactCarouselSlider> | ||
) | ||
``` | ||
|
||
Complete example | ||
|
||
```tsx | ||
import React from 'react' | ||
|
||
import { ReactCarouselSlider } from 'react-carousel' | ||
import 'react-carousel/dist/index.css' | ||
|
||
const App: React.FC = () => { | ||
const MyComponent: React.FC = () => { | ||
|
||
const boxesStyle: React.CSSProperties = { | ||
height: "250px", | ||
width: "400px", | ||
border: ".5px solid rgba(0, 0, 0, .4)", | ||
borderRadius: "5px" | ||
} | ||
|
||
const boxes: React.ReactNode = ( | ||
<div style={boxesStyle}></div> | ||
<div style={boxesStyle}></div> | ||
<div style={boxesStyle}></div> | ||
<div style={boxesStyle}></div> | ||
<div style={boxesStyle}></div> | ||
) | ||
|
||
const prevIcon = ( | ||
<i className="far fa-chevron-left"></i> | ||
) | ||
|
||
const nextIcon = ( | ||
<i className="far fa-chevron-right"></i> | ||
) | ||
|
||
return ( | ||
<ReactCarouselSlider itemsHeight={700} itemsWidth={300} elementsMargin={10} prevIcon={prevIcon} nextIcon={nextIcon}> | ||
<div></div> | ||
{/* ..... */} | ||
<ReactCarouselSlider | ||
itemsHeight={boxesStyle.height} | ||
itemsWidth={boxesStyle.width} | ||
elementsMargin={10} | ||
prevIcon={prevIcon} | ||
nextIcon={nextIcon}> | ||
|
||
{boxes} | ||
|
||
</ReactCarouselSlider> | ||
) | ||
} | ||
``` | ||
|
||
## License | ||
## API | ||
---------- | ||
### Properties **ReactCarouselSlider** | ||
|
||
| Name | Type | Description | | ||
| --------------- | ----------- | ----------- | | ||
| itemsHeight | number | this property sets the height of container (in px) | | ||
| itemsWidth | number | this property is used to calculate the container's width (in px) | | ||
| elementsMargin | number | this property represent the margin (in px) between each element in the carousel | | ||
| prevIcon | React.ReactNode | the element used to slide the carousel to the left | | ||
| nextIcon | React.ReactNode | the element used to slide the carousel to the right | | ||
| theme | 'light' \| 'dark' \| '' | default themes for the slider buttons | | ||
|
||
MIT © [marchintosh94](https://github.com/marchintosh94/) | ||
|
||
## License | ||
---------- | ||
MIT © [marchintosh](https://github.com/marchintosh94/react-carousel) |
Oops, something went wrong.