https://github.com/mkosir/react-parallax-tilt
👀 Easily apply tilt hover effect to React components - lightweight/zero dependencies 3kB
https://github.com/mkosir/react-parallax-tilt
gyroscope parallax parallax-effect react react-library react-tilt tilt typescript
Last synced: 4 days ago
JSON representation
👀 Easily apply tilt hover effect to React components - lightweight/zero dependencies 3kB
- Host: GitHub
- URL: https://github.com/mkosir/react-parallax-tilt
- Owner: mkosir
- License: mit
- Created: 2019-08-07T09:32:52.000Z (over 5 years ago)
- Default Branch: main
- Last Pushed: 2025-04-10T06:31:36.000Z (8 days ago)
- Last Synced: 2025-04-10T07:37:32.442Z (8 days ago)
- Topics: gyroscope, parallax, parallax-effect, react, react-library, react-tilt, tilt, typescript
- Language: TypeScript
- Homepage: https://mkosir.github.io/react-parallax-tilt
- Size: 102 MB
- Stars: 1,009
- Watchers: 20
- Forks: 121
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- best-of-react - GitHub
- best-of-react - GitHub
- awesome-react-cn - react-parallax-tilt - Easily apply tilt hover effect on React components (Uncategorized / Uncategorized)
- awesome-react-components - react-parallax-tilt - [demo](https://mkosir.github.io/react-parallax-tilt) - Easily apply parallax tilt hover effect on components. (UI Animation / Parallax)
- awesome-react - react-parallax-tilt - Easily apply parallax tilt hover effect on components.  (UI Animation / Parallax)
- fucking-awesome-readme - mkosir/react-parallax-tilt - GIF demo. Multiple badges. Feature list. Great live demo with code examples. Easy to follow instructions for local development set up. (Examples)
- awesome-learning-resources - react-parallax-tilt - Easily apply tilt hover effect on React components (Uncategorized / Uncategorized)
- awesome-react-components - react-parallax-tilt - [demo](https://mkosir.github.io/react-parallax-tilt) - Easily apply parallax tilt hover effect on components. (UI Animation / Parallax)
- awesome-react-components - react-parallax-tilt - [demo](https://mkosir.github.io/react-parallax-tilt) - Easily apply parallax tilt hover effect on components. (UI Animation / Parallax)
- best-of-react - GitHub
- fucking-awesome-react-components - react-parallax-tilt - 🌎 [demo](mkosir.github.io/react-parallax-tilt) - Easily apply parallax tilt hover effect on components. (UI Animation / Parallax)
- awesome-react - react-parallax-tilt - Easily apply tilt hover effect on React components - lightweight/zero dependencies ` 📝 5 days ago` (React [🔝](#readme))
- awesome-react - react-parallax-tilt - Easily apply tilt hover effect on React components (**Awesome React** [](https://github.com/sindresorhus/awesome) / React)
- awesome-readme - React Parallax Tilt - GIF demo. Multiple badges. Feature list. Great live demo with code examples. Easy to follow instructions for local development set up. (Examples)
- trackawesomelist - mkosir/react-parallax-tilt (⭐987) - GIF demo. Multiple badges. Feature list. Great live demo with code examples. Easy to follow instructions for local development set up. (Recently Updated / [Jan 22, 2025](/content/2025/01/22/README.md))
- awesome-readme - mkosir/react-parallax-tilt - GIF demo. Multiple badges. Feature list. Great live demo with code examples. Easy to follow instructions for local development set up. (Examples)
- awesome-react-components - react-parallax-tilt - [demo](https://mkosir.github.io/react-parallax-tilt) - Easily apply parallax tilt hover effect on components. (UI Animation / Parallax)
- awesome-react-components - react-parallax-tilt - [demo](https://mkosir.github.io/react-parallax-tilt) - Easily apply parallax tilt hover effect on components. (UI Animation / Parallax)
README
# React Tilt
[![npm version][npm-badge]][npm-url]
[![npm downloads][downloads-badge]][npm-url]
[![npm bundle size][size-badge]][size-url]
[![Open issues][issues-badge]][issues-url]
[![TypeScript][typescript-badge]][typescript-url]
[![semantic-release][semantic-badge]][semantic-url][![CI][lint-badge]][lint-url]
[![CI][tsc-badge]][tsc-url]
[![CI][build-badge]][build-url]
[![CI][test-badge]][test-url]
[![CI][test-e2e-badge]][test-e2e-url]
[![Codecov Coverage][coverage-badge]][coverage-url][![CI][deploy-storybook-badge]][deploy-storybook-url]
[![CI][npm-release-badge]][npm-release-url]_👀 Easily apply tilt hover effects to React components_
[](https://mkosir.github.io/react-parallax-tilt/?path=/story/react-parallax-tilt--glare-effect)
## [Live Demo 💥](https://mkosir.github.io/react-parallax-tilt)
## Install
```bash
npm install react-parallax-tilt
```## Features
- Lightweight 3kB, zero dependencies 📦
- Tree-shakable 🌳 ESM and CommonJS support
- Works with React v15 onwards
- Supports **mouse** and **touch** events
- Support for device tilting (**gyroscope**)
- **Glare** effect 🌟 with custom props (color, position, etc.) [🔗demo](https://mkosir.github.io/react-parallax-tilt/?path=/story/react-parallax-tilt--parallax-effect-glare-scale)
- **Event tracking** for component values 📐 (tilt, glare, mousemove, etc.) [🔗demo](https://mkosir.github.io/react-parallax-tilt/?path=/story/react-parallax-tilt--event-params)
- Multiple built-in effects:
- **Scale** on hover [🔗demo](https://mkosir.github.io/react-parallax-tilt/?path=/story/react-parallax-tilt--scale)
- **Disable** x/y axis [🔗demo](https://mkosir.github.io/react-parallax-tilt/?path=/story/react-parallax-tilt--tilt-disable-axis)
- **Flip** component vertically/horizontally [🔗demo](https://mkosir.github.io/react-parallax-tilt/?path=/story/react-parallax-tilt--flip-vh)
- **Window** tilt hover effect [🔗demo](https://mkosir.github.io/react-parallax-tilt/?path=/story/react-parallax-tilt--track-on-window)
- **Manual tilt** control 🕹 (via joystick, slider, etc.) [🔗demo](https://mkosir.github.io/react-parallax-tilt/?path=/story/react-parallax-tilt--tilt-manual-input)
- **Parallax** effect for overlaid images [🔗demo](https://mkosir.github.io/react-parallax-tilt/?path=/story/react-parallax-tilt--parallax-effect-img)## Example
```jsx
import Tilt from 'react-parallax-tilt';const App = () => {
return (
React Parallax Tilt 👀
);
};
```## Props
All props are optional.
Here's the complete list of available props and their default values:> ▶︎ indicates the default value
**tiltEnable**: _boolean_ ▶︎ `true`
Enables/disables the tilt effect.**tiltReverse**: _boolean_ ▶︎ `false`
Reverses the tilt direction.**tiltAngleXInitial**: _number_ ▶︎ `0`
Initial tilt angle (in degrees) on the x-axis.**tiltAngleYInitial**: _number_ ▶︎ `0`
Initial tilt angle (in degrees) on the y-axis.**tiltMaxAngleX**: _number_ ▶︎ `20`
Maximum tilt rotation (in degrees) on the x-axis. Range: `0°-90°`.**tiltMaxAngleY**: _number_ ▶︎ `20`
Maximum tilt rotation (in degrees) on the y-axis. Range: `0°-90°`.**tiltAxis**: _'x' | 'y'_ ▶︎ `undefined`
Enables tilt on a single axis only.**tiltAngleXManual**: _number_ | null ▶︎ `null`
Manual tilt rotation (in degrees) on the x-axis.**tiltAngleYManual**: _number_ | null ▶︎ `null`
Manual tilt rotation (in degrees) on the y-axis.**glareEnable**: _boolean_ ▶︎ `false`
Enables/disables the glare effect.**glareMaxOpacity**: _number_ ▶︎ `0.7`
Maximum glare opacity (`0.5 = 50%, 1 = 100%`). Range: `0-1`**glareColor**: _string_ ▶︎ `#ffffff`
Sets the color of the glare effect.**glarePosition**: _'top' | 'right' | 'bottom' | 'left' | 'all'_ ▶︎ `bottom`
Sets the position of the glare effect.**glareReverse**: _boolean_ ▶︎ `false`
Reverses the glare direction.**glareBorderRadius**: _string_ ▶︎ `0`
Sets the border radius of the glare. Accepts any standard CSS border radius value.**scale**: _number_ ▶︎ `1`
Scale of the component (`1.5 = 150%, 2 = 200%`).**perspective**: _number_ ▶︎ `1000`
Defines how far the tilt component appears from the user. Lower values create more extreme tilt effects.**flipVertically**: _boolean_ ▶︎ `false`
Enables/disables vertical flipping of the component.**flipHorizontally**: _boolean_ ▶︎ `false`
Enables/disables horizontal flipping of the component.**reset**: _boolean_ ▶︎ `true`
Determines if effects should reset on `onLeave` event.**transitionEasing**: _string_ ▶︎ `cubic-bezier(.03,.98,.52,.99)`
Easing function for the transition.**transitionSpeed**: _number_ ▶︎ `400`
Speed of the transition.**trackOnWindow**: _boolean_ ▶︎ `false`
Tracks mouse and touch events across the entire window.**gyroscope**: _boolean_ ▶︎ `false`
Enables/disables device orientation detection.**onMove**: ({ **tiltAngleX**: _number_, **tiltAngleY**: _number_, **tiltAngleXPercentage**: _number_, **tiltAngleYPercentage**: _number_, **glareAngle**: _number_, **glareOpacity**: _number_, **event**: _Event_ }) => _void_
Callback triggered when user moves on the component.**onEnter**: (**event**: _Event_) => _void_
Callback triggered when user enters the component.**onLeave**: (**event**: _Event_) => _void_
Callback triggered when user leaves the component.## Gyroscope - Device Orientation
Please note that device orientation detection is currently [experimental technology](https://developer.mozilla.org/en-US/docs/MDN/Contribute/Guidelines/Conventions_definitions#Experimental).
Check the [browser compatibility](https://caniuse.com/#search=DeviceOrientation) before using it in production.
Important considerations when using device orientation:- Always use secure origins (such as `https`)
- It may not work in all browsers when used within a cross-origin `` elementDevice Orientation on iOS 13+
Apple disabled device motion and orientation by default starting with iOS 12.2.
iOS 13+ provides a permission API to access device orientation events.When using the gyroscope feature:
```jsx
React Parallax Tilt 👀
```
A permission dialog will prompt the user to allow motion and orientation access at the domain level:
Note: User interaction (like tapping a button) is required to display the permission dialog - it cannot be triggered automatically on page load.
## Development
_Easily set up a local development environment!_
Build project and start storybook on [localhost](http://localhost:9009):
- clone
- `npm install`
- `npm start`**Start coding!** 🎉
Alternative setup using npm link
1. Clone this repository and navigate to its location
2. Run the following commands:```bash
npm install
npm link # link your local repo to your global packages
npm run build:watch # build the files and watch for changes
```3. Clone the project you want to test with react-parallax-tilt and run:
```bash
npm install
npm link react-parallax-tilt # link your local copy into this project's node_modules
npm start
```## Contributing
All contributions are welcome!
Please review contribution guidelines: [Pull Requests](.github/pull_request_template.md) | [Issues](https://github.com/mkosir/react-parallax-tilt/issues/new/choose)[npm-url]: https://www.npmjs.com/package/react-parallax-tilt
[npm-badge]: https://img.shields.io/npm/v/react-parallax-tilt.svg
[size-url]: https://bundlephobia.com/package/react-parallax-tilt
[size-badge]: https://badgen.net/bundlephobia/minzip/react-parallax-tilt
[downloads-badge]: https://img.shields.io/npm/dm/react-parallax-tilt.svg?color=blue
[lint-badge]: https://github.com/mkosir/react-parallax-tilt/actions/workflows/lint.yml/badge.svg
[lint-url]: https://github.com/mkosir/react-parallax-tilt/actions/workflows/lint.yml
[tsc-badge]: https://github.com/mkosir/react-parallax-tilt/actions/workflows/tsc.yml/badge.svg
[tsc-url]: https://github.com/mkosir/react-parallax-tilt/actions/workflows/tsc.yml
[build-badge]: https://github.com/mkosir/react-parallax-tilt/actions/workflows/build.yml/badge.svg
[build-url]: https://github.com/mkosir/react-parallax-tilt/actions/workflows/build.yml
[test-badge]: https://github.com/mkosir/react-parallax-tilt/actions/workflows/test.yml/badge.svg
[test-url]: https://react-parallax-tilt-test-unit-report.netlify.app/
[test-e2e-badge]: https://github.com/mkosir/react-parallax-tilt/actions/workflows/test-e2e.yml/badge.svg
[test-e2e-url]: https://react-parallax-tilt-test-e2e-report.netlify.app/
[deploy-storybook-badge]: https://github.com/mkosir/react-parallax-tilt/actions/workflows/deploy-storybook.yml/badge.svg
[deploy-storybook-url]: https://github.com/mkosir/react-parallax-tilt/actions/workflows/deploy-storybook.yml
[npm-release-badge]: https://github.com/mkosir/react-parallax-tilt/actions/workflows/npm-release.yml/badge.svg
[npm-release-url]: https://github.com/mkosir/react-parallax-tilt/actions/workflows/npm-release.yml
[coverage-badge]: https://codecov.io/gh/mkosir/react-parallax-tilt/branch/main/graph/badge.svg
[coverage-url]: https://app.codecov.io/github/mkosir/react-parallax-tilt/tree/main
[issues-badge]: https://img.shields.io/github/issues/mkosir/react-parallax-tilt
[issues-url]: https://github.com/mkosir/react-parallax-tilt/issues
[semantic-badge]: https://img.shields.io/badge/%20%20%F0%9F%93%A6%F0%9F%9A%80-semantic--release-e10079.svg
[semantic-url]: https://github.com/semantic-release/semantic-release
[typescript-badge]: https://badges.frapsoft.com/typescript/code/typescript.svg?v=101
[typescript-url]: https://github.com/microsoft/TypeScript