Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/devgru/redux-tween
Tween Redux store state 🕛🕑🕓🕕🕗🕙🕛
https://github.com/devgru/redux-tween
animation redux tweening
Last synced: about 2 months ago
JSON representation
Tween Redux store state 🕛🕑🕓🕕🕗🕙🕛
- Host: GitHub
- URL: https://github.com/devgru/redux-tween
- Owner: devgru
- Created: 2017-02-18T12:27:49.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2017-10-10T00:20:04.000Z (about 7 years ago)
- Last Synced: 2024-10-29T21:21:02.764Z (2 months ago)
- Topics: animation, redux, tweening
- Language: JavaScript
- Homepage:
- Size: 1.07 MB
- Stars: 8
- Watchers: 2
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Redux Tween
> Tween store state.
>
> Library is experimental and may not meet your expectations.
>
> If you need a simple way to animate several parameters in React-based elements try [Jeremy Stucki's approach](https://bl.ocks.org/herrstucki/27dc76b6f8411b4725bb) using well-known [React Motion](https://github.com/chenglou/react-motion) library.Redux Tween provides a way to change state in Redux store smoothly, interpolating states in between.
To achieve this Redux Tween either enhances store or wraps some of action creators and reducers (i.e. some of your [ducks](https://github.com/erikras/ducks-modular-redux)).
## How it works
Redux Tween uses wrapped reducer to calculate next state. Instead of immediately applying new state, Redux Tween launches transition to push interpolated states on every frame.
Redux Tween uses [d3-transition](https://github.com/d3/d3-transition) to start and interrupt transitions. Redux Tween allows running one transition per reducer, interrupting previous transition if necessary.
Redux Tween uses [d3-interpolate](https://github.com/d3/d3-interpolate) which allows interpolating between numbers, strings, colors, dates. Most importantly, it supports objects and arrays interpolation so you can interpolate custom nested data structures (even the store itself).
## Installing
```sh
$ yarn add redux-tween
# or
$ npm install --save redux-tween
```## Integration and usage
- [Basic](./docs/BASIC.md), store-based integration.
- [Advanced](./docs/ADVANCED.md), per-reducer integration.## API Reference
Is [here](./docs/API.md).
## Running examples
```sh
$ cd examples/store
$ # or
$ cd examples/action-and-reducer
$ yarn
$ yarn start
```## TODO
- Add basic/advanced integrations comparison;
- More tests;
- Better examples;
- Improve examples and dependencies organization (300 MiB is too much);
- Check for corner cases;
- Rewrite in TS.## Development
Your input is highly appreciated.
This library is experimental, bug reports and PRs are welcome. I'd be happy to help you integrating Redux Tween into other software.
To modify library, follow these steps:
* Install dependencies: `yarn`;
* Develop;
* Run tests: `yarn test`;
* Build `yarn build`.## License
MIT © [Dmitriy Semyushkin](https://devg.ru)