UNPKG

ant-design-x-vue

Version:
2 lines (1 loc) 4.93 kB
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("vue"),c=require("../../chunks/module-chunk.js"),A=require("./AudioIcon.js"),M=require("./VideoIcon.js"),j=require("../context.js");require("../../x-provider/index.js");const x=require("../util.js"),B=require("../style/index.js"),D=require("../../_util/hooks/use-state.js"),p=require("ant-design-vue"),o=require("../constants.js"),z=require("../../x-provider/hooks/use-x-provider-context.js"),U=require("../../chunks/helper-chunk.js"),g=" ",s="#8c8c8c",W=e.defineComponent({name:"AXAttachmentsFileListCard",__name:"FileListCard",props:{prefixCls:{type:String,required:!1},item:{type:Object,required:!0},onRemove:{type:Function,required:!1},className:{type:String,required:!1},style:{required:!1},imageProps:{required:!1},icon:{required:!1},type:{type:String,required:!1}},setup(t,{expose:E}){e.toRef(t,"prefixCls");const F=[{key:"default",icon:e.createVNode(c.FileTextFilled,null,null),color:s,ext:new Set([])},{key:"excel",icon:e.createVNode(c.FileExcelFilled,null,null),color:"#22b35e",ext:o.EXCEL_EXTS},{key:"image",icon:e.createVNode(c.FileImageFilled,null,null),color:s,ext:o.IMG_EXTS},{key:"markdown",icon:e.createVNode(c.FileMarkdownFilled,null,null),color:s,ext:o.MARKDOWN_EXTS},{key:"pdf",icon:e.createVNode(c.FilePdfFilled,null,null),color:"#ff4d4f",ext:o.PDF_EXTS},{key:"ppt",icon:e.createVNode(c.FilePptFilled,null,null),color:"#ff6e31",ext:o.PPT_EXTS},{key:"word",icon:e.createVNode(c.FileWordFilled,null,null),color:"#1677ff",ext:o.WORD_EXTS},{key:"zip",icon:e.createVNode(c.FileZipFilled,null,null),color:"#fab714",ext:o.ZIP_EXTS},{key:"video",icon:e.createVNode(M.default,null,null),color:"#ff4d4f",ext:o.VIDEO_EXTS},{key:"audio",icon:e.createVNode(A.default,null,null),color:"#8c8c8c",ext:o.AUDIO_EXTS}];function I(i){let n=i;const u=["B","KB","MB","GB","TB","PB","EB"];let v=0;for(;n>=1024&&v<u.length-1;)n/=1024,v++;return`${n.toFixed(0)} ${u[v]}`}const q=j.useAttachmentContextInject(),P=e.computed(()=>q.value.disabled),k=e.computed(()=>t.item.name),h=e.computed(()=>t.item.size),d=e.computed(()=>t.item.percent),a=e.computed(()=>t.item.status||"done"),N=e.computed(()=>t.item.description),{getPrefixCls:$}=z.default(),V=e.computed(()=>$("attachment",t.prefixCls)),l=`${V.value}-list-card`,[T,w,b]=B.default(V),O=e.useTemplateRef("file-list-card-container"),r=e.computed(()=>{const i=k.value||"",n=i.match(/^(.*)\.[^.]+$/);return{namePrefix:n?n[1]:i,nameSuffix:n?i.slice(n[1].length):""}}),X=e.computed(()=>x.matchExt(r.value.nameSuffix,o.IMG_EXTS)),y=e.computed(()=>N.value?N.value:a.value==="uploading"?`${d.value||0}%`:a.value==="error"?t.item.response||g:h.value?I(h.value):g),S=e.computed(()=>{if(t.icon)if(typeof t.icon=="string"){const i=F.find(n=>n.key===t.icon);if(i)return{icon:i.icon,color:i.color}}else return{icon:t.icon,color:void 0};for(const{ext:i,icon:n,color:u}of F)if(x.matchExt(r.value.nameSuffix,i))return{icon:n,iconColor:u};return{icon:e.createVNode(c.FileTextFilled,{key:"defaultIcon"},null),iconColor:s}}),[L,C]=D.default();e.watch(()=>t.item.originFileObj,()=>{if(t.item.originFileObj){let i=!0;x.previewImage(t.item.originFileObj).then(n=>{i&&C(n)}),e.onWatcherCleanup(()=>{i=!1})}C(void 0)},{immediate:!0});const m=e.computed(()=>t.item.thumbUrl||t.item.url||L.value),f=e.computed(()=>t.type==="image"||t.type!=="file"&&X.value&&(t.item.originFileObj||m.value)),R=e.computed(()=>f.value?e.createVNode(e.Fragment,null,[m.value&&e.createVNode(p.Image,e.mergeProps(t.imageProps,{alt:"preview",src:m.value}),null),a.value!=="done"&&e.createVNode("div",{class:`${l}-img-mask`},[a.value==="uploading"&&d.value!==void 0&&e.createVNode(p.Progress,{percent:d.value,prefixCls:l},null),a.value==="error"&&e.createVNode("div",{class:`${l}-desc`},[e.createVNode("div",{class:`${l}-ellipsis-prefix`},[y.value])])])]):e.createVNode(e.Fragment,null,[e.createVNode("div",{class:`${l}-icon`,style:{color:S.value.iconColor}},[S.value.icon]),e.createVNode("div",{class:`${l}-content`},[e.createVNode("div",{class:`${l}-name`},[e.createVNode("div",{class:`${l}-ellipsis-prefix`},[r.value.namePrefix??g]),e.createVNode("div",{class:`${l}-ellipsis-suffix`},[r.value.nameSuffix])]),e.createVNode("div",{class:`${l}-desc`},[e.createVNode("div",{class:`${l}-ellipsis-prefix`},[y.value])])])]));return E({nativeElement:O}),()=>T(e.createVNode("div",{class:c.classnames(l,{[`${l}-status-${a.value}`]:a.value,[`${l}-type-preview`]:f.value,[`${l}-type-overview`]:!f.value},t.className,w.value,b),style:t.style,ref:"file-list-card-container"},[R.value,!P.value&&t.onRemove&&e.createVNode("button",{type:"button",class:`${l}-remove`,onClick:()=>{t.onRemove(t.item)}},[e.createVNode(c.CloseCircleFilled,null,null)])]))}}),G=U._export_sfc(W,[["__file","/Users/wangzhichao/办公/code/github/ant-design-x-vue-pure/ant-design-x-vue/src/attachments/FileList/FileListCard.vue"]]);exports.default=G;