From 5cffe7c57faddb2dad9314916002c25b1d087b9f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E2=80=98lijianhao=E2=80=99?= Date: Mon, 25 Jul 2022 16:37:07 +0800 Subject: [PATCH] =?UTF-8?q?=E5=85=BB=E6=8A=A4=E5=A4=A7=E5=B1=8F=E9=83=A8?= =?UTF-8?q?=E5=88=86=E6=95=B0=E6=8D=AE=E6=8E=A5=E5=85=A5?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../organization/components/depModal.js | 7 ++- .../footer/conserve/action/index.js | 0 .../containers/footer/conserve/index.js | 31 ++++++++++-- .../quanju/containers/footer/conserve/left.js | 11 ++-- .../footer/conserve/left/left-center.js | 50 ++++++++++++------- .../footer/conserve/left/left-top.js | 40 +++++++-------- .../containers/footer/conserve/right.js | 9 ++-- 7 files changed, 94 insertions(+), 54 deletions(-) create mode 100644 web/client/src/sections/quanju/containers/footer/conserve/action/index.js diff --git a/web/client/src/sections/organization/components/depModal.js b/web/client/src/sections/organization/components/depModal.js index bd624b48..ae12d57d 100644 --- a/web/client/src/sections/organization/components/depModal.js +++ b/web/client/src/sections/organization/components/depModal.js @@ -75,7 +75,12 @@ function mapStateToProps(state) { title: d.name, value: d.id, // key: d.id, - children: pakData(d.subordinate) + children: d.subordinate.map(s => { + return { + title: s.name, + value: s.id, + } + }) } }) } diff --git a/web/client/src/sections/quanju/containers/footer/conserve/action/index.js b/web/client/src/sections/quanju/containers/footer/conserve/action/index.js new file mode 100644 index 00000000..e69de29b diff --git a/web/client/src/sections/quanju/containers/footer/conserve/index.js b/web/client/src/sections/quanju/containers/footer/conserve/index.js index 5e83a6d5..9eda76b9 100644 --- a/web/client/src/sections/quanju/containers/footer/conserve/index.js +++ b/web/client/src/sections/quanju/containers/footer/conserve/index.js @@ -1,14 +1,35 @@ -import React from 'react' +import React, { useEffect, useState } from 'react' import Left from './left' import Right from './right' +import { connect } from 'react-redux' +import { getdaolutongji } from '../../../actions/example' -const Conserve = () => { + +const Conserve = (props) => { + + const [roadData, setRoadData] = useState() + const [loading, setLoading] = useState(true) + const { dispatch } = props + useEffect(() => { + dispatch(getdaolutongji()).then(res => { + setLoading(false) + setRoadData(res.payload.data || {}) + }) + }, []) return (
- - + +
) } -export default Conserve \ No newline at end of file +function mapStateToProps(state) { + + // const { auth } = state; + + return { + + } +} +export default connect(mapStateToProps)(Conserve) \ No newline at end of file diff --git a/web/client/src/sections/quanju/containers/footer/conserve/left.js b/web/client/src/sections/quanju/containers/footer/conserve/left.js index 18d2ee4b..51b846e5 100644 --- a/web/client/src/sections/quanju/containers/footer/conserve/left.js +++ b/web/client/src/sections/quanju/containers/footer/conserve/left.js @@ -3,12 +3,13 @@ import LeftBottom from './left/left-bottom' import LeftCenter from './left/left-center' import LeftTop from './left/left-top' -const Left = () => { +const Left = (props) => { + const { roadData,loading } = props return ( -
- - - +
+ + +
) } diff --git a/web/client/src/sections/quanju/containers/footer/conserve/left/left-center.js b/web/client/src/sections/quanju/containers/footer/conserve/left/left-center.js index d2cd5330..9115358c 100644 --- a/web/client/src/sections/quanju/containers/footer/conserve/left/left-center.js +++ b/web/client/src/sections/quanju/containers/footer/conserve/left/left-center.js @@ -4,9 +4,16 @@ import { useEffect, useRef } from 'react' import Module from '../../../public/module' import * as echarts from 'echarts'; -const LeftCenter = () => { +const LeftCenter = (props) => { const style = { height: "31%", marginTop: "3%" } const chartRef = useRef(null); + const { roadData } = props + const data = roadData?.greenMileage || {} + const grad = Object.keys(data).map(g => g + '级可绿化里程') || [] + const value = Object.values(data)?.map(s => s.canBeGreen.toFixed(3)) + let totalData = value?.reduce((pre, cur) => Number(pre) + Number(cur), 0) || 0 + let max = Math.max.apply(Math, value) + 10 || 0 + useEffect(() => { let chartInstance = echarts.init(chartRef.current); let colorArray = [ @@ -34,9 +41,9 @@ const LeftCenter = () => { grid: { left: "5%", top: "12%", - right: "5%", + right: "1%", bottom: "8%", - width:'92%', + width: '100%', containLabel: true, }, @@ -46,6 +53,7 @@ const LeftCenter = () => { position: "bottom", axisTick: { show: true, + interval: 2, lineStyle: { color: "rgba(176,215,255,0.25)", // type: "dashed", @@ -57,6 +65,10 @@ const LeftCenter = () => { color: "rgba(216,240,255,0.8000)", }, }, + axisLabel: { + interval: 2 + }, + splitLine: { show: true, lineStyle: { @@ -85,7 +97,7 @@ const LeftCenter = () => { }, }, zlevel: 100, - data: ["县级可绿化里程", "乡级可绿化里程", "村级可绿化里程"], + data: grad, }, { type: "category", @@ -106,12 +118,12 @@ const LeftCenter = () => { width: 70, height: 22, color: '#D8F0FF', - margin:50, + margin: 40, verticalAlign: 'middle', align: 'center', - textShadowColor:'#1AD0FF', - textShadowBlur:6, - fontSize:14 + textShadowColor: '#1AD0FF', + textShadowBlur: 6, + fontSize: 14 // formatter:(f) =>{console.log('f:',f);} }, inverse: true, //排序 @@ -122,7 +134,7 @@ const LeftCenter = () => { }, }, - data: [60, 132, 89], + data: value, }, ], series: [ @@ -133,7 +145,7 @@ const LeftCenter = () => { barGap: "100%", barCategoryGap: "50%", color: "#15356E", - data: [150, 150, 150, 150], + data: [max, max, max], tooltip: { show: false, }, @@ -145,7 +157,7 @@ const LeftCenter = () => { barWidth: 3, barGap: "-100%", barCategoryGap: "50%", - data: [60, 132, 89], + data: value, label: { show: true, position: 'right', // 位置 @@ -201,12 +213,12 @@ const LeftCenter = () => { ], }; chartInstance.setOption(option); - window.addEventListener('resize',() =>{ - if(chartInstance) { - chartInstance.resize() + window.addEventListener('resize', () => { + if (chartInstance) { + chartInstance.resize() } - }) - }, []); + }) + }, [roadData]); return ( <> @@ -214,12 +226,12 @@ const LeftCenter = () => { - icon + icon 可绿化里程总数 - 1234 + {totalData} -
+
diff --git a/web/client/src/sections/quanju/containers/footer/conserve/left/left-top.js b/web/client/src/sections/quanju/containers/footer/conserve/left/left-top.js index eaadc4f8..5a3fc468 100644 --- a/web/client/src/sections/quanju/containers/footer/conserve/left/left-top.js +++ b/web/client/src/sections/quanju/containers/footer/conserve/left/left-top.js @@ -1,19 +1,20 @@ import React, { useEffect, useRef } from 'react'; import Module from '../../../public/module' import * as echarts from 'echarts'; -import { Badge } from 'antd'; +import { Badge, Spin } from 'antd'; -const LeftTop = () => { +const LeftTop = (props) => { const seasonChartRef = useRef(null); const frequentlyChartRef = useRef(null); - + const { roadData,loading } = props + let total = roadData?.curingPeriod?.frequent + roadData?.curingPeriod?.season useEffect(() => { let chartInstance = echarts.init(seasonChartRef.current); const seasonOption = { - tooltip:{ - show:true + tooltip: { + show: true }, title: [ { @@ -26,7 +27,7 @@ const LeftTop = () => { }, }, { - text: "2333", + text: roadData?.curingPeriod?.season || 0, x: "center", y: "35%", textStyle: { @@ -48,7 +49,7 @@ const LeftTop = () => { containLabel: true, }, angleAxis: { - max: 100, + max: total || 0, show: false, }, radiusAxis: { @@ -71,7 +72,7 @@ const LeftTop = () => { roundCap: true, barWidth: 30, showBackground: true, - data: [{value:40,name:'季节性'}], + data: [{ value: roadData?.curingPeriod?.season || 0, name: '季节性' }], coordinateSystem: "polar", itemStyle: { normal: { @@ -91,19 +92,19 @@ const LeftTop = () => { ], }; chartInstance.setOption(seasonOption); - window.addEventListener('resize',() =>{ - if(chartInstance) { + window.addEventListener('resize', () => { + if (chartInstance) { chartInstance.resize() } - }) + }) - }, []) + }, [roadData]) useEffect(() => { let chartInstance = echarts.init(frequentlyChartRef.current); const frequentlyOption = { - tooltip:{ - show:true, + tooltip: { + show: true, trigger: "item", }, title: [ @@ -117,7 +118,7 @@ const LeftTop = () => { }, }, { - text: "2333", + text: roadData?.curingPeriod?.frequent || 0, x: "center", y: "35%", textStyle: { @@ -140,7 +141,7 @@ const LeftTop = () => { containLabel: true, }, angleAxis: { - max: 100, + max: total || 0, show: false, }, radiusAxis: { @@ -163,7 +164,7 @@ const LeftTop = () => { roundCap: true, barWidth: 30, showBackground: true, - data:[{value:40,name:'经常性'}], + data: [{ value: roadData?.curingPeriod?.frequent || 0, name: '经常性' }], coordinateSystem: "polar", itemStyle: { normal: { @@ -190,10 +191,10 @@ const LeftTop = () => { chartInstance.resize() } }) - }, []) + }, [roadData]) const style = { height: "31%", marginTop: "3%" } return ( - <> +
@@ -217,7 +218,6 @@ const LeftTop = () => { }} />
- ) } export default LeftTop \ No newline at end of file diff --git a/web/client/src/sections/quanju/containers/footer/conserve/right.js b/web/client/src/sections/quanju/containers/footer/conserve/right.js index ee25d2ca..98464eec 100644 --- a/web/client/src/sections/quanju/containers/footer/conserve/right.js +++ b/web/client/src/sections/quanju/containers/footer/conserve/right.js @@ -3,12 +3,13 @@ import RightBottom from './right/right-bottom' import RightCenter from './right/right-center' import RightTop from './right/right-top' -const Right = () => { +const Right = (props) => { + const { roadData } = props return (
- - - + + +
) }