element-plus
Version:
A Component Library for Vue 3
1 lines • 20.5 kB
Source Map (JSON)
{"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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"}