react-image-gallery 1.1.0
Install from the command line:
Learn more about npm packages
$ npm install @lovelysystems/react-image-gallery@1.1.0
Install via package.json:
"@lovelysystems/react-image-gallery": "1.1.0"
About this version
Live demo: linxtion.com/demo/react-image-gallery
React image gallery is a React component for building image galleries and carousels
Features of react-image-gallery
- Mobile Swipe Gestures
- Thumbnail Navigation
- Fullscreen Support
- Custom Rendered Slides
- Responsive Design
- Tons of customization options (see props below)
- Lightweight ~8kb (gzipped, excluding react)
The following environment variables need to be set:
GITHUB_TOKEN=YOUR_PAT_FROM_GITHUB_HERE
Your PAT from GitHub should be scoped with read: packages
React Image Gallery requires React 16.0.0 or later.
npm install react-image-gallery
# SCSS
@import "~react-image-gallery/styles/scss/image-gallery.scss";
# CSS
@import "~react-image-gallery/styles/css/image-gallery.css";
# Stylesheet with no icons
node_modules/react-image-gallery/styles/scss/image-gallery-no-icon.scss
node_modules/react-image-gallery/styles/css/image-gallery-no-icon.css
Need more example? See example/app.js
import ImageGallery from 'react-image-gallery';
const images = [
{
original: 'https://picsum.photos/id/1018/1000/600/',
thumbnail: 'https://picsum.photos/id/1018/250/150/',
},
{
original: 'https://picsum.photos/id/1015/1000/600/',
thumbnail: 'https://picsum.photos/id/1015/250/150/',
},
{
original: 'https://picsum.photos/id/1019/1000/600/',
thumbnail: 'https://picsum.photos/id/1019/250/150/',
},
];
class MyGallery extends React.Component {
render() {
return <ImageGallery items={images} />;
}
}
-
items
: (required) Array of objects, see example above,- Available Properties
-
original
- image src url -
thumbnail
- image thumbnail src url -
originalClass
- custom image class -
thumbnailClass
- custom thumbnail class -
renderItem
- Function for custom renderer (see renderItem below) -
renderThumbInner
- Function for custom thumbnail renderer (see renderThumbInner below) -
originalAlt
- image alt -
thumbnailAlt
- thumbnail image alt -
originalTitle
- image title -
thumbnailTitle
- thumbnail image title -
thumbnailLabel
- label for thumbnail -
description
- description for image -
imageSet
- array of<source>
using<picture>
element (seeapp.js
for example) -
srcSet
- image srcset (html5 attribute) -
sizes
- image sizes (html5 attribute) -
bulletClass
- extra class for the bullet of the item -
bulletOnClick
-callback({item, itemIndex, currentIndex})
- A function that will be called upon bullet click.
-
- Available Properties
-
infinite
: Boolean, defaulttrue
- infinite sliding
-
lazyLoad
: Boolean, defaultfalse
-
showNav
: Boolean, defaulttrue
-
showThumbnails
: Boolean, defaulttrue
-
thumbnailPosition
: String, defaultbottom
- available positions:
top, right, bottom, left
- available positions:
-
showFullscreenButton
: Boolean, defaulttrue
-
useBrowserFullscreen
: Boolean, defaulttrue
- if false, fullscreen will be done via css within the browser
-
useTranslate3D
: Boolean, defaulttrue
- if false, will use
translate
instead oftranslate3d
css property to transition slides
- if false, will use
-
showPlayButton
: Boolean, defaulttrue
-
isRTL
: Boolean, defaultfalse
- if true, gallery's direction will be from right-to-left (to support right-to-left languages)
-
showBullets
: Boolean, defaultfalse
-
showIndex
: Boolean, defaultfalse
-
autoPlay
: Boolean, defaultfalse
-
disableThumbnailScroll
: Boolean, defaultfalse
- disables the thumbnail container from adjusting
-
disableArrowKeys
: Boolean, defaultfalse
- disables keydown listener for left and right keyboard arrow keys
-
disableSwipe
: Boolean, defaultfalse
-
onErrorImageURL
: String, defaultundefined
- an image src pointing to your default image if an image fails to load
- handles both slide image, and thumbnail image
-
indexSeparator
: String, default' / '
, ignored ifshowIndex
is false -
slideDuration
: Number, default450
- transition duration during image slide in milliseconds
-
swipingTransitionDuration
: Number, default0
- transition duration while swiping in milliseconds
-
slideInterval
: Number, default3000
-
slideOnThumbnailOver
: Boolean, defaultfalse
-
flickThreshold
: Number (float), default0.4
- Determines the max velocity of a swipe before it's considered a flick (lower = more sensitive)
-
swipeThreshold
: Number, default30
- A percentage of how far the offset of the current slide is swiped to trigger a slide event. e.g. If the current slide is swiped less than 30% to the left or right, it will not trigger a slide event.
-
stopPropagation
: Boolean, defaultfalse
- Automatically calls stopPropagation on all 'swipe' events.
-
preventDefaultTouchmoveEvent
: Boolean, defaultfalse
- An option to prevent the browser's touchmove event (stops the gallery from scrolling up or down when swiping)
-
startIndex
: Number, default0
-
onImageError
: Function,callback(event)
- overrides onErrorImage
-
onThumbnailError
: Function,callback(event)
- overrides onErrorImage
-
onThumbnailClick
: Function,callback(event, index)
-
onImageLoad
: Function,callback(event)
-
onSlide
: Function,callback(currentIndex)
-
onScreenChange
: Function,callback(fullscreenElement, wasInFullscreen)
-
fullscreenElement
will either be a DOM node or a boolean (for unsupported browsers) - in order to detect the gallery's previous fullscreen state, onScreenChange will provide a second argument (eg. for analytics)
-
-
onPause
: Function,callback(currentIndex)
-
onPlay
: Function,callback(currentIndex)
-
onClick
: Function,callback(event)
-
onTouchMove
: Function,callback(event) on gallery slide
-
onTouchEnd
: Function,callback(event) on gallery slide
-
onTouchStart
: Function,callback(event) on gallery slide
-
onMouseOver
: Function,callback(event) on gallery slide
-
onMouseLeave
: Function,callback(event) on gallery slide
-
additionalClass
: String,- Additional class that will be added to the root node of the component.
-
renderCustomControls
: Function, custom controls rendering- Use this to render custom controls or other elements on the currently displayed image (like the fullscreen button)
_renderCustomControls() { return <a href='' className='image-gallery-custom-action' onClick={this._customAction.bind(this)}/> }
-
renderItem
: Function, custom item rendering- On a specific item
[{thumbnail: '...', renderItem: this.myRenderItem}]
or - As a prop passed into
ImageGallery
to completely override_renderItem
, see source for reference
- On a specific item
-
renderThumbInner
: Function, custom thumbnail rendering- On a specific item
[{thumbnail: '...', renderThumbInner: this.myRenderThumbInner}]
or - As a prop passed into
ImageGallery
to completely override_renderThumbInner
, see source for reference
- On a specific item
-
renderLeftNav
: Function, custom left nav component- Use this to render a custom left nav control
- Passes
onClick
callback that will slide to the previous item anddisabled
argument for when to disable the nav
renderLeftNav(onClick, disabled) { return ( <button className='image-gallery-custom-left-nav' disabled={disabled} onClick={onClick}/> ) }
-
renderRightNav
: Function, custom right nav component- Use this to render a custom right nav control
- Passes
onClick
callback that will slide to the next item anddisabled
argument for when to disable the nav
renderRightNav(onClick, disabled) { return ( <button className='image-gallery-custom-right-nav' disabled={disabled} onClick={onClick}/> ) }
-
renderPlayPauseButton
: Function, play pause button component- Use this to render a custom play pause button
- Passes
onClick
callback that will toggle play/pause andisPlaying
argument for when gallery is playing
renderPlayPauseButton: (onClick, isPlaying) => { return ( <button type="button" className={`image-gallery-play-button${isPlaying ? ' active' : ''}`} onClick={onClick} /> ); };
-
renderFullscreenButton
: Function, custom fullscreen button component- Use this to render a custom fullscreen button
- Passes
onClick
callback that will toggle fullscreen andisFullscreen
argument for when fullscreen is active
renderFullscreenButton: (onClick, isFullscreen) => { return ( <button type='button' className={ `image-gallery-fullscreen-button${isFullscreen ? ' active' : ''}`} onClick={onClick} /> ); },
The following functions can be accessed using refs
-
play()
: plays the slides -
pause()
: pauses the slides -
fullScreen()
: activates full screen -
exitFullScreen()
: deactivates full screen -
slideToIndex(index)
: slides to a specific index -
getCurrentIndex()
: returns the current index
Each PR should be specific and isolated to the issue you're trying to fix. Please do not stack features/chores/refactors/enhancements in one PR. Describe your feature/implementation in the PR. If you're unsure its useful or if it is a major change, please open an issue first and get feedback.
- Follow eslint provided
- Comment your code
- Write clean code
git clone https://github.com/xiaolin/react-image-gallery.git
cd react-image-gallery
npm install
npm start
Then open localhost:8001
in a browser.
Github uses personal access tokens (PAT) for authentication. To generate one go to your Github token settings page. Consult the Github Docs for more information on how tokens work. Your token needs to be scoped with write: package
The following environment variables need to be set:
GITHUB_TOKEN=YOUR_PAT_FROM_GITHUB_HERE
We are using GitHub Packages to host this repo to npm. GitHub Packages Docs and here
- increase version in
package.json
- Check in all changes and commit
- run
git tag <version>
- run
git push --tags
- run
npm run build
- run
npm publish
Please note that if you encounter Error: Error: Node Sass does not yet support your current environment: Windows 64-bit with false
, also see here
you can try and run npm rebuild node-sass
to make npm run build
work properly.
Details
- react-image-gallery
- lovelysystems
- over 2 years ago
- MIT
- 37 dependencies
Assets
- react-image-gallery-1.1.0-npm.tgz
Download activity
- Total downloads 835
- Last 30 days 5
- Last week 0
- Today 0