mirror of
https://github.com/ant-design/ant-design.git
synced 2024-11-25 11:40:04 +08:00
44 lines
837 B
JavaScript
44 lines
837 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
|
|
node.style.display = show ? 'block' : 'none';
|
|
velocity(node, transitionName, {
|
|
duration: 240,
|
|
complete: 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;
|