0.1.0 • Published 3 years ago

react-animated-routes v0.1.0

Weekly downloads
-
License
ISC
Repository
github
Last release
3 years ago

react-animated-routes

Small wrapper over the Route and CSSTransition with the ability to override CSSTransition props.

Install

npm i react-animated-routes
# You also need to make sure you have peer dependencies installed
npm i react react-dom react-router-dom react-router-last-location

Basic usage

<AnimatedRoute /> combines <Route /> and <CSSTransition /> logic and props, so it's easier to use:

// You can write
<AnimatedRoute exact path="/page" timeout={300} classNames="fade">
    <div>Page</div>
</AnimatedRoute>

// Instead of
<Route exact path="/page">
  {({ match }) => (
    <CSSTransition
      in={match != null}
      timeout={300}
      classNames="fade"
      unmountOnExit
    >
      <div>Page</div>
    </CSSTransition>
  )}
</Route>

Override props

You can also override CSSTransition props with location state.

To do this, you need to declare <LastLocationProvider /> inside <Router />:

import { BrowserRouter as Router } from 'react-router-dom';
import { LastLocationProvider } from 'react-router-last-location';

const App = () => (
  <Router>
    <LastLocationProvider>...</LastLocationProvider>
  </Router>
);

Then you can override CSSTransition props with history object or Link component:

// Override CSSTransition props
const transition = { timeout: 400, classNames="slide" };

// With history object
history.push('/page', { transition });

// Or Link component
<Link
  to={{
    pathname: '/page',
    state: { transition },
  }}
/>

Demo

See it in action.

0.1.0

3 years ago

0.0.8

4 years ago

0.0.3

4 years ago

0.0.5

4 years ago

0.0.4

4 years ago

0.0.7

4 years ago

0.0.6

4 years ago

0.0.2

4 years ago

0.0.1

4 years ago