asb_cloud_front/src/pages/Documents/DocumentsTemplate.jsx

193 lines
5.4 KiB
React
Raw Normal View History

2021-08-17 16:46:46 +05:00
import { useState, useEffect } from "react"
import { DatePicker, Button, Input } from "antd"
import moment from "moment"
import { FileService } from "../../services/api"
import {
invokeWebApiWrapperAsync,
downloadFile,
2021-08-31 12:30:44 +05:00
formatBytes,
2021-08-17 16:46:46 +05:00
} from "../../components/factory"
import { EditableTable, makePaginationObject } from "../../components/Table"
2021-08-17 16:46:46 +05:00
import UploadForm from "../../components/UploadForm"
import LoaderPortal from "../../components/LoaderPortal"
2021-08-31 12:30:44 +05:00
import {UserView} from '../../components/UserView'
import {CompanyView} from '../../components/CompanyView'
2021-08-17 10:46:28 +05:00
const pageSize = 12
2021-08-17 16:46:46 +05:00
const { RangePicker } = DatePicker
const { Search } = Input
2021-08-17 10:46:28 +05:00
export default function DocumentsTemplate({ idCategory, idWell, accept, headerChild, onChange }) {
2021-08-17 10:46:28 +05:00
const [page, setPage] = useState(1)
2021-08-17 17:01:19 +05:00
const [filterDataRange, setFilterDataRange] = useState([])
const [filterCompanyName, setFilterCompanyName] = useState([])
2021-08-17 17:01:19 +05:00
const [filterFileName, setFilterFileName] = useState('')
2021-08-17 10:46:28 +05:00
const [pagination, setPagination] = useState(null)
const [files, setFiles] = useState([])
const [showLoader, setShowLoader] = useState(false)
const uploadUrl = `/api/well/${idWell}/files/?idCategory=${idCategory}`
2021-08-17 10:46:28 +05:00
2021-08-17 16:46:46 +05:00
const handleUploadComplete = () => {
update()
}
2021-08-20 15:28:13 +05:00
const handleFileDelete = async (file) => {
await FileService.delete(idWell, file.id)
2021-08-17 16:46:46 +05:00
update()
}
const hanleCompanySearch = (value, _) => {
setFilterCompanyName(value)
2021-08-17 17:01:19 +05:00
}
const hanleFileNameSearch = (value, _) => {
setFilterFileName(value)
2021-08-17 10:46:28 +05:00
}
2021-08-17 16:46:46 +05:00
2021-08-17 10:46:28 +05:00
const columns = [
{
2021-08-17 16:46:46 +05:00
title: "Документ",
key: "document",
dataIndex: "name",
render: (name, row) => (
<Button type="link" onClick={() => downloadFile(row)} download={name}>
2021-08-17 16:46:46 +05:00
{name}
</Button>),
2021-08-17 10:46:28 +05:00
},
{
2021-08-17 16:46:46 +05:00
title: "Дата загрузки",
key: "uploadDate",
dataIndex: "uploadDate",
2021-08-31 12:30:44 +05:00
render: item =>
2021-08-17 16:46:46 +05:00
moment.utc(item).local().format("DD MMM YYYY, HH:mm:ss"),
2021-08-17 10:46:28 +05:00
},
{
2021-08-31 12:30:44 +05:00
title: "Размер",
key: "size",
dataIndex: "size",
render: item => formatBytes(item)
},
{
title: "Автор",
key: "author",
dataIndex: "author",
render: item => <UserView user={item}/>
2021-08-17 16:46:46 +05:00
},
{
title: "Компания",
key: "company",
render: (_, record) => <CompanyView company={record?.author?.company}/>
2021-08-17 16:46:46 +05:00
},
]
2021-08-17 10:46:28 +05:00
2021-08-17 16:46:46 +05:00
const update = () => {
2021-08-17 10:46:28 +05:00
let begin = null
let end = null
2021-08-17 17:01:19 +05:00
if (filterDataRange?.length > 1) {
begin = filterDataRange[0].toISOString()
end = filterDataRange[1].toISOString()
2021-08-17 10:46:28 +05:00
}
invokeWebApiWrapperAsync(
2021-08-17 16:46:46 +05:00
async () => {
2021-08-17 10:46:28 +05:00
const paginatedFiles = await FileService.getFilesInfo(
2021-08-31 12:30:44 +05:00
idWell,
2021-08-17 10:46:28 +05:00
idCategory,
filterCompanyName,
2021-08-31 12:30:44 +05:00
filterFileName,
2021-08-17 10:46:28 +05:00
begin,
2021-08-31 12:30:44 +05:00
end,
(page - 1) * pageSize,
pageSize,
2021-08-17 16:46:46 +05:00
)
if (!paginatedFiles)
return
const filesInfos = paginatedFiles.items??[]
setFiles(filesInfos)
2021-08-17 10:46:28 +05:00
const newPagination = makePaginationObject(paginatedFiles)
setPagination(newPagination)
},
setShowLoader,
2021-08-17 16:46:46 +05:00
`Не удалось загрузить файлы по скважине "${idWell}"`
)
}
useEffect(update, [idWell, idCategory, page, filterDataRange, filterCompanyName, filterFileName])
useEffect(()=>{
if(onChange)
onChange(files)
}, [files, onChange])
2021-08-17 16:46:46 +05:00
const companies = [...new Set(files.map(file=>file.company))]
.filter(company=>company)
2021-08-17 10:46:28 +05:00
2021-08-17 16:46:46 +05:00
const DataListCompanies = <datalist id="listCompanies">
2021-08-17 17:01:19 +05:00
{companies.map((company)=><option key={company} value={company}>{company}</option>)}
</datalist>
const filenames = [...new Set(files.map(file=>file.name))]
.filter(name=>name)
const DataListFileNames = <datalist id="listFileNames">
{filenames.map((name)=><option key={name} value={name}>{name}</option>)}
2021-08-17 16:46:46 +05:00
</datalist>
return (
2021-08-17 10:46:28 +05:00
<LoaderPortal show={showLoader}>
2021-08-17 16:46:46 +05:00
<div style={{margin:16, display:'flex'}}>
<div>
<span>Фильтр по дате</span>
<div>
2021-08-17 17:01:19 +05:00
<RangePicker showTime onChange={setFilterDataRange} />
2021-08-17 16:46:46 +05:00
</div>
</div>
&nbsp;
<div>
<span>Фильтр по компании</span>
<Search
list='listCompanies'
placeholder="Фильтр по компании"
onSearch={hanleCompanySearch}/>
{DataListCompanies}
2021-08-17 17:01:19 +05:00
</div>
&nbsp;
<div>
<span>Фильтр по имени файла</span>
<Search
list='listFileNames'
placeholder="Фильтр по имени файла"
onSearch={hanleFileNameSearch}/>
{DataListFileNames}
2021-08-17 16:46:46 +05:00
</div>
&nbsp;&nbsp;
<div>
<span>Загрузка</span>
<UploadForm
url={uploadUrl}
accept={accept}
2021-08-17 16:46:46 +05:00
onUploadStart={() => setShowLoader(true)}
onUploadComplete={handleUploadComplete}/>
</div>
&nbsp;&nbsp;
{headerChild}
2021-08-17 16:46:46 +05:00
</div>
<EditableTable
2021-08-17 10:46:28 +05:00
columns={columns}
dataSource={files}
2021-08-17 16:46:46 +05:00
size={"small"}
2021-08-17 10:46:28 +05:00
pagination={{
...pagination,
showSizeChanger: false,
2021-08-17 16:46:46 +05:00
onChange: (page) => setPage(page),
}}
onRowDelete={handleFileDelete}
2021-08-17 10:46:28 +05:00
rowKey={(record) => record.id}
/>
2021-08-17 16:46:46 +05:00
</LoaderPortal>
)
}