import { defineComponent, openBlock, createBlock, Transition, mergeProps, unref, toHandlers, withCtx, renderSlot } from 'vue';
|
import '../../../hooks/index.mjs';
|
import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
|
import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
|
|
const __default__ = defineComponent({
|
name: "ElCollapseTransition"
|
});
|
const _sfc_main = /* @__PURE__ */ defineComponent({
|
...__default__,
|
setup(__props) {
|
const ns = useNamespace("collapse-transition");
|
const on = {
|
beforeEnter(el) {
|
if (!el.dataset)
|
el.dataset = {};
|
el.dataset.oldPaddingTop = el.style.paddingTop;
|
el.dataset.oldPaddingBottom = el.style.paddingBottom;
|
el.style.maxHeight = 0;
|
el.style.paddingTop = 0;
|
el.style.paddingBottom = 0;
|
},
|
enter(el) {
|
el.dataset.oldOverflow = el.style.overflow;
|
if (el.scrollHeight !== 0) {
|
el.style.maxHeight = `${el.scrollHeight}px`;
|
el.style.paddingTop = el.dataset.oldPaddingTop;
|
el.style.paddingBottom = el.dataset.oldPaddingBottom;
|
} else {
|
el.style.maxHeight = 0;
|
el.style.paddingTop = el.dataset.oldPaddingTop;
|
el.style.paddingBottom = el.dataset.oldPaddingBottom;
|
}
|
el.style.overflow = "hidden";
|
},
|
afterEnter(el) {
|
el.style.maxHeight = "";
|
el.style.overflow = el.dataset.oldOverflow;
|
},
|
beforeLeave(el) {
|
if (!el.dataset)
|
el.dataset = {};
|
el.dataset.oldPaddingTop = el.style.paddingTop;
|
el.dataset.oldPaddingBottom = el.style.paddingBottom;
|
el.dataset.oldOverflow = el.style.overflow;
|
el.style.maxHeight = `${el.scrollHeight}px`;
|
el.style.overflow = "hidden";
|
},
|
leave(el) {
|
if (el.scrollHeight !== 0) {
|
el.style.maxHeight = 0;
|
el.style.paddingTop = 0;
|
el.style.paddingBottom = 0;
|
}
|
},
|
afterLeave(el) {
|
el.style.maxHeight = "";
|
el.style.overflow = el.dataset.oldOverflow;
|
el.style.paddingTop = el.dataset.oldPaddingTop;
|
el.style.paddingBottom = el.dataset.oldPaddingBottom;
|
}
|
};
|
return (_ctx, _cache) => {
|
return openBlock(), createBlock(Transition, mergeProps({
|
name: unref(ns).b()
|
}, toHandlers(on)), {
|
default: withCtx(() => [
|
renderSlot(_ctx.$slots, "default")
|
]),
|
_: 3
|
}, 16, ["name"]);
|
};
|
}
|
});
|
var CollapseTransition = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "/home/runner/work/element-plus/element-plus/packages/components/collapse-transition/src/collapse-transition.vue"]]);
|
|
export { CollapseTransition as default };
|
//# sourceMappingURL=collapse-transition.mjs.map
|