ant-design/components/common/openAnimation.js
2016-01-11 09:49:31 +08:00

46 lines
870 B
JavaScript

let velocity;
if (typeof document !== 'undefined' && typeof window !== 'undefined') {
velocity = require('velocity-animate');
}
function animate(node, show, transitionName, done) {
let ok;
function complete() {
if (!ok) {
ok = true;
done();
}
}
// Fix safari flash bug
/*eslint-disable */
node.style.display = show ? 'block' : 'none';
/*eslint-enable */
velocity(node, transitionName, {
duration: 240,
complete,
easing: 'easeInOutQuad'
});
return {
stop() {
velocity(node, 'finish');
complete();
}
};
}
const animation = {
enter(node, done) {
return animate(node, false, 'slideDown', done);
},
leave(node, done) {
return animate(node, true, 'slideUp', done);
},
appear(node, done) {
return animate(node, false, 'slideDown', done);
},
};
module.exports = animation;