You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
2 lines
11 KiB
2 lines
11 KiB
import{J as $,d as ye,a8 as be,e as w,q as M,v as Ce,x as Y,z as Ee,A as he,a3 as Be,L as k,o as f,c as g,w as m,D as N,Q as C,M as p,n as r,g as x,$ as z,f as U,X as D,V as T,O as R,an as P,r as we,N as K,E as q,T as Me,C as le,i as re,aD as ie,aE as _,I as ke,R as Te,ar as ee,ak as ne}from"./index-7ade0fa6.js";import{_ as Se,B as Ie,E as Ae,a1 as Re,a2 as se,a3 as oe,D as $e}from"./el-button-98327865.js";import{E as Oe}from"./el-input-7c688efc.js";import{b as Ve,c as Le,e as ze}from"./el-message-01c953f1.js";import{E as De,e as Pe}from"./el-scrollbar-7a0c56b8.js";import{o as te}from"./aria-bc8e8b0f.js";import{i as Fe}from"./validator-d3f529a0.js";import{u as He}from"./el-message-box-35f36743.js";const j="_trap-focus-children",E=[],ae=e=>{if(E.length===0)return;const n=E[E.length-1][j];if(n.length>0&&e.code===De.tab){if(n.length===1){e.preventDefault(),document.activeElement!==n[0]&&n[0].focus();return}const a=e.shiftKey,i=e.target===n[0],l=e.target===n[n.length-1];i&&a&&(e.preventDefault(),n[n.length-1].focus()),l&&!a&&(e.preventDefault(),n[0].focus())}},Ne={beforeMount(e){e[j]=te(e),E.push(e),E.length<=1&&document.addEventListener("keydown",ae)},updated(e){$(()=>{e[j]=te(e)})},unmounted(){E.shift(),E.length===0&&document.removeEventListener("keydown",ae)}},Ue=ye({name:"ElMessageBox",directives:{TrapFocus:Ne},components:{ElButton:Ie,ElFocusTrap:Pe,ElInput:Oe,ElOverlay:Ve,ElIcon:Ae,...Re},inheritAttrs:!1,props:{buttonSize:{type:String,validator:Fe},modal:{type:Boolean,default:!0},lockScroll:{type:Boolean,default:!0},showClose:{type:Boolean,default:!0},closeOnClickModal:{type:Boolean,default:!0},closeOnPressEscape:{type:Boolean,default:!0},closeOnHashChange:{type:Boolean,default:!0},center:Boolean,draggable:Boolean,roundButton:{default:!1,type:Boolean},container:{type:String,default:"body"},boxType:{type:String,default:""}},emits:["vanish","action"],setup(e,{emit:n}){const{locale:a,zIndex:i,ns:l,size:o}=be("message-box",w(()=>e.buttonSize)),{t:d}=a,{nextZIndex:c}=i,b=M(!1),s=Ce({autofocus:!0,beforeClose:null,callback:null,cancelButtonText:"",cancelButtonClass:"",confirmButtonText:"",confirmButtonClass:"",customClass:"",customStyle:{},dangerouslyUseHTMLString:!1,distinguishCancelAndClose:!1,icon:"",inputPattern:null,inputPlaceholder:"",inputType:"text",inputValue:null,inputValidator:null,inputErrorMessage:"",message:null,modalFade:!0,modalClass:"",showCancelButton:!1,showConfirmButton:!0,type:"",title:void 0,showInput:!1,action:"",confirmButtonLoading:!1,cancelButtonLoading:!1,confirmButtonDisabled:!1,editorErrorMessage:"",validateError:!1,zIndex:c()}),F=w(()=>{const t=s.type;return{[l.bm("icon",t)]:t&&se[t]}}),H=oe(),u=oe(),ue=w(()=>s.icon||se[s.type]||""),de=w(()=>!!s.message),h=M(),G=M(),I=M(),V=M(),X=M(),fe=w(()=>s.confirmButtonClass);Y(()=>s.inputValue,async t=>{await $(),e.boxType==="prompt"&&t!==null&&Q()},{immediate:!0}),Y(()=>b.value,t=>{var v,B;t&&(e.boxType!=="prompt"&&(s.autofocus?I.value=(B=(v=X.value)==null?void 0:v.$el)!=null?B:h.value:I.value=h.value),s.zIndex=c()),e.boxType==="prompt"&&(t?$().then(()=>{var Z;V.value&&V.value.$el&&(s.autofocus?I.value=(Z=ve())!=null?Z:h.value:I.value=h.value)}):(s.editorErrorMessage="",s.validateError=!1))});const ce=w(()=>e.draggable);He(h,G,ce),Ee(async()=>{await $(),e.closeOnHashChange&&window.addEventListener("hashchange",A)}),he(()=>{e.closeOnHashChange&&window.removeEventListener("hashchange",A)});function A(){b.value&&(b.value=!1,$(()=>{s.action&&n("action",s.action)}))}const J=()=>{e.closeOnClickModal&&L(s.distinguishCancelAndClose?"close":"cancel")},me=ze(J),pe=t=>{if(s.inputType!=="textarea")return t.preventDefault(),L("confirm")},L=t=>{var v;e.boxType==="prompt"&&t==="confirm"&&!Q()||(s.action=t,s.beforeClose?(v=s.beforeClose)==null||v.call(s,t,s,A):A())},Q=()=>{if(e.boxType==="prompt"){const t=s.inputPattern;if(t&&!t.test(s.inputValue||""))return s.editorErrorMessage=s.inputErrorMessage||d("el.messagebox.error"),s.validateError=!0,!1;const v=s.inputValidator;if(typeof v=="function"){const B=v(s.inputValue);if(B===!1)return s.editorErrorMessage=s.inputErrorMessage||d("el.messagebox.error"),s.validateError=!0,!1;if(typeof B=="string")return s.editorErrorMessage=B,s.validateError=!0,!1}}return s.editorErrorMessage="",s.validateError=!1,!0},ve=()=>{const t=V.value.$refs;return t.input||t.textarea},W=()=>{L("close")},ge=()=>{e.closeOnPressEscape&&W()};return e.lockScroll&&Le(b),{...Be(s),ns:l,overlayEvent:me,visible:b,hasMessage:de,typeClass:F,contentId:H,inputId:u,btnSize:o,iconComponent:ue,confirmButtonClasses:fe,rootRef:h,focusStartRef:I,headerRef:G,inputRef:V,confirmRef:X,doClose:A,handleClose:W,onCloseRequested:ge,handleWrapperClick:J,handleInputEnter:pe,handleAction:L,t:d}}}),Ke=["aria-label","aria-describedby"],qe=["aria-label"],je=["id"];function Ge(e,n,a,i,l,o){const d=k("el-icon"),c=k("close"),b=k("el-input"),s=k("el-button"),F=k("el-focus-trap"),H=k("el-overlay");return f(),g(Me,{name:"fade-in-linear",onAfterLeave:n[11]||(n[11]=u=>e.$emit("vanish")),persisted:""},{default:m(()=>[N(C(H,{"z-index":e.zIndex,"overlay-class":[e.ns.is("message-box"),e.modalClass],mask:e.modal},{default:m(()=>[p("div",{role:"dialog","aria-label":e.title,"aria-modal":"true","aria-describedby":e.showInput?void 0:e.contentId,class:r(`${e.ns.namespace.value}-overlay-message-box`),onClick:n[8]||(n[8]=(...u)=>e.overlayEvent.onClick&&e.overlayEvent.onClick(...u)),onMousedown:n[9]||(n[9]=(...u)=>e.overlayEvent.onMousedown&&e.overlayEvent.onMousedown(...u)),onMouseup:n[10]||(n[10]=(...u)=>e.overlayEvent.onMouseup&&e.overlayEvent.onMouseup(...u))},[C(F,{loop:"",trapped:e.visible,"focus-trap-el":e.rootRef,"focus-start-el":e.focusStartRef,onReleaseRequested:e.onCloseRequested},{default:m(()=>[p("div",{ref:"rootRef",class:r([e.ns.b(),e.customClass,e.ns.is("draggable",e.draggable),{[e.ns.m("center")]:e.center}]),style:x(e.customStyle),tabindex:"-1",onClick:n[7]||(n[7]=z(()=>{},["stop"]))},[e.title!==null&&e.title!==void 0?(f(),U("div",{key:0,ref:"headerRef",class:r(e.ns.e("header"))},[p("div",{class:r(e.ns.e("title"))},[e.iconComponent&&e.center?(f(),g(d,{key:0,class:r([e.ns.e("status"),e.typeClass])},{default:m(()=>[(f(),g(D(e.iconComponent)))]),_:1},8,["class"])):T("v-if",!0),p("span",null,R(e.title),1)],2),e.showClose?(f(),U("button",{key:0,type:"button",class:r(e.ns.e("headerbtn")),"aria-label":e.t("el.messagebox.close"),onClick:n[0]||(n[0]=u=>e.handleAction(e.distinguishCancelAndClose?"close":"cancel")),onKeydown:n[1]||(n[1]=P(z(u=>e.handleAction(e.distinguishCancelAndClose?"close":"cancel"),["prevent"]),["enter"]))},[C(d,{class:r(e.ns.e("close"))},{default:m(()=>[C(c)]),_:1},8,["class"])],42,qe)):T("v-if",!0)],2)):T("v-if",!0),p("div",{id:e.contentId,class:r(e.ns.e("content"))},[p("div",{class:r(e.ns.e("container"))},[e.iconComponent&&!e.center&&e.hasMessage?(f(),g(d,{key:0,class:r([e.ns.e("status"),e.typeClass])},{default:m(()=>[(f(),g(D(e.iconComponent)))]),_:1},8,["class"])):T("v-if",!0),e.hasMessage?(f(),U("div",{key:1,class:r(e.ns.e("message"))},[we(e.$slots,"default",{},()=>[e.dangerouslyUseHTMLString?(f(),g(D(e.showInput?"label":"p"),{key:1,for:e.showInput?e.inputId:void 0,innerHTML:e.message},null,8,["for","innerHTML"])):(f(),g(D(e.showInput?"label":"p"),{key:0,for:e.showInput?e.inputId:void 0},{default:m(()=>[K(R(e.dangerouslyUseHTMLString?"":e.message),1)]),_:1},8,["for"]))])],2)):T("v-if",!0)],2),N(p("div",{class:r(e.ns.e("input"))},[C(b,{id:e.inputId,ref:"inputRef",modelValue:e.inputValue,"onUpdate:modelValue":n[2]||(n[2]=u=>e.inputValue=u),type:e.inputType,placeholder:e.inputPlaceholder,"aria-invalid":e.validateError,class:r({invalid:e.validateError}),onKeydown:P(e.handleInputEnter,["enter"])},null,8,["id","modelValue","type","placeholder","aria-invalid","class","onKeydown"]),p("div",{class:r(e.ns.e("errormsg")),style:x({visibility:e.editorErrorMessage?"visible":"hidden"})},R(e.editorErrorMessage),7)],2),[[q,e.showInput]])],10,je),p("div",{class:r(e.ns.e("btns"))},[e.showCancelButton?(f(),g(s,{key:0,loading:e.cancelButtonLoading,class:r([e.cancelButtonClass]),round:e.roundButton,size:e.btnSize,onClick:n[3]||(n[3]=u=>e.handleAction("cancel")),onKeydown:n[4]||(n[4]=P(z(u=>e.handleAction("cancel"),["prevent"]),["enter"]))},{default:m(()=>[K(R(e.cancelButtonText||e.t("el.messagebox.cancel")),1)]),_:1},8,["loading","class","round","size"])):T("v-if",!0),N(C(s,{ref:"confirmRef",type:"primary",loading:e.confirmButtonLoading,class:r([e.confirmButtonClasses]),round:e.roundButton,disabled:e.confirmButtonDisabled,size:e.btnSize,onClick:n[5]||(n[5]=u=>e.handleAction("confirm")),onKeydown:n[6]||(n[6]=P(z(u=>e.handleAction("confirm"),["prevent"]),["enter"]))},{default:m(()=>[K(R(e.confirmButtonText||e.t("el.messagebox.confirm")),1)]),_:1},8,["loading","class","round","disabled","size"]),[[q,e.showConfirmButton]])],2)],6)]),_:3},8,["trapped","focus-trap-el","focus-start-el","onReleaseRequested"])],42,Ke)]),_:3},8,["z-index","overlay-class","mask"]),[[q,e.visible]])]),_:3})}var Xe=Se(Ue,[["render",Ge],["__file","/home/runner/work/element-plus/element-plus/packages/components/message-box/src/index.vue"]]);const O=new Map,Je=e=>{let n=document.body;return e.appendTo&&(le(e.appendTo)&&(n=document.querySelector(e.appendTo)),ne(e.appendTo)&&(n=e.appendTo),ne(n)||(n=document.body)),n},Qe=(e,n,a=null)=>{const i=C(Xe,e,ee(e.message)||re(e.message)?{default:ee(e.message)?e.message:()=>e.message}:null);return i.appContext=a,ie(i,n),Je(e).appendChild(n.firstElementChild),i.component},We=()=>document.createElement("div"),Ze=(e,n)=>{const a=We();e.onVanish=()=>{ie(null,a),O.delete(l)},e.onAction=o=>{const d=O.get(l);let c;e.showInput?c={value:l.inputValue,action:o}:c=o,e.callback?e.callback(c,i.proxy):o==="cancel"||o==="close"?e.distinguishCancelAndClose&&o!=="cancel"?d.reject("close"):d.reject("cancel"):d.resolve(c)};const i=Qe(e,a,n),l=i.proxy;for(const o in e)_(e,o)&&!_(l.$props,o)&&(l[o]=e[o]);return l.visible=!0,l};function S(e,n=null){if(!$e)return Promise.reject();let a;return le(e)||re(e)?e={message:e}:a=e.callback,new Promise((i,l)=>{const o=Ze(e,n??S._context);O.set(o,{options:e,callback:a,resolve:i,reject:l})})}const Ye=["alert","confirm","prompt"],xe={alert:{closeOnPressEscape:!1,closeOnClickModal:!1},confirm:{showCancelButton:!0},prompt:{showCancelButton:!0,showInput:!0}};Ye.forEach(e=>{S[e]=_e(e)});function _e(e){return(n,a,i,l)=>{let o="";return ke(a)?(i=a,o=""):Te(a)?o="":o=a,S(Object.assign({title:o,message:n,type:"",...xe[e]},i,{boxType:e}),l)}}S.close=()=>{O.forEach((e,n)=>{n.doClose()}),O.clear()};S._context=null;const y=S;y.install=e=>{y._context=e._context,e.config.globalProperties.$msgbox=y,e.config.globalProperties.$messageBox=y,e.config.globalProperties.$alert=y.alert,e.config.globalProperties.$confirm=y.confirm,e.config.globalProperties.$prompt=y.prompt};const un=y;export{un as E};
|