| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206 | import { Fragment as _Fragment, withDirectives as _withDirectives, mergeProps as _mergeProps, vShow as _vShow, createVNode as _createVNode } from "vue";import { ref, watch, provide, Teleport, nextTick, computed, onMounted, Transition, onActivated, onDeactivated, defineComponent } from "vue";import { popupSharedProps } from "./shared.mjs";import { isDef, extend, makeStringProp, callInterceptor, createNamespace, HAPTICS_FEEDBACK } from "../utils/index.mjs";import { useEventListener } from "@vant/use";import { useExpose } from "../composables/use-expose.mjs";import { useLockScroll } from "../composables/use-lock-scroll.mjs";import { useLazyRender } from "../composables/use-lazy-render.mjs";import { POPUP_TOGGLE_KEY } from "../composables/on-popup-reopen.mjs";import { useGlobalZIndex } from "../composables/use-global-z-index.mjs";import { Icon } from "../icon/index.mjs";import { Overlay } from "../overlay/index.mjs";const popupProps = extend({}, popupSharedProps, {  round: Boolean,  position: makeStringProp("center"),  closeIcon: makeStringProp("cross"),  closeable: Boolean,  transition: String,  iconPrefix: String,  closeOnPopstate: Boolean,  closeIconPosition: makeStringProp("top-right"),  safeAreaInsetTop: Boolean,  safeAreaInsetBottom: Boolean});const [name, bem] = createNamespace("popup");var stdin_default = defineComponent({  name,  inheritAttrs: false,  props: popupProps,  emits: ["open", "close", "opened", "closed", "keydown", "update:show", "click-overlay", "click-close-icon"],  setup(props, {    emit,    attrs,    slots  }) {    let opened;    let shouldReopen;    const zIndex = ref();    const popupRef = ref();    const lazyRender = useLazyRender(() => props.show || !props.lazyRender);    const style = computed(() => {      const style2 = {        zIndex: zIndex.value      };      if (isDef(props.duration)) {        const key = props.position === "center" ? "animationDuration" : "transitionDuration";        style2[key] = `${props.duration}s`;      }      return style2;    });    const open = () => {      if (!opened) {        opened = true;        zIndex.value = props.zIndex !== void 0 ? +props.zIndex : useGlobalZIndex();        emit("open");      }    };    const close = () => {      if (opened) {        callInterceptor(props.beforeClose, {          done() {            opened = false;            emit("close");            emit("update:show", false);          }        });      }    };    const onClickOverlay = (event) => {      emit("click-overlay", event);      if (props.closeOnClickOverlay) {        close();      }    };    const renderOverlay = () => {      if (props.overlay) {        return _createVNode(Overlay, {          "show": props.show,          "class": props.overlayClass,          "zIndex": zIndex.value,          "duration": props.duration,          "customStyle": props.overlayStyle,          "role": props.closeOnClickOverlay ? "button" : void 0,          "tabindex": props.closeOnClickOverlay ? 0 : void 0,          "onClick": onClickOverlay        }, {          default: slots["overlay-content"]        });      }    };    const onClickCloseIcon = (event) => {      emit("click-close-icon", event);      close();    };    const renderCloseIcon = () => {      if (props.closeable) {        return _createVNode(Icon, {          "role": "button",          "tabindex": 0,          "name": props.closeIcon,          "class": [bem("close-icon", props.closeIconPosition), HAPTICS_FEEDBACK],          "classPrefix": props.iconPrefix,          "onClick": onClickCloseIcon        }, null);      }    };    const onOpened = () => emit("opened");    const onClosed = () => emit("closed");    const onKeydown = (event) => emit("keydown", event);    const renderPopup = lazyRender(() => {      var _a;      const {        round,        position,        safeAreaInsetTop,        safeAreaInsetBottom      } = props;      return _withDirectives(_createVNode("div", _mergeProps({        "ref": popupRef,        "style": style.value,        "role": "dialog",        "tabindex": 0,        "class": [bem({          round,          [position]: position        }), {          "van-safe-area-top": safeAreaInsetTop,          "van-safe-area-bottom": safeAreaInsetBottom        }],        "onKeydown": onKeydown      }, attrs), [(_a = slots.default) == null ? void 0 : _a.call(slots), renderCloseIcon()]), [[_vShow, props.show]]);    });    const renderTransition = () => {      const {        position,        transition,        transitionAppear      } = props;      const name2 = position === "center" ? "van-fade" : `van-popup-slide-${position}`;      return _createVNode(Transition, {        "name": transition || name2,        "appear": transitionAppear,        "onAfterEnter": onOpened,        "onAfterLeave": onClosed      }, {        default: renderPopup      });    };    watch(() => props.show, (show) => {      if (show && !opened) {        open();        if (attrs.tabindex === 0) {          nextTick(() => {            var _a;            (_a = popupRef.value) == null ? void 0 : _a.focus();          });        }      }      if (!show && opened) {        opened = false;        emit("close");      }    });    useExpose({      popupRef    });    useLockScroll(popupRef, () => props.show && props.lockScroll);    useEventListener("popstate", () => {      if (props.closeOnPopstate) {        close();        shouldReopen = false;      }    });    onMounted(() => {      if (props.show) {        open();      }    });    onActivated(() => {      if (shouldReopen) {        emit("update:show", true);        shouldReopen = false;      }    });    onDeactivated(() => {      if (props.show && props.teleport) {        close();        shouldReopen = true;      }    });    provide(POPUP_TOGGLE_KEY, () => props.show);    return () => {      if (props.teleport) {        return _createVNode(Teleport, {          "to": props.teleport        }, {          default: () => [renderOverlay(), renderTransition()]        });      }      return _createVNode(_Fragment, null, [renderOverlay(), renderTransition()]);    };  }});export {  stdin_default as default};
 |