| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990 |
- import { defineComponent, openBlock, createBlock, Transition, mergeProps, unref, toHandlers, withCtx, renderSlot } from 'vue';
- 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 reset = (el) => {
- el.style.maxHeight = "";
- el.style.overflow = el.dataset.oldOverflow;
- el.style.paddingTop = el.dataset.oldPaddingTop;
- el.style.paddingBottom = el.dataset.oldPaddingBottom;
- };
- const on = {
- beforeEnter(el) {
- if (!el.dataset)
- el.dataset = {};
- el.dataset.oldPaddingTop = el.style.paddingTop;
- el.dataset.oldPaddingBottom = el.style.paddingBottom;
- if (el.style.height)
- el.dataset.elExistsHeight = el.style.height;
- el.style.maxHeight = 0;
- el.style.paddingTop = 0;
- el.style.paddingBottom = 0;
- },
- enter(el) {
- requestAnimationFrame(() => {
- el.dataset.oldOverflow = el.style.overflow;
- if (el.dataset.elExistsHeight) {
- el.style.maxHeight = el.dataset.elExistsHeight;
- } else if (el.scrollHeight !== 0) {
- el.style.maxHeight = `${el.scrollHeight}px`;
- } 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;
- },
- enterCancelled(el) {
- reset(el);
- },
- 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) {
- reset(el);
- },
- leaveCancelled(el) {
- reset(el);
- }
- };
- 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", "collapse-transition.vue"]]);
- export { CollapseTransition as default };
- //# sourceMappingURL=collapse-transition.mjs.map
|