🚀 Big News: Socket Acquires Coana to Bring Reachability Analysis to Every Appsec Team.Learn more
Socket
DemoInstallSign in
Socket

react-native-image-view

Package Overview
Dependencies
Maintainers
1
Versions
42
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

react-native-image-view

React Native modal image view with pinch zoom

2.1.9
latest
Source
npm
Version published
Maintainers
1
Created
Source

If you are using React Native >= 0.59.0 I recommend to use the clone of this package https://github.com/jobtoday/react-native-image-viewing as improved and more optimized version!

npm version

React Native modal image view with pinch zoom and carousel.

Try with expo: https://expo.io/@antonkalinin/react-native-image-view

Warning: Breaking changes since v2.0.0:

  • instead of prop source => images
  • no title prop for footer, please use renderFooter instead

Installation

yarn add react-native-image-view

or

npm install --save react-native-image-view

Demo

Usage

import ImageView from 'react-native-image-view';

const images = [
    {
        source: {
            uri: 'https://cdn.pixabay.com/photo/2017/08/17/10/47/paris-2650808_960_720.jpg',
        },
        title: 'Paris',
        width: 806,
        height: 720,
    },
];

<ImageView
    images={images}
    imageIndex={0}
    isVisible={this.state.isImageViewVisible}
    renderFooter={(currentImage) => (<View><Text>My footer</Text></View>)}
/>

See example for better understanding

Props

Prop nameDescriptionTypeDefault valuePlatform
animationTypeType of animation modal presented with"none", "fade", "slide""none"
backgroundColorBackground color of the modal in HEX (#0099CC)stringnull
controlsConfig of available controls (see below)Object{close: true}
glideAlwaysEmulates ScrollView glide animation if built-in was not triggeredbooleanfalseAndroid
glideAlwaysDelayDefines delay in milliseconds for glideAlwaysnumber75Android
imagesArray of images to display, see below image item descriptionarray[]
imageIndexCurrent index of image to displaynumber0
isVisibleIs modal shown or notbooleanfalse
isTapZoomEnabledZoom image when double tappedbooleantrue
isPinchZoomEnabledZoom image with pinch gesturebooleantrue
isSwipeCloseEnabledClose modal with swipe up or downbooleantrue
onCloseFunction called on modal closedfunctionnone
onImageChangeFunction called when image is changedfunctionnone
renderFooterFunction returns a footer elementfunctionnone

Image item:

{
  source: any, // Image Component source object
  width: ?number, // Width of full screen image (optional but recommended)
  height: ?number, // Height of full screen image (optional but recommended)
  // any other props you need to render your footer
}

It's recommended to specify width and height to speed up rendering, overwise component needs to fetch images sizes and cache them in images objects passed as props.

controls prop:

type ControlType = React.Component<{onPress: () => void}> | null | boolean,

{
  close: ControlType // Component for close button in up right corner, as onPress prop accepts function to close modal
  next: ControlType, // Component for next image button, as onPress prop accepts function to scroll to next image
  prev: ControlType, // Component for previous image button, as onPress prop accepts function to scroll to previous image
}

To use default components just set {next: true, prev: true}, close is showing by default. To create custom controls check src/controls.

License

MIT

Keywords

react-native

FAQs

Package last updated on 03 Jan 2020

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts