el-image-2171f3ff.js 4.0 KB

1
  1. import{az as te,aA as A,aJ as se,bp as ne,d as N,aW as oe,aB as ie,bm as re,bF as ce,r as c,J as u,bq as m,K as ue,k as ve,o as i,c as v,aC as x,g as T,t as de,a,Y as g,F as $,ai as pe,O as f,q as me,w as fe,at as ye,aD as ge,am as we,bG as be,bs as he,bH as ke,bI as q,bJ as _e,bK as Se,aE as xe,__tla as ze}from"./index-2eab2d23.js";import{E as Ee,__tla as Ie}from"./el-image-viewer-5d14bc77.js";let F,Ce=Promise.all([(()=>{try{return ze}catch{}})(),(()=>{try{return Ie}catch{}})()]).then(async()=>{const M=te({hideOnClickModal:Boolean,src:{type:String,default:""},fit:{type:String,values:["","contain","cover","fill","none","scale-down"],default:""},loading:{type:String,values:["eager","lazy"]},lazy:Boolean,scrollContainer:{type:A([String,Object])},previewSrcList:{type:A(Array),default:()=>se([])},previewTeleported:Boolean,zIndex:{type:Number},initialIndex:{type:Number,default:0},infinite:{type:Boolean,default:!0},closeOnPressEscape:{type:Boolean,default:!0},zoomRate:{type:Number,default:1.2},minScale:{type:Number,default:.2},maxScale:{type:Number,default:7}}),Y={load:n=>n instanceof Event,error:n=>n instanceof Event,switch:n=>ne(n),close:()=>!0,show:()=>!0},J=["src","loading"],K={key:0},P=N({name:"ElImage",inheritAttrs:!1});F=xe(ge(N({...P,props:M,emits:Y,setup(n,{emit:d}){const l=n;let z="";const{t:j}=oe(),o=ie("image"),D=re(),H=ce(),w=c(),p=c(!1),r=c(!0),b=c(!1),y=c(),s=c(),R=m&&"loading"in HTMLImageElement.prototype;let h,k;const G=u(()=>[o.e("inner"),_.value&&o.e("preview"),r.value&&o.is("loading")]),W=u(()=>D.style),Q=u(()=>{const{fit:e}=l;return m&&e?{objectFit:e}:{}}),_=u(()=>{const{previewSrcList:e}=l;return Array.isArray(e)&&e.length>0}),U=u(()=>{const{previewSrcList:e,initialIndex:t}=l;let O=t;return t>e.length-1&&(O=0),O}),E=u(()=>l.loading!=="eager"&&(!R&&l.loading==="lazy"||l.lazy)),S=()=>{m&&(r.value=!0,p.value=!1,w.value=l.src)};function V(e){r.value=!1,p.value=!1,d("load",e)}function X(e){r.value=!1,p.value=!0,d("error",e)}function I(){_e(y.value,s.value)&&(S(),L())}const C=Se(I,200,!0);async function B(){var e;if(!m)return;await we();const{scrollContainer:t}=l;be(t)?s.value=t:he(t)&&t!==""?s.value=(e=document.querySelector(t))!=null?e:void 0:y.value&&(s.value=ke(y.value)),s.value&&(h=q(s,"scroll",C),setTimeout(()=>I(),100))}function L(){m&&s.value&&C&&(h==null||h(),s.value=void 0)}function Z(e){if(e.ctrlKey)return e.deltaY<0||e.deltaY>0?(e.preventDefault(),!1):void 0}function ee(){_.value&&(k=q("wheel",Z,{passive:!1}),z=document.body.style.overflow,document.body.style.overflow="hidden",b.value=!0,d("show"))}function ae(){k==null||k(),document.body.style.overflow=z,b.value=!1,d("close")}function le(e){d("switch",e)}return ue(()=>l.src,()=>{E.value?(r.value=!0,p.value=!1,L(),B()):S()}),ve(()=>{E.value?B():S()}),(e,t)=>(i(),v("div",{ref_key:"container",ref:y,class:g([a(o).b(),e.$attrs.class]),style:ye(a(W))},[p.value?x(e.$slots,"error",{key:0},()=>[T("div",{class:g(a(o).e("error"))},de(a(j)("el.image.error")),3)]):(i(),v($,{key:1},[w.value!==void 0?(i(),v("img",pe({key:0},a(H),{src:w.value,loading:e.loading,style:a(Q),class:a(G),onClick:ee,onLoad:V,onError:X}),null,16,J)):f("v-if",!0),r.value?(i(),v("div",{key:1,class:g(a(o).e("wrapper"))},[x(e.$slots,"placeholder",{},()=>[T("div",{class:g(a(o).e("placeholder"))},null,2)])],2)):f("v-if",!0)],64)),a(_)?(i(),v($,{key:2},[b.value?(i(),me(a(Ee),{key:0,"z-index":e.zIndex,"initial-index":a(U),infinite:e.infinite,"zoom-rate":e.zoomRate,"min-scale":e.minScale,"max-scale":e.maxScale,"url-list":e.previewSrcList,"hide-on-click-modal":e.hideOnClickModal,teleported:e.previewTeleported,"close-on-press-escape":e.closeOnPressEscape,onClose:ae,onSwitch:le},{default:fe(()=>[e.$slots.viewer?(i(),v("div",K,[x(e.$slots,"viewer")])):f("v-if",!0)]),_:3},8,["z-index","initial-index","infinite","zoom-rate","min-scale","max-scale","url-list","hide-on-click-modal","teleported","close-on-press-escape"])):f("v-if",!0)],64)):f("v-if",!0)],6))}}),[["__file","/home/runner/work/element-plus/element-plus/packages/components/image/src/image.vue"]]))});export{F as E,Ce as __tla};