ant-design-vue
Version:
An enterprise-class UI design language and Vue-based implementation
62 lines (56 loc) • 1.68 kB
JavaScript
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _vue = require("vue");
var _class = require("../vc-util/Dom/class");
var collapseMotion = function collapseMotion() {
var name = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'ant-motion-collapse';
var appear = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;
return {
name: name,
appear: appear,
css: true,
onBeforeEnter: function onBeforeEnter(node) {
node.style.height = '0px';
node.style.opacity = '0';
(0, _class.addClass)(node, name);
},
onEnter: function onEnter(node) {
(0, _vue.nextTick)(function () {
node.style.height = "".concat(node.scrollHeight, "px");
node.style.opacity = '1';
});
},
onAfterEnter: function onAfterEnter(node) {
if (node) {
(0, _class.removeClass)(node, name);
node.style.height = null;
node.style.opacity = null;
}
},
onBeforeLeave: function onBeforeLeave(node) {
(0, _class.addClass)(node, name);
node.style.height = "".concat(node.offsetHeight, "px");
node.style.opacity = null;
},
onLeave: function onLeave(node) {
setTimeout(function () {
node.style.height = '0px';
node.style.opacity = '0';
});
},
onAfterLeave: function onAfterLeave(node) {
if (node) {
(0, _class.removeClass)(node, name);
if (node.style) {
node.style.height = null;
node.style.opacity = null;
}
}
}
};
};
var _default = collapseMotion;
exports.default = _default;
;