Browse Source

养护布点

dev
巴林闲侠 2 years ago
parent
commit
9db673e6a5
  1. 27
      api/app/lib/controllers/report/index.js
  2. 26
      web/client/src/sections/quanju/containers/example.js
  3. 1
      web/client/src/sections/quanju/containers/footer/conserve/index.js
  4. 232
      web/client/src/sections/quanju/containers/public/olMap.js
  5. 1
      web/client/src/utils/webapi.js

27
api/app/lib/controllers/report/index.js

@ -100,8 +100,33 @@ async function reportList(ctx) {
let reportRes = null; let reportRes = null;
if (isTop) { if (isTop) {
const sqlStr = 'select * from (SELECT R.*, "row_number"() OVER(PARTITION BY R.user_id ORDER BY R."time" DESC) AS NEWINDEX FROM report AS R ) AS NR WHERE NEWINDEX = 1' const sqlStr = `
select NR.*, "user".name as user_name
from (SELECT R.*, "row_number"() OVER (PARTITION BY R.user_id ORDER BY R."time" DESC) AS NEWINDEX
FROM report AS R
${reportType ? `
where report_type = '${reportType}'
`: ''
}
) AS NR
left join "user" on "user".id = NR.user_id
WHERE NEWINDEX = 1;
`
reportRes = await sequelize.query(sqlStr, { type: QueryTypes.SELECT }); reportRes = await sequelize.query(sqlStr, { type: QueryTypes.SELECT });
if (reportType == 'road') {
const projectNameArr = reportRes.map(item => item.project_name).filter(item => item)
const projectRes = projectNameArr.length ? await models.Project.findAll({
where: {
entryName: { $in: projectNameArr }
}
}) : []
for (let r of reportRes) {
let corProject = projectRes.find(item => item.entryName == r.project_name)
if (corProject) {
r.project = corProject.dataValues
}
}
}
} else { } else {
reportRes = await models.Report.findAll(findOption) reportRes = await models.Report.findAll(findOption)
} }

26
web/client/src/sections/quanju/containers/example.js

@ -8,17 +8,39 @@ import Footer from './footer';
import ProTable, { TableDropdown } from '@ant-design/pro-table'; import ProTable, { TableDropdown } from '@ant-design/pro-table';
import Gis from './footer/gis/gis'; import Gis from './footer/gis/gis';
import OlMap from './public/olMap' import OlMap from './public/olMap'
import { getReportList } from '../../fillion/actions/patrol'
const MAPID = 'screenGis' const MAPID = 'screenGis'
const Example = (props) => { const Example = (props) => {
const { dispatch, actions, user, loading } = props const { dispatch, actions, user, loading } = props
const [tabKey, setTabKey] = useState('leadership') const [tabKey, setTabKey] = useState('leadership')
const [mapObj, setMapObj] = useState(); const [patrolList, setPatrolList] = useState([]);
const [roadProjectList, setRoadProjectList] = useState([]);
const tabChange = (tab) => { const tabChange = (tab) => {
setTabKey(tab) setTabKey(tab)
// dispatch({ type: 'TAB-CHANGE', data: tab }) // dispatch({ type: 'TAB-CHANGE', data: tab })
console.log(tab);
if (tab === 'conserve') {
dispatch(getReportList({
reportType: 'patrol',
isTop: true
})).then(res => {
console.log(res);
if (res.success) {
setPatrolList(res.payload.data || [])
}
})
dispatch(getReportList({
reportType: 'road',
isTop: true
})).then(res => {
if (res.success) {
setRoadProjectList(res.payload.data || [])
}
})
}
} }
return ( return (
@ -34,7 +56,7 @@ const Example = (props) => {
</div> </div>
<div style={{ position: 'absolute', width: "100%", height: "90%" }}> <div style={{ position: 'absolute', width: "100%", height: "90%" }}>
{/* <Gis tabKey={tabKey} /> */} {/* <Gis tabKey={tabKey} /> */}
<OlMap /> <OlMap patrolList={patrolList} roadProjectList={roadProjectList} />
<Footer tabKey={tabKey} dispatch={dispatch} /> <Footer tabKey={tabKey} dispatch={dispatch} />
</div> </div>
</div> </div>

1
web/client/src/sections/quanju/containers/footer/conserve/index.js

@ -6,7 +6,6 @@ import moment from 'moment';
import { getdaolutongji } from '../../../actions/example' import { getdaolutongji } from '../../../actions/example'
import { getHighways, getRoadMaintenances, getxiuyang, getMaintenance } from './action' import { getHighways, getRoadMaintenances, getxiuyang, getMaintenance } from './action'
const Conserve = (props) => { const Conserve = (props) => {
const [roadData, setRoadData] = useState() const [roadData, setRoadData] = useState()
const [highwaysData, setHighwaysData] = useState() const [highwaysData, setHighwaysData] = useState()

232
web/client/src/sections/quanju/containers/public/olMap.js

@ -1,11 +1,16 @@
import React, { useEffect, useState } from 'react'; import React, { useEffect, useState } from 'react';
import { connect } from 'react-redux'; import { connect } from 'react-redux';
import request from 'superagent' import request from 'superagent'
import Hua from '../footer/leadership/centerleft/hudong'
import moment from 'moment';
import { OlMapRequest } from '$utils' import { OlMapRequest } from '$utils'
const OlMap = (props) => { const OlMap = (props) => {
const { dispatch, actions, user, olMapArcgisHost, olMapGeoDataHost } = props const { dispatch, actions, user, olMapArcgisHost, olMapGeoDataHost, patrolList, roadProjectList } = props
const [olMapOpenData, setOlMapOpenData] = useState([]) const [olMapOpenData, setOlMapOpenData] = useState([])
const [olMap, setOlMap] = useState()
const [pointItem, setPointItem] = useState({})
useEffect(() => { useEffect(() => {
}, []) }, [])
@ -48,7 +53,9 @@ const OlMap = (props) => {
}) })
olMapTool.map.on('singleclick', function (p) { olMapTool.map.on('singleclick', function (p) {
setOlMapOpenData([]) setOlMapOpenData([])
setPointItem({})
olMapTool.closeOverlay('clickOpen') olMapTool.closeOverlay('clickOpen')
olMapTool.closeOverlay('pointClickOpen')
olMapTool.removeGeometryLayer('geometry0') olMapTool.removeGeometryLayer('geometry0')
request.post(`${olMapGeoDataHost || 'http://36.2.6.32:8811'}/geoserver-pg/rest/bufferSearch`) request.post(`${olMapGeoDataHost || 'http://36.2.6.32:8811'}/geoserver-pg/rest/bufferSearch`)
@ -136,9 +143,120 @@ const OlMap = (props) => {
} }
}) })
}) })
setOlMap(olMapTool)
} }
}, [olMapGeoDataHost]) }, [olMapGeoDataHost])
useEffect(() => {
if (patrolList.length && olMap) {
patrolList.forEach((d, index) => {
console.log(d, index);
olMap.addGeometryLayer({
features: [
{
name: 'patrolPoint',
attributes: {
callbackParams: {
type: 'patrolPoint',
id: d.id,
},
callback: (p) => {
setPointItem(d)
olMap.addOverlay('pointClickOpen', {
id: 'pointClickOpen',
offset: [0, 25], // 偏移
position: [d.longitude, d.latitude], // 坐标
autoPan: true,
autoPanMargin: 100,
positioning: 'top-right'
})
}
},
geometry: [d.longitude, d.latitude],
geometryType: 'Point',
},
],
style: {
icon: {
src: '/assets/images/worker.png',
// anchor: [0.5, 1],
scale: 0.08, // 图标引用
},
// stroke: { width: 1, color: '#ffff00' },
// circle: {
// radius: 12, // 直径
// fill: '#ff0000', // 颜色
// stroke: { width: 1, color: '#ffff00' },
// },
},
selectStyle: {
icon: {
src: '/assets/images/worker.png',
// anchor: [0.5, 1],
scale: 0.08, // 图标引用
},
// circle: {
// radius: 16, // 直径
// fill: '#ff0000', // 颜色
// stroke: { width: 2, color: '#ffff00' },
// },
// stroke: { width: 2, color: '#ffff00' },
},
layerName: 'geometry_patrol_' + index
});
});
}
}, [patrolList, olMap])
useEffect(() => {
if (roadProjectList.length && olMap) {
roadProjectList.forEach((d, index) => {
olMap.addGeometryLayer({
features: [
{
name: 'roadPoint',
attributes: {
callbackParams: {
type: 'roadPoint',
id: d.id,
},
callback: (p) => {
setPointItem(d)
olMap.addOverlay('pointClickOpen', {
id: 'pointClickOpen',
offset: [0, 25], // 偏移
position: [d.longitude, d.latitude], // 坐标
// position: [115.944220000000, 28.545380000000],
autoPan: true,
autoPanMargin: 100,
positioning: 'top-right'
})
}
},
geometry: [d.longitude, d.latitude],
// geometry: [115.944220000000, 28.545380000000],
geometryType: 'Point',
},
],
style: {
icon: {
src: '/assets/images/worker.png',
scale: 0.08, // 图标引用
},
},
selectStyle: {
icon: {
src: '/assets/images/worker.png',
scale: 0.08, // 图标引用
},
},
layerName: 'geometry_road_' + index
});
});
}
}, [roadProjectList, olMap])
const isRoadProject = pointItem.report_type == 'road'
return ( return (
<div id="olMap" style={{ position: 'absolute', height: '100%', width: "100%" }}> <div id="olMap" style={{ position: 'absolute', height: '100%', width: "100%" }}>
<div slot="overlays" style={{ display: 'none', }}> <div slot="overlays" style={{ display: 'none', }}>
@ -171,6 +289,118 @@ const OlMap = (props) => {
} }
</div> </div>
</div> </div>
<div slot="overlays" style={{ display: 'none', }}>
<div id="pointClickOpen" style={{
width: "400px", zIndex: 100, right: "24%", marginTop: "0", top: "25%", backgroundImage: `url(../../../../../assets/images/leadership/beijinglan.png)`, backgroundPosition: 'center',
backgroundSize: '100% 100%',
padding: '24px',
backgroundRepeat: 'no-repeat',
}}>
{/* <img src='/assets/images/leadership/beijinglan.png' style={{ width: "100%", height: "100%" }} /> */}
<div style={{ display: "flex", }}>
<div style={{ width: "50%", height: "100%", }}>
{
pointItem.id ?
<Hua shuzu={[{
"imgs": pointItem.conserve_after_pic ?
pointItem.conserve_after_pic[0] : ""
}, {
"imgs": pointItem.conserve_before_pic ?
pointItem.conserve_before_pic[0] : ""
}, {
"imgs": pointItem.conserve_underway_pic ?
pointItem.conserve_underway_pic[0] : ""
}]} />
: ''
}
</div>
<div style={{ width: "50%", left: "50%", }}>
<p style={{ marginTop: "20px", color: "#FFFFFF", fontSize: "16px", fontFamily: "YouSheBiaoTiHei" }}>
{
isRoadProject ?
pointItem.user_name || '--'
:
<>
{
pointItem.road_section_start ? pointItem.road_section_start : ""
}{
pointItem.road_section_start && pointItem.road_section_end ? "——" : ""
}{
pointItem.road_section_end ? pointItem.road_section_end : ""
}{
pointItem.road_section_start || pointItem.road_section_end ? "" : "--"
}
</>
}
</p>
<p style={{ color: "rgba(216,240,255,0.8)", fontSize: "14px", fontFamily: "PingFangSC-Regular, PingFang SC" }}>
{
isRoadProject ? '上报内容' : '养护内容'
}
<span style={{ color: "#EEF4FF", marginLeft: "30px", fontFamily: " PingFangSC-Medium, PingFang SC", overflowWrap: 'break-word' }}>
{
pointItem.content ? pointItem.content : "--"
}
</span>
</p>
{
isRoadProject ? '' :
<p style={{ color: "rgba(216,240,255,0.8)", fontSize: "14px", fontFamily: "PingFangSC-Regular, PingFang SC" }}>
负责人
<span style={{ color: "#EEF4FF", marginLeft: "45px", fontFamily: " PingFangSC-Medium, PingFang SC" }}>
{
pointItem.user_name ? pointItem.user_name : "--"
}
</span>
</p>
}
<p style={{ color: "rgba(216,240,255,0.8)", fontSize: "14px", fontFamily: "PingFangSC-Regular, PingFang SC" }}>
日期
<span style={{ color: "#EEF4FF", marginLeft: "60px", fontFamily: " PingFangSC-Medium, PingFang SC" }}>
{
pointItem.time ? moment(pointItem.time).format("YYYY-MM-DD") : "--"
}
</span>
</p>
</div>
</div>
{
isRoadProject && pointItem.project ?
<div style={{ paddingTop: 24 }}>
{[{
n: '项目名称',
k: 'entryName',
}, {
n: '项目规模(公里)',
k: 'projectMileage',
}, {
n: '项目投资(万元)',
k: 'investment',
}, {
n: '开工时间',
k: 'startTime',
},].map(s => {
return (
<p style={{ color: "rgba(216,240,255,0.8)", fontSize: "14px", fontFamily: "PingFangSC-Regular, PingFang SC" }}>
{s.n}
<span style={{ color: "#EEF4FF", marginLeft: "45px", fontFamily: " PingFangSC-Medium, PingFang SC" }}>
{
s.k == 'startTime' ?
pointItem.project[s.k] ? moment(pointItem.project[s.k]).format("YYYY-MM-DD") : "--"
:
pointItem.project[s.k] || "--"
}
</span>
</p>
)
})}
</div>
: ''
}
</div>
</div>
</div> </div>
) )
} }

1
web/client/src/utils/webapi.js

@ -2,7 +2,6 @@
import { ProxyRequest } from "@peace/utils"; import { ProxyRequest } from "@peace/utils";
export const GodTransRequest = new ProxyRequest("_godTrans"); export const GodTransRequest = new ProxyRequest("_godTrans");
export const OlMapRequest = new ProxyRequest("_olMap");
export const ApiTable = { export const ApiTable = {
login: 'login', login: 'login',

Loading…
Cancel
Save