{"version":3,"file":"index.mjs","names":[],"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=\"[ns.is('message-box'), modalClass]\"\n      :mask=\"modal\"\n    >\n      <div\n        role=\"dialog\"\n        :aria-label=\"title\"\n        aria-modal=\"true\"\n        :aria-describedby=\"!showInput ? contentId : undefined\"\n        :class=\"`${ns.namespace.value}-overlay-message-box`\"\n        @click=\"overlayEvent.onClick\"\n        @mousedown=\"overlayEvent.onMousedown\"\n        @mouseup=\"overlayEvent.onMouseup\"\n      >\n        <el-focus-trap\n          loop\n          :trapped=\"visible\"\n          :focus-trap-el=\"rootRef\"\n          :focus-start-el=\"focusStartRef\"\n          @release-requested=\"onCloseRequested\"\n        >\n          <div\n            ref=\"rootRef\"\n            :class=\"[\n              ns.b(),\n              customClass,\n              ns.is('draggable', draggable),\n              ns.is('dragging', isDragging),\n              { [ns.m('center')]: center },\n            ]\"\n            :style=\"customStyle\"\n            tabindex=\"-1\"\n            @click.stop=\"\"\n          >\n            <div\n              v-if=\"title !== null && title !== undefined\"\n              ref=\"headerRef\"\n              :class=\"[ns.e('header'), { 'show-close': showClose }]\"\n            >\n              <div :class=\"ns.e('title')\">\n                <el-icon\n                  v-if=\"iconComponent && center\"\n                  :class=\"[ns.e('status'), 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=\"ns.e('headerbtn')\"\n                :aria-label=\"t('el.messagebox.close')\"\n                @click=\"\n                  handleAction(distinguishCancelAndClose ? 'close' : 'cancel')\n                \"\n                @keydown.prevent.enter=\"\n                  handleAction(distinguishCancelAndClose ? 'close' : 'cancel')\n                \"\n              >\n                <el-icon :class=\"ns.e('close')\">\n                  <component :is=\"closeIcon || 'close'\" />\n                </el-icon>\n              </button>\n            </div>\n            <div :id=\"contentId\" :class=\"ns.e('content')\">\n              <div :class=\"ns.e('container')\">\n                <el-icon\n                  v-if=\"iconComponent && !center && hasMessage\"\n                  :class=\"[ns.e('status'), typeClass]\"\n                >\n                  <component :is=\"iconComponent\" />\n                </el-icon>\n                <div v-if=\"hasMessage\" :class=\"ns.e('message')\">\n                  <slot>\n                    <component\n                      :is=\"showInput ? 'label' : 'p'\"\n                      v-if=\"!dangerouslyUseHTMLString\"\n                      :for=\"showInput ? inputId : undefined\"\n                      v-text=\"message\"\n                    />\n                    <component\n                      :is=\"showInput ? 'label' : 'p'\"\n                      v-else\n                      :for=\"showInput ? inputId : undefined\"\n                      v-html=\"message\"\n                    />\n                  </slot>\n                </div>\n              </div>\n              <div v-show=\"showInput\" :class=\"ns.e('input')\">\n                <el-input\n                  :id=\"inputId\"\n                  ref=\"inputRef\"\n                  v-model=\"inputValue\"\n                  :type=\"inputType\"\n                  :placeholder=\"inputPlaceholder\"\n                  :aria-invalid=\"validateError\"\n                  :class=\"{ invalid: validateError }\"\n                  @keydown.enter=\"handleInputEnter\"\n                />\n                <div\n                  :class=\"ns.e('errormsg')\"\n                  :style=\"{\n                    visibility: !!editorErrorMessage ? 'visible' : 'hidden',\n                  }\"\n                >\n                  {{ editorErrorMessage }}\n                </div>\n              </div>\n            </div>\n            <div :class=\"ns.e('btns')\">\n              <el-button\n                v-if=\"showCancelButton\"\n                :type=\"cancelButtonType === 'text' ? '' : cancelButtonType\"\n                :text=\"cancelButtonType === 'text'\"\n                :loading=\"cancelButtonLoading\"\n                :loading-icon=\"cancelButtonLoadingIcon\"\n                :class=\"[cancelButtonClass]\"\n                :round=\"roundButton\"\n                :size=\"btnSize\"\n                @click=\"handleAction('cancel')\"\n                @keydown.prevent.enter=\"handleAction('cancel')\"\n              >\n                {{ cancelButtonText || t('el.messagebox.cancel') }}\n              </el-button>\n              <el-button\n                v-show=\"showConfirmButton\"\n                ref=\"confirmRef\"\n                :type=\"confirmButtonType === 'text' ? '' : confirmButtonType\"\n                :text=\"confirmButtonType === 'text'\"\n                :loading=\"confirmButtonLoading\"\n                :loading-icon=\"confirmButtonLoadingIcon\"\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 || t('el.messagebox.confirm') }}\n              </el-button>\n            </div>\n          </div>\n        </el-focus-trap>\n      </div>\n    </el-overlay>\n  </transition>\n</template>\n\n<script lang=\"ts\">\nimport {\n  computed,\n  defineComponent,\n  markRaw,\n  nextTick,\n  onBeforeUnmount,\n  onMounted,\n  reactive,\n  ref,\n  toRefs,\n  watch,\n} from 'vue'\nimport ElButton from '@element-plus/components/button'\nimport { TrapFocus } from '@element-plus/directives'\nimport {\n  useDraggable,\n  useId,\n  useLockscreen,\n  useSameTarget,\n} from '@element-plus/hooks'\nimport ElInput from '@element-plus/components/input'\nimport { ElOverlay } from '@element-plus/components/overlay'\nimport {\n  TypeComponents,\n  TypeComponentsMap,\n  isFunction,\n  isString,\n  isValidComponentSize,\n} from '@element-plus/utils'\nimport { ElIcon } from '@element-plus/components/icon'\nimport { Loading } from '@element-plus/icons-vue'\nimport ElFocusTrap from '@element-plus/components/focus-trap'\nimport { useGlobalComponentSettings } from '@element-plus/components/config-provider'\n\nimport type { ComponentPublicInstance, PropType } from 'vue'\nimport type { ComponentSize } from '@element-plus/constants'\nimport type {\n  Action,\n  MessageBoxState,\n  MessageBoxType,\n} from './message-box.type'\nimport type { InputInstance } from '@element-plus/components/input'\n\nexport default defineComponent({\n  name: 'ElMessageBox',\n  directives: {\n    TrapFocus,\n  },\n  components: {\n    ElButton,\n    ElFocusTrap,\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    overflow: Boolean,\n    roundButton: Boolean,\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 {\n      locale,\n      zIndex,\n      ns,\n      size: btnSize,\n    } = useGlobalComponentSettings(\n      'message-box',\n      computed(() => props.buttonSize)\n    )\n\n    const { t } = locale\n    const { nextZIndex } = zIndex\n\n    const visible = ref(false)\n    // s represents state\n    const state = reactive<MessageBoxState>({\n      // autofocus element when open message-box\n      autofocus: true,\n      beforeClose: null,\n      callback: null,\n      cancelButtonText: '',\n      cancelButtonClass: '',\n      confirmButtonText: '',\n      confirmButtonClass: '',\n      cancelButtonType: '',\n      confirmButtonType: 'primary',\n      customClass: '',\n      customStyle: {},\n      dangerouslyUseHTMLString: false,\n      distinguishCancelAndClose: false,\n      icon: '',\n      closeIcon: '',\n      inputPattern: null,\n      inputPlaceholder: '',\n      inputType: 'text',\n      inputValue: '',\n      inputValidator: undefined,\n      inputErrorMessage: '',\n      message: '',\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      confirmButtonLoadingIcon: markRaw(Loading),\n      cancelButtonLoadingIcon: markRaw(Loading),\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 { [ns.bm('icon', type)]: type && TypeComponentsMap[type] }\n    })\n\n    const contentId = useId()\n    const inputId = useId()\n\n    const iconComponent = computed(() => {\n      const type = state.type\n      return state.icon || (type && TypeComponentsMap[type]) || ''\n    })\n    const hasMessage = computed(() => !!state.message)\n    const rootRef = ref<HTMLElement>()\n    const headerRef = ref<HTMLElement>()\n    const focusStartRef = ref<HTMLElement>()\n    const inputRef = ref<InputInstance>()\n    const confirmRef = ref<ComponentPublicInstance>()\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) {\n          validate()\n        }\n      },\n      { immediate: true }\n    )\n\n    watch(\n      () => visible.value,\n      (val) => {\n        if (val) {\n          if (props.boxType !== 'prompt') {\n            if (state.autofocus) {\n              focusStartRef.value = confirmRef.value?.$el ?? rootRef.value\n            } else {\n              focusStartRef.value = rootRef.value\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              if (state.autofocus) {\n                focusStartRef.value = getInputElement() ?? rootRef.value\n              } else {\n                focusStartRef.value = rootRef.value\n              }\n            }\n          })\n        } else {\n          state.editorErrorMessage = ''\n          state.validateError = false\n        }\n      }\n    )\n\n    const draggable = computed(() => props.draggable)\n    const overflow = computed(() => props.overflow)\n    const { isDragging } = useDraggable(rootRef, headerRef, draggable, overflow)\n\n    onMounted(async () => {\n      await nextTick()\n      if (props.closeOnHashChange) {\n        window.addEventListener('hashchange', doClose)\n      }\n    })\n\n    onBeforeUnmount(() => {\n      if (props.closeOnHashChange) {\n        window.removeEventListener('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 = (e: KeyboardEvent | Event) => {\n      if (state.inputType !== 'textarea' && !inputRef.value?.isComposing) {\n        e.preventDefault()\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 =\n            state.inputErrorMessage || t('el.messagebox.error')\n          state.validateError = true\n          return false\n        }\n        const inputValidator = state.inputValidator\n        if (isFunction(inputValidator)) {\n          const validateResult = inputValidator(state.inputValue)\n          if (validateResult === false) {\n            state.editorErrorMessage =\n              state.inputErrorMessage || t('el.messagebox.error')\n            state.validateError = true\n            return false\n          }\n          if (isString(validateResult)) {\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 like this\n    // to dispatch, it could callout another message box.\n    const onCloseRequested = () => {\n      if (props.closeOnPressEscape) {\n        handleClose()\n      }\n    }\n\n    // locks the screen to prevent scroll\n    if (props.lockScroll) {\n      useLockscreen(visible, { ns })\n    }\n\n    return {\n      ...toRefs(state),\n      ns,\n      overlayEvent,\n      visible,\n      hasMessage,\n      typeClass,\n      contentId,\n      inputId,\n      btnSize,\n      iconComponent,\n      confirmButtonClasses,\n      rootRef,\n      focusStartRef,\n      headerRef,\n      inputRef,\n      isDragging,\n      confirmRef,\n      doClose, // for outside usage\n      handleClose, // for out side usage\n      onCloseRequested,\n      handleWrapperClick,\n      handleInputEnter,\n      handleAction,\n      t,\n    }\n  },\n})\n</script>\n"],"mappings":"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"}