Research
Security News
Malicious PyPI Package ‘pycord-self’ Targets Discord Developers with Token Theft and Backdoor Exploit
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
react-zoom-pan-pinch
Advanced tools
The react-zoom-pan-pinch package is a React library that provides functionalities for zooming, panning, and pinching elements within a React application. It is particularly useful for creating interactive and responsive user interfaces where users need to manipulate the view of an element, such as images, maps, or any other content that benefits from zoom and pan capabilities.
Zoom
This feature allows users to zoom in and out of an element. The code sample demonstrates how to wrap an image with TransformWrapper and TransformComponent to enable zoom functionality.
import { TransformWrapper, TransformComponent } from 'react-zoom-pan-pinch';
function ZoomExample() {
return (
<TransformWrapper>
<TransformComponent>
<img src="path/to/image.jpg" alt="Zoomable" />
</TransformComponent>
</TransformWrapper>
);
}
Pan
This feature allows users to pan around an element. The code sample shows how to enable panning on a div element by wrapping it with TransformWrapper and TransformComponent.
import { TransformWrapper, TransformComponent } from 'react-zoom-pan-pinch';
function PanExample() {
return (
<TransformWrapper>
<TransformComponent>
<div style={{ width: '500px', height: '500px', background: 'lightgray' }}>
<p>Pan around this area</p>
</div>
</TransformComponent>
</TransformWrapper>
);
}
Pinch
This feature allows users to pinch to zoom in and out on touch devices. The code sample demonstrates how to enable pinch functionality on an image by setting the pinch property in TransformWrapper.
import { TransformWrapper, TransformComponent } from 'react-zoom-pan-pinch';
function PinchExample() {
return (
<TransformWrapper pinch={{ disabled: false }}>
<TransformComponent>
<img src="path/to/image.jpg" alt="Pinchable" />
</TransformComponent>
</TransformWrapper>
);
}
react-pan-and-zoom-hoc is a higher-order component that provides pan and zoom functionalities to any React component. It is similar to react-zoom-pan-pinch but focuses more on providing a higher-order component approach rather than a wrapper component.
react-svg-pan-zoom is a React component specifically designed for SVG elements, providing pan and zoom functionalities. It is more specialized compared to react-zoom-pan-pinch, which can be used with any HTML element.
react-easy-panzoom is a simple and lightweight library for adding pan and zoom functionalities to React components. It offers a straightforward API and is easy to integrate, similar to react-zoom-pan-pinch, but with a focus on simplicity.
Super fast and light react npm package for zooming, panning and pinching html elements in easy way
npm install --save react-zoom-pan-pinch
or
yarn add react-zoom-pan-pinch
import React, { Component } from "react";
import { TransformWrapper, TransformComponent } from "react-zoom-pan-pinch";
class Example extends Component {
render() {
return (
<TransformWrapper>
<TransformComponent>
<img src="image.jpg" alt="test" />
</TransformComponent>
</TransformWrapper>
);
}
}
or
import React, { Component } from "react";
import { TransformWrapper, TransformComponent } from "react-zoom-pan-pinch";
class Example extends Component {
render() {
return (
<TransformWrapper
defaultScale={1}
defaultPositionX={200}
defaultPositionY={100}
>
{({ zoomIn, zoomOut, resetTransform, ...rest }) => (
<React.Fragment>
<div className="tools">
<button onClick={zoomIn}>+</button>
<button onClick={zoomOut}>-</button>
<button onClick={resetTransform}>x</button>
</div>
<TransformComponent>
<img src="image.jpg" alt="test" />
<div>Example text</div>
</TransformComponent>
</React.Fragment>
)}
</TransformWrapper>
);
}
}
Props | Default | Type |
---|---|---|
scale | 1 | number |
positionX | auto | number |
positionY | auto | number |
defaultPositionX | null | number |
defaultPositionY | null | number |
defaultScale | null | number |
options | {...} | object |
wheel | {...} | object |
pan | {...} | object |
pinch | {...} | object |
zoomIn | {...} | object |
zoomOut | {...} | object |
doubleClick | {...} | object |
reset | {...} | object |
scalePadding | {...} | object |
onWheelStart | null | Function |
onWheel | null | Function |
onWheelStop | null | Function |
onPanningStart | null | Function |
onPanning | null | Function |
onPanningStop | null | Function |
onPinchingStart | null | Function |
onPinching | null | Function |
onPinchingStop | null | Function |
onZoomChange | null | Function |
enablePadding | true | Boolean |
enablePanPadding | true | Boolean |
Props | Default | Type |
---|---|---|
disabled | false | boolean |
transformEnabled | true | boolean |
minPositionX | null | null, number |
maxPositionX | null | null, number |
minPositionY | null | null, number |
maxPositionY | null | null, number |
minScale | 1 | number |
maxScale | 8 | number |
limitToBounds | true | boolean |
centerContent | true | boolean |
Props | Default | Type |
---|---|---|
disabled | false | boolean |
size | 0.45 | number |
animationTime | 200 | number |
animationType | easeOut | string |
Props | Default | Type |
---|---|---|
disabled | false | boolean |
step | 6.5 | number |
wheelEnabled | true | boolean |
touchPadEnabled | true | boolean |
limitsOnWheel | true | boolean |
Props | Default | Type |
---|---|---|
disabled | false | boolean |
disableOnTarget | [] | array of class names or node tags (div,span...) |
lockAxisX | false | boolean |
lockAxisY | false | boolean |
velocity | false | boolean |
velocityEqualToMove | false | boolean |
velocitySensitivity | 1 | number |
velocityMinSpeed | 1.2 | number |
velocityBaseTime | 1800 | number |
velocityAnimationType | easeOut | string |
limitToWrapper | false | boolean |
padding | true | boolean |
paddingSize | 40 | number |
animationTime | 200 | number |
animationType | easeOut | string |
Props | Default | Type |
---|---|---|
disabled | false | boolean |
Props | Default | Type |
---|---|---|
disabled | false | boolean |
step | 70 | number |
animation | true | boolean |
animationTime | 200 | number |
animationType | easeOut | string |
Props | Default | Type |
---|---|---|
disabled | false | boolean |
step | 70 | number |
animation | true | boolean |
animationTime | 200 | number |
animationType | easeOut | string |
Props | Default | Type |
---|---|---|
disabled | false | boolean |
step | 70 | number |
animation | true | boolean |
animationTime | 200 | number |
animationType | easeOut | string |
mode | zoomIn | zoomIn / zoomOut / reset |
Props | Default | Type |
---|---|---|
disabled | false | boolean |
animation | true | boolean |
animationTime | 200 | number |
animationType | easeOut | string |
Value |
---|
easeOut |
linear |
easeInQuad |
easeOutQuad |
easeInOutQuad |
easeInCubic |
easeOutCubic |
easeInOutCubic |
easeInQuart |
easeOutQuart |
easeInOutQuart |
easeInQuint |
easeOutQuint |
easeInOutQuint |
Value |
---|
zoomIn |
zoomOut |
reset |
Value | Description | Type |
---|---|---|
setScale(scale, animationTime, animationType) | Sets scale | Number |
setPositionX(positionX, animationTime, animationType) | Sets position x | Number |
setPositionY(positionY, animationTime, animationType) | Sets position y | Number |
zoomIn() | Zooming in function, used for controls button | --- |
zoomOut() | Zooming out function, used for controls button | --- |
setTransform(positionX, positionY, scale, animationTime, animationType) | Sets transformations of content | Number or null |
resetTransform() | Reset transformations to the initial values | Number |
MIT © prc5
Thanks goes to these wonderful people (emoji key):
Maciej Pyrc 👀 💻 🚇 🚧 💡 💬 | Shaneeza 🐛 | gabrielfmp 💻 | Pablo Vega Uceta 💻 | Selvam M 💻 | David Liu 💻 |
This project follows the all-contributors specification. Contributions of any kind welcome!
FAQs
Zoom and pan html elements in easy way
The npm package react-zoom-pan-pinch receives a total of 275,726 weekly downloads. As such, react-zoom-pan-pinch popularity was classified as popular.
We found that react-zoom-pan-pinch demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
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.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.
Security News
Snyk's use of malicious npm packages for research raises ethical concerns, highlighting risks in public deployment, data exfiltration, and unauthorized testing.