index.c6c0e9cb.js 1.7 KB

1
  1. import{e as x,S as w,r as u,aj as E,ak as N,w as $,al as B,am as D,g as a,U,an as f,W as c,ao as j,ap as C,ab as S,a4 as y,X as R}from"./App.a6f994ff.js";var[k,n]=U("image"),F=x({name:k,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=u(!1),t=u(!0),d=u(),{$Lazyload:l}=E().proxy,I=N(()=>{var e={};return f(r.width)&&(e.width=c(r.width)),f(r.height)&&(e.height=c(r.height)),f(r.radius)&&(e.overflow="hidden",e.borderRadius=c(r.radius)),e});$(()=>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(y,{size:r.iconSize,name:r.loadingIcon,class:n("loading-icon"),classPrefix:r.iconPrefix},null),z=()=>i.error?i.error():a(y,{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?j(a("img",S({ref:d},e),null),[[C("lazy"),r.src]]):a("img",S({src:r.src,onLoad:v,onError:g},e),null)}},h=({el:e})=>{e===d.value&&t.value&&v()},m=({el:e})=>{e===d.value&&!o.value&&g()};return l&&B&&(l.$on("loaded",h),l.$on("error",m),D(()=>{l.$off("loaded",h),l.$off("error",m)})),()=>a("div",{class:n({round:r.round}),style:I.value},[P(),b(),i.default==null?void 0:i.default()])}}),W=R(F);export{W as I};