|
@ -3,14 +3,14 @@ |
|
|
|
|
|
|
|
|
import React, { useEffect, useState } from 'react'; |
|
|
import React, { useEffect, useState } from 'react'; |
|
|
import { connect } from 'react-redux'; |
|
|
import { connect } from 'react-redux'; |
|
|
import { Form, Input, Select, Button, Table, Modal, DatePicker } from 'antd'; |
|
|
import { Form, Input, Select, Button, Table, Modal, DatePicker, Checkbox, Row, Col } from 'antd'; |
|
|
import moment from "moment"; |
|
|
import moment from "moment"; |
|
|
|
|
|
|
|
|
const PatrolRecord = (props) => { |
|
|
const PatrolRecord = (props) => { |
|
|
const { dispatch, actions, } = props |
|
|
const { dispatch, actions, } = props |
|
|
const { patrolManage } = actions |
|
|
const { patrolManage } = actions |
|
|
const [tableList, settableList] = useState([]) |
|
|
const [tableList, settableList] = useState([]) |
|
|
const [addModel, setAddModel] = useState(false) |
|
|
const [showDetailModal, setShowDetail] = useState(false) |
|
|
const [modelData, setModelData] = useState({}) |
|
|
const [modelData, setModelData] = useState({}) |
|
|
const [query, setQuery] = useState({ limit: 10, page: 0 }) |
|
|
const [query, setQuery] = useState({ limit: 10, page: 0 }) |
|
|
const [limits, setLimits] = useState() |
|
|
const [limits, setLimits] = useState() |
|
@ -22,80 +22,82 @@ const PatrolRecord = (props) => { |
|
|
}, []) |
|
|
}, []) |
|
|
|
|
|
|
|
|
const record = (params) => { |
|
|
const record = (params) => { |
|
|
dispatch(patrolManage.records(`patrolRecord/all/${params.time[0]}/${params.time[1]}/${params.state}/1`)).then(res => { |
|
|
dispatch(patrolManage.records(`patrolRecord/all/${params.time[0]}/${params.time[1]}/${params.state}/null`)).then(res => { |
|
|
if (res.success) { |
|
|
if (res.success) { |
|
|
settableList(res.payload.data?.map(v => ({ ...v, key: v.id }))) |
|
|
settableList(params.name != null ? res.payload.data?.filter(v => |
|
|
|
|
|
(v.points.user.name.indexOf(params.name) != -1 || v.points.project.name.indexOf(params.name) != -1)) |
|
|
|
|
|
.map(v => ({ ...v, key: v.id })) : res.payload.data?.map(v => ({ ...v, key: v.id }))) |
|
|
setLimits(res.payload.data?.length) |
|
|
setLimits(res.payload.data?.length) |
|
|
} |
|
|
} |
|
|
}) |
|
|
}) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
const columns = [{ |
|
|
const columns = [{ |
|
|
title: '结构物名称', |
|
|
title: '结构物名称', |
|
|
dataIndex: 'name', |
|
|
dataIndex: 'name', |
|
|
key: 'name', |
|
|
key: 'name', |
|
|
render: (text, record, index) => { |
|
|
render: (text, record, index) => { |
|
|
return !record.points?.project? '':<div style={{ width: 100 }}>{record.points.project.name}</div> |
|
|
return !record.points?.project ? '' : <div style={{ width: 100 }}>{record.points.project.name}</div> |
|
|
} |
|
|
} |
|
|
}, { |
|
|
}, { |
|
|
title: '巡检人', |
|
|
title: '巡检人', |
|
|
dataIndex: 'type', |
|
|
dataIndex: 'type', |
|
|
key: 'type', |
|
|
key: 'type', |
|
|
render: (text, record, index) => { |
|
|
render: (text, record, index) => { |
|
|
return !record.points?.user? '':<div style={{ width: 100 }}>{record.points.user.name}</div> |
|
|
return !record.points?.user ? '' : <div style={{ width: 100 }}>{record.points.user.name}</div> |
|
|
} |
|
|
|
|
|
}, { |
|
|
|
|
|
title: '巡检点位', |
|
|
|
|
|
dataIndex: 'type', |
|
|
|
|
|
key: 'type', |
|
|
|
|
|
render: (text, record, index) => { |
|
|
|
|
|
return !record.points?.user? '':<div style={{ width: 100 }}>{record.points.itemData.name}</div> |
|
|
|
|
|
} |
|
|
|
|
|
}, { |
|
|
|
|
|
title: '巡检单位', |
|
|
|
|
|
dataIndex: 'type', |
|
|
|
|
|
key: 'type', |
|
|
|
|
|
render: (text, record, index) => { |
|
|
|
|
|
return !record.points?.user? '':<div style={{ width: 100 }}>{record.points.user.department.name}</div> |
|
|
|
|
|
} |
|
|
|
|
|
}, { |
|
|
|
|
|
title: '巡检频次', |
|
|
|
|
|
dataIndex: 'describe', |
|
|
|
|
|
key: 'describe', |
|
|
|
|
|
render: (text, record, index) => { |
|
|
|
|
|
return !record.points? '':<div style={{ width: 100 }}>{record.points.frequency}</div> |
|
|
|
|
|
} |
|
|
|
|
|
}, { |
|
|
|
|
|
title: '上次巡检日期', |
|
|
|
|
|
dataIndex: 'describe', |
|
|
|
|
|
key: 'describe', |
|
|
|
|
|
render: (text, record, index) => moment(record.lastInspectionTime).format('YYYY-MM-DD HH:mm') || '--' |
|
|
|
|
|
}, { |
|
|
|
|
|
title: '本次巡检日期', |
|
|
|
|
|
dataIndex: 'describe', |
|
|
|
|
|
key: 'describe', |
|
|
|
|
|
render: (text, record, index) => moment(record.inspectionTime).format('YYYY-MM-DD HH:mm') || '--' |
|
|
|
|
|
}, { |
|
|
|
|
|
title: '巡检结果', |
|
|
|
|
|
dataIndex: 'describe', |
|
|
|
|
|
key: 'describe', |
|
|
|
|
|
render: (text, record, index) => !record.alarm? '正常':'异常' |
|
|
|
|
|
}, { |
|
|
|
|
|
title: '操作', |
|
|
|
|
|
dataIndex: 'operation', |
|
|
|
|
|
key: 'operation', |
|
|
|
|
|
render: (text, record, index) => { |
|
|
|
|
|
return ( |
|
|
|
|
|
<div style={{ width: 190 }}> |
|
|
|
|
|
<Button type="link" onClick={() => { |
|
|
|
|
|
setAddModel(true) |
|
|
|
|
|
setModelData(record) |
|
|
|
|
|
}}> |
|
|
|
|
|
查看详情</Button> |
|
|
|
|
|
</div> |
|
|
|
|
|
) |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
} |
|
|
|
|
|
}, { |
|
|
|
|
|
title: '巡检点位', |
|
|
|
|
|
dataIndex: 'type', |
|
|
|
|
|
key: 'type', |
|
|
|
|
|
render: (text, record, index) => { |
|
|
|
|
|
return !record.points?.user ? '' : <div style={{ width: 100 }}>{record.points.itemData.name}</div> |
|
|
|
|
|
} |
|
|
|
|
|
}, { |
|
|
|
|
|
title: '巡检单位', |
|
|
|
|
|
dataIndex: 'type', |
|
|
|
|
|
key: 'type', |
|
|
|
|
|
render: (text, record, index) => { |
|
|
|
|
|
return !record.points?.user ? '' : <div style={{ width: 100 }}>{record.points.user.department.name}</div> |
|
|
|
|
|
} |
|
|
|
|
|
}, { |
|
|
|
|
|
title: '巡检频次', |
|
|
|
|
|
dataIndex: 'describe', |
|
|
|
|
|
key: 'describe', |
|
|
|
|
|
render: (text, record, index) => { |
|
|
|
|
|
return !record.points ? '' : <div style={{ width: 100 }}>{record.points.frequency}</div> |
|
|
|
|
|
} |
|
|
|
|
|
}, { |
|
|
|
|
|
title: '上次巡检日期', |
|
|
|
|
|
dataIndex: 'describe', |
|
|
|
|
|
key: 'describe', |
|
|
|
|
|
render: (text, record, index) => moment(record.lastInspectionTime).format('YYYY-MM-DD HH:mm') || '--' |
|
|
|
|
|
}, { |
|
|
|
|
|
title: '本次巡检日期', |
|
|
|
|
|
dataIndex: 'describe', |
|
|
|
|
|
key: 'describe', |
|
|
|
|
|
render: (text, record, index) => moment(record.inspectionTime).format('YYYY-MM-DD HH:mm') || '--' |
|
|
|
|
|
}, { |
|
|
|
|
|
title: '巡检结果', |
|
|
|
|
|
dataIndex: 'describe', |
|
|
|
|
|
key: 'describe', |
|
|
|
|
|
render: (text, record, index) => !record.alarm ? '正常' : '异常' |
|
|
|
|
|
}, { |
|
|
|
|
|
title: '操作', |
|
|
|
|
|
dataIndex: 'operation', |
|
|
|
|
|
key: 'operation', |
|
|
|
|
|
render: (text, record, index) => { |
|
|
|
|
|
return ( |
|
|
|
|
|
<div style={{ width: 190 }}> |
|
|
|
|
|
<Button type="link" onClick={() => { |
|
|
|
|
|
setShowDetail(true) |
|
|
|
|
|
setModelData(record) |
|
|
|
|
|
}}> |
|
|
|
|
|
查看详情</Button> |
|
|
|
|
|
</div> |
|
|
|
|
|
) |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
] |
|
|
] |
|
|
|
|
|
|
|
|
return ( |
|
|
return ( |
|
@ -122,10 +124,10 @@ const PatrolRecord = (props) => { |
|
|
style={{ marginRight: 16, }} |
|
|
style={{ marginRight: 16, }} |
|
|
initialValue={[moment(search.time[0], format), moment(search.time[1], format)]} |
|
|
initialValue={[moment(search.time[0], format), moment(search.time[1], format)]} |
|
|
> |
|
|
> |
|
|
<DatePicker.RangePicker style={{ marginRight: 16, }}/> |
|
|
<DatePicker.RangePicker showTime style={{ marginRight: 16, }} /> |
|
|
</Form.Item> |
|
|
</Form.Item> |
|
|
<Form.Item |
|
|
<Form.Item |
|
|
name="state" |
|
|
name="state" |
|
|
style={{ marginRight: 16, }} |
|
|
style={{ marginRight: 16, }} |
|
|
initialValue={'null'} |
|
|
initialValue={'null'} |
|
|
> |
|
|
> |
|
@ -160,6 +162,33 @@ const PatrolRecord = (props) => { |
|
|
} |
|
|
} |
|
|
}} |
|
|
}} |
|
|
/> |
|
|
/> |
|
|
|
|
|
<Modal |
|
|
|
|
|
title='巡检记录详情' |
|
|
|
|
|
open={showDetailModal} |
|
|
|
|
|
onCancel={() => setShowDetail(false)} |
|
|
|
|
|
footer={[<Button onClick={() => setShowDetail(false)}>关闭</Button>]} |
|
|
|
|
|
> |
|
|
|
|
|
<Row align='middle' justify='center' style={{ marginBottom: 10 }}> |
|
|
|
|
|
当前点位:{modelData?.points?.itemData?.name} |
|
|
|
|
|
</Row> |
|
|
|
|
|
<Row align='middle' justify='center' style={{ marginBottom: 10 }}> |
|
|
|
|
|
当前位置:{modelData?.points?.address} |
|
|
|
|
|
</Row> |
|
|
|
|
|
<Row align='middle' justify='center' style={{ marginBottom: 10 }}> |
|
|
|
|
|
巡检结果:{modelData.alarm? '异常':'正常'} |
|
|
|
|
|
</Row> |
|
|
|
|
|
{ !modelData.alarm? '': |
|
|
|
|
|
<Row align='middle' justify='center' style={{ marginBottom: 10 }}> |
|
|
|
|
|
巡检详情:{modelData?.points?.msgInp} |
|
|
|
|
|
</Row> } |
|
|
|
|
|
{ !modelData.alarm? '': |
|
|
|
|
|
<Row align='middle' justify='center' style={{ marginBottom: 10 }}> |
|
|
|
|
|
异常等级:{modelData?.points?.changeThree} |
|
|
|
|
|
</Row> } |
|
|
|
|
|
{ !modelData.alarm? '':<Row align='middle' justify='center' style={{ marginBottom: 10 }}> |
|
|
|
|
|
{ modelData?.points?.imgs?.map(rs => <img key={rs} src={`/_file-server/${rs}`} style={{ display: 'inline-block', width: 260, marginBottom: 10 }} />)} |
|
|
|
|
|
</Row> } |
|
|
|
|
|
</Modal> |
|
|
</> |
|
|
</> |
|
|
) |
|
|
) |
|
|
} |
|
|
} |
|
|