|
|
-import{t as w,H as x,m as E,I as u,q as f,J as I,w as N}from"./index.b7909896.js";import{d as $,i as c,A as B,q as D,w as q,D as C,b as a,E as R,V as U,I as y}from"./base.9b18f185.js";var[V,n]=E("image"),j=$({name:V,props:{src:String,alt:String,fit:String,round:Boolean,width:[Number,String],height:[Number,String],radius:[Number,String],lazyLoad:Boolean,iconSize:[Number,String],showError:w,iconPrefix:String,showLoading:w,errorIcon:{type:String,default:"photo-fail"},loadingIcon:{type:String,default:"photo"}},emits:["load","error"],setup(r,{emit:s,slots:i}){var o=c(!1),t=c(!0),d=c(),{$Lazyload:l}=B().proxy,S=D(()=>{var e={};return u(r.width)&&(e.width=f(r.width)),u(r.height)&&(e.height=f(r.height)),u(r.radius)&&(e.overflow="hidden",e.borderRadius=f(r.radius)),e});q(()=>r.src,()=>{o.value=!1,t.value=!0});var v=e=>{t.value=!1,s("load",e)},g=e=>{o.value=!0,t.value=!1,s("error",e)},L=()=>i.loading?i.loading():a(I,{size:r.iconSize,name:r.loadingIcon,class:n("loading-icon"),classPrefix:r.iconPrefix},null),z=()=>i.error?i.error():a(I,{size:r.iconSize,name:r.errorIcon,class:n("error-icon"),classPrefix:r.iconPrefix},null),b=()=>{if(t.value&&r.showLoading)return a("div",{class:n("loading")},[L()]);if(o.value&&r.showError)return a("div",{class:n("error")},[z()])},P=()=>{if(!(o.value||!r.src)){var e={alt:r.alt,class:n("img"),style:{objectFit:r.fit}};return r.lazyLoad?R(a("img",y({ref:d},e),null),[[U("lazy"),r.src]]):a("img",y({src:r.src,onLoad:v,onError:g},e),null)}},m=({el:e})=>{e===d.value&&t.value&&v()},h=({el:e})=>{e===d.value&&!o.value&&g()};return l&&x&&(l.$on("loaded",m),l.$on("error",h),C(()=>{l.$off("loaded",m),l.$off("error",h)})),()=>a("div",{class:n({round:r.round}),style:S.value},[P(),b(),i.default==null?void 0:i.default()])}}),H=N(j);export{H as I};
|