|  | @@ -1,16 +1,24 @@
 | 
	
		
			
				|  |  |  import SvgIcon from '@/components/SvgIcon'
 | 
	
		
			
				|  |  | +import { apiSaveFileInfo } from '@/pages/Safe/Content/Info/Detail/api'
 | 
	
		
			
				|  |  | +import { iFile, iOSSData } from '@/types/file'
 | 
	
		
			
				|  |  |  import consts from '@/utils/consts'
 | 
	
		
			
				|  |  |  import { dayjsFomrat } from '@/utils/util'
 | 
	
		
			
				|  |  | -import { Modal, Table } from 'antd'
 | 
	
		
			
				|  |  | +import { InboxOutlined } from '@ant-design/icons'
 | 
	
		
			
				|  |  | +import { message, Modal, Table, Upload } from 'antd'
 | 
	
		
			
				|  |  |  import { ColumnsType } from 'antd/lib/table'
 | 
	
		
			
				|  |  | +import { UploadChangeParam } from 'antd/lib/upload'
 | 
	
		
			
				|  |  | +import { UploadFile } from 'antd/lib/upload/interface'
 | 
	
		
			
				|  |  |  import React, { useEffect, useState } from 'react'
 | 
	
		
			
				|  |  |  import { ZhCloseButton } from '../Button'
 | 
	
		
			
				|  |  | +import { getSignature } from '../OssUpload/ali-oss'
 | 
	
		
			
				|  |  |  import { apiGetFileList } from './api'
 | 
	
		
			
				|  |  | +const { Dragger } = Upload
 | 
	
		
			
				|  |  |  interface iFileModalProps {
 | 
	
		
			
				|  |  |    dataId: string
 | 
	
		
			
				|  |  |    visible: boolean
 | 
	
		
			
				|  |  |    dataType: number
 | 
	
		
			
				|  |  |    onCancel: () => void
 | 
	
		
			
				|  |  | +  showUpload?: boolean
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  interface iFileModalState {
 | 
	
		
			
				|  |  |    id: string
 | 
	
	
		
			
				|  | @@ -20,11 +28,22 @@ interface iFileModalState {
 | 
	
		
			
				|  |  |    createTime: string
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  export default function FileModal(props: iFileModalProps) {
 | 
	
		
			
				|  |  | -  const { dataId = "", visible = false, onCancel, dataType = 1 } = props
 | 
	
		
			
				|  |  | +  const { dataId = "", visible = false, onCancel, dataType = 1, showUpload = false } = props
 | 
	
		
			
				|  |  |    const [ files, setFiles ] = useState<Array<iFileModalState>>([])
 | 
	
		
			
				|  |  |    const [ total, setTotal ] = useState<number>(0)
 | 
	
		
			
				|  |  | +  const [ OSSData, setOssData ] = useState<iOSSData>({
 | 
	
		
			
				|  |  | +    dir: '',
 | 
	
		
			
				|  |  | +    expire: '',
 | 
	
		
			
				|  |  | +    host: '',
 | 
	
		
			
				|  |  | +    accessId: '',
 | 
	
		
			
				|  |  | +    policy: '',
 | 
	
		
			
				|  |  | +    signature: ''
 | 
	
		
			
				|  |  | +  })
 | 
	
		
			
				|  |  |    useEffect(() => {
 | 
	
		
			
				|  |  | -    visible && initData()
 | 
	
		
			
				|  |  | +    if (props.visible) {
 | 
	
		
			
				|  |  | +      initOssData()
 | 
	
		
			
				|  |  | +      initData()
 | 
	
		
			
				|  |  | +    }
 | 
	
		
			
				|  |  |    }, [ visible ])
 | 
	
		
			
				|  |  |    const initData = async(pageNo: number = 1, pageSize: number = consts.PAGE_SIZE) => {
 | 
	
		
			
				|  |  |      // const { current: pageNo = 1, pageSize = consts.PAGESIZE } = pagination || {}
 | 
	
	
		
			
				|  | @@ -34,9 +53,78 @@ export default function FileModal(props: iFileModalProps) {
 | 
	
		
			
				|  |  |        setTotal(total)
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  | -  // const onTableChange = (pagination: TablePaginationConfig) => {
 | 
	
		
			
				|  |  | +  // 上传文件改变时的状态
 | 
	
		
			
				|  |  | +  const onChange = async (info: UploadChangeParam) => {
 | 
	
		
			
				|  |  | +    const { status } = info.file
 | 
	
		
			
				|  |  | +    if (status !== 'uploading') {
 | 
	
		
			
				|  |  | +      // console.log(info.file, info.fileList)
 | 
	
		
			
				|  |  | +    }
 | 
	
		
			
				|  |  | +    if (status === 'done') {
 | 
	
		
			
				|  |  | +      // message.success(`${info.file.name} 上传成功!`)
 | 
	
		
			
				|  |  | +      const newFileList: iFile[] = [
 | 
	
		
			
				|  |  | +        {
 | 
	
		
			
				|  |  | +          createTime: new Date(),
 | 
	
		
			
				|  |  | +          filepath: info.file.url,
 | 
	
		
			
				|  |  | +          filename: info.file.name
 | 
	
		
			
				|  |  | +        }
 | 
	
		
			
				|  |  | +      ]
 | 
	
		
			
				|  |  | +      const { code = -1 } = await apiSaveFileInfo(newFileList, consts.DATA_TYPE.RETURN, dataId)
 | 
	
		
			
				|  |  | +      if (code === consts.RET_CODE.SUCCESS) {
 | 
	
		
			
				|  |  | +        initData()
 | 
	
		
			
				|  |  | +      }
 | 
	
		
			
				|  |  | +    } else if (status === 'error') {
 | 
	
		
			
				|  |  | +      message.error(`${info.file.name} 上传失败!`)
 | 
	
		
			
				|  |  | +    }
 | 
	
		
			
				|  |  | +  }
 | 
	
		
			
				|  |  | +  // 初始化、获取签名
 | 
	
		
			
				|  |  | +  const initOssData = async () => {
 | 
	
		
			
				|  |  | +    try {
 | 
	
		
			
				|  |  | +      const { code = -1, data = {} } = await getSignature()
 | 
	
		
			
				|  |  | +      if (code === consts.RET_CODE.SUCCESS) {
 | 
	
		
			
				|  |  | +        setOssData({ ...OSSData, ...data })
 | 
	
		
			
				|  |  | +      } else {
 | 
	
		
			
				|  |  | +        message.error("获取签名失败,请联系管理员!")
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +      }
 | 
	
		
			
				|  |  | +    } catch (error) {
 | 
	
		
			
				|  |  | +      message.error(error)
 | 
	
		
			
				|  |  | +    }
 | 
	
		
			
				|  |  | +  }
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +  // 额外参数、oss签名
 | 
	
		
			
				|  |  | +  const getExtraData = (file: UploadFile) => {
 | 
	
		
			
				|  |  | +    return {
 | 
	
		
			
				|  |  | +      key: file.url,
 | 
	
		
			
				|  |  | +      OSSAccessKeyId: OSSData.accessId,
 | 
	
		
			
				|  |  | +      policy: OSSData.policy,
 | 
	
		
			
				|  |  | +      Signature: OSSData.signature
 | 
	
		
			
				|  |  | +    }
 | 
	
		
			
				|  |  | +  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -  // }
 | 
	
		
			
				|  |  | +  const transformFile = (file: any) => {
 | 
	
		
			
				|  |  | +    file.url = OSSData.dir + file.name
 | 
	
		
			
				|  |  | +    return file
 | 
	
		
			
				|  |  | +  }
 | 
	
		
			
				|  |  | +  // 上传前的回调
 | 
	
		
			
				|  |  | +  const beforeUpload = (file: any) => {
 | 
	
		
			
				|  |  | +    const { UPLOAD_LIMIT } = consts
 | 
	
		
			
				|  |  | +    const isLt30M = file.size / 1024 / 1024 < UPLOAD_LIMIT
 | 
	
		
			
				|  |  | +    if (!isLt30M) {
 | 
	
		
			
				|  |  | +      message.error("上传附件大小限制在30MB!")
 | 
	
		
			
				|  |  | +      return false
 | 
	
		
			
				|  |  | +    }
 | 
	
		
			
				|  |  | +    const expire = parseInt(OSSData.expire) * 1000
 | 
	
		
			
				|  |  | +    if (expire < Date.now()) {
 | 
	
		
			
				|  |  | +      initOssData()
 | 
	
		
			
				|  |  | +      return false
 | 
	
		
			
				|  |  | +    }
 | 
	
		
			
				|  |  | +    return true
 | 
	
		
			
				|  |  | +  }
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +  // 移除文件
 | 
	
		
			
				|  |  | +  const onRemove = (file: any) => {
 | 
	
		
			
				|  |  | +    console.log(file)
 | 
	
		
			
				|  |  | +  }
 | 
	
		
			
				|  |  |    const columns: ColumnsType<iFileModalState> = [
 | 
	
		
			
				|  |  |      {
 | 
	
		
			
				|  |  |        title: "文件名",
 | 
	
	
		
			
				|  | @@ -81,6 +169,32 @@ export default function FileModal(props: iFileModalProps) {
 | 
	
		
			
				|  |  |        onCancel={onCancel}
 | 
	
		
			
				|  |  |        footer={<ZhCloseButton onClick={() => onCancel()} size="small">关闭</ZhCloseButton>}
 | 
	
		
			
				|  |  |        >
 | 
	
		
			
				|  |  | +        {
 | 
	
		
			
				|  |  | +          showUpload ?
 | 
	
		
			
				|  |  | +          <div className="pi-mg-bottom-10">
 | 
	
		
			
				|  |  | +            <Dragger
 | 
	
		
			
				|  |  | +              name="file"
 | 
	
		
			
				|  |  | +              action={OSSData.host}
 | 
	
		
			
				|  |  | +              multiple={true}
 | 
	
		
			
				|  |  | +              onChange={onChange}
 | 
	
		
			
				|  |  | +              beforeUpload={beforeUpload}
 | 
	
		
			
				|  |  | +              data={getExtraData}
 | 
	
		
			
				|  |  | +              transformFile={transformFile}
 | 
	
		
			
				|  |  | +              showUploadList={false}
 | 
	
		
			
				|  |  | +              // accept={consts.UPLOAD_WHITE}
 | 
	
		
			
				|  |  | +              onRemove={onRemove}
 | 
	
		
			
				|  |  | +            >
 | 
	
		
			
				|  |  | +                <p className="ant-upload-drag-icon">
 | 
	
		
			
				|  |  | +                <InboxOutlined />
 | 
	
		
			
				|  |  | +                </p>
 | 
	
		
			
				|  |  | +                <p className="ant-upload-text">把文件拖入指定区域,完成上传,同样支持点击上传。</p>
 | 
	
		
			
				|  |  | +                <p className="ant-upload-hint">
 | 
	
		
			
				|  |  | +                  支持单文件/多文件上传。附件大小最大为30MB!
 | 
	
		
			
				|  |  | +                </p>
 | 
	
		
			
				|  |  | +            </Dragger>
 | 
	
		
			
				|  |  | +          </div>
 | 
	
		
			
				|  |  | +          : ''
 | 
	
		
			
				|  |  | +        }
 | 
	
		
			
				|  |  |        <Table
 | 
	
		
			
				|  |  |          dataSource={files}
 | 
	
		
			
				|  |  |          columns={columns}
 |