{"version":3,"file":"index.vue.mjs","sources":["../../../../../packages/components/message-box/src/index.vue"],"sourcesContent":["<template>\n  <transition name=\"fade-in-linear\" @after-leave=\"$emit('vanish')\">\n    <el-overlay\n      v-show=\"visible\"\n      :z-index=\"zIndex\"\n      :overlay-class=\"['is-message-box', modalClass]\"\n      :mask=\"modal\"\n    >\n      <div\n        class=\"el-overlay-message-box\"\n        @click=\"overlayEvent.onClick\"\n        @mousedown=\"overlayEvent.onMousedown\"\n        @mouseup=\"overlayEvent.onMouseup\"\n      >\n        <div\n          ref=\"rootRef\"\n          v-trap-focus\n          role=\"dialog\"\n          :aria-label=\"title || 'dialog'\"\n          aria-modal=\"true\"\n          :class=\"[\n            'el-message-box',\n            customClass,\n            { 'el-message-box--center': center, 'is-draggable': draggable }\n          ]\"\n          :style=\"customStyle\"\n          @click.stop=\"\"\n        >\n          <div\n            v-if=\"title !== null && title !== undefined\"\n            ref=\"headerRef\"\n            class=\"el-message-box__header\"\n          >\n            <div class=\"el-message-box__title\">\n              <el-icon\n                v-if=\"iconComponent && center\"\n                class=\"el-message-box__status\"\n                :class=\"typeClass\"\n              >\n                <component :is=\"iconComponent\" />\n              </el-icon>\n              <span>{{ title }}</span>\n            </div>\n            <button\n              v-if=\"showClose\"\n              type=\"button\"\n              class=\"el-message-box__headerbtn\"\n              aria-label=\"Close\"\n              @click=\"handleAction(distinguishCancelAndClose ? 'close' : 'cancel')\"\n              @keydown.prevent.enter=\"handleAction(distinguishCancelAndClose ? 'close' : 'cancel')\"\n            >\n              <el-icon class=\"el-message-box__close\">\n                <close />\n              </el-icon>\n            </button>\n          </div>\n          <div class=\"el-message-box__content\">\n            <div class=\"el-message-box__container\">\n              <el-icon\n                v-if=\"iconComponent && !center && hasMessage\"\n                class=\"el-message-box__status\"\n                :class=\"typeClass\"\n              >\n                <component :is=\"iconComponent\" />\n              </el-icon>\n              <div v-if=\"hasMessage\" class=\"el-message-box__message\">\n                <slot>\n                  <p v-if=\"!dangerouslyUseHTMLString\">{{ message }}</p>\n                  <p v-else v-html=\"message\"></p>\n                </slot>\n              </div>\n            </div>\n            <div v-show=\"showInput\" class=\"el-message-box__input\">\n              <el-input\n                ref=\"inputRef\"\n                v-model=\"inputValue\"\n                :type=\"inputType\"\n                :placeholder=\"inputPlaceholder\"\n                :class=\"{ invalid: validateError }\"\n                @keydown.prevent.enter=\"handleInputEnter\"\n              />\n              <div\n                class=\"el-message-box__errormsg\"\n                :style=\"{\n                  visibility: !!editorErrorMessage ? 'visible' : 'hidden'\n                }\"\n              >\n                {{ editorErrorMessage }}\n              </div>\n            </div>\n          </div>\n          <div class=\"el-message-box__btns\">\n            <el-button\n              v-if=\"showCancelButton\"\n              :loading=\"cancelButtonLoading\"\n              :class=\"[cancelButtonClass]\"\n              :round=\"roundButton\"\n              :size=\"btnSize\"\n              @click=\"handleAction('cancel')\"\n              @keydown.prevent.enter=\"handleAction('cancel')\"\n            >\n              {{ cancelButtonText }}\n            </el-button>\n            <el-button\n              v-show=\"showConfirmButton\"\n              ref=\"confirmRef\"\n              type=\"primary\"\n              :loading=\"confirmButtonLoading\"\n              :class=\"[confirmButtonClasses]\"\n              :round=\"roundButton\"\n              :disabled=\"confirmButtonDisabled\"\n              :size=\"btnSize\"\n              @click=\"handleAction('confirm')\"\n              @keydown.prevent.enter=\"handleAction('confirm')\"\n            >\n              {{ confirmButtonText }}\n            </el-button>\n          </div>\n        </div>\n      </div>\n    </el-overlay>\n  </transition>\n</template>\n<script lang=\"ts\">\nimport {\n  defineComponent,\n  nextTick,\n  onMounted,\n  onBeforeUnmount,\n  computed,\n  watch,\n  reactive,\n  ref,\n  toRefs\n} from 'vue'\nimport ElButton from '@element-ultra/components/button'\nimport { TrapFocus } from '@element-ultra/directives'\nimport {\n  useModal,\n  useLockscreen,\n  useRestoreActive,\n  usePreventGlobal,\n  useDraggable,\n  useSameTarget,\n  useZIndex\n} from '@element-ultra/hooks'\nimport ElInput from '@element-ultra/components/input'\nimport { ElOverlay } from '@element-ultra/components/overlay'\nimport {\n  on,\n  off,\n  isValidComponentSize,\n  TypeComponents,\n  TypeComponentsMap\n} from '@element-ultra/utils'\nimport { EVENT_CODE } from '@element-ultra/shared'\nimport { ElIcon } from '@element-ultra/components/icon'\n\nimport type { PropType } from 'vue'\nimport type { ComponentSize } from '@element-ultra/shared'\nimport type { Action, MessageBoxState, MessageBoxType } from './message-box.type'\n\nexport default defineComponent({\n  name: 'ElMessageBox',\n  directives: {\n    TrapFocus\n  },\n  components: {\n    ElButton,\n    ElInput,\n    ElOverlay,\n    ElIcon,\n    ...TypeComponents\n  },\n  inheritAttrs: false,\n  props: {\n    buttonSize: {\n      type: String as PropType<ComponentSize>,\n      validator: isValidComponentSize\n    },\n    modal: {\n      type: Boolean,\n      default: true\n    },\n    lockScroll: {\n      type: Boolean,\n      default: true\n    },\n    showClose: {\n      type: Boolean,\n      default: true\n    },\n    closeOnClickModal: {\n      type: Boolean,\n      default: true\n    },\n    closeOnPressEscape: {\n      type: Boolean,\n      default: true\n    },\n    closeOnHashChange: {\n      type: Boolean,\n      default: true\n    },\n    center: Boolean,\n    draggable: Boolean,\n    roundButton: {\n      default: false,\n      type: Boolean\n    },\n    container: {\n      type: String, // default append to body\n      default: 'body'\n    },\n    boxType: {\n      type: String as PropType<MessageBoxType>,\n      default: ''\n    }\n  },\n  emits: ['vanish', 'action'],\n  setup(props, { emit }) {\n    // const popup = usePopup(props, doClose)\n    const visible = ref(false)\n    const { nextZIndex } = useZIndex()\n    // s represents state\n    const state = reactive<MessageBoxState>({\n      beforeClose: null,\n      callback: null,\n      cancelButtonText: '取消',\n      cancelButtonClass: '',\n      confirmButtonText: '确认',\n      confirmButtonClass: '',\n      customClass: '',\n      customStyle: {},\n      dangerouslyUseHTMLString: false,\n      distinguishCancelAndClose: false,\n      icon: '',\n      inputPattern: null,\n      inputPlaceholder: '',\n      inputType: 'text',\n      inputValue: null,\n      inputValidator: null,\n      inputErrorMessage: '',\n      message: null,\n      modalFade: true,\n      modalClass: '',\n      showCancelButton: false,\n      showConfirmButton: true,\n      type: '',\n      title: undefined,\n      showInput: false,\n      action: '' as Action,\n      confirmButtonLoading: false,\n      cancelButtonLoading: false,\n      confirmButtonDisabled: false,\n      editorErrorMessage: '',\n      // refer to: https://github.com/ElemeFE/element/commit/2999279ae34ef10c373ca795c87b020ed6753eed\n      // seemed ok for now without this state.\n      // isOnComposition: false, // temporary remove\n      validateError: false,\n      zIndex: nextZIndex()\n    })\n\n    const typeClass = computed(() => {\n      const type = state.type\n      return type && TypeComponentsMap[type] ? `el-message-box-icon--${type}` : ''\n    })\n\n    const btnSize = computed(() => props.buttonSize)\n\n    const iconComponent = computed(() => state.icon || TypeComponentsMap[state.type] || '')\n    const hasMessage = computed(() => !!state.message)\n    const rootRef = ref<HTMLElement>()\n    const headerRef = ref<HTMLElement>()\n    const inputRef = ref<HTMLElement>()\n    const confirmRef = ref<HTMLElement>()\n\n    const confirmButtonClasses = computed(() => state.confirmButtonClass)\n\n    watch(\n      () => state.inputValue,\n      async val => {\n        await nextTick()\n        if (props.boxType === 'prompt' && val !== null) {\n          validate()\n        }\n      },\n      { immediate: true }\n    )\n\n    watch(\n      () => visible.value,\n      val => {\n        if (val) {\n          if (props.boxType === 'alert' || props.boxType === 'confirm') {\n            nextTick().then(() => {\n              confirmRef.value?.$el?.focus?.()\n            })\n          }\n          state.zIndex = nextZIndex()\n        }\n        if (props.boxType !== 'prompt') return\n        if (val) {\n          nextTick().then(() => {\n            if (inputRef.value && inputRef.value.$el) {\n              getInputElement().focus()\n            }\n          })\n        } else {\n          state.editorErrorMessage = ''\n          state.validateError = false\n        }\n      }\n    )\n\n    const draggable = computed(() => props.draggable)\n    useDraggable(rootRef, headerRef, draggable)\n\n    onMounted(async () => {\n      await nextTick()\n      if (props.closeOnHashChange) {\n        on(window, 'hashchange', doClose)\n      }\n    })\n\n    onBeforeUnmount(() => {\n      if (props.closeOnHashChange) {\n        off(window, 'hashchange', doClose)\n      }\n    })\n\n    function doClose() {\n      if (!visible.value) return\n      visible.value = false\n      nextTick(() => {\n        if (state.action) emit('action', state.action)\n      })\n    }\n\n    const handleWrapperClick = () => {\n      if (props.closeOnClickModal) {\n        handleAction(state.distinguishCancelAndClose ? 'close' : 'cancel')\n      }\n    }\n\n    const overlayEvent = useSameTarget(handleWrapperClick)\n\n    const handleInputEnter = () => {\n      if (state.inputType !== 'textarea') {\n        return handleAction('confirm')\n      }\n    }\n\n    const handleAction = (action: Action) => {\n      if (props.boxType === 'prompt' && action === 'confirm' && !validate()) {\n        return\n      }\n\n      state.action = action\n\n      if (state.beforeClose) {\n        state.beforeClose?.(action, state, doClose)\n      } else {\n        doClose()\n      }\n    }\n\n    const validate = () => {\n      if (props.boxType === 'prompt') {\n        const inputPattern = state.inputPattern\n        if (inputPattern && !inputPattern.test(state.inputValue || '')) {\n          state.editorErrorMessage = state.inputErrorMessage || '输入的数据不合法'\n          state.validateError = true\n          return false\n        }\n        const inputValidator = state.inputValidator\n        if (typeof inputValidator === 'function') {\n          const validateResult = inputValidator(state.inputValue)\n          if (validateResult === false) {\n            state.editorErrorMessage = state.inputErrorMessage || '输入的数据不合法'\n            state.validateError = true\n            return false\n          }\n          if (typeof validateResult === 'string') {\n            state.editorErrorMessage = validateResult\n            state.validateError = true\n            return false\n          }\n        }\n      }\n      state.editorErrorMessage = ''\n      state.validateError = false\n      return true\n    }\n\n    const getInputElement = () => {\n      const inputRefs = inputRef.value.$refs\n      return (inputRefs.input || inputRefs.textarea) as HTMLElement\n    }\n\n    const handleClose = () => {\n      handleAction('close')\n    }\n\n    // when close on press escape is disabled, pressing esc should not callout\n    // any other message box and close any other dialog-ish elements\n    // e.g. Dialog has a close on press esc feature, and when it closes, it calls\n    // props.beforeClose method to make a intermediate state by callout a message box\n    // for some verification or alerting. then if we allow global event liek this\n    // to dispatch, it could callout another message box.\n    if (props.closeOnPressEscape) {\n      useModal(\n        {\n          handleClose\n        },\n        visible\n      )\n    } else {\n      usePreventGlobal(visible, 'keydown', (e: KeyboardEvent) => e.code === EVENT_CODE.esc)\n    }\n\n    // locks the screen to prevent scroll\n    if (props.lockScroll) {\n      useLockscreen(visible)\n    }\n\n    // restore to prev active element.\n    useRestoreActive(visible)\n\n    return {\n      ...toRefs(state),\n      overlayEvent,\n      visible,\n      hasMessage,\n      typeClass,\n      btnSize,\n      iconComponent,\n      confirmButtonClasses,\n      rootRef,\n      headerRef,\n      inputRef,\n      confirmRef,\n      doClose, // for outside usage\n      handleClose, // for out side usage\n      handleWrapperClick,\n      handleInputEnter,\n      handleAction\n    }\n  }\n})\n</script>\n"],"names":["_resolveDirective","_openBlock","_createBlock","_Transition","_withCtx","_withDirectives","_createVNode","_createElementVNode","_createElementBlock","_normalizeClass","_withModifiers","_createCommentVNode","_toDisplayString","_withKeys","_renderSlot"],"mappings":"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"}