@exah/promise-animejs
v0.0.2
Published
Simple wrapper around Anime.js, that resolves Promise when animation is complete
Downloads
6
Readme
Promise + Anime.js
Simple wrapper around Anime.js, that resolves Promise when animation is complete.
Install
Note: this package include animejs as peer dependency, so you must install it manually
$ npm install -S animejs @exah/promise-animejs
Why?
It can help chain animation, i.e. animate multiple dom nodes in order:
import promiseAnime from '@exah/promise-animejs'
const $nodes = document.querySelectorAll('.class-to-animate')
const animations = Array.from($nodes).reduce(
(promise, $el) => promise.then(() =>
promiseAnime({
targets: $el,
opacity: [0, 1],
easing: 'easeOutCirc'
})
),
Promise.resolve()
)
/* All animations is finished */
animations
.then(() => console.log('complete'))
Usage
API
promiseAnime(
{ /* anime options */ },
function (animation) { /* control animation */ }
)
.then(animation => /* animation complete */)
Example
Simply pass Anime.js options to promiseAnime
function.
// before
anime({
targets: 'div',
opacity: [0, 1],
easing: 'easeOutCirc',
complete(animation) {
console.log('complete')
}
})
// after
promiseAnime({
targets: 'div',
opacity: [0, 1],
easing: 'easeOutCirc'
})
.then(animation => console.log('complete'))
Since wrapper returns Promise, to access animation instance simply pass handler as second argument.
promiseAnime({ /* options */ }, animation => {
animation.pause() // pause animation
})
.then(animation => console.log('complete'))
MIT License. © 2017 John Grishin.