├── .babelrc
├── .gitignore
├── CHANGELOG.md
├── LICENSE
├── README.md
├── __tests__
├── overdrive.test.js
└── prefix.test.js
├── assets
├── browserstack-logo.png
├── nextgram-overdrive.gif
├── overdrive.gif
└── rr-overdrive.gif
├── demos
├── nextgram
│ ├── .babelrc
│ ├── README.md
│ ├── components
│ │ ├── frame.js
│ │ └── modal.js
│ ├── package.json
│ └── pages
│ │ ├── index.js
│ │ ├── photo.js
│ │ └── profile.js
├── nextjs
│ ├── .babelrc
│ ├── README.md
│ ├── package.json
│ ├── pages
│ │ ├── _document.js
│ │ ├── character.js
│ │ └── index.js
│ └── static
│ │ ├── bender.jpg
│ │ ├── fry.jpg
│ │ ├── leela.jpg
│ │ └── zoidberg.png
├── react-router-v4
│ ├── README.md
│ ├── package.json
│ ├── public
│ │ └── index.html
│ └── src
│ │ ├── App.js
│ │ ├── index.css
│ │ └── index.js
└── website
│ ├── .babelrc
│ ├── README.md
│ ├── package.json
│ ├── pages
│ ├── _document.js
│ ├── character.js
│ └── index.js
│ └── static
│ ├── bender.jpg
│ ├── fry.jpg
│ ├── leela.jpg
│ └── zoidberg.png
├── index.d.ts
├── lib
├── Overdrive.js
├── Overdrive.js.map
└── Overdrive.min.js
├── package.json
├── src
├── index.js
├── overdrive.js
└── prefix.js
├── webpack.config.js
└── yarn.lock
/.babelrc:
--------------------------------------------------------------------------------
1 | {
2 | "presets": [
3 | "react",
4 | "es2015",
5 | "es2017"
6 | ],
7 | "plugins": [
8 | "transform-runtime",
9 | "transform-decorators-legacy",
10 | "transform-class-properties",
11 | "transform-object-rest-spread"
12 | ]
13 | }
14 |
--------------------------------------------------------------------------------
/.gitignore:
--------------------------------------------------------------------------------
1 | # Logs
2 | logs
3 | *.log
4 |
5 | # Runtime data
6 | pids
7 | *.pid
8 | *.seed
9 |
10 | # Directory for instrumented libs generated by jscoverage/JSCover
11 | lib-cov
12 |
13 | # Coverage directory used by tools like istanbul
14 | coverage
15 |
16 | # Grunt intermediate storage (http://gruntjs.com/creating-plugins#storing-task-files)
17 | .grunt
18 |
19 | # node-waf configuration
20 | .lock-wscript
21 |
22 | # Compiled binary addons (http://nodejs.org/api/addons.html)
23 | build/Release
24 |
25 | # Dependency directory
26 | # https://www.npmjs.org/doc/misc/npm-faq.html#should-i-check-my-node_modules-folder-into-git
27 | node_modules
28 |
29 | # Remove some common IDE working directories
30 | .idea
31 | .vscode
32 |
33 | # nextjs - demo
34 | .next
--------------------------------------------------------------------------------
/CHANGELOG.md:
--------------------------------------------------------------------------------
1 | ## 0.0.10 (May 16, 2018)
2 |
3 | * Added support for custom easing ([@pizza3](https://github.com/pizza3) in [#46](https://github.com/berzniz/react-overdrive/pull/46))
4 |
5 | ## 0.0.9 (October 3, 2017)
6 |
7 | * React 16 support ([@knpwrs](https://github.com/knpwrs) in [#37](https://github.com/berzniz/react-overdrive/pull/37))
8 |
9 | ## 0.0.8 (July 23, 2017)
10 |
11 | * Added TypeScript definitions ([@sbking](https://github.com/sbking) in [#33](https://github.com/berzniz/react-overdrive/pull/33))
12 |
13 | ## 0.0.7 (May 29, 2017)
14 |
15 | * Added AnimationEnd Event ([@vasco-santos](https://github.com/vasco-santos) in [#28](https://github.com/berzniz/react-overdrive/pull/28))
16 |
17 | ## 0.0.6 (May 20, 2017)
18 |
19 | * Upgrade React and use `prop-types` npm package ([@na-ji](https://github.com/na-ji) in [#26](https://github.com/berzniz/react-overdrive/pull/26))
20 |
21 | ## 0.0.5 (April 16, 2017)
22 |
23 | * Verify `` only takes a single children (`only children`) ([@yujiangshui](https://github.com/yujiangshui) in [#23](https://github.com/berzniz/react-overdrive/pull/23))
24 | * Add `element` prop ([@yujiangshui](https://github.com/yujiangshui) in [#23](https://github.com/berzniz/react-overdrive/pull/23))
25 | * Added `nextgram` demo
26 |
27 | ## 0.0.4 (March 24, 2017)
28 |
29 | * Add style prefix function to support older Safari ([@abstracthat](https://github.com/abstracthat) in [#15](https://github.com/berzniz/react-overdrive/pull/15))
30 | * README.md fixes ([@lex111](https://github.com/lex111) in [#16](https://github.com/berzniz/react-overdrive/pull/16))
31 |
32 | ## 0.0.3 (March 22, 2017)
33 |
34 | * Fix components that use context ([@Anujan](https://github.com/Anujan) in [#12](https://github.com/berzniz/react-overdrive/pull/12))
35 |
36 | ## 0.0.2 (March 21, 2017)
37 |
38 | * Use window.pageYOffset for better cross browser support [#8](https://github.com/berzniz/react-overdrive/pull/8))
39 | * Use defaultProps for duration ([@diegomura](https://github.com/diegomura) in [#3](https://github.com/berzniz/react-overdrive/pull/3))
40 | * README.md improvements ([@timbuckley](https://github.com/timbuckley) in [#4](https://github.com/berzniz/react-overdrive/pull/4))
41 |
42 | ## 0.0.1 (March 6, 2017)
43 |
44 | * Initial public release
45 |
--------------------------------------------------------------------------------
/LICENSE:
--------------------------------------------------------------------------------
1 | The MIT License (MIT)
2 |
3 | Copyright (c) 2017 Tal Bereznitskey
4 |
5 | Permission is hereby granted, free of charge, to any person obtaining a copy
6 | of this software and associated documentation files (the "Software"), to deal
7 | in the Software without restriction, including without limitation the rights
8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9 | copies of the Software, and to permit persons to whom the Software is
10 | furnished to do so, subject to the following conditions:
11 |
12 | The above copyright notice and this permission notice shall be included in all
13 | copies or substantial portions of the Software.
14 |
15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21 | SOFTWARE.
22 |
23 |
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 | # react-overdrive
2 | Super easy magic-move transitions for React apps.
3 |
4 | ## Demos
5 |
6 | 1. [Page transitions](https://overdrive-demo.now.sh)
7 |
8 | 
9 |
10 | 2. [Image Gallery with next.js](https://nextgram-overdrive.now.sh)
11 |
12 | 
13 |
14 | 3. [With React Router](https://overdrive-rr4.now.sh)
15 |
16 | 
17 |
18 | ## Install
19 |
20 | ```
21 | $ npm install react-overdrive --save
22 | ```
23 |
24 | ## Usage
25 |
26 | ### Example with routing
27 |
28 | Wrap any element (not just images) in a `` component. Add the same `id` to create a transition between the elements.
29 |
30 | On `page1.js`:
31 | ```js
32 | import Overdrive from 'react-overdrive'
33 |
34 | const pageA = (props) => (
35 |
36 |
Page A
37 |
38 |
39 |
40 |
41 | );
42 | ```
43 |
44 | On `page2.js`:
45 | ```js
46 | import Overdrive from 'react-overdrive'
47 |
48 | const pageB = (props) => (
49 |
50 |
Page B
51 |
52 |
53 |
54 |
55 | );
56 | ```
57 |
58 | Now route between the pages.
59 |
60 | ### Example without routing
61 |
62 | On `page.js`:
63 | ```js
64 | import Overdrive from 'react-overdrive'
65 |
66 | const page = (props) => (
67 |
68 | {props.loading && }
69 | {!props.loading && }
70 |
71 | );
72 | ```
73 |
74 | ## API
75 |
76 | | Prop | Description | Default Value |
77 | |----------------|------------------------------------------------------------------------------------------------------------------------------|---------------|
78 | | id | Required. A unique string to identify the component. | |
79 | | element | Wrapping element type. | 'div' |
80 | | duration | Animation duration (in milliseconds). | 200 |
81 | | easing | Animation easing function. | '' |
82 | | animationDelay | Add delay of calculating the mounted component position. Setting to `1` usually helps avoiding issues with window scrolling. | null |
83 | | onAnimationEnd | Event dispatched when the animation has finished. | null |
84 |
85 | ## How does it work?
86 |
87 | A transition is made when an `` component is unmounted and another `` is mounted not later than 100ms.
88 |
89 | The transition is made by cloning the unmounted and mounted components, adding them with `absolute` position and CSS transformed from the source to the target position.
90 |
91 | ## Sponsors
92 |
93 | Thanks to the following companies for generously providing their services/products to help improve this project:
94 |
95 |
96 |
97 | Thanks to [BrowserStack](https://browserstack.com/) for providing cross-browser testing.
98 |
99 | ## Who made this?
100 |
101 | Tal Bereznitskey. Find me on Twitter as [@ketacode](https://twitter.com/ketacode).
102 |
--------------------------------------------------------------------------------
/__tests__/overdrive.test.js:
--------------------------------------------------------------------------------
1 | /* global describe, it, expect */
2 |
3 | import React from 'react'
4 | import Overdrive from '../src/overdrive'
5 | import renderer from 'react-test-renderer'
6 |
7 | describe('Overdrive', () => {
8 | it('should use props element to render', () => {
9 | const component = renderer.create(
10 | test
11 | )
12 | let tree = component.toJSON()
13 | expect(tree.type).toEqual('h1')
14 | })
15 | })
16 |
--------------------------------------------------------------------------------
/__tests__/prefix.test.js:
--------------------------------------------------------------------------------
1 | /* global describe, it, expect */
2 |
3 | import prefix from '../src/prefix'
4 |
5 | describe('prefix', () => {
6 | it('should return an object on empty input', () => {
7 | expect(prefix()).toEqual({})
8 | expect(prefix(null)).toEqual({})
9 | expect(prefix({})).toEqual({})
10 | })
11 |
12 | it('should add webkit prefix to correct properties', () => {
13 | expect(prefix({
14 | width: '50px',
15 | transform: 1,
16 | transformOrigin: 2,
17 | transition: 3
18 | })).toEqual({
19 | width: '50px',
20 | WebkitTransform: 1,
21 | WebkitTransformOrigin: 2,
22 | WebkitTransition: 3,
23 | transform: 1,
24 | transformOrigin: 2,
25 | transition: 3
26 | })
27 | })
28 | })
29 |
--------------------------------------------------------------------------------
/assets/browserstack-logo.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/berzniz/react-overdrive/07666391e5d2f7e46685f3efeb82fa66dc0c32d8/assets/browserstack-logo.png
--------------------------------------------------------------------------------
/assets/nextgram-overdrive.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/berzniz/react-overdrive/07666391e5d2f7e46685f3efeb82fa66dc0c32d8/assets/nextgram-overdrive.gif
--------------------------------------------------------------------------------
/assets/overdrive.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/berzniz/react-overdrive/07666391e5d2f7e46685f3efeb82fa66dc0c32d8/assets/overdrive.gif
--------------------------------------------------------------------------------
/assets/rr-overdrive.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/berzniz/react-overdrive/07666391e5d2f7e46685f3efeb82fa66dc0c32d8/assets/rr-overdrive.gif
--------------------------------------------------------------------------------
/demos/nextgram/.babelrc:
--------------------------------------------------------------------------------
1 | {
2 | "presets": ["next/babel"]
3 | }
--------------------------------------------------------------------------------
/demos/nextgram/README.md:
--------------------------------------------------------------------------------
1 |
2 | # NextGram
3 |
4 | Cloned from https://github.com/zeit/nextgram and added `` for transitions.
5 |
6 | # Installation
7 |
8 | $ npm install
9 |
10 | # Running the app
11 |
12 | $ npm run dev
13 |
--------------------------------------------------------------------------------
/demos/nextgram/components/frame.js:
--------------------------------------------------------------------------------
1 | import React from 'react'
2 | import Link from 'next/link'
3 | import Overdrive from 'react-overdrive'
4 |
5 | export default ({ id }) => (
6 |
7 |
8 |
9 |
10 | {id}
11 |
12 |
13 |
14 |
15 | -
16 | @nkzawa
17 | - Great photo!
18 |
19 |
20 |
21 |
22 |
61 |
62 |
63 | )
64 |
--------------------------------------------------------------------------------
/demos/nextgram/components/modal.js:
--------------------------------------------------------------------------------
1 | import React from 'react'
2 | import Photo from './frame'
3 |
4 | export default class extends React.Component {
5 | dismiss (e) {
6 | if (this._shim === e.target ||
7 | this._photoWrap === e.target) {
8 | if (this.props.onDismiss) {
9 | this.props.onDismiss()
10 | }
11 | }
12 | }
13 |
14 | render () {
15 | return (
16 | (this._shim = el)} className='shim' onClick={(e) => this.dismiss(e)}>
17 |
(this._photoWrap = el)} className='photo'>
18 |
19 |
20 |
38 |
39 | )
40 | }
41 | }
42 |
--------------------------------------------------------------------------------
/demos/nextgram/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "nextgram",
3 | "private": true,
4 | "dependencies": {
5 | "next": "^9.3.3",
6 | "react": "^16.0.0",
7 | "react-dom": "^16.0.0",
8 | "react-overdrive": "^0.0.7"
9 | },
10 | "devDependencies": {
11 | "babel-eslint": "7.0.0",
12 | "standard": "8.4.0"
13 | },
14 | "standard": {
15 | "parser": "babel-eslint"
16 | },
17 | "scripts": {
18 | "dev": "next",
19 | "build": "next build",
20 | "start": "NODE_ENV=production next start",
21 | "lint": "standard"
22 | }
23 | }
24 |
--------------------------------------------------------------------------------
/demos/nextgram/pages/index.js:
--------------------------------------------------------------------------------
1 | import React from 'react'
2 | import Router from 'next/router'
3 | import Overdrive from 'react-overdrive'
4 | import Modal from '../components/modal'
5 |
6 | export default class extends React.Component {
7 | static getInitialProps () {
8 | return {
9 | photos: new Array(15).fill(0).map((v, k) => k + 1)
10 | }
11 | }
12 |
13 | constructor (props) {
14 | super(props)
15 | this.onKeyDown = this.onKeyDown.bind(this)
16 | }
17 |
18 | // handling escape close
19 | componentDidMount () {
20 | document.addEventListener('keydown', this.onKeyDown)
21 | }
22 |
23 | componentWillUnmount () {
24 | document.removeEventListener('keydown', this.onKeyDown)
25 | }
26 |
27 | onKeyDown (e) {
28 | if (!this.props.url.query.photoId) return
29 | if (e.keyCode === 27) {
30 | this.props.url.back()
31 | }
32 | }
33 |
34 | dismissModal () {
35 | Router.push('/')
36 | }
37 |
38 | showPhoto (e, id) {
39 | e.preventDefault()
40 | Router.push(`/?photoId=${id}`, `/photo?id=${id}`)
41 | }
42 |
43 | render () {
44 | const { url, photos } = this.props
45 |
46 | return (
47 |
48 | {
49 | url.query.photoId &&
50 |
this.dismissModal()}
53 | />
54 | }
55 | {
56 | photos
57 | .filter((id) => (id !== url.query.photoId))
58 | .map((id) => (
59 |
60 |
69 |
70 | ))
71 | }
72 |
101 |
102 | )
103 | }
104 | }
105 |
--------------------------------------------------------------------------------
/demos/nextgram/pages/photo.js:
--------------------------------------------------------------------------------
1 | import React from 'react'
2 | import Photo from '../components/frame'
3 |
4 | export default ({ url: { query: { id } } }) => (
5 |
22 | )
23 |
--------------------------------------------------------------------------------
/demos/nextgram/pages/profile.js:
--------------------------------------------------------------------------------
1 | import React from 'react'
2 |
3 | export default ({ url: { query: { id } } }) => (
4 |
5 |
6 | User profile:
7 | {' '}
8 | {id}
9 |
10 |
23 |
24 | )
25 |
--------------------------------------------------------------------------------
/demos/nextjs/.babelrc:
--------------------------------------------------------------------------------
1 | {
2 | "presets": ["next/babel"]
3 | }
--------------------------------------------------------------------------------
/demos/nextjs/README.md:
--------------------------------------------------------------------------------
1 | # next.js demo
2 |
3 | Run demo:
4 | ```
5 | npm install
6 | npm run dev
7 | // open http://localhost:3000
8 | ```
--------------------------------------------------------------------------------
/demos/nextjs/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "react-overdrive-nextjs-demo",
3 | "version": "0.0.1",
4 | "private": true,
5 | "scripts": {
6 | "dev": "next",
7 | "build": "next build",
8 | "start": "next start"
9 | },
10 | "keywords": [],
11 | "author": "Tal Bereznitskey (http://berzniz.com/)",
12 | "license": "ISC",
13 | "dependencies": {
14 | "glamor": "^2.20.24",
15 | "next": "^9.3.3",
16 | "react": "^16.0.0",
17 | "react-dom": "^16.0.0",
18 | "react-overdrive": "^0.0.7"
19 | }
20 | }
21 |
--------------------------------------------------------------------------------
/demos/nextjs/pages/_document.js:
--------------------------------------------------------------------------------
1 | import Document, {Head, Main, NextScript} from 'next/document'
2 | import {renderStatic} from 'glamor/server'
3 |
4 | export default class MyDocument extends Document {
5 | static async getInitialProps ({renderPage}) {
6 | const page = renderPage()
7 | const styles = renderStatic(() => page.html)
8 | return {...page, ...styles}
9 | }
10 |
11 | constructor (props) {
12 | super(props)
13 | const {__NEXT_DATA__, ids} = props
14 | if (ids) {
15 | __NEXT_DATA__.ids = this.props.ids
16 | }
17 | }
18 |
19 | render () {
20 | return (
21 |
22 |
23 | Demo
24 |
25 |
26 |
27 |
28 |
29 |
30 |
31 |
32 | )
33 | }
34 | }
35 |
--------------------------------------------------------------------------------
/demos/nextjs/pages/character.js:
--------------------------------------------------------------------------------
1 | import Overdrive from 'react-overdrive'
2 | import Link from 'next/link'
3 | import {css} from 'glamor'
4 |
5 | const container = css({
6 | textAlign: 'center'
7 | })
8 |
9 | const image = css({
10 | boxSizing: 'border-box',
11 | background: '#fff',
12 | width: '180px',
13 | height: '180px',
14 | borderRadius: '10px',
15 | border: '1px solid #ccc',
16 | padding: '5px',
17 | margin: '10px'
18 | })
19 |
20 | const page = ({url}) => {
21 | return (
22 |
23 |
24 |
25 |
26 |
27 |
{url.query.name}!
28 |
Back
29 |
30 |
31 | )
32 | }
33 |
34 | export default page
35 |
--------------------------------------------------------------------------------
/demos/nextjs/pages/index.js:
--------------------------------------------------------------------------------
1 | import React from 'react'
2 | import Overdrive from 'react-overdrive'
3 | import Link from 'next/link'
4 | import {css} from 'glamor'
5 |
6 | const image = css({
7 | boxSizing: 'border-box',
8 | background: '#fff',
9 | width: '80px',
10 | height: '80px',
11 | borderRadius: '50%',
12 | border: '1px solid #ccc',
13 | padding: '5px',
14 | margin: '10px'
15 | })
16 |
17 | const container = css({
18 | marginTop: '200px',
19 | textAlign: 'center',
20 | ' a': {
21 | display: 'inline-block'
22 | }
23 | })
24 |
25 | const characters = [
26 | {
27 | id: 'bender',
28 | name: 'Bender',
29 | image: '40Wzdn4OQbi2ncxkG96z'
30 | },
31 | {
32 | id: 'fry',
33 | name: 'Fry',
34 | image: 'zbglqWZQAyYO5vsHqIbw'
35 | },
36 | {
37 | id: 'leela',
38 | name: 'Leela',
39 | image: 'klwhl9wXRIqRTGWFNoBT'
40 | },
41 | {
42 | id: 'zoidberg',
43 | name: 'Zoidberg',
44 | image: '6xL1j1OQDC4VLBBLieN7'
45 | }
46 | ]
47 |
48 | class page extends React.Component {
49 | constructor (props) {
50 | super(props)
51 | this.state = {characters}
52 | }
53 |
54 | shuffleCharacters () {
55 | const characters = [...this.state.characters]
56 | for (let i = characters.length; i; i--) {
57 | let j = Math.floor(Math.random() * i);
58 | [characters[i - 1], characters[j]] = [characters[j], characters[i - 1]]
59 | }
60 | this.setState({characters})
61 | }
62 |
63 | render () {
64 | const {characters} = this.state
65 | return (
66 |
67 |
Best character?
68 |
69 | {characters.map(character => (
70 |
72 |
73 |
74 |
75 |
76 |
77 |
78 | ))}
79 |
80 |
81 |
82 |
83 |
84 |
85 | This is a small demo of react-overdrive, creating a magic-move experience
86 | while routing.
87 |
88 |
89 | )
90 | }
91 | }
92 |
93 | export default page
94 |
--------------------------------------------------------------------------------
/demos/nextjs/static/bender.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/berzniz/react-overdrive/07666391e5d2f7e46685f3efeb82fa66dc0c32d8/demos/nextjs/static/bender.jpg
--------------------------------------------------------------------------------
/demos/nextjs/static/fry.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/berzniz/react-overdrive/07666391e5d2f7e46685f3efeb82fa66dc0c32d8/demos/nextjs/static/fry.jpg
--------------------------------------------------------------------------------
/demos/nextjs/static/leela.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/berzniz/react-overdrive/07666391e5d2f7e46685f3efeb82fa66dc0c32d8/demos/nextjs/static/leela.jpg
--------------------------------------------------------------------------------
/demos/nextjs/static/zoidberg.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/berzniz/react-overdrive/07666391e5d2f7e46685f3efeb82fa66dc0c32d8/demos/nextjs/static/zoidberg.png
--------------------------------------------------------------------------------
/demos/react-router-v4/README.md:
--------------------------------------------------------------------------------
1 | # react-router demo
2 |
3 | Run demo:
4 | ```
5 | npm install
6 | npm start
7 | // open http://localhost:3000
8 | ```
--------------------------------------------------------------------------------
/demos/react-router-v4/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "react-overdrive-react-router-v4-demo",
3 | "version": "0.1.0",
4 | "private": true,
5 | "dependencies": {
6 | "react": "^16.0.0",
7 | "react-dom": "^16.0.0",
8 | "react-overdrive": "^0.0.7",
9 | "react-router-dom": "^4.0.0"
10 | },
11 | "devDependencies": {
12 | "react-scripts": "0.9.5"
13 | },
14 | "scripts": {
15 | "start": "react-scripts start",
16 | "build": "react-scripts build",
17 | "test": "react-scripts test --env=jsdom",
18 | "eject": "react-scripts eject"
19 | }
20 | }
21 |
--------------------------------------------------------------------------------
/demos/react-router-v4/public/index.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 | React Overdrive demo
7 |
8 |
9 |
10 |
11 |
12 |
--------------------------------------------------------------------------------
/demos/react-router-v4/src/App.js:
--------------------------------------------------------------------------------
1 | import React from 'react'
2 | import Overdrive from 'react-overdrive'
3 | import {
4 | BrowserRouter as Router,
5 | Route,
6 | Link
7 | } from 'react-router-dom'
8 |
9 | const img = ''
10 |
11 | const Home = () => (
12 |
13 |
Feel free to navigate...
14 |
15 |
16 |
17 |
18 | )
19 |
20 | const Circle = () => (
21 |
26 | )
27 |
28 | const Square = () => (
29 |
34 | )
35 |
36 | const App = () => (
37 |
38 |
39 |
40 | - Home
41 | - Circle
42 | - Square
43 |
44 |
45 |
46 |
47 |
48 |
49 |
50 |
51 |
52 | )
53 |
54 | export default App
55 |
--------------------------------------------------------------------------------
/demos/react-router-v4/src/index.css:
--------------------------------------------------------------------------------
1 | * {
2 | box-sizing: border-box;
3 | }
4 |
5 | li {
6 | display: inline-block;
7 | width: 100px;
8 | }
9 |
10 | .page {
11 | position: absolute;
12 | left: 15px;
13 | right: 15px;
14 | }
15 |
16 | .circle {
17 | background: #3cafe4;
18 | border-radius: 50%;
19 | width: 200px;
20 | height: 200px;
21 | }
22 |
23 | .square {
24 | background: #3ce4af;
25 | width: 300px;
26 | height: 300px;
27 | float: right;
28 | }
--------------------------------------------------------------------------------
/demos/react-router-v4/src/index.js:
--------------------------------------------------------------------------------
1 | import React from 'react'
2 | import ReactDOM from 'react-dom'
3 | import App from './App'
4 | import './index.css'
5 |
6 | ReactDOM.render(
7 | ,
8 | document.getElementById('root')
9 | )
10 |
--------------------------------------------------------------------------------
/demos/website/.babelrc:
--------------------------------------------------------------------------------
1 | {
2 | "presets": ["next/babel"]
3 | }
--------------------------------------------------------------------------------
/demos/website/README.md:
--------------------------------------------------------------------------------
1 | # website
2 |
3 | Run demo:
4 | ```
5 | npm install
6 | npm run dev
7 | // open http://localhost:3000
8 | ```
--------------------------------------------------------------------------------
/demos/website/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "react-overdrive-website",
3 | "version": "0.0.1",
4 | "private": true,
5 | "scripts": {
6 | "dev": "next",
7 | "build": "next build",
8 | "start": "next start"
9 | },
10 | "keywords": [],
11 | "author": "Tal Bereznitskey (http://berzniz.com/)",
12 | "license": "ISC",
13 | "dependencies": {
14 | "glamor": "^2.20.24",
15 | "next": "^9.3.3",
16 | "react": "^16.0.0",
17 | "react-dom": "^16.0.0",
18 | "react-overdrive": "^0.0.7"
19 | }
20 | }
21 |
--------------------------------------------------------------------------------
/demos/website/pages/_document.js:
--------------------------------------------------------------------------------
1 | import Document, {Head, Main, NextScript} from 'next/document'
2 | import {renderStatic} from 'glamor/server'
3 |
4 | export default class MyDocument extends Document {
5 | static async getInitialProps ({renderPage}) {
6 | const page = renderPage()
7 | const styles = renderStatic(() => page.html)
8 | return {...page, ...styles}
9 | }
10 |
11 | constructor (props) {
12 | super(props)
13 | const {__NEXT_DATA__, ids} = props
14 | if (ids) {
15 | __NEXT_DATA__.ids = this.props.ids
16 | }
17 | }
18 |
19 | render () {
20 | return (
21 |
22 |
23 | Demo
24 |
25 |
26 |
27 |
28 |
29 |
30 |
31 |
32 | )
33 | }
34 | }
35 |
--------------------------------------------------------------------------------
/demos/website/pages/character.js:
--------------------------------------------------------------------------------
1 | import Overdrive from 'react-overdrive'
2 | import Link from 'next/link'
3 | import {css} from 'glamor'
4 |
5 | const container = css({
6 | textAlign: 'center'
7 | })
8 |
9 | const image = css({
10 | background: '#fff',
11 | width: '180px',
12 | height: '180px',
13 | borderRadius: '10px',
14 | border: '1px solid #ccc',
15 | padding: '5px',
16 | margin: '10px'
17 | })
18 |
19 | const page = ({url}) => {
20 | return (
21 |
22 |
23 |
24 |
25 |
26 |
{url.query.name}!
27 |
Back
28 |
29 |
30 | )
31 | }
32 |
33 | export default page
34 |
--------------------------------------------------------------------------------
/demos/website/pages/index.js:
--------------------------------------------------------------------------------
1 | import React from 'react'
2 | import Overdrive from 'react-overdrive'
3 | import Link from 'next/link'
4 | import { css } from 'glamor'
5 |
6 | css.global('*', {
7 | boxSizing: 'border-box'
8 | })
9 |
10 | css.global('body', {
11 | fontFamily: '-apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif',
12 | textRendering: 'optimizeLegibility',
13 | margin: 0,
14 | fontWeight: 300,
15 | lineHeight: 1.4
16 | })
17 |
18 | const bold = css({
19 | fontWeight: 400
20 | })
21 |
22 | const h1 = css({
23 | fontSize: '32px',
24 | fontWeight: 200,
25 | lineHeight: '40px',
26 | marginTop: 0
27 | })
28 |
29 | const image = css({
30 | background: '#fff',
31 | width: '80px',
32 | height: '80px',
33 | borderRadius: '50%',
34 | border: '1px solid #ccc',
35 | padding: '5px',
36 | margin: '10px'
37 | })
38 |
39 | const container = css({
40 | textAlign: 'center',
41 | ' a': {
42 | display: 'inline-block'
43 | },
44 | marginTop: '50px'
45 | })
46 |
47 | const inset = css({
48 | width: '480px',
49 | maxWidth: '100%',
50 | margin: 'auto'
51 | })
52 |
53 | const originalCharacters = [
54 | {
55 | id: 'bender',
56 | name: 'Bender',
57 | image: '40Wzdn4OQbi2ncxkG96z'
58 | },
59 | {
60 | id: 'fry',
61 | name: 'Fry',
62 | image: 'zbglqWZQAyYO5vsHqIbw'
63 | },
64 | {
65 | id: 'leela',
66 | name: 'Leela',
67 | image: 'klwhl9wXRIqRTGWFNoBT'
68 | },
69 | {
70 | id: 'zoidberg',
71 | name: 'Zoidberg',
72 | image: '6xL1j1OQDC4VLBBLieN7'
73 | }
74 | ]
75 |
76 | const circle = css({
77 | display: 'inline-block',
78 | width: '30px',
79 | height: '30px',
80 | borderRadius: '50%',
81 | background: '#3cafe4'
82 | })
83 |
84 | const square = css({
85 | display: 'inline-block',
86 | width: '30px',
87 | height: '30px',
88 | background: '#3ce4af'
89 | })
90 |
91 | const triangle = css({
92 | display: 'inline-block',
93 | width: '30px',
94 | height: '30px',
95 | borderStyle: 'solid',
96 | borderWidth: '0 15px 30px 15px',
97 | borderColor: 'transparent transparent #af3ce4 transparent'
98 | })
99 |
100 | const code = css({
101 | background: '#272822',
102 | color: '#fff',
103 | padding: '5px',
104 | textAlign: 'left'
105 | })
106 |
107 | const regular = css({
108 | padding: '60px'
109 | })
110 |
111 | const inverse = css({
112 | background: '#333',
113 | color: 'white',
114 | padding: '60px'
115 | })
116 |
117 | const logos = [
118 | 'spotify.com',
119 | 'google.com',
120 | 'apple.com',
121 | 'facebook.com',
122 | 'samsung.com',
123 | 'snapchat.com',
124 | 'tesla.com',
125 | 'walmart.com'
126 | ]
127 |
128 | const Shape = ({ shape, align }) => (
129 |
130 |
131 |
132 | )
133 |
134 | class page extends React.Component {
135 | constructor (props) {
136 | super(props)
137 | this.state = {
138 | logos,
139 | turn: 0
140 | }
141 | }
142 |
143 | componentDidMount () {
144 | this.interval = setInterval(() => {
145 | this.shuffleCharacters()
146 | }, 2000)
147 | }
148 |
149 | componentWillUnmount () {
150 | clearInterval(this.interval)
151 | }
152 |
153 | shuffleCharacters () {
154 | const logos = [...this.state.logos]
155 | for (let i = logos.length; i; i--) {
156 | let j = Math.floor(Math.random() * i);
157 | [logos[i - 1], logos[j]] = [logos[j], logos[i - 1]]
158 | }
159 | this.setState({
160 | logos,
161 | turn: (this.state.turn + 1) % 3
162 | })
163 | }
164 |
165 | render () {
166 | const { turn } = this.state
167 | return (
168 |
169 |
170 |
171 | React Overdrive
172 |
173 | Simple and Powerful animations
174 |
175 |
176 |
npm install react-overdrive --save
177 |
178 |
179 | {turn === 0 && }
180 | {turn === 1 && }
181 | {turn === 2 && }
182 | {turn === 3 && }
183 |
184 |
185 |
186 |
187 |
188 | React Overdrive has a simple component based API to transition
189 | any
190 | element to any element
191 |
192 |
193 |
194 |
195 |
Animate elements between different pages
196 |
211 |
(Click on a character)
212 |
213 |
214 |
215 |
216 |
217 |
Shuffle some Company logos
218 |
219 | {this.state.logos.map(character => (
220 |
223 |
224 |
225 | ))}
226 |
227 |
228 |
229 |
230 |
234 |
235 | )
236 | }
237 | }
238 |
239 | export default page
240 |
--------------------------------------------------------------------------------
/demos/website/static/bender.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/berzniz/react-overdrive/07666391e5d2f7e46685f3efeb82fa66dc0c32d8/demos/website/static/bender.jpg
--------------------------------------------------------------------------------
/demos/website/static/fry.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/berzniz/react-overdrive/07666391e5d2f7e46685f3efeb82fa66dc0c32d8/demos/website/static/fry.jpg
--------------------------------------------------------------------------------
/demos/website/static/leela.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/berzniz/react-overdrive/07666391e5d2f7e46685f3efeb82fa66dc0c32d8/demos/website/static/leela.jpg
--------------------------------------------------------------------------------
/demos/website/static/zoidberg.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/berzniz/react-overdrive/07666391e5d2f7e46685f3efeb82fa66dc0c32d8/demos/website/static/zoidberg.png
--------------------------------------------------------------------------------
/index.d.ts:
--------------------------------------------------------------------------------
1 | declare module 'react-overdrive' {
2 | import {Component, CSSProperties} from 'react'
3 | export interface Props {
4 | id: string
5 | duration?: number
6 | easing?: string
7 | element?: string
8 | animationDelay?: number
9 | onAnimationEnd?: () => void
10 | style?: CSSProperties
11 | }
12 | export interface State {
13 | loading: boolean
14 | }
15 | export default class Overdrive extends Component {}
16 | }
17 |
--------------------------------------------------------------------------------
/lib/Overdrive.min.js:
--------------------------------------------------------------------------------
1 | !function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e(require("react"),require("react-dom")):"function"==typeof define&&define.amd?define("Overdrive",["react","react-dom"],e):"object"==typeof exports?exports.Overdrive=e(require("react"),require("react-dom")):t.Overdrive=e(t.React,t.ReactDOM)}(this,function(t,e){return function(t){function e(r){if(n[r])return n[r].exports;var o=n[r]={i:r,l:!1,exports:{}};return t[r].call(o.exports,o,o.exports,e),o.l=!0,o.exports}var n={};return e.m=t,e.c=n,e.i=function(t){return t},e.d=function(t,n,r){e.o(t,n)||Object.defineProperty(t,n,{configurable:!1,enumerable:!0,get:r})},e.n=function(t){var n=t&&t.__esModule?function(){return t.default}:function(){return t};return e.d(n,"a",n),n},e.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},e.p="",e(e.s=108)}([function(t,e){var n=t.exports={version:"2.6.9"};"number"==typeof __e&&(__e=n)},function(t,e,n){t.exports=!n(6)(function(){return 7!=Object.defineProperty({},"a",{get:function(){return 7}}).a})},function(t,e){var n=t.exports="undefined"!=typeof window&&window.Math==Math?window:"undefined"!=typeof self&&self.Math==Math?self:Function("return this")();"number"==typeof __g&&(__g=n)},function(t,e,n){var r=n(2),o=n(0),i=n(34),u=n(7),a=n(4),c="prototype",f=function(t,e,n){var s,l,p,d=t&f.F,y=t&f.G,m=t&f.S,v=t&f.P,h=t&f.B,b=t&f.W,g=y?o:o[e]||(o[e]={}),O=g[c],w=y?r:m?r[e]:(r[e]||{})[c];y&&(n=e);for(s in n)(l=!d&&w&&void 0!==w[s])&&a(g,s)||(p=l?w[s]:n[s],g[s]=y&&"function"!=typeof w[s]?n[s]:h&&l?i(p,r):b&&w[s]==p?function(t){var e=function(e,n,r){if(this instanceof t){switch(arguments.length){case 0:return new t;case 1:return new t(e);case 2:return new t(e,n)}return new t(e,n,r)}return t.apply(this,arguments)};return e[c]=t[c],e}(p):v&&"function"==typeof p?i(Function.call,p):p,v&&((g.virtual||(g.virtual={}))[s]=p,t&f.R&&O&&!O[s]&&u(O,s,p)))};f.F=1,f.G=2,f.S=4,f.P=8,f.B=16,f.W=32,f.U=64,f.R=128,t.exports=f},function(t,e){var n={}.hasOwnProperty;t.exports=function(t,e){return n.call(t,e)}},function(t,e,n){var r=n(11),o=n(36),i=n(28),u=Object.defineProperty;e.f=n(1)?Object.defineProperty:function(t,e,n){if(r(t),e=i(e,!0),r(n),o)try{return u(t,e,n)}catch(t){}if("get"in n||"set"in n)throw TypeError("Accessors not supported!");return"value"in n&&(t[e]=n.value),t}},function(t,e){t.exports=function(t){try{return!!t()}catch(t){return!0}}},function(t,e,n){var r=n(5),o=n(17);t.exports=n(1)?function(t,e,n){return r.f(t,e,o(1,n))}:function(t,e,n){return t[e]=n,t}},function(t,e){t.exports=function(t){return"object"==typeof t?null!==t:"function"==typeof t}},function(t,e,n){var r=n(37),o=n(19);t.exports=function(t){return r(o(t))}},function(t,e,n){var r=n(26)("wks"),o=n(18),i=n(2).Symbol,u="function"==typeof i;(t.exports=function(t){return r[t]||(r[t]=u&&i[t]||(u?i:o)("Symbol."+t))}).store=r},function(t,e,n){var r=n(8);t.exports=function(t){if(!r(t))throw TypeError(t+" is not an object!");return t}},function(t,e,n){var r=n(42),o=n(20);t.exports=Object.keys||function(t){return r(t,o)}},function(t,e,n){var r=n(19);t.exports=function(t){return Object(r(t))}},function(t,e){function n(){throw new Error("setTimeout has not been defined")}function r(){throw new Error("clearTimeout has not been defined")}function o(t){if(s===setTimeout)return setTimeout(t,0);if((s===n||!s)&&setTimeout)return s=setTimeout,setTimeout(t,0);try{return s(t,0)}catch(e){try{return s.call(null,t,0)}catch(e){return s.call(this,t,0)}}}function i(t){if(l===clearTimeout)return clearTimeout(t);if((l===r||!l)&&clearTimeout)return l=clearTimeout,clearTimeout(t);try{return l(t)}catch(e){try{return l.call(null,t)}catch(e){return l.call(this,t)}}}function u(){m&&d&&(m=!1,d.length?y=d.concat(y):v=-1,y.length&&a())}function a(){if(!m){var t=o(u);m=!0;for(var e=y.length;e;){for(d=y,y=[];++v1)for(var n=1;n";for(e.style.display="none",n(74).appendChild(e),e.src="javascript:",t=e.contentWindow.document,t.open(),t.write(o+"script"+u+"document.F=Object"+o+"/script"+u),t.close(),f=t.F;r--;)delete f[c][i[r]];return f()};t.exports=Object.create||function(t,e){var n;return null!==t?(a[c]=r(t),n=new a,a[c]=null,n[u]=t):n=f(),void 0===e?n:o(n,e)}},function(t,e){e.f=Object.getOwnPropertySymbols},function(t,e,n){var r=n(5).f,o=n(4),i=n(10)("toStringTag");t.exports=function(t,e,n){t&&!o(t=n?t:t.prototype,i)&&r(t,i,{configurable:!0,value:e})}},function(t,e,n){var r=n(26)("keys"),o=n(18);t.exports=function(t){return r[t]||(r[t]=o(t))}},function(t,e,n){var r=n(0),o=n(2),i="__core-js_shared__",u=o[i]||(o[i]={});(t.exports=function(t,e){return u[t]||(u[t]=void 0!==e?e:{})})("versions",[]).push({version:r.version,mode:n(15)?"pure":"global",copyright:"© 2019 Denis Pushkarev (zloirock.ru)"})},function(t,e){var n=Math.ceil,r=Math.floor;t.exports=function(t){return isNaN(t=+t)?0:(t>0?r:n)(t)}},function(t,e,n){var r=n(8);t.exports=function(t,e){if(!r(t))return t;var n,o;if(e&&"function"==typeof(n=t.toString)&&!r(o=n.call(t)))return o;if("function"==typeof(n=t.valueOf)&&!r(o=n.call(t)))return o;if(!e&&"function"==typeof(n=t.toString)&&!r(o=n.call(t)))return o;throw TypeError("Can't convert object to primitive value")}},function(t,e,n){var r=n(2),o=n(0),i=n(15),u=n(30),a=n(5).f;t.exports=function(t){var e=o.Symbol||(o.Symbol=i?{}:r.Symbol||{});"_"==t.charAt(0)||t in e||a(e,t,{value:u.f(t)})}},function(t,e,n){e.f=n(10)},function(t,e,n){"use strict";t.exports="SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED"},function(t,e,n){"use strict";function r(t){return t&&t.__esModule?t:{default:t}}e.__esModule=!0;var o=n(55),i=r(o),u=n(54),a=r(u),c="function"==typeof a.default&&"symbol"==typeof i.default?function(t){return typeof t}:function(t){return t&&"function"==typeof a.default&&t.constructor===a.default&&t!==a.default.prototype?"symbol":typeof t};e.default="function"==typeof a.default&&"symbol"===c(i.default)?function(t){return void 0===t?"undefined":c(t)}:function(t){return t&&"function"==typeof a.default&&t.constructor===a.default&&t!==a.default.prototype?"symbol":void 0===t?"undefined":c(t)}},function(t,e){var n={}.toString;t.exports=function(t){return n.call(t).slice(8,-1)}},function(t,e,n){var r=n(70);t.exports=function(t,e,n){if(r(t),void 0===e)return t;switch(n){case 1:return function(n){return t.call(e,n)};case 2:return function(n,r){return t.call(e,n,r)};case 3:return function(n,r,o){return t.call(e,n,r,o)}}return function(){return t.apply(e,arguments)}}},function(t,e,n){var r=n(8),o=n(2).document,i=r(o)&&r(o.createElement);t.exports=function(t){return i?o.createElement(t):{}}},function(t,e,n){t.exports=!n(1)&&!n(6)(function(){return 7!=Object.defineProperty(n(35)("div"),"a",{get:function(){return 7}}).a})},function(t,e,n){var r=n(33);t.exports=Object("z").propertyIsEnumerable(0)?Object:function(t){return"String"==r(t)?t.split(""):Object(t)}},function(t,e,n){"use strict";var r=n(15),o=n(3),i=n(44),u=n(7),a=n(21),c=n(76),f=n(24),s=n(41),l=n(10)("iterator"),p=!([].keys&&"next"in[].keys()),d="keys",y="values",m=function(){return this};t.exports=function(t,e,n,v,h,b,g){c(n,e,v);var O,w,S,_=function(t){if(!p&&t in T)return T[t];switch(t){case d:case y:return function(){return new n(this,t)}}return function(){return new n(this,t)}},x=e+" Iterator",E=h==y,j=!1,T=t.prototype,P=T[l]||T["@@iterator"]||h&&T[h],M=P||_(h),k=h?E?_("entries"):M:void 0,C="Array"==e?T.entries||P:P;if(C&&(S=s(C.call(new t)))!==Object.prototype&&S.next&&(f(S,x,!0),r||"function"==typeof S[l]||u(S,l,m)),E&&P&&P.name!==y&&(j=!0,M=function(){return P.call(this)}),r&&!g||!p&&!j&&T[l]||u(T,l,M),a[e]=M,a[x]=m,h)if(O={values:E?M:_(y),keys:b?M:_(d),entries:k},g)for(w in O)w in T||i(T,w,O[w]);else o(o.P+o.F*(p||j),e,O);return O}},function(t,e,n){var r=n(16),o=n(17),i=n(9),u=n(28),a=n(4),c=n(36),f=Object.getOwnPropertyDescriptor;e.f=n(1)?f:function(t,e){if(t=i(t),e=u(e,!0),c)try{return f(t,e)}catch(t){}if(a(t,e))return o(!r.f.call(t,e),t[e])}},function(t,e,n){var r=n(42),o=n(20).concat("length","prototype");e.f=Object.getOwnPropertyNames||function(t){return r(t,o)}},function(t,e,n){var r=n(4),o=n(13),i=n(25)("IE_PROTO"),u=Object.prototype;t.exports=Object.getPrototypeOf||function(t){return t=o(t),r(t,i)?t[i]:"function"==typeof t.constructor&&t instanceof t.constructor?t.constructor.prototype:t instanceof Object?u:null}},function(t,e,n){var r=n(4),o=n(9),i=n(72)(!1),u=n(25)("IE_PROTO");t.exports=function(t,e){var n,a=o(t),c=0,f=[];for(n in a)n!=u&&r(a,n)&&f.push(n);for(;e.length>c;)r(a,n=e[c++])&&(~i(f,n)||f.push(n));return f}},function(t,e,n){var r=n(3),o=n(0),i=n(6);t.exports=function(t,e){var n=(o.Object||{})[t]||Object[t],u={};u[t]=e(n),r(r.S+r.F*i(function(){n(1)}),"Object",u)}},function(t,e,n){t.exports=n(7)},function(t,e,n){"use strict";(function(e){"production"===e.env.NODE_ENV?t.exports=n(105):t.exports=n(104)}).call(e,n(14))},function(t,e,n){"use strict";function r(t){return t&&t.__esModule?t:{default:t}}Object.defineProperty(e,"__esModule",{value:!0});var o=n(60),i=r(o),u=n(58),a=r(u),c=n(51),f=r(c),s=n(56),l=r(s),p=n(57),d=r(p),y=n(61),m=r(y),v=n(59),h=r(v),b=n(106),g=r(b),O=n(107),w=r(O),S=n(47),_=r(S),x=n(103),E=r(x),j=w.default.unstable_renderSubtreeIntoContainer,T={},P=function(t){function e(t){(0,l.default)(this,e);var n=(0,m.default)(this,(e.__proto__||(0,f.default)(e)).call(this,t));return n.state={loading:!0},n.animateEnd=n.animateEnd.bind(n),n}return(0,h.default)(e,t),(0,d.default)(e,[{key:"animate",value:function(t,e){var n=this,r=this.props,o=r.duration,i=r.easing;t.top+=window.pageYOffset||document.documentElement.scrollTop;var u=this.getPosition(!0),c="scaleX(1) scaleY(1) translateX(0px) translateY(0px)",f=t.width/u.width,s=t.height/u.height,l=t.left-u.left,p=t.top-u.top;if(1!==f||1!==s||0!==l||0!==p){var d={transition:"transform "+o/1e3+"s "+i+", opacity "+o/1e3+"s "+i,transformOrigin:"0 0 0"},y=g.default.cloneElement(e,{key:"1",style:(0,_.default)((0,a.default)({},d,t,{opacity:1,transform:c}))}),m=g.default.cloneElement(e,{key:"1",style:(0,_.default)((0,a.default)({},d,t,{margin:u.margin,opacity:0,transform:"matrix("+1/f+", 0, 0, "+1/s+", "+-l+", "+-p+")"}))}),v=g.default.cloneElement(this.props.children,{key:"2",style:(0,_.default)((0,a.default)({},d,u,{margin:t.margin,opacity:0,transform:"matrix("+f+", 0, 0, "+s+", "+l+", "+p+")"}))}),h=g.default.cloneElement(this.props.children,{key:"2",style:(0,_.default)((0,a.default)({},d,u,{opacity:1,transform:c}))}),b=g.default.createElement("div",null,y,v),O=g.default.createElement("div",null,m,h);this.setState({loading:!0});var w=document.createElement("div");window.document.body.appendChild(w),this.bodyElement=w,j(this,b,w),this.animationTimeout=setTimeout(function(){j(n,O,w),n.animationTimeout=setTimeout(n.animateEnd,o)},0)}}},{key:"animateEnd",value:function(){this.animationTimeout=null,this.setState({loading:!1}),this.props.onAnimationEnd&&this.props.onAnimationEnd(),window.document.body.removeChild(this.bodyElement)}},{key:"onHide",value:function(){var t=this.props.id,e=g.default.cloneElement(this.props.children),n=this.getPosition();T[t]={prevPosition:n,prevElement:e},this.clearAnimations(),setTimeout(function(){T[t]=!1},100)}},{key:"onShow",value:function(){if(!this.onShowLock){this.onShowLock=!0;var t=this.props,e=t.id,n=t.animationDelay;if(T[e]){var r=T[e],o=r.prevPosition,i=r.prevElement;T[e]=!1,n?this.animationDelayTimeout=setTimeout(this.animate.bind(this,o,i),n):this.animate(o,i)}else this.setState({loading:!1})}}},{key:"componentDidMount",value:function(){this.onShow()}},{key:"clearAnimations",value:function(){clearTimeout(this.animationDelayTimeout),clearTimeout(this.animationTimeout),this.animationTimeout&&this.animateEnd()}},{key:"componentWillUnmount",value:function(){this.onHide()}},{key:"componentWillReceiveProps",value:function(){this.onShowLock=!1,this.onHide()}},{key:"componentDidUpdate",value:function(){this.onShow()}},{key:"getPosition",value:function(t){var e=this.element,n=e.getBoundingClientRect(),r=window.getComputedStyle(e),o=parseInt(r.marginTop,10),i=parseInt(r.marginLeft,10);return{top:n.top-o+(t?1:0)*(window.pageYOffset||document.documentElement.scrollTop),left:n.left-i,width:n.width,height:n.height,margin:r.margin,padding:r.padding,borderRadius:r.borderRadius,position:"absolute"}}},{key:"render",value:function(){var t=this,e=this.props,n=(e.id,e.duration,e.animationDelay,e.style),r=void 0===n?{}:n,o=e.children,u=e.element,c=(0,i.default)(e,["id","duration","animationDelay","style","children","element"]),f=(0,a.default)({},r,{opacity:this.state.loading?0:1}),s=g.default.Children.only(o);return g.default.createElement(u,(0,a.default)({ref:function(e){return t.element=e&&e.firstChild},style:f},c),s)}}]),e}(g.default.Component);P.propTypes={id:E.default.string.isRequired,duration:E.default.number,easing:E.default.string,element:E.default.string,animationDelay:E.default.number,onAnimationEnd:E.default.func},P.defaultProps={element:"div",duration:200,easing:""},e.default=P},function(t,e,n){"use strict";function r(t){return t&&t.__esModule?t:{default:t}}Object.defineProperty(e,"__esModule",{value:!0});var o=n(52),i=r(o),u={transform:!0,transformOrigin:!0,transition:!0},a="Webkit",c=function(t){var e={};return(0,i.default)(t||{}).forEach(function(n){if(u[n]){var r=a+n[0].toUpperCase()+n.slice(1);e[r]=t[n]}e[n]=t[n]}),e};e.default=c},function(t,e,n){t.exports={default:n(62),__esModule:!0}},function(t,e,n){t.exports={default:n(63),__esModule:!0}},function(t,e,n){t.exports={default:n(64),__esModule:!0}},function(t,e,n){t.exports={default:n(65),__esModule:!0}},function(t,e,n){t.exports={default:n(66),__esModule:!0}},function(t,e,n){t.exports={default:n(67),__esModule:!0}},function(t,e,n){t.exports={default:n(68),__esModule:!0}},function(t,e,n){t.exports={default:n(69),__esModule:!0}},function(t,e,n){"use strict";e.__esModule=!0,e.default=function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}},function(t,e,n){"use strict";function r(t){return t&&t.__esModule?t:{default:t}}e.__esModule=!0;var o=n(50),i=r(o);e.default=function(){function t(t,e){for(var n=0;n=0||Object.prototype.hasOwnProperty.call(t,r)&&(n[r]=t[r]);return n}},function(t,e,n){"use strict";function r(t){return t&&t.__esModule?t:{default:t}}e.__esModule=!0;var o=n(32),i=r(o);e.default=function(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!==(void 0===e?"undefined":(0,i.default)(e))&&"function"!=typeof e?t:e}},function(t,e,n){n(87),t.exports=n(0).Object.assign},function(t,e,n){n(88);var r=n(0).Object;t.exports=function(t,e){return r.create(t,e)}},function(t,e,n){n(89);var r=n(0).Object;t.exports=function(t,e,n){return r.defineProperty(t,e,n)}},function(t,e,n){n(90),t.exports=n(0).Object.getPrototypeOf},function(t,e,n){n(91),t.exports=n(0).Object.keys},function(t,e,n){n(92),t.exports=n(0).Object.setPrototypeOf},function(t,e,n){n(95),n(93),n(96),n(97),t.exports=n(0).Symbol},function(t,e,n){n(94),n(98),t.exports=n(30).f("iterator")},function(t,e){t.exports=function(t){if("function"!=typeof t)throw TypeError(t+" is not a function!");return t}},function(t,e){t.exports=function(){}},function(t,e,n){var r=n(9),o=n(85),i=n(84);t.exports=function(t){return function(e,n,u){var a,c=r(e),f=o(c.length),s=i(u,f);if(t&&n!=n){for(;f>s;)if((a=c[s++])!=a)return!0}else for(;f>s;s++)if((t||s in c)&&c[s]===n)return t||s||0;return!t&&-1}}},function(t,e,n){var r=n(12),o=n(23),i=n(16);t.exports=function(t){var e=r(t),n=o.f;if(n)for(var u,a=n(t),c=i.f,f=0;a.length>f;)c.call(t,u=a[f++])&&e.push(u);return e}},function(t,e,n){var r=n(2).document;t.exports=r&&r.documentElement},function(t,e,n){var r=n(33);t.exports=Array.isArray||function(t){return"Array"==r(t)}},function(t,e,n){"use strict";var r=n(22),o=n(17),i=n(24),u={};n(7)(u,n(10)("iterator"),function(){return this}),t.exports=function(t,e,n){t.prototype=r(u,{next:o(1,n)}),i(t,e+" Iterator")}},function(t,e){t.exports=function(t,e){return{value:e,done:!!t}}},function(t,e,n){var r=n(18)("meta"),o=n(8),i=n(4),u=n(5).f,a=0,c=Object.isExtensible||function(){return!0},f=!n(6)(function(){return c(Object.preventExtensions({}))}),s=function(t){u(t,r,{value:{i:"O"+ ++a,w:{}}})},l=function(t,e){if(!o(t))return"symbol"==typeof t?t:("string"==typeof t?"S":"P")+t;if(!i(t,r)){if(!c(t))return"F";if(!e)return"E";s(t)}return t[r].i},p=function(t,e){if(!i(t,r)){if(!c(t))return!0;if(!e)return!1;s(t)}return t[r].w},d=function(t){return f&&y.NEED&&c(t)&&!i(t,r)&&s(t),t},y=t.exports={KEY:r,NEED:!1,fastKey:l,getWeak:p,onFreeze:d}},function(t,e,n){"use strict";var r=n(1),o=n(12),i=n(23),u=n(16),a=n(13),c=n(37),f=Object.assign;t.exports=!f||n(6)(function(){var t={},e={},n=Symbol(),r="abcdefghijklmnopqrst";return t[n]=7,r.split("").forEach(function(t){e[t]=t}),7!=f({},t)[n]||Object.keys(f({},e)).join("")!=r})?function(t,e){for(var n=a(t),f=arguments.length,s=1,l=i.f,p=u.f;f>s;)for(var d,y=c(arguments[s++]),m=l?o(y).concat(l(y)):o(y),v=m.length,h=0;v>h;)d=m[h++],r&&!p.call(y,d)||(n[d]=y[d]);return n}:f},function(t,e,n){var r=n(5),o=n(11),i=n(12);t.exports=n(1)?Object.defineProperties:function(t,e){o(t);for(var n,u=i(e),a=u.length,c=0;a>c;)r.f(t,n=u[c++],e[n]);return t}},function(t,e,n){var r=n(9),o=n(40).f,i={}.toString,u="object"==typeof window&&window&&Object.getOwnPropertyNames?Object.getOwnPropertyNames(window):[],a=function(t){try{return o(t)}catch(t){return u.slice()}};t.exports.f=function(t){return u&&"[object Window]"==i.call(t)?a(t):o(r(t))}},function(t,e,n){var r=n(8),o=n(11),i=function(t,e){if(o(t),!r(e)&&null!==e)throw TypeError(e+": can't set as prototype!")};t.exports={set:Object.setPrototypeOf||("__proto__"in{}?function(t,e,r){try{r=n(34)(Function.call,n(39).f(Object.prototype,"__proto__").set,2),r(t,[]),e=!(t instanceof Array)}catch(t){e=!0}return function(t,n){return i(t,n),e?t.__proto__=n:r(t,n),t}}({},!1):void 0),check:i}},function(t,e,n){var r=n(27),o=n(19);t.exports=function(t){return function(e,n){var i,u,a=String(o(e)),c=r(n),f=a.length;return c<0||c>=f?t?"":void 0:(i=a.charCodeAt(c),i<55296||i>56319||c+1===f||(u=a.charCodeAt(c+1))<56320||u>57343?t?a.charAt(c):i:t?a.slice(c,c+2):u-56320+(i-55296<<10)+65536)}}},function(t,e,n){var r=n(27),o=Math.max,i=Math.min;t.exports=function(t,e){return t=r(t),t<0?o(t+e,0):i(t,e)}},function(t,e,n){var r=n(27),o=Math.min;t.exports=function(t){return t>0?o(r(t),9007199254740991):0}},function(t,e,n){"use strict";var r=n(71),o=n(77),i=n(21),u=n(9);t.exports=n(38)(Array,"Array",function(t,e){this._t=u(t),this._i=0,this._k=e},function(){var t=this._t,e=this._k,n=this._i++;return!t||n>=t.length?(this._t=void 0,o(1)):"keys"==e?o(0,n):"values"==e?o(0,t[n]):o(0,[n,t[n]])},"values"),i.Arguments=i.Array,r("keys"),r("values"),r("entries")},function(t,e,n){var r=n(3);r(r.S+r.F,"Object",{assign:n(79)})},function(t,e,n){var r=n(3);r(r.S,"Object",{create:n(22)})},function(t,e,n){var r=n(3);r(r.S+r.F*!n(1),"Object",{defineProperty:n(5).f})},function(t,e,n){var r=n(13),o=n(41);n(43)("getPrototypeOf",function(){return function(t){return o(r(t))}})},function(t,e,n){var r=n(13),o=n(12);n(43)("keys",function(){return function(t){return o(r(t))}})},function(t,e,n){var r=n(3);r(r.S,"Object",{setPrototypeOf:n(82).set})},function(t,e){},function(t,e,n){"use strict";var r=n(83)(!0);n(38)(String,"String",function(t){this._t=String(t),this._i=0},function(){var t,e=this._t,n=this._i;return n>=e.length?{value:void 0,done:!0}:(t=r(e,n),this._i+=t.length,{value:t,done:!1})})},function(t,e,n){"use strict";var r=n(2),o=n(4),i=n(1),u=n(3),a=n(44),c=n(78).KEY,f=n(6),s=n(26),l=n(24),p=n(18),d=n(10),y=n(30),m=n(29),v=n(73),h=n(75),b=n(11),g=n(8),O=n(13),w=n(9),S=n(28),_=n(17),x=n(22),E=n(81),j=n(39),T=n(23),P=n(5),M=n(12),k=j.f,C=P.f,A=E.f,N=r.Symbol,I=r.JSON,L=I&&I.stringify,$="prototype",R=d("_hidden"),D=d("toPrimitive"),F={}.propertyIsEnumerable,V=s("symbol-registry"),W=s("symbols"),q=s("op-symbols"),z=Object[$],Y="function"==typeof N&&!!T.f,G=r.QObject,H=!G||!G[$]||!G[$].findChild,U=i&&f(function(){return 7!=x(C({},"a",{get:function(){return C(this,"a",{value:7}).a}})).a})?function(t,e,n){var r=k(z,e);r&&delete z[e],C(t,e,n),r&&t!==z&&C(z,e,r)}:C,J=function(t){var e=W[t]=x(N[$]);return e._k=t,e},B=Y&&"symbol"==typeof N.iterator?function(t){return"symbol"==typeof t}:function(t){return t instanceof N},K=function(t,e,n){return t===z&&K(q,e,n),b(t),e=S(e,!0),b(n),o(W,e)?(n.enumerable?(o(t,R)&&t[R][e]&&(t[R][e]=!1),n=x(n,{enumerable:_(0,!1)})):(o(t,R)||C(t,R,_(1,{})),t[R][e]=!0),U(t,e,n)):C(t,e,n)},X=function(t,e){b(t);for(var n,r=v(e=w(e)),o=0,i=r.length;i>o;)K(t,n=r[o++],e[n]);return t},Q=function(t,e){return void 0===e?x(t):X(x(t),e)},Z=function(t){var e=F.call(this,t=S(t,!0));return!(this===z&&o(W,t)&&!o(q,t))&&(!(e||!o(this,t)||!o(W,t)||o(this,R)&&this[R][t])||e)},tt=function(t,e){if(t=w(t),e=S(e,!0),t!==z||!o(W,e)||o(q,e)){var n=k(t,e);return!n||!o(W,e)||o(t,R)&&t[R][e]||(n.enumerable=!0),n}},et=function(t){for(var e,n=A(w(t)),r=[],i=0;n.length>i;)o(W,e=n[i++])||e==R||e==c||r.push(e);return r},nt=function(t){for(var e,n=t===z,r=A(n?q:w(t)),i=[],u=0;r.length>u;)!o(W,e=r[u++])||n&&!o(z,e)||i.push(W[e]);return i};Y||(N=function(){if(this instanceof N)throw TypeError("Symbol is not a constructor!");var t=p(arguments.length>0?arguments[0]:void 0),e=function(n){this===z&&e.call(q,n),o(this,R)&&o(this[R],t)&&(this[R][t]=!1),U(this,t,_(1,n))};return i&&H&&U(z,t,{configurable:!0,set:e}),J(t)},a(N[$],"toString",function(){return this._k}),j.f=tt,P.f=K,n(40).f=E.f=et,n(16).f=Z,T.f=nt,i&&!n(15)&&a(z,"propertyIsEnumerable",Z,!0),y.f=function(t){return J(d(t))}),u(u.G+u.W+u.F*!Y,{Symbol:N});for(var rt="hasInstance,isConcatSpreadable,iterator,match,replace,search,species,split,toPrimitive,toStringTag,unscopables".split(","),ot=0;rt.length>ot;)d(rt[ot++]);for(var it=M(d.store),ut=0;it.length>ut;)m(it[ut++]);u(u.S+u.F*!Y,"Symbol",{for:function(t){return o(V,t+="")?V[t]:V[t]=N(t)},keyFor:function(t){if(!B(t))throw TypeError(t+" is not a symbol!");for(var e in V)if(V[e]===t)return e},useSetter:function(){H=!0},useSimple:function(){H=!1}}),u(u.S+u.F*!Y,"Object",{create:Q,defineProperty:K,defineProperties:X,getOwnPropertyDescriptor:tt,getOwnPropertyNames:et,getOwnPropertySymbols:nt});var at=f(function(){T.f(1)});u(u.S+u.F*at,"Object",{getOwnPropertySymbols:function(t){return T.f(O(t))}}),I&&u(u.S+u.F*(!Y||f(function(){var t=N();return"[null]"!=L([t])||"{}"!=L({a:t})||"{}"!=L(Object(t))})),"JSON",{stringify:function(t){for(var e,n,r=[t],o=1;arguments.length>o;)r.push(arguments[o++]);if(n=e=r[1],(g(e)||void 0!==t)&&!B(t))return h(e)||(e=function(t,e){if("function"==typeof n&&(e=n.call(this,t,e)),!B(e))return e}),r[1]=e,L.apply(I,r)}}),N[$][D]||n(7)(N[$],D,N[$].valueOf),l(N,"Symbol"),l(Math,"Math",!0),l(r.JSON,"JSON",!0)},function(t,e,n){n(29)("asyncIterator")},function(t,e,n){n(29)("observable")},function(t,e,n){n(86);for(var r=n(2),o=n(7),i=n(21),u=n(10)("toStringTag"),a="CSSRuleList,CSSStyleDeclaration,CSSValueList,ClientRectList,DOMRectList,DOMStringList,DOMTokenList,DataTransferItemList,FileList,HTMLAllCollection,HTMLCollection,HTMLFormElement,HTMLSelectElement,MediaList,MimeTypeArray,NamedNodeMap,NodeList,PaintRequestList,Plugin,PluginArray,SVGLengthList,SVGNumberList,SVGPathSegList,SVGPointList,SVGStringList,SVGTransformList,SourceBufferList,StyleSheetList,TextTrackCueList,TextTrackList,TouchList".split(","),c=0;c1?"Invalid arguments supplied to oneOf, expected an array, got "+arguments.length+" arguments. A common mistake is to write oneOf(x, y, z) instead of oneOf([x, y, z]).":"Invalid argument supplied to oneOf, expected an array."),r)}function w(t){function e(e,n,r,o,i){if("function"!=typeof t)return new p("Property `"+i+"` of component `"+r+"` has invalid PropType notation inside objectOf.");var a=e[n],f=P(a);if("object"!==f)return new p("Invalid "+o+" `"+i+"` of type `"+f+"` supplied to `"+r+"`, expected an object.");for(var s in a)if(c(a,s)){var l=t(a,s,r,o,i+"."+s,u);if(l instanceof Error)return l}return null}return d(e)}function S(t){function n(e,n,r,o,i){for(var a=0;a>",L={array:y("array"),bool:y("boolean"),func:y("function"),number:y("number"),object:y("object"),string:y("string"),symbol:y("symbol"),any:m(),arrayOf:v,element:h(),elementType:b(),instanceOf:g,node:_(),objectOf:w,oneOf:O,oneOfType:S,shape:x,exact:E};return p.prototype=Error.prototype,L.checkPropTypes=a,L.resetWarningCache=a.resetWarningCache,L.PropTypes=L,L}}).call(e,n(14))},function(t,e,n){(function(e){if("production"!==e.env.NODE_ENV){var r=n(45);t.exports=n(102)(r.isElement,!0)}else t.exports=n(101)()}).call(e,n(14))},function(t,e,n){"use strict";(function(t){/** @license React v16.9.0
7 | * react-is.development.js
8 | *
9 | * Copyright (c) Facebook, Inc. and its affiliates.
10 | *
11 | * This source code is licensed under the MIT license found in the
12 | * LICENSE file in the root directory of this source tree.
13 | */
14 | "production"!==t.env.NODE_ENV&&function(){function t(t){return"string"==typeof t||"function"==typeof t||t===g||t===E||t===w||t===O||t===T||t===P||"object"==typeof t&&null!==t&&(t.$$typeof===k||t.$$typeof===M||t.$$typeof===S||t.$$typeof===_||t.$$typeof===j||t.$$typeof===C||t.$$typeof===A)}function n(t){if("object"==typeof t&&null!==t){var e=t.$$typeof;switch(e){case h:var n=t.type;switch(n){case x:case E:case g:case w:case O:case T:return n;default:var r=n&&n.$$typeof;switch(r){case _:case j:case S:return r;default:return e}}case k:case M:case b:return e}}}function r(t){return B||(B=!0,L(!1,"The ReactIs.isAsyncMode() alias has been deprecated, and will be removed in React 17+. Update your code to use ReactIs.isConcurrentMode() instead. It has the exact same API.")),o(t)||n(t)===x}function o(t){return n(t)===E}function i(t){return n(t)===_}function u(t){return n(t)===S}function a(t){return"object"==typeof t&&null!==t&&t.$$typeof===h}function c(t){return n(t)===j}function f(t){return n(t)===g}function s(t){return n(t)===k}function l(t){return n(t)===M}function p(t){return n(t)===b}function d(t){return n(t)===w}function y(t){return n(t)===O}function m(t){return n(t)===T}Object.defineProperty(e,"__esModule",{value:!0});var v="function"==typeof Symbol&&Symbol.for,h=v?Symbol.for("react.element"):60103,b=v?Symbol.for("react.portal"):60106,g=v?Symbol.for("react.fragment"):60107,O=v?Symbol.for("react.strict_mode"):60108,w=v?Symbol.for("react.profiler"):60114,S=v?Symbol.for("react.provider"):60109,_=v?Symbol.for("react.context"):60110,x=v?Symbol.for("react.async_mode"):60111,E=v?Symbol.for("react.concurrent_mode"):60111,j=v?Symbol.for("react.forward_ref"):60112,T=v?Symbol.for("react.suspense"):60113,P=v?Symbol.for("react.suspense_list"):60120,M=v?Symbol.for("react.memo"):60115,k=v?Symbol.for("react.lazy"):60116,C=v?Symbol.for("react.fundamental"):60117,A=v?Symbol.for("react.responder"):60118,N=function(){},I=function(t){for(var e=arguments.length,n=Array(e>1?e-1:0),r=1;r2?n-2:0),o=2;o{sourceStart}{targetStart}
84 | const end = {sourceEnd}{targetEnd}
85 |
86 | this.setState({ loading: true })
87 |
88 | const bodyElement = document.createElement('div')
89 | window.document.body.appendChild(bodyElement)
90 | this.bodyElement = bodyElement
91 | renderSubtreeIntoContainer(this, start, bodyElement)
92 |
93 | this.animationTimeout = setTimeout(() => {
94 | renderSubtreeIntoContainer(this, end, bodyElement)
95 | this.animationTimeout = setTimeout(this.animateEnd, duration)
96 | }, 0)
97 | }
98 |
99 | animateEnd () {
100 | this.animationTimeout = null
101 | this.setState({ loading: false })
102 | this.props.onAnimationEnd && this.props.onAnimationEnd()
103 | window.document.body.removeChild(this.bodyElement)
104 | }
105 |
106 | onHide () {
107 | const { id } = this.props
108 | const prevElement = React.cloneElement(this.props.children)
109 | const prevPosition = this.getPosition()
110 | components[id] = {
111 | prevPosition,
112 | prevElement
113 | }
114 |
115 | this.clearAnimations()
116 |
117 | setTimeout(() => {
118 | components[id] = false
119 | }, 100)
120 | }
121 |
122 | onShow () {
123 | if (this.onShowLock) {
124 | return
125 | }
126 | this.onShowLock = true
127 | const { id, animationDelay } = this.props
128 | if (components[id]) {
129 | const { prevPosition, prevElement } = components[id]
130 | components[id] = false
131 | if (animationDelay) {
132 | this.animationDelayTimeout = setTimeout(this.animate.bind(this, prevPosition, prevElement), animationDelay)
133 | } else {
134 | this.animate(prevPosition, prevElement)
135 | }
136 | } else {
137 | this.setState({ loading: false })
138 | }
139 | }
140 |
141 | componentDidMount () {
142 | this.onShow()
143 | }
144 |
145 | clearAnimations () {
146 | clearTimeout(this.animationDelayTimeout)
147 | clearTimeout(this.animationTimeout)
148 |
149 | if (this.animationTimeout) {
150 | this.animateEnd()
151 | }
152 | }
153 |
154 | componentWillUnmount () {
155 | this.onHide()
156 | }
157 |
158 | componentWillReceiveProps () {
159 | this.onShowLock = false
160 | this.onHide()
161 | }
162 |
163 | componentDidUpdate () {
164 | this.onShow()
165 | }
166 |
167 | getPosition (addOffset) {
168 | const node = this.element
169 | const rect = node.getBoundingClientRect()
170 | const computedStyle = window.getComputedStyle(node)
171 | const marginTop = parseInt(computedStyle.marginTop, 10)
172 | const marginLeft = parseInt(computedStyle.marginLeft, 10)
173 | return {
174 | top: (rect.top - marginTop) + ((addOffset ? 1 : 0) * (window.pageYOffset || document.documentElement.scrollTop)),
175 | left: (rect.left - marginLeft),
176 | width: rect.width,
177 | height: rect.height,
178 | margin: computedStyle.margin,
179 | padding: computedStyle.padding,
180 | borderRadius: computedStyle.borderRadius,
181 | position: 'absolute'
182 | }
183 | }
184 |
185 | render () {
186 | const { id, duration, animationDelay, style = {}, children, element, ...rest } = this.props
187 | const newStyle = {
188 | ...style,
189 | opacity: (this.state.loading ? 0 : 1)
190 | }
191 | const onlyChild = React.Children.only(children)
192 |
193 | return React.createElement(
194 | element,
195 | {
196 | ref: c => (this.element = c && c.firstChild),
197 | style: newStyle,
198 | ...rest
199 | },
200 | onlyChild
201 | )
202 | }
203 | }
204 |
205 | Overdrive.propTypes = {
206 | id: PropTypes.string.isRequired,
207 | duration: PropTypes.number,
208 | easing: PropTypes.string,
209 | element: PropTypes.string,
210 | animationDelay: PropTypes.number,
211 | onAnimationEnd: PropTypes.func
212 | }
213 |
214 | Overdrive.defaultProps = {
215 | element: 'div',
216 | duration: 200,
217 | easing: ''
218 | }
219 |
220 | export default Overdrive
221 |
--------------------------------------------------------------------------------
/src/prefix.js:
--------------------------------------------------------------------------------
1 | const propertiesToPrefix = {
2 | transform: true,
3 | transformOrigin: true,
4 | transition: true
5 | }
6 |
7 | const webkitPrefix = 'Webkit'
8 |
9 | const prefix = (styles) => {
10 | const prefixedStyles = {}
11 | const styleProperties = Object.keys(styles || {})
12 | styleProperties.forEach(property => {
13 | if (propertiesToPrefix[property]) {
14 | const prefixedProperty = webkitPrefix + property[0].toUpperCase() + property.slice(1)
15 | prefixedStyles[prefixedProperty] = styles[property]
16 | }
17 | prefixedStyles[property] = styles[property]
18 | })
19 | return prefixedStyles
20 | }
21 |
22 | export default prefix
23 |
--------------------------------------------------------------------------------
/webpack.config.js:
--------------------------------------------------------------------------------
1 | /* global __dirname, require, module */
2 |
3 | const webpack = require('webpack')
4 | const UglifyJsPlugin = webpack.optimize.UglifyJsPlugin
5 | const path = require('path')
6 | const env = require('yargs').argv.env // use --env with webpack 2
7 |
8 | const libraryName = 'Overdrive'
9 |
10 | const plugins = []
11 | let outputFile
12 |
13 | if (env === 'build') {
14 | plugins.push(new UglifyJsPlugin({ minimize: true }))
15 | outputFile = libraryName + '.min.js'
16 | } else {
17 | outputFile = libraryName + '.js'
18 | }
19 |
20 | const config = {
21 | entry: path.join(__dirname, '/src/index.js'),
22 | devtool: 'source-map',
23 | output: {
24 | path: path.join(__dirname, '/lib'),
25 | filename: outputFile,
26 | library: libraryName,
27 | libraryTarget: 'umd',
28 | umdNamedDefine: true
29 | },
30 | module: {
31 | rules: [
32 | {
33 | test: /(\.jsx|\.js)$/,
34 | loader: 'babel-loader',
35 | exclude: /(node_modules|bower_components)/,
36 | query: {
37 | presets: ['react', ['es2015', { modules: false }], 'es2017'],
38 | plugins: [
39 | 'transform-runtime',
40 | 'transform-decorators-legacy',
41 | 'transform-class-properties',
42 | 'transform-object-rest-spread'
43 | ]
44 | }
45 | }
46 | ]
47 | },
48 | externals: {
49 | react: {
50 | root: 'React',
51 | commonjs2: 'react',
52 | commonjs: 'react',
53 | amd: 'react'
54 | },
55 | 'react-dom': {
56 | root: 'ReactDOM',
57 | commonjs2: 'react-dom',
58 | commonjs: 'react-dom',
59 | amd: 'react-dom'
60 | }
61 | },
62 | plugins: plugins
63 | }
64 |
65 | module.exports = config
66 |
--------------------------------------------------------------------------------