|  |  |  | 
|---|
|  |  |  | :operationColumnWidth="240" | 
|---|
|  |  |  | :showTableColumnSetting="false" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <template #fileBusinessType="{ row }"> | 
|---|
|  |  |  | {{ FourStreamsMaterialFileBusinessTypeEnumText[row.fileBusinessType] }} | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | <template #operationBtn-uploadBtn="{ data, row }"> | 
|---|
|  |  |  | <BlFileUpload | 
|---|
|  |  |  | v-model:file-url="row.fileList" | 
|---|
|  |  |  | v-model:file-url="row.listFiles" | 
|---|
|  |  |  | multiple | 
|---|
|  |  |  | :limit="1" | 
|---|
|  |  |  | :limit="99" | 
|---|
|  |  |  | ref="uploadRef" | 
|---|
|  |  |  | :showTip="false" | 
|---|
|  |  |  | :show-file-list="false" | 
|---|
|  |  |  | 
|---|
|  |  |  | </BlFileUpload> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | </ProTableV2> | 
|---|
|  |  |  | <FourStreamsBatchMaterialFileDialog | 
|---|
|  |  |  | v-bind="dialogProps" | 
|---|
|  |  |  | :name="''" | 
|---|
|  |  |  | :zipName="currentFourStreamsMaterialFileTableItem.fileTypeName" | 
|---|
|  |  |  | v-model:fileList="currentFourStreamsMaterialFileTableItem.listFiles" | 
|---|
|  |  |  | :showDeleteBtn="showDeleteBtn" | 
|---|
|  |  |  | :yearMonth="date" | 
|---|
|  |  |  | :onDelete="(file) => handleDialogDelete(currentFourStreamsMaterialFileTableItem, file)" | 
|---|
|  |  |  | /> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <script setup lang="ts"> | 
|---|
|  |  |  | import { | 
|---|
|  |  |  | FourStreamsMaterialFileTableProps, | 
|---|
|  |  |  | FourStreamsMaterialFileTableItem, | 
|---|
|  |  |  | FourStreamsMaterialFileBusinessTypeEnumText, | 
|---|
|  |  |  | } from './types'; | 
|---|
|  |  |  | <script setup lang="ts" generic="T"> | 
|---|
|  |  |  | import { FourStreamsMaterialFileTableProps } from './types'; | 
|---|
|  |  |  | import { | 
|---|
|  |  |  | ProTableV2, | 
|---|
|  |  |  | defineColumns, | 
|---|
|  |  |  | defineOperationBtns, | 
|---|
|  |  |  | BlFileUpload, | 
|---|
|  |  |  | bolePreview, | 
|---|
|  |  |  | useDialog, | 
|---|
|  |  |  | UploadUserFile, | 
|---|
|  |  |  | } from '@bole-core/components'; | 
|---|
|  |  |  | import { downloadFileByUrl } from '@/utils'; | 
|---|
|  |  |  | import { Message, isFileCanPreview } from '@bole-core/core'; | 
|---|
|  |  |  | import { Message, isFileCanPreview, downloadWithZip } from '@bole-core/core'; | 
|---|
|  |  |  | import { useDefineColumns } from '@/hooks'; | 
|---|
|  |  |  | import FourStreamsBatchMaterialFileDialog from './FourStreamsBatchMaterialFileDialog.vue'; | 
|---|
|  |  |  | import { CustomerApplyFileTypeListItem } from './utils'; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | defineOptions({ | 
|---|
|  |  |  | name: 'FourStreamsMaterialFileTable', | 
|---|
|  |  |  | 
|---|
|  |  |  | downloadBtnText: '下载', | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const list = defineModel<FourStreamsMaterialFileTableItem[]>('list'); | 
|---|
|  |  |  | const list = defineModel<CustomerApplyFileTypeListItem[]>('list'); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const columns = defineColumns([ | 
|---|
|  |  |  | { | 
|---|
|  |  |  | id: '1', | 
|---|
|  |  |  | enCode: 'fileBusinessType', | 
|---|
|  |  |  | enCode: 'fileTypeName', | 
|---|
|  |  |  | name: '材料名称', | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | ]); | 
|---|
|  |  |  | 
|---|
|  |  |  | name: '上传', | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | extraProps: { | 
|---|
|  |  |  | hide: (row: FourStreamsMaterialFileTableItem) => { | 
|---|
|  |  |  | if (!props.showUploadBtn) return true; | 
|---|
|  |  |  | let fileList = row?.fileList?.filter?.((item) => item.status === 'success'); | 
|---|
|  |  |  | return fileList?.length > 0; | 
|---|
|  |  |  | hide: (row: CustomerApplyFileTypeListItem) => { | 
|---|
|  |  |  | return !props.showUploadBtn; | 
|---|
|  |  |  | // if (!props.showUploadBtn) return true; | 
|---|
|  |  |  | // let fileList = row?.fileList?.filter?.((item) => item.status === 'success'); | 
|---|
|  |  |  | // return fileList?.length > 0; | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | 
|---|
|  |  |  | onClick: (row) => handlePreview(row), | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | extraProps: { | 
|---|
|  |  |  | hide: (row: FourStreamsMaterialFileTableItem) => { | 
|---|
|  |  |  | hide: (row: CustomerApplyFileTypeListItem) => { | 
|---|
|  |  |  | if (!props.showCheckBtn) return true; | 
|---|
|  |  |  | let fileList = row?.fileList?.filter?.((item) => item.status === 'success'); | 
|---|
|  |  |  | let fileList = row?.listFiles?.filter?.((item) => item.status === 'success'); | 
|---|
|  |  |  | if (!fileList?.length) { | 
|---|
|  |  |  | return true; | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | 
|---|
|  |  |  | onClick: (row) => handleBatchDownload(row), | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | extraProps: { | 
|---|
|  |  |  | hide: (row: FourStreamsMaterialFileTableItem) => { | 
|---|
|  |  |  | hide: (row: CustomerApplyFileTypeListItem) => { | 
|---|
|  |  |  | return ( | 
|---|
|  |  |  | !props.showDownloadBtn || | 
|---|
|  |  |  | !row?.fileList?.filter?.((item) => item.status === 'success')?.length | 
|---|
|  |  |  | !row?.listFiles?.filter?.((item) => item.status === 'success')?.length | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | 
|---|
|  |  |  | onClick: (row) => handleDelete(row), | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | extraProps: { | 
|---|
|  |  |  | hide: (row: FourStreamsMaterialFileTableItem) => { | 
|---|
|  |  |  | hide: (row: CustomerApplyFileTypeListItem) => { | 
|---|
|  |  |  | if (!props.showDeleteBtn) return true; | 
|---|
|  |  |  | let fileList = row?.fileList?.filter?.((item) => item.status === 'success'); | 
|---|
|  |  |  | let fileList = row?.listFiles?.filter?.((item) => item.status === 'success'); | 
|---|
|  |  |  | return !fileList?.length; | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | 
|---|
|  |  |  | ], | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | async function handleDelete(row: FourStreamsMaterialFileTableItem) { | 
|---|
|  |  |  | async function handleDelete(row: CustomerApplyFileTypeListItem) { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | await Message.deleteMessage(); | 
|---|
|  |  |  | row.fileList = []; | 
|---|
|  |  |  | if (row.listFiles.length > 1) { | 
|---|
|  |  |  | currentFourStreamsMaterialFileTableItem.value = row; | 
|---|
|  |  |  | await nextTick(); | 
|---|
|  |  |  | dialogState.dialogVisible = true; | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | await Message.deleteMessage(); | 
|---|
|  |  |  | if (props.onDelete) { | 
|---|
|  |  |  | await props.onDelete(row, row.listFiles[0].id); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | row.listFiles = []; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } catch (error) {} | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | async function handlePreview(row: FourStreamsMaterialFileTableItem) { | 
|---|
|  |  |  | if (row.fileList.length > 1) { | 
|---|
|  |  |  | // currentEnterpriseMaterialFileTableItem.value = row; | 
|---|
|  |  |  | // await nextTick(); | 
|---|
|  |  |  | // dialogState.dialogVisible = true; | 
|---|
|  |  |  | async function handleDialogDelete( | 
|---|
|  |  |  | row: CustomerApplyFileTypeListItem, | 
|---|
|  |  |  | listFile: API.CustomerUploadMonthApplyFileTypeDto & UploadUserFile | 
|---|
|  |  |  | ) { | 
|---|
|  |  |  | if (props.onDelete) { | 
|---|
|  |  |  | await props.onDelete(row, listFile.id); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const currentFourStreamsMaterialFileTableItem = ref<CustomerApplyFileTypeListItem>({ | 
|---|
|  |  |  | fileSearchTypeId: '', | 
|---|
|  |  |  | fileTypeName: '', | 
|---|
|  |  |  | lastUpdateTime: '', | 
|---|
|  |  |  | listFiles: [], | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | const { dialogProps, dialogState } = useDialog(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | async function handlePreview(row: CustomerApplyFileTypeListItem) { | 
|---|
|  |  |  | if (row.listFiles.length > 1) { | 
|---|
|  |  |  | currentFourStreamsMaterialFileTableItem.value = row; | 
|---|
|  |  |  | await nextTick(); | 
|---|
|  |  |  | dialogState.dialogVisible = true; | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | bolePreview({ | 
|---|
|  |  |  | fileUrl: row.fileList[0].url, | 
|---|
|  |  |  | fileUrl: row.listFiles[0].url, | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | function handleBatchDownload(row: FourStreamsMaterialFileTableItem) { | 
|---|
|  |  |  | const successFileList = row.fileList.filter((item) => item.status === 'success'); | 
|---|
|  |  |  | async function handleBatchDownload(row: CustomerApplyFileTypeListItem) { | 
|---|
|  |  |  | const successFileList = row.listFiles.filter((item) => item.status === 'success'); | 
|---|
|  |  |  | if (successFileList.length === 0) { | 
|---|
|  |  |  | Message.errorMessage('没有可下载的文件'); | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | // downloadWithZip( | 
|---|
|  |  |  | //   successFileList.map((item) => ({ data: item.url })), | 
|---|
|  |  |  | //   `${AllEnterpriseMaterialFileBusinessTypeEnumText[row.fileBusinessType]}材料文件` | 
|---|
|  |  |  | //   `${props.BusinessTypeEnumText[row.fileBusinessType as any]}` | 
|---|
|  |  |  | // ); | 
|---|
|  |  |  | currentFourStreamsMaterialFileTableItem.value = row; | 
|---|
|  |  |  | await nextTick(); | 
|---|
|  |  |  | dialogState.dialogVisible = true; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | </script> | 
|---|