Browse Source

*大屏运营数据接入及条件过滤及部分样式

release_0.0.1
wanyiwei 3 years ago
parent
commit
700edca359
  1. 48
      weapp/src/packages/components/inputPicker/index.jsx
  2. 30
      weapp/src/packages/components/inputPicker/index.scss
  3. 313
      weapp/src/packages/patrol/index.jsx
  4. 38
      weapp/src/packages/patrol/index.scss
  5. 2
      weapp/src/packages/patrolView/index.jsx
  6. 4
      weapp/src/services/api.js
  7. 16
      web/client/src/sections/quanju/actions/example.js
  8. 54
      web/client/src/sections/quanju/containers/footer/build/Leftbottom.js
  9. 32
      web/client/src/sections/quanju/containers/footer/build/Rightbottom.js
  10. 63
      web/client/src/sections/quanju/containers/footer/build/Rightcenter.js
  11. 108
      web/client/src/sections/quanju/containers/footer/build/index.js
  12. 4
      web/client/src/sections/quanju/containers/footer/build/style.less
  13. 27
      web/client/src/sections/quanju/containers/footer/conserve/action/index.js
  14. 74
      web/client/src/sections/quanju/containers/footer/conserve/chart/pie-chart.js
  15. 12
      web/client/src/sections/quanju/containers/footer/conserve/index.js
  16. 24
      web/client/src/sections/quanju/containers/footer/conserve/left/left-bottom.js
  17. 8
      web/client/src/sections/quanju/containers/footer/conserve/right.js
  18. 43
      web/client/src/sections/quanju/containers/footer/conserve/right/right-bottom.js
  19. 75
      web/client/src/sections/quanju/containers/footer/conserve/right/right-center.js
  20. 80
      web/client/src/sections/quanju/containers/footer/conserve/right/right-top.js
  21. 2
      web/client/src/sections/quanju/containers/footer/guanli/index.js
  22. 2
      web/client/src/sections/quanju/containers/footer/guanli/style.less
  23. 12
      web/client/src/utils/webapi.js

48
weapp/src/packages/components/inputPicker/index.jsx

@ -0,0 +1,48 @@
/*
* 输入框筛选选择器
*/
import React, { useState, useEffect } from 'react'
import { View, Picker, Image, Input } from '@tarojs/components'
import arrowIcon from '../../../static/img/patrol/arrow-down.svg'
import './index.scss'
export default function InputPicker(props) {
const { title, placeholder, selector, value, onInput } = props
const [curSelector, setCurSelector] = useState([])
useEffect(() => {
setCurSelector(selector)
}, [])
function handleInput({ detail: { value: v } }) {
onInput(v)
if (v) {
setCurSelector(selector.filter(item => item.includes(v)))
} else {
setCurSelector(selector)
}
}
const handlePickerChange = (e) => {
onInput(curSelector[e.detail.value])
}
return (
<View className='input-picker'>
<View className='input-box'>
<View className='title'>{title}</View>
<Input
className='input'
type='text'
placeholder={placeholder}
border={false}
value={value}
onInput={handleInput}
/>
</View>
<Picker mode='selector' range={curSelector} onChange={handlePickerChange}>
<Image src={arrowIcon} className='img' />
</Picker>
</View>
)
}

30
weapp/src/packages/components/inputPicker/index.scss

@ -0,0 +1,30 @@
.input-picker {
display: flex;
justify-content: space-between;
height: 96px;
align-items: center;
background-color: #fff;
margin-bottom: 5px;
.input-box {
padding: 12px 0;
flex-grow: 1;
display: flex;
align-items: center;
.title {
margin-left: 30px;
}
.input {
margin-left: 20px;
flex-grow: 1;
}
}
.img {
width: 24px;
height: 14px;
margin: 0 30px;
}
}

313
weapp/src/packages/patrol/index.jsx

@ -7,86 +7,158 @@ import {
Button, Button,
Image, Image,
Input, Input,
Textarea,
Picker Picker
} from '@tarojs/components'; } from '@tarojs/components';
import { AtForm, AtInput, AtButton, AtTextarea, AtImagePicker, AtTimeline } from 'taro-ui'; import { AtButton, AtTextarea, AtImagePicker } from 'taro-ui';
// import InputPicker from '../components/inputPicker'; import InputPicker from '../components/inputPicker';
import request from '@/services/request';
import { postReport } from '@/services/api';
import './index.scss'; import './index.scss';
import arrowIcon from '../../static/img/patrol/arrow-down.svg'; import arrowIcon from '../../static/img/patrol/arrow-down.svg';
const Index = () => { const Index = () => {
const [isPatrol, setIsPatrol] = useState(true) // or const [reportType, setReportType] = useState('patrol') //
const [prjTypeSelector, setPrjTypeSelector] = useState([]) const [projectType, setProjectType] = useState('') //
const [roadSelector, setRoadSelector] = useState([]) const [road, setRoad] = useState('') //
const [projectType, setProjectType] = useState('') const [roadSectionStart, setRoadSectionStart] = useState('') // Start
const [road, setRoad] = useState('') const [roadSectionEnd, setRoadSectionEnd] = useState('') // End
const [address, setAddress] = useState('') //
const [content, setContent] = useState('') //
const [scenePic, setScenePic] = useState([]) //
const [conserveBeforePic, setConserveBeforePic] = useState([]) //
const [conserveUnderwayPic, setConserveUnderwayPic] = useState([]) //
const [conserveAfterPic, setConserveAfterPic] = useState([]) //
const [images, setimages] = useState([]) const [roadStartSelector, setRoadStartSelector] = useState([])
const [roadEndSelector, setRoadEndSelector] = useState([])
const reportType = [ const rPrjTypeSelector = ['道路', '桥梁', '涵洞', '其他']
{ const rRoadSelector = ['富山一路', '金沙大道', '玉湖路']
value: '巡查',
text: '巡查', const rRoadStartSelector = ['一段', '二段', '三段']
checked: true const rRoadEndSelector = ['一段', '二段', '三段']
},
{
value: '养护',
text: '养护',
checked: false
}
]
useEffect(() => { useEffect(() => {
const prjTypeSelector = ['道路', '桥梁', '涵洞', '其他'] setRoadStartSelector(rRoadStartSelector)
const roadSelector = ['富山一路', '金沙大道', '玉湖路'] setRoadEndSelector(rRoadEndSelector)
setPrjTypeSelector(prjTypeSelector)
setRoadSelector(roadSelector)
}, []) }, [])
useEffect(() => { function report() {
if (projectType) { let data = {
setPrjTypeSelector(prjTypeSelector.filter(s => s.includes(projectType))) reportType,
} projectType,
}, [projectType]) road,
// useEffect(() => { roadSectionStart,
// if (projectType) { roadSectionEnd,
// setPrjTypeSelector(prjTypeSelector.filter(s => s.includes(projectType))) address,
// } content,
// }, [projectType]) longitude: 37.000000000000,
latitude: 69.000000000000
function onTypeChange(e) { }
if (e.detail.value === '巡查') { if (reportType === 'patrol') {
setIsPatrol(true) data['scenePic'] = scenePic.length > 0 && scenePic.map(item => item.url)
} else { } else {
setIsPatrol(false) data['conserveBeforePic'] = conserveBeforePic.length > 0 && conserveBeforePic.map(item => item.url)
data['conserveUnderwayPic'] = conserveUnderwayPic.length > 0 && conserveUnderwayPic.map(item => item.url)
data['conserveAfterPic'] = conserveAfterPic.length > 0 && conserveAfterPic.map(item => item.url)
}
for (var key in data) {
if (!data[key]) {
Taro.showToast({ title: '请完善信息', icon: 'none' })
return
}
} }
if (rPrjTypeSelector.indexOf(data.projectType) === -1) {
Taro.showToast({ title: '工程类型错误', icon: 'none' })
return
}
request.post(postReport(), data).then(res => {
if (res.statusCode == 200 || res.statusCode == 204) {
Taro.showToast({ title: '上报成功', icon: 'none' })
} else {
Taro.showToast({ title: res.data.message || '请求出错', icon: 'none' })
}
}, err => {
Taro.showToast({ title: err.message || '请求出错', icon: 'none' })
})
} }
function onPrjTypeChange(e) { function handleInput({ detail: { value } }, type) {
setProjectType(selector[e.detail.value]) switch (type) {
case 'roadSectionStart':
setRoadSectionStart(value)
if (value) {
setRoadStartSelector(rRoadStartSelector.filter(item => item.includes(value)))
} else {
setRoadStartSelector(rRoadStartSelector)
}
break;
case 'roadSectionEnd':
setRoadSectionEnd(value)
if (value) {
setRoadEndSelector(rRoadEndSelector.filter(item => item.includes(value)))
} else {
setRoadEndSelector(rRoadEndSelector)
}
break;
case 'address':
setAddress(value)
break;
case 'content':
setContent(value)
default:
break;
}
} }
function onImgPickerChange(files) { function handleTypeChange(e) {
setimages(files) setReportType(e.detail.value)
} }
function onImageClick(index, file) {
function handleImgChange(files, type) {
switch (type) {
case 'scenePic':
setScenePic(files)
break;
case 'conserveBeforePic':
setConserveBeforePic(files)
break;
case 'conserveUnderwayPic':
setConserveUnderwayPic(files)
break;
case 'conserveAfterPic':
setConserveAfterPic(files)
break;
default:
break;
}
}
function handleImgClick(index, file) {
Taro.previewImage({ Taro.previewImage({
urls: [file.url] // http urls: [file.url] // http
}) })
} }
useEffect(() => { const typeList = [
console.log(images); {
}, [images]) value: 'patrol',
text: '巡查',
checked: true
},
{
value: 'conserve',
text: '养护',
checked: false
}
]
return ( return (
<View> <View className='patrol'>
<View className='report-type'> <View className='report-type'>
<View className='text'>上报类型</View> <View className='text'>上报类型</View>
<RadioGroup onChange={onTypeChange}> <RadioGroup onChange={handleTypeChange}>
{ {
reportType.map((item, i) => { typeList.map((item, i) => {
return ( return (
<Radio <Radio
key={i} key={i}
@ -103,107 +175,88 @@ const Index = () => {
</RadioGroup> </RadioGroup>
</View> </View>
<View className='input-picker'> <InputPicker
<AtInput
className='input'
title='工程类型:'
type='text'
placeholder='请选择工程类型'
border={false}
value={projectType}
onChange={value => setProjectType(value)}
/>
<Picker mode='selector' range={prjTypeSelector} onChange={onPrjTypeChange}>
<Image src={arrowIcon} className='img-r' />
</Picker>
</View>
<View className='input-picker'>
<AtInput
className='input'
title='所在道路:'
type='text'
placeholder='请选择您所在的道路'
border={false}
value={road}
onChange={value => setRoad(value)}
/>
<Picker mode='selector' range={roadSelector} onChange={onPrjTypeChange}>
<Image src={arrowIcon} className='img-r' />
</Picker>
</View>
{/* <InputPicker
className='input-picker'
title='工程类型:' title='工程类型:'
placeholder='请选择工程类型' placeholder='请选择工程类型'
value={projectType} value={projectType}
onChange={setProjectType} onInput={setProjectType}
selector={prjTypeSelector} selector={rPrjTypeSelector}
/> />
<InputPicker <InputPicker
className='input-picker'
title='所在道路:' title='所在道路:'
placeholder='请选择您所在的道路' placeholder='请选择或输入您所在的道路'
value={road} value={road}
onChange={setRoad} onInput={setRoad}
selector={roadSelector} selector={rRoadSelector}
/> */} />
<View className='input-picker'> <View className='road-section'>
<AtInput <View className='title'>所属路段</View>
<Input
className='input' className='input'
title='所属路段:'
type='text' type='text'
placeholder='路段名称' placeholder='路段名称'
border={false} border={false}
// value={this.state.value} value={roadSectionStart}
// onChange={this.handleChange.bind(this, 'value')} onInput={e => handleInput(e, 'roadSectionStart')}
/> />
<Picker mode='selector' range={roadSelector} onChange={onPrjTypeChange}> <Picker
mode='selector'
range={roadStartSelector}
onChange={e => setRoadSectionStart(roadStartSelector[e.detail.value])}
>
<Image src={arrowIcon} className='img-l' /> <Image src={arrowIcon} className='img-l' />
</Picker> </Picker>
<AtInput <View>&nbsp;</View>
<Input
className='input' className='input'
type='text' type='text'
placeholder='路段名称' placeholder='路段名称'
border={false} border={false}
// value={this.state.value} value={roadSectionEnd}
// onChange={this.handleChange.bind(this, 'value')} onInput={e => handleInput(e, 'roadSectionEnd')}
/> />
<Picker mode='selector' range={roadSelector} onChange={onPrjTypeChange}> <Picker
mode='selector'
range={roadEndSelector}
onChange={e => setRoadSectionEnd(roadEndSelector[e.detail.value])}
>
<Image src={arrowIcon} className='img-r' /> <Image src={arrowIcon} className='img-r' />
</Picker> </Picker>
</View> </View>
<AtTextarea <View className='address'>
count={false} <View className='title'>具体位置</View>
title='具体位置:' <Input
placeholder='具体位置:根据定位自动获取,可手动修改' className='input'
// value={this.state.value} type='text'
// onChange={this.handleChange.bind(this, 'value')} placeholder='根据定位自动获取,可手动修改'
value={address}
onInput={e => handleInput(e, 'address')}
/> />
</View>
<AtTextarea <AtTextarea
count={false} count={false}
title='巡查内容:' title='巡查内容:'
placeholder='请输入巡查内容' placeholder='请输入巡查内容'
// value={this.state.value} value={content}
// onChange={this.handleChange.bind(this, 'value')} onChange={(v, e) => handleInput(e, 'content')}
/> />
{ {
isPatrol ? reportType === 'patrol' ?
<View className='patrol-picker'> <View className='patrol-img'>
现场图片 现场图片
<AtImagePicker <AtImagePicker
className='img-picker' className='img-picker'
count={3 - images.length} count={3 - scenePic.length}
showAddBtn={images.length >= 3 ? false : true} showAddBtn={scenePic.length >= 3 ? false : true}
files={images} files={scenePic}
onChange={onImgPickerChange} onChange={files => handleImgChange(files, 'scenePic')}
onImageClick={onImageClick} onImageClick={handleImgClick}
/> />
</View> : </View> :
<View className='conserve-picker'> <View className='conserve-img'>
养护图片: 养护图片:
<View className='horizontal-line hl-one'> <View className='horizontal-line hl-one'>
<View className='circle c-one'></View> <View className='circle c-one'></View>
@ -211,9 +264,11 @@ const Index = () => {
</View> </View>
<AtImagePicker <AtImagePicker
className='img-picker' className='img-picker'
count={3} count={3 - conserveBeforePic.length}
files={images} showAddBtn={conserveBeforePic.length >= 3 ? false : true}
onChange={onImgPickerChange} files={conserveBeforePic}
onChange={files => handleImgChange(files, 'conserveBeforePic')}
onImageClick={handleImgClick}
/> />
<View className='horizontal-line hl-two'> <View className='horizontal-line hl-two'>
<View className='circle c-two'></View> <View className='circle c-two'></View>
@ -221,9 +276,11 @@ const Index = () => {
</View> </View>
<AtImagePicker <AtImagePicker
className='img-picker' className='img-picker'
count={3} count={3 - conserveUnderwayPic.length}
files={images} showAddBtn={conserveUnderwayPic.length >= 3 ? false : true}
onChange={onImgPickerChange} files={conserveUnderwayPic}
onChange={files => handleImgChange(files, 'conserveUnderwayPic')}
onImageClick={handleImgClick}
/> />
<View className='horizontal-line hl-three'> <View className='horizontal-line hl-three'>
<View className='circle c-three'></View> <View className='circle c-three'></View>
@ -231,15 +288,15 @@ const Index = () => {
</View> </View>
<AtImagePicker <AtImagePicker
className='img-picker' className='img-picker'
count={3} count={3 - conserveAfterPic.length}
files={images} showAddBtn={conserveAfterPic.length >= 3 ? false : true}
onChange={onImgPickerChange} files={conserveAfterPic}
onChange={files => handleImgChange(files, 'conserveAfterPic')}
onImageClick={handleImgClick}
/> />
</View> </View>
} }
<AtButton type='primary' className='sub-btn' onClick={report}>上报</AtButton>
<AtButton formType='submit' type='primary' className='sub-btn'>上报</AtButton>
</View> </View>
) )
} }

38
weapp/src/packages/patrol/index.scss

@ -3,6 +3,10 @@ page {
width: 100vw; width: 100vw;
background-color: #f6f6f6; background-color: #f6f6f6;
.patrol {
font-size: 28px;
}
.report-type { .report-type {
height: 96px; height: 96px;
background-color: #fff; background-color: #fff;
@ -20,32 +24,58 @@ page {
} }
} }
.input-picker { .road-section {
display: flex; display: flex;
justify-content: space-between; justify-content: space-between;
height: 96px;
align-items: center; align-items: center;
background-color: #fff; background-color: #fff;
margin-bottom: 5px; margin-bottom: 5px;
.title {
margin-left: 30px;
}
.input {
width: 200px;
}
.img-r { .img-r {
width: 24px; width: 24px;
height: 14px; height: 14px;
margin-right: 30px; margin-right: 30px;
// margin-left: 10px;
} }
.img-l { .img-l {
width: 24px; width: 24px;
height: 14px; height: 14px;
margin-right: 10px;
}
}
.address {
background-color: #fff;
display: flex;
align-items: center;
height: 96px;
margin-bottom: 5px;
.title {
margin-left: 30px;
}
.input {
margin-left: 20px;
flex-grow: 1;
} }
} }
.patrol-picker { .patrol-img {
background-color: #fff; background-color: #fff;
padding: 20px; padding: 20px;
} }
.conserve-picker { .conserve-img {
background-color: #fff; background-color: #fff;
padding: 20px; padding: 20px;

2
weapp/src/packages/patrolView/index.jsx

@ -35,7 +35,7 @@ function Index() {
throw new Error(error); throw new Error(error);
} }
useEffect(() => { useEffect(() => {
request.get(getReportList(),{}, { hideErrorToast: true, hideLoading: true }).then(res => { request.get(getReportList(), {}, { hideErrorToast: true, hideLoading: true }).then(res => {
if (res.statusCode == 200) { if (res.statusCode == 200) {
console.log(res); console.log(res);
setListData(res.data) setListData(res.data)

4
weapp/src/services/api.js

@ -11,6 +11,10 @@ export const getReportList = () => {
return `/report/list`; return `/report/list`;
}; };
export const postReport = () => {
return `/report`;
};
//行业查询 //行业查询
export const getIndustryUrl = () => { export const getIndustryUrl = () => {
return `/elec/business/industry` return `/elec/business/industry`

16
web/client/src/sections/quanju/actions/example.js

@ -34,7 +34,7 @@ export function getjiandmanage() {
dispatch: dispatch, dispatch: dispatch,
actionType: 'GET_JIANDMANAGE', actionType: 'GET_JIANDMANAGE',
url: ApiTable.getzhichaomanager, url: ApiTable.getzhichaomanager,
msg: { error: '获取治超监测点处理数据信息' }, msg: { error: '获取治超监测点处理数据信息失败' },
// reducer: { name: 'members' } // reducer: { name: 'members' }
}); });
} }
@ -47,7 +47,19 @@ export function getjiandetail() {
dispatch: dispatch, dispatch: dispatch,
actionType: 'GET_JIANDETAIL', actionType: 'GET_JIANDETAIL',
url: ApiTable.getzhichaodetail, url: ApiTable.getzhichaodetail,
msg: { error: '获取治超监测点处理数据信息' }, msg: { error: '获取治超监测点处理数据信息失败' },
// reducer: { name: 'members' }
});
}
//获取宣传数据
export function getxuanchuan() {
return dispatch => basicAction({
type: 'get',
dispatch: dispatch,
actionType: 'GET_XUANCHUAN',
url: ApiTable.getpropagata,
msg: { error: '获取宣传信息失败' },
// reducer: { name: 'members' } // reducer: { name: 'members' }
}); });
} }

54
web/client/src/sections/quanju/containers/footer/build/Leftbottom.js

@ -24,6 +24,8 @@ function Leftbottom(props) {
const chartTitle = '道路总公里'; const chartTitle = '道路总公里';
const title = '基础设施安全监测版块'; const title = '基础设施安全监测版块';
let name = [], emptyName = [] let name = [], emptyName = []
console.log(data,'传入的值')
console.log(emptyName,'第二个')
// const name = data?.map(d) // const name = data?.map(d)
data?.forEach(d => { data?.forEach(d => {
name.push(d.name) name.push(d.name)
@ -132,18 +134,60 @@ function Leftbottom(props) {
tooltip: { tooltip: {
trigger: "item", trigger: "item",
}, },
legend: { // title: {
// text:total,//主标题文本
// left:'20%',
// // top:'35%',
// subtext:chartTitle,//副标题文本
// textStyle:{
// fontFamily : "YouSheBiaoTiHei",
// fontSize: 20,
// color:'#FFFFFF',
// marginLeft:'20%',
// align:'center'
// },
// subtextStyle:{
// fontFamily : "PingFangSC-Medium PingFang SC",
// fontSize: 12,
// fontWeight:500,
// color:'#E9F7FF',
// align:'center'
// }
// },
legend: {
orient: "vertical", orient: "vertical",
itemWidth: 10, itemWidth: 10,
itemHeight: 10, itemHeight: 10,
right: '30%', // right: '30%',
right: '10%',
top: 'center', top: 'center',
align: 'left', align: 'left',
data: name, data: name,
formatter: (name) => {
for (let i = 0; i < option.series[1].data.length; i += 1) {
if (name === option.series[1].data[i].name) {
let arr = [`{a|${name}}`, `{b|${option.series[1].data[i].value}}`]
return arr.join('\t');
}
}
},
textStyle: { textStyle: {
color: "#fff", rich: {
a: {
color: '#E9F7FF',
fontSize: 14,
padding:[0,10]
}, },
b: {
fontSize: 16,
fontFamily: 'YouSheBiaoTiHei',
color: '#fff',
padding:[0,0,0,15]
}, },
}
}
},
grid: { grid: {
left: '10%' left: '10%'
}, },
@ -219,12 +263,12 @@ function Leftbottom(props) {
return ()=>{ return ()=>{
// clearInterval(changePieInterval) // clearInterval(changePieInterval)
} }
}, []); }, [data]);
return ( return (
<div className='build-left-bottom'> <div className='build-left-bottom'>
<div className='build-left-bottom-title'> <div className='build-left-bottom-title'>
<h2>3234.23</h2> <h2>{total}</h2>
<span>道路总公里</span> <span>道路总公里</span>
</div> </div>
<img src='/assets/images/quanju/chart-circle.png'></img> <img src='/assets/images/quanju/chart-circle.png'></img>

32
web/client/src/sections/quanju/containers/footer/build/Rightbottom.js

@ -53,12 +53,34 @@ function Rightbottom(props) {
orient: "vertical", orient: "vertical",
itemWidth: 10, itemWidth: 10,
itemHeight: 10, itemHeight: 10,
right: '30%', // right: '30%',
left: '50%',
top: 'center', top: 'center',
align: 'left', align: 'left',
data: name,
formatter: (name) => {
for (let i = 0; i < option.series[1].data.length; i += 1) {
if (name === option.series[1].data[i].name) {
let arr = [`{a|${name}}`, `{b|${option.series[1].data[i].value}}`]
return arr.join('\t');
}
}
},
textStyle: { textStyle: {
color: "#fff", rich: {
a: {
color: '#E9F7FF',
fontSize: 14,
padding:[0,10]
}, },
b: {
fontSize: 16,
fontFamily: 'YouSheBiaoTiHei',
color: '#fff',
padding:[0,0,0,15]
},
}
}
}, },
grid: { grid: {
left: '10%' left: '10%'
@ -133,14 +155,14 @@ function Rightbottom(props) {
// } // }
myChart.setOption(option); myChart.setOption(option);
return ()=>{ return ()=>{
clearInterval(changePieInterval) // clearInterval(changePieInterval)
} }
}, []); }, [data]);
return ( return (
<div className='build-right-bottom'> <div className='build-right-bottom'>
<div className='build-right-bottom-title'> <div className='build-right-bottom-title'>
<h2>3234.23</h2> <h2>{total||0}</h2>
<span>道路总公里</span> <span>道路总公里</span>
</div> </div>
<img src='/assets/images/quanju/chart-circle.png'></img> <img src='/assets/images/quanju/chart-circle.png'></img>

63
web/client/src/sections/quanju/containers/footer/build/Rightcenter.js

@ -1,32 +1,33 @@
import React from 'react' import React from 'react'
import './style.less' import './style.less'
import AutoRollComponent from './AutoRollComponent' import AutoRollComponent from './AutoRollComponent'
export default function Rightcenter() { export default function Rightcenter({data,sundata}) {
const data =[ {name: '莲塘镇', total: 12739}, // const data =[ {name: '莲塘镇', total: 12739},
{name: '向塘镇', total: 2445}, // {name: '向塘镇', total: 2445},
{name: '蒋巷镇', total: 2035}, // {name: '蒋巷镇', total: 2035},
{name: '幽兰镇', total: 1999}, // {name: '幽兰镇', total: 1999},
{name: '塘南镇', total: 1915}, // {name: '塘南镇', total: 1915},
{name: '武阳镇', total: 1842}, // {name: '武阳镇', total: 1842},
{name: '冈上镇', total: 1446}, // {name: '冈上镇', total: 1446},
{name: '广福镇', total: 1063}, // {name: '广福镇', total: 1063},
{name: '三江镇', total: 851}, // {name: '三江镇', total: 851},
{name: '泾口乡', total: 657}, // {name: '泾口乡', total: 657},
{name: '南新镇', total: 640}, // {name: '南新镇', total: 640},
{name: '八一乡', total: 569}, // {name: '八一乡', total: 569},
{name: '黄马乡', total: 541}, // {name: '黄马乡', total: 541},
{name: '塔城乡', total: 534}, // {name: '塔城乡', total: 534},
{name: '富山乡', total: 515}, // {name: '富山乡', total: 515},
{name: '东新乡', total: 513}, // {name: '东新乡', total: 513},
{name: '银三角', total: 513}, // {name: '银三角', total: 513},
{name: '八月湖街道', total: 513},] // {name: '八月湖街道', total: 513},]
const province = undefined // const province = undefined
const FIRST = "linear-gradient(360deg, rgba(43, 180, 211, 0.1) 0%, rgba(43, 180, 211, 0.4) 100%)" const FIRST = "linear-gradient(360deg, rgba(43, 180, 211, 0.1) 0%, rgba(43, 180, 211, 0.4) 100%)"
const SECOND = "linear-gradient(360deg, rgba(255, 209, 86, 0.1) 0%, rgba(255, 209, 86, 0.4) 100%)" const SECOND = "linear-gradient(360deg, rgba(255, 209, 86, 0.1) 0%, rgba(255, 209, 86, 0.4) 100%)"
const THIRD = "linear-gradient(360deg, rgba(148, 148, 255, 0.1) 0%, rgba(148, 148, 255, 0.4) 100%)" const THIRD = "linear-gradient(360deg, rgba(148, 148, 255, 0.1) 0%, rgba(148, 148, 255, 0.4) 100%)"
const OTHER = "linear-gradient(360deg, rgba(28, 96, 253, 0) 0%, rgba(28, 96, 253, 0.2) 100%)" const OTHER = "linear-gradient(360deg, rgba(28, 96, 253, 0) 0%, rgba(28, 96, 253, 0.2) 100%)"
let TOTALS = data?.map(({ name, total }, index) => { let TOTALS = data?.map(({ name, total }, index) => {
let max = province ? data.length * 30 + 100 : data.length * 500 + 100 let max = Math.max(...data.map(item=>item.total))
console.log(data.map(item=>item.total),'好朋友吗')
return { return {
name, name,
value: total, value: total,
@ -35,7 +36,7 @@ let TOTALS = data?.map(({ name, total }, index) => {
}) })
let new_TOTALS = TOTALS && TOTALS.length > 10 ? TOTALS.slice(0, 10) : TOTALS let new_TOTALS = TOTALS && TOTALS.length > 10 ? TOTALS.slice(0, 10) : TOTALS
function Cell(props) { function Cell(props) {
const { name, rank, value, percent, style = {} } = props const { name, rank, value, percent, style = {},cebg } = props
let bg = RNAKS[rank] || OTHER let bg = RNAKS[rank] || OTHER
console.log(percent,'百分比') console.log(percent,'百分比')
return <div style={{ return <div style={{
@ -57,9 +58,11 @@ function Cell(props) {
<div style={{ display: 'flex', justifyContent: "space-between", alignItems: "center", height: 13 }}> <div style={{ display: 'flex', justifyContent: "space-between", alignItems: "center", height: 13 }}>
<div style={{display:'flex', width:"85%"}}> <div style={{display:'flex', width:"85%"}}>
<div style={{ <div style={{
position:'relative',
width: percent, height: 5, width: percent, height: 5,
background: "linear-gradient(270deg, #1C60FE 0%, rgba(28, 96, 254, 0) 100%)" background: cebg || "linear-gradient(270deg, #1C60FE 0%, rgba(28, 96, 254, 0) 100%)"
}} /> }} >{cebg?<span style={{position:'absolute',right:'0',top:'0',backgroundColor:"#FFF",height:"5px",width:"5px",borderRadius:"2.5px"}}/>:""}</div>
<div style={{width:`calc(100% - ${percent})`,background:'rgba(255,255,255,0.0800)'}}/> <div style={{width:`calc(100% - ${percent})`,background:'rgba(255,255,255,0.0800)'}}/>
</div> </div>
<div style={{ marginLeft: 10, fontSize: 12,color:"#FFFFFF" }}>{value}</div> <div style={{ marginLeft: 10, fontSize: 12,color:"#FFFFFF" }}>{value}</div>
@ -68,11 +71,11 @@ function Cell(props) {
</div> </div>
} }
const renderContent = () => { const renderContent = () => {
return <div >
{new_TOTALS?.map(({ name, value, percent }, index) => { return new_TOTALS?.map(({ name, value, percent }, index) => {
return <Cell key={index} rank={index} name={name} value={value} percent={percent} /> return <Cell key={index} rank={index} name={name} value={value} percent={percent} cebg={index===0?'linear-gradient(63deg, rgba(16, 39, 75, 1) 0%, rgba(7, 185, 254, 1) 100%)':undefined}/>
})} })
</div>
} }
const RNAKS = [FIRST, SECOND, THIRD] const RNAKS = [FIRST, SECOND, THIRD]
@ -81,7 +84,7 @@ const RNAKS = [FIRST, SECOND, THIRD]
<div className='build-right-center-top'> <div className='build-right-center-top'>
<img src="/assets/images/quanju/gonglugongcheng.png"></img> <img src="/assets/images/quanju/gonglugongcheng.png"></img>
<div>在线公路工程数量</div> <div>在线公路工程数量</div>
<h2>1234,123</h2> <h2>{sundata}</h2>
</div> </div>
<AutoRollComponent content={renderContent()} <AutoRollComponent content={renderContent()}
containerStyle={{ position: "relative", height: "65%", }} containerStyle={{ position: "relative", height: "65%", }}

108
web/client/src/sections/quanju/containers/footer/build/index.js

@ -11,38 +11,90 @@ import Module from '../../public/module'
import RightBottom from './Rightbottom' import RightBottom from './Rightbottom'
import AutoRollComponent from './AutoRollComponent' import AutoRollComponent from './AutoRollComponent'
import './style.less' import './style.less'
import {getdaolutongji} from '../../../actions/example' import {getdaolutongji,getxuanchuan} from '../../../actions/example'
const Build = (props) => { const Build = (props) => {
const { dispatch } = props const { dispatch } = props
let data = [ let data1 = [
{ value: 435, name: "县道" }, {name: "县", value: 207},
{ value: 679, name: "乡道" }, {name: "乡", value: 729},
{ value: 848, name: "村道" }, {name: "村", value: 1938}
] ]
const safetyData = [ // const safetyData = [
{name: '一级公路', value: 42}, // {name: '一级公路', value: 42},
{name: '二级公路', value: 17}, // {name: '二级公路', value: 17},
{name: '三级公路', value: 17}, // {name: '三级公路', value: 17},
{name: '四级公路', value: 30}, // {name: '四级公路', value: 30},
] // ]
const [buildingnumber,setbuildingnumber] = useState(0) const [buildingnumber,setbuildingnumber] = useState(0)
const [data,setdata] = useState([])
const [xuandata,setxuandata] = useState(null)
//获取道路管理数据
const requestbuildingnumber = async ()=>{ const requestbuildingnumber = async ()=>{
const res = await dispatch(getdaolutongji()); const res = await dispatch(getdaolutongji());
let alltype = Object.keys(res.payload.data?.roadType || {}).map((item)=>({name:item,value:Number(keepThreeNum(res.payload.data.roadType[item]))}))
setdata(alltype.filter(item=>item.name!=='null'))
setbuildingnumber(res.payload.data) setbuildingnumber(res.payload.data)
// console.log(res.payload.data,'哈哈哈') console.log(res.payload.data,'哈哈哈')
}
//获取宣传栏数据
const requestxuanchuanlan = async ()=>{
const res = await dispatch(getxuanchuan());
// setdata(alltype.filter(item=>item.name!=='null'))
setxuandata(res.payload.data)
console.log(res.payload.data,'宣传栏数据')
} }
let t1 = Object.values(buildingnumber?.townRoad || {})
let totalgongli = t1.length!==0 ? t1.reduce((x,y)=>x+y.mileage,0):0 //乡镇道路占比总公里数
let totalcount = t1.length !==0 ? t1.reduce((x,y)=>x+y.roadCount,0):0 //乡镇道路占比公路总条数
// let sungongli = alltype.reduce((x,y)=>x+y.value,0)
const keepThreeNum=(value)=> {
let resValue = 0
//小数点的位置
let index = value&&value.toString().indexOf('.') + 1
//小数的位数
let num = value&&Math.abs(Number(value)).toString().length - index
if(index && num > 3){
resValue = value&&Number(value).toFixed(3)
} else {
resValue = value
}
return resValue
}
let datas = Object.keys(buildingnumber?.townRoad || {}).map((item)=>({name:item,number:buildingnumber.townRoad[item].roadCount,gongli:Number(keepThreeNum(buildingnumber.townRoad[item].mileage))}))
//道路等级数据
let alldengji = Object.keys(buildingnumber?.roadLevel || {}).map((item)=>({name:item,value:Number(keepThreeNum(buildingnumber.roadLevel[item]))}))
let onlineproject = Object.keys(buildingnumber?.townProject||{}).map((item)=>({name:item,total:buildingnumber.townProject[item]}))
let sunonlineproject = onlineproject.reduce((x,y)=>x+y.total,0)
let safetyData = alldengji.filter(item=>item.name!=='null')
let sundata = data.reduce((x,y)=>x+y.value,0)
let sunsafetyData = safetyData.reduce((x,y)=>x+y.value,0)
console.log(safetyData,'好凶猛')
console.log(data1,'对比')
// console.log(totalgongli,"好好的")
// console.log(keepThreeNum(totalgongli),'jjjjj')
useEffect(()=>{ useEffect(()=>{
requestbuildingnumber() requestbuildingnumber();
requestxuanchuanlan()
},[]) },[])
const datas = new Array(15) // const datas = new Array(15)
datas.fill({ // datas.fill({
name:"东乡镇", // name:"东乡镇",
number:"11111", // number:"11111",
gongli:'9999' // gongli:'9999'
},0,15) // },0,15)
const rendercontent = ()=>{ const rendercontent = ()=>{
return (<div className='build-left-center-content'> return (<div className='build-left-center-content'>
{datas.map(({name,number,gongli},index)=><div className='build-left-center-item' key={index}> {datas.map(({name,number,gongli},index)=><div className='build-left-center-item' key={index}>
@ -65,7 +117,7 @@ const Build = (props) => {
<span/> <span/>
<span>在建公路数量</span> <span>在建公路数量</span>
</div> </div>
<div>{buildingnumber.buildingRoad || 0}</div> <div>{buildingnumber?.buildingRoad || 0}</div>
</div> </div>
<img src='/assets/images/quanju/zhuangtaigonglui.png' className='build-left-top-center'/> <img src='/assets/images/quanju/zhuangtaigonglui.png' className='build-left-top-center'/>
<div className='build-left-top-item'> <div className='build-left-top-item'>
@ -74,7 +126,7 @@ const Build = (props) => {
<span/> <span/>
<span>已建公路数量</span> <span>已建公路数量</span>
</div> </div>
<div>{buildingnumber.buildedRoad || 0}</div> <div>{buildingnumber?.buildedRoad || 0}</div>
</div> </div>
</div> </div>
</Module> </Module>
@ -87,14 +139,14 @@ const Build = (props) => {
<img src='/assets/images/quanju/gonglugongli.png'></img> <img src='/assets/images/quanju/gonglugongli.png'></img>
<div> <div>
<span>公路公里数/公里</span> <span>公路公里数/公里</span>
<span>1234,123</span> <span>{keepThreeNum(totalgongli)}</span>
</div> </div>
</div> </div>
<div> <div>
<img src='/assets/images/quanju/gongluzong.png'></img> <img src='/assets/images/quanju/gongluzong.png'></img>
<div> <div>
<span>公路公里数/公里</span> <span>公路总数/</span>
<span>1234,123</span> <span>{totalcount||0}</span>
</div> </div>
</div> </div>
</div> </div>
@ -115,7 +167,7 @@ const Build = (props) => {
width='100%' width='100%'
height='100%' height='100%'
text='道路总公里' text='道路总公里'
total={2344.13} total={keepThreeNum(sundata)}
// colorList={colorList} // colorList={colorList}
// underColorList={underColorList} // underColorList={underColorList}
/> />
@ -134,7 +186,7 @@ const Build = (props) => {
<Module title={"各乡镇在建公路工程"} style={{ width: "100%", <Module title={"各乡镇在建公路工程"} style={{ width: "100%",
height:" 33%",marginTop:'3%' height:" 33%",marginTop:'3%'
}} customize = {true}> }} customize = {true}>
<Rightcenter/> <Rightcenter data={onlineproject} sundata={sunonlineproject}/>
</Module> </Module>
<Module title={"公路等级统计"} style={{ width: "100%", <Module title={"公路等级统计"} style={{ width: "100%",
height:" 30%",marginTop:'3%' height:" 30%",marginTop:'3%'
@ -142,8 +194,8 @@ const Build = (props) => {
<RightBottom width='100%' <RightBottom width='100%'
height='100%' height='100%'
text='道路总公里' text='道路总公里'
total={2344.13} total={sunsafetyData}
data={safetyData}/> data={keepThreeNum(safetyData)}/>
</Module> </Module>
</div> </div>
</div> </div>

4
web/client/src/sections/quanju/containers/footer/build/style.less

@ -141,6 +141,10 @@
display: flex ; display: flex ;
width: 100%; width: 100%;
height: 28px; height: 28px;
align-items: center;
&:hover{
background: linear-gradient(270deg, rgba(0,124,230,0) 0%, rgba(0,70,200,0.8700) 100%);
}
span{ span{
flex:1; flex:1;
text-align: center; text-align: center;

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

@ -0,0 +1,27 @@
'use strict';
import { basicAction } from '@peace/utils'
import { ApiTable } from '$utils'
//获取路政列表
export function getHighways() {
return dispatch => basicAction({
type: 'get',
dispatch: dispatch,
actionType: 'GET_HIGHWAYS',
url: ApiTable.getHighways,
msg: { error: '获取路政列表失败' },
reducer: { name: 'highways' }
});
}
//获取道路养护统计及列表
export function getRoadMaintenances() {
return dispatch => basicAction({
type: 'get',
dispatch: dispatch,
actionType: 'GET_ROAD_MAINTENANCES',
url: ApiTable.getRoadMaintenance,
msg: { error: '获取道路养护列表失败' },
reducer: { name: 'RoadMaintenances' }
});
}

74
web/client/src/sections/quanju/containers/footer/conserve/chart/pie-chart.js

@ -5,7 +5,6 @@ import * as echarts from 'echarts';
const PieChart = (props) => { const PieChart = (props) => {
const { width, height, data, colorList, underColorList, total, text } = props const { width, height, data, colorList, underColorList, total, text } = props
const chartRef = useRef(null); const chartRef = useRef(null);
let name = [], emptyName = [] let name = [], emptyName = []
// const name = data?.map(d) // const name = data?.map(d)
@ -26,13 +25,34 @@ const PieChart = (props) => {
orient: "vertical", orient: "vertical",
itemWidth: 10, itemWidth: 10,
itemHeight: 10, itemHeight: 10,
right: '30%', // right: '30%',
left: '50%',
top: 'center', top: 'center',
align: 'left', align: 'left',
data: name, data: name,
formatter: (name) => {
for (let i = 0; i < option.series[1].data.length; i += 1) {
if (name === option.series[1].data[i].name) {
let arr = [`{a|${name}}`, `{b|${option.series[1].data[i].value}}`]
return arr.join('\t');
}
}
},
textStyle: { textStyle: {
color: "#fff", rich: {
a: {
color: '#E9F7FF',
fontSize: 14,
padding:[0,2]
}, },
b: {
fontSize: 16,
fontFamily: 'YouSheBiaoTiHei',
color: '#fff',
padding:[0,0,0,10]
},
}
}
}, },
grid: { grid: {
left: '10%' left: '10%'
@ -58,13 +78,55 @@ const PieChart = (props) => {
// }, // },
// }, // },
// ], // ],
graphic: {
elements: [
{
type: 'image',
style: {
image: 'assets/images/quanju/chart-circle.png',
width: 120,
height: 120,
align: 'center',
// x:90,
// y:100
},
left: '14%',
top: 'center',
bounding: 'raw'
// position: ['40%', '40%'],
},
{
type: 'text',
style: {
text: text,
align: 'center',
fill: '#fff',
font: '12px "YouSheBiaoTiHei", sans-serif',
},
left: '17%',
top: '55%',
},
{
type: 'text',
style: {
text: total,
align: 'center',
fill: '#fff',
font: '20px "YouSheBiaoTiHei", sans-serif',
},
left: '18.5%',
top: 'center',
},
],
},
series: [ series: [
{ {
name: "底层背景", name: "底层背景",
type: "pie", type: "pie",
hoverAnimation: false, hoverAnimation: false,
legendHoverLink: false, legendHoverLink: false,
radius: ["60%", "72%"], radius: ["58%", "67%"],
center: ['25%', '50%'], center: ['25%', '50%'],
color: underColorList, color: underColorList,
label: { label: {
@ -82,7 +144,7 @@ const PieChart = (props) => {
{ {
name: "已绿化里程统计", name: "已绿化里程统计",
type: "pie", type: "pie",
radius: ["67%", "80%"], radius: ["65%", "75%"],
center: ['25%', '50%'], center: ['25%', '50%'],
color: colorList, color: colorList,
label: { label: {
@ -99,7 +161,7 @@ const PieChart = (props) => {
chartInstance.resize() chartInstance.resize()
} }
}) })
}, []) }, [data])
return ( return (
<div style={{ width: width || '100%', height: height || '100%' }}> <div style={{ width: width || '100%', height: height || '100%' }}>
<div ref={chartRef} style={{ width: '100%', height: '100%' }}></div> <div ref={chartRef} style={{ width: '100%', height: '100%' }}></div>

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

@ -3,11 +3,15 @@ import Left from './left'
import Right from './right' import Right from './right'
import { connect } from 'react-redux' import { connect } from 'react-redux'
import { getdaolutongji } from '../../../actions/example' import { getdaolutongji } from '../../../actions/example'
import { getHighways, getRoadMaintenances } from './action'
const Conserve = (props) => { const Conserve = (props) => {
const [roadData, setRoadData] = useState() const [roadData, setRoadData] = useState()
const [highwaysData, setHighwaysData] = useState()
const [roadMaintenances, setRoadMaintenances] = useState()
const [loading, setLoading] = useState(true) const [loading, setLoading] = useState(true)
const { dispatch } = props const { dispatch } = props
useEffect(() => { useEffect(() => {
@ -15,12 +19,18 @@ const Conserve = (props) => {
setLoading(false) setLoading(false)
setRoadData(res.payload.data || {}) setRoadData(res.payload.data || {})
}) })
dispatch(getHighways()).then(res =>{
setHighwaysData(res.payload.data || [])
})
dispatch(getRoadMaintenances()).then(res =>{
setRoadMaintenances(res.payload.data || [])
})
}, []) }, [])
return ( return (
<div style={{ display: 'flex', width: '100%', height: '100%', justifyContent: 'space-between' }}> <div style={{ display: 'flex', width: '100%', height: '100%', justifyContent: 'space-between' }}>
<Left roadData={roadData} loading={loading} /> <Left roadData={roadData} loading={loading} />
<Right roadData={roadData} loading={loading} /> <Right highwaysData={highwaysData} roadMaintenances={roadMaintenances}/>
</div> </div>
) )
} }

24
web/client/src/sections/quanju/containers/footer/conserve/left/left-bottom.js

@ -2,11 +2,6 @@ import React from 'react'
import Module from '../../../public/module' import Module from '../../../public/module'
import PieChart from '../chart/pie-chart'; import PieChart from '../chart/pie-chart';
let data = [
{ value: 435, name: "县道" },
{ value: 679, name: "乡道" },
{ value: 848, name: "村道" },
]
let colorList = [ let colorList = [
"rgba(7,185,254,1)", "rgba(7,185,254,1)",
"rgba(28,96,254,1)", "rgba(28,96,254,1)",
@ -17,18 +12,29 @@ let underColorList = [
"rgba(28,96,254,0.5)", "rgba(28,96,254,0.5)",
"rgba(4,251,240,0.5)", "rgba(4,251,240,0.5)",
] ]
const LeftBottom = () => { const LeftBottom = (props) => {
const style = { height: "31%", marginTop: "3%" } const style = { height: "31%", marginTop: "3%" }
const { roadData } = props
const list = roadData?.greenMileage || {}
let grade = ['县道', '乡道', '村道']
let totalData = null
const value = Object.values(list)?.map((s, index) => {
totalData += s.isGreen
return {
name: grade[index],
value: s.isGreen.toFixed(3)
}
})
return ( return (
<> <>
<Module style={style} title={"已绿化里程统计"}> <Module style={style} title={"已绿化里程统计"}>
{/* <div ref = {chartRef} style={{ width: '100%', height: '100%' }}></div> */}
<PieChart <PieChart
data={data} data={value}
width='100%' width='100%'
height='100%' height='100%'
text='已绿化里程' text='已绿化里程'
total={2344.13} total={totalData?.toFixed(3) || 0}
colorList={colorList} colorList={colorList}
underColorList={underColorList} underColorList={underColorList}
/> />

8
web/client/src/sections/quanju/containers/footer/conserve/right.js

@ -4,12 +4,12 @@ import RightCenter from './right/right-center'
import RightTop from './right/right-top' import RightTop from './right/right-top'
const Right = (props) => { const Right = (props) => {
const { roadData } = props const { highwaysData,roadMaintenances } = props
return ( return (
<div style={{ display: 'flex', flexDirection: 'column', width: "23%", height: "100%", marginRight: "1%", }}> <div style={{ display: 'flex', flexDirection: 'column', width: "23%", height: "100%", marginRight: "1%", }}>
<RightTop roadData={roadData} /> <RightTop highwaysData={highwaysData}/>
<RightCenter roadData={roadData} /> <RightCenter highwaysData={highwaysData}/>
<RightBottom roadData={roadData} /> <RightBottom roadMaintenances={roadMaintenances}/>
</div> </div>
) )
} }

43
web/client/src/sections/quanju/containers/footer/conserve/right/right-bottom.js

@ -2,12 +2,6 @@ import React from 'react'
import Module from '../../../public/module' import Module from '../../../public/module'
import PieChart from '../chart/pie-chart'; import PieChart from '../chart/pie-chart';
let data = [
{ value: 435, name: "道路" },
{ value: 679, name: "桥梁" },
{ value: 848, name: "涵洞" },
{ value: 666, name: "其他" },
]
let colorList = [ let colorList = [
"rgba(7,185,254,1)", "rgba(7,185,254,1)",
"rgba(28,96,254,1)", "rgba(28,96,254,1)",
@ -20,18 +14,49 @@ let underColorList = [
"rgba(4,251,240,0.5)", "rgba(4,251,240,0.5)",
"rgba(255,194,20,0.5)" "rgba(255,194,20,0.5)"
] ]
const RightBottom = () => {
const type = ['road', 'culvert', 'bridge']
const RightBottom = (props) => {
const { roadMaintenances } = props
let totalData = null
let typesNum = null
const list = roadMaintenances?.reportCount?.map((r, index) => {
totalData += Number(r.count)
if (r.projectType === type[index]) {
typesNum += Number(r.count)
}
switch (r.projectType) {
case 'road':
return {
name: '道路',
value: r.count
};
case 'culvert':
return {
name: '涵洞',
value: r.count
};
case 'bridge':
return {
name: '桥梁',
value: r.count
}
}
}).filter(f => f !== undefined)
const otherNum = totalData - typesNum
otherNum !== null && list?.push({ name: '其他', value: otherNum })
const style = { height: "31%", marginTop: "3%" } const style = { height: "31%", marginTop: "3%" }
return ( return (
<> <>
<Module style={style} title={"养护完成情况"}> <Module style={style} title={"养护完成情况"}>
{/* <div ref = {chartRef} style={{ width: '100%', height: '100%' }}></div> */} {/* <div ref = {chartRef} style={{ width: '100%', height: '100%' }}></div> */}
<PieChart <PieChart
data={data} data={list}
width='100%' width='100%'
height='100%' height='100%'
text='养护总数' text='养护总数'
total={2344.13} total={totalData || 0}
colorList={colorList} colorList={colorList}
underColorList={underColorList} underColorList={underColorList}
/> />

75
web/client/src/sections/quanju/containers/footer/conserve/right/right-center.js

@ -2,47 +2,56 @@ import React from 'react'
import Module from '../../../public/module' import Module from '../../../public/module'
import { Col, Row } from 'antd' import { Col, Row } from 'antd'
const RightCenter = () => { // const unit =['个','个',]
const icon = [
'assets/images/quanju/jiancha.png',
'assets/images/quanju/yushui.png',
'assets/images/quanju/lupai.png',
'assets/images/quanju/zerenpai.png'
]
const RightCenter = (props) => {
const { highwaysData } = props
const style = { height: "31%", marginTop: "3%" } const style = { height: "31%", marginTop: "3%" }
const textStyle = { fontSize: 14, color: '#E9F7FF' } const textStyle = { fontSize: 14, color: '#E9F7FF' }
const numStyle = { color: '#fff', fontSize: 24, fontFamily: 'YouSheBiaoTiHei', textShadow: '0px 0px 8px #1C60FE', marginTop: 8 } const numStyle = { color: '#fff', fontSize: 21, fontFamily: 'YouSheBiaoTiHei', textShadow: '0px 0px 8px #1C60FE', marginTop: 8 }
const list = highwaysData?.slice(4, 8).map((h,index)=>{
return {
id:h.id,
name:h.name,
count:h.count,
// unit:unit[index],
icon:icon[index]
}
})
const arrayChunk = (array, size) => {
let data = []
for (let i = 0; i < array.length; i += size) {
data.push(array.slice(i, i + size))
}
return data
}
let lists = list ? arrayChunk(list, 2) : []
return ( return (
<> <>
<Module style={style} title={"各类附属设施数量统计"}> <Module style={style} title={"各类附属设施数量统计"}>
<div style={{ paddingLeft: '8%' }}> <div style={{ paddingLeft: '8%' }}>
<Row style={{ marginTop: 20, justifyContent: 'space-around' }}> {
<Col style={{ display: 'flex', width: '50%' }}> lists?.map((item, index) => {
<img src='assets/images/quanju/jiancha.png' alt='icon' /> return <div style={{ display: 'flex', marginTop: "5%", justifyContent: 'space-around' }} key={index}>
{
item?.map(i => (
<div style={{ display: 'flex', width: '50%' }} key={i.id}>
<img src={i.icon} alt='icon' style={{ width: '36%', height: '100%' }} />
<div style={{ marginLeft: 10 }}> <div style={{ marginLeft: 10 }}>
<div style={textStyle}>检查井</div> <div style={textStyle}>{i.name}</div>
<div style={numStyle}>89</div> <div style={numStyle}>{`${i.count}`}</div>
</div>
</div>
))
}
</div> </div>
</Col> })
<Col style={{ display: 'flex', width: '50%' }}> }
<img src='assets/images/quanju/yushui.png' alt='icon' />
<span style={{ marginLeft: 10 }}>
<div style={textStyle}>雨水口</div>
<div style={numStyle}>61</div>
</span>
</Col>
</Row>
<Row style={{ marginTop: 20, justifyContent: 'space-around' }}>
<Col style={{ display: 'flex', width: '50%' }}>
<img src='assets/images/quanju/lupai.png' alt='icon' />
<span style={{ marginLeft: 10 }}>
<div style={textStyle}>路牌名</div>
<div style={numStyle}>2230</div>
</span>
</Col>
<Col span={12} style={{ display: 'flex', width: '50%' }}>
<img src='assets/images/quanju/zerenpai.png' alt='icon' />
<span style={{ marginLeft: 10 }}>
<div style={textStyle}>养护责任牌</div>
<div style={numStyle}>1217</div>
</span>
</Col>
</Row>
</div> </div>
</Module> </Module>
</> </>

80
web/client/src/sections/quanju/containers/footer/conserve/right/right-top.js

@ -1,47 +1,61 @@
import { Col, Row } from 'antd' import { Col, Row } from 'antd'
import React from 'react' import React, { useState, useEffect } from 'react'
import Module from '../../../public/module' import Module from '../../../public/module'
const RightTop = () => {
const iconSrc = [
'assets/images/quanju/biaoxian.png',
'assets/images/quanju/renxing.png',
'assets/images/quanju/biaozhi.png',
'assets/images/quanju/fanghu.png'
]
const unit = ['km', '处', '个', 'km']
const RightTop = (props) => {
const { highwaysData } = props
const style = { height: "31%", marginTop: "3%" } const style = { height: "31%", marginTop: "3%" }
const textStyle = { fontSize: 14, color: '#E9F7FF' } const textStyle = { fontSize: 14, color: '#E9F7FF' }
const numStyle = { color: '#fff', fontSize: 20, fontFamily: 'YouSheBiaoTiHei', textShadow: '0px 0px 8px #1C60FE', marginTop: 8 } const numStyle = { color: '#fff', fontSize: 21, fontFamily: 'YouSheBiaoTiHei', textShadow: '0px 0px 8px #1C60FE', marginTop: 8 }
const list = highwaysData?.slice(0, 4).map((h,index)=>{
return {
id:h.id,
name:h.name,
count:h.count,
unit:unit[index],
icon:iconSrc[index]
}
})
const arrayChunk = (array, size) => {
let data = []
for (let i = 0; i < array.length; i += size) {
data.push(array.slice(i, i + size))
}
return data
}
let lists = list ? arrayChunk(list, 2) : []
return ( return (
<> <>
<Module style={style} title={"道路设施数量统计"}> <Module style={style} title={"道路设施数量统计"}>
<div style={{ paddingLeft: '8%' }}> <div style={{ paddingLeft: '8%' }}>
<Row style={{ marginTop: "5%", justifyContent: 'space-around' }}> {
<Col style={{ display: 'flex', width: '50%' }}> lists?.map((item, index) => {
<img src='assets/images/quanju/biaoxian.png' alt='icon' /> return <div style={{ display: 'flex', marginTop: "5%", justifyContent: 'space-around' }} key={index}>
{
item?.map(i => (
<div style={{ display: 'flex', width: '50%' }} key={i.id}>
<img src={i.icon} alt='icon' style={{ width: '36%', height: '100%' }} />
<div style={{ marginLeft: 10 }}> <div style={{ marginLeft: 10 }}>
<div style={textStyle}>标线</div> <div style={textStyle}>{i.name}</div>
<div style={numStyle}>1352km</div> <div style={numStyle}>{`${i.count}${i.unit}`}</div>
</div>
</div>
))
}
</div> </div>
</Col> })
<Col style={{ display: 'flex', width: '50%' }}> }
<img src='assets/images/quanju/renxing.png' alt='icon' />
<span style={{ marginLeft: 10 }}>
<div style={textStyle}>人行道</div>
<div style={numStyle}>80</div>
</span>
</Col>
</Row>
<Row style={{ justifyContent: 'space-around' }}>
<Col style={{ display: 'flex', width: '50%' }}>
<img src='assets/images/quanju/biaozhi.png' alt='icon' />
<span style={{ marginLeft: 10 }}>
<div style={textStyle}>标志牌</div>
<div style={numStyle}>4563</div>
</span>
</Col>
<Col span={12} style={{ display: 'flex', width: '50%' }}>
<img src='assets/images/quanju/fanghu.png' alt='icon' />
<span style={{ marginLeft: 10 }}>
<div style={textStyle}>防护栏</div>
<div style={numStyle}>1054km</div>
</span>
</Col>
</Row>
</div> </div>
</Module> </Module>
</> </>

2
web/client/src/sections/quanju/containers/footer/guanli/index.js

@ -59,7 +59,7 @@ const Guanli = (props) => {
<div className = "guanli-right-top"> <div className = "guanli-right-top">
<img src="/assets/images/quanju/zhicaolog.png"></img> <img src="/assets/images/quanju/zhicaolog.png"></img>
<span>已处理</span> <span>已处理</span>
<span>{rightDatas.processed||0}</span> <span>{rightDatas?.processed||0}</span>
<span></span> <span></span>
</div> </div>
<div className='guanli-right-title'> <div className='guanli-right-title'>

2
web/client/src/sections/quanju/containers/footer/guanli/style.less

@ -153,7 +153,7 @@
font-weight: 400; font-weight: 400;
color: rgba(216,240,255,0.8000); color: rgba(216,240,255,0.8000);
line-height: 20px; line-height: 20px;
// flex:1; flex:1;
text-align: center; text-align: center;
// &:nth-child(1){ // &:nth-child(1){

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

@ -60,12 +60,20 @@ export const ApiTable = {
getzhichaodetail: '/manage/overspeed', getzhichaodetail: '/manage/overspeed',
//大屏运营 —— 公交车辆层级信息 //大屏运营 —— 公交车辆层级信息
getBusTier:'/operation/car_level' getBusTier:'/operation/car_level',
};
//获取路政列表
getHighways: 'road_manage',
//获取道路养护统计及列表
getRoadMaintenance: 'conserve/statistic',
//获取宣传数据
getpropagata:'publicity',
};
export const RouteTable = { export const RouteTable = {
apiRoot: '/api/root', apiRoot: '/api/root',

Loading…
Cancel
Save