React Animation Suite
Finally an animation library which is developer friendly!
This is a customisable developer-friendly library for animating react components. This library is unopinionated about what should be the theory of animation, rather it focuses on how it should be implemented in React.
Usage
Install
npm i react-animation-suite -g
OR
yarn add react-animation-suite
Importing
import { Slider } from "react-animation-suite"
OR
import { Slider } from "react-transition-suite/dist/lib/Slider"
Using
Say you have a component whose JSX is like below:
<div className="container">
<WannabeSlider {...props} />
</div>
Now you can slide the WannabeSlider like this:
<div className="container">
<Slider {...sliderProps} direction={0} childProps={{height: 100, width: 100, transitionTime: 300}}>
<WannabeSlider {...props} />
</Slider>
</div>
Prior learnings required from a developer implementing it:
- ReactJS
- Javascript
CSS
Yes, that’s it!
You don’t need to know complicated physics concepts like spring, animation basics, using react component's lifecycle methods, nothing! Just plug and play.
Problem Statement
- Animation libraries are very opinionated about how animations should be done, how to implement timings, stiffness, etc.
- Almost all libraries require a lot of learning before implementing.
- Animation libraries tend to do magic underneath, reading their source code is a difficult task if you want to know their internal working. So it is difficult to contribute in them.
- Implementing any animation library requires a developer to implement it from starting phase of development of target component. Implementing a library in the middle or end stage of development is very tough.
- Some animation libraries create dom element and try to handle async processes. This should ideally be a part of developer’s app.
Solution proposed in this library:
- Do not create DOM elements for consumer(developer implementing this library), many Slider libraries do so.
- Do not handle dom events, observables, timeouts or any async operation for consumer. If something can cause bad user experience then throw an error or give a warning.
- Take least data from consumer.
- Provide more control to consumer.
- Taking data or providing controls should be done only through props. In case of HOCs, it should be simple json config data.
- Animation should be generic for any scenario that a developer may face, but it should be specific for a particular animation type, ex. Slider.
- Expressing the implementation of animation should be as easy as possible, preferably plain js or css properties should be written.
- Most important of all - Applying animation should be like decorating a component. Animation components should not affect the logic of developer's component and it should not be thought prior to development of any component.
- Checkout the codesandbox. Keep your eyes on two components - SliderWithAnimation and SliderWithoutAnimation. Just check the render method of both(rest of the code is just any other react typescript app). Check how SingleElement is written in both, and you will know how easy it is to implement Slider provided from this library.
Try it out yourself:
Documentations exported components:
Features
- For now we have only Slider component.
Tech
- ReactJS - Obvious!
- React Transition Group - This library is being used internally. This is a transition state management library and is very simple. Please read about how to use this in CONTRIBUTING.md.
- Typescript - This won't be downloaded as dependency, but just to point out - I am using typescript and I would suggest other developers to use typescript as it makes life so good!!!
Don't get intimidated by typescript if you don't know it. You can use this library in your plain javascript project too!
Note -- There is no flow implementation as of now but if someone can contribute for that, it will be great.
Want to contribute? Great!
Please read CONTRIBUTING.md.
Special thanks to TypeScript library starter for simplifying the process to create a javascript library with typescript.
I am currently working in Microsoft and I am a big enthusiast of javascript.