|
@ -1,49 +1,114 @@ |
|
|
import React from 'react' |
|
|
import React from 'react' |
|
|
import { Box, AutoRollComponent } from '$components'; |
|
|
import { Box, NoData } from '$components'; |
|
|
|
|
|
import ReactEcharts from 'echarts-for-react'; |
|
|
|
|
|
import moment from 'moment'; |
|
|
|
|
|
|
|
|
function Infrastructure(props) { |
|
|
function Infrastructure(props) { |
|
|
|
|
|
const { fireTrend } = props; |
|
|
|
|
|
let Ydata = fireTrend.map(t => t.count); |
|
|
|
|
|
let Xdata = fireTrend.map(t => moment(t.time).format('MM月DD日')); |
|
|
|
|
|
|
|
|
const getContent = () => { |
|
|
const option = { |
|
|
return <div className='today_real_alarm'> |
|
|
tooltip: { |
|
|
<div className='today_item'> |
|
|
trigger: "axis", |
|
|
<div className='column1_alarm1'>14:22</div> |
|
|
axisPointer: { |
|
|
<div className='text_blue'><div className='_icon1' />红花岗区大队</div> |
|
|
type: "shadow", |
|
|
<div className='text_blue'><div className='_icon2' />划龙桥路77号</div> |
|
|
}, |
|
|
</div> |
|
|
backgroundColor: "rgba(255,255,255,0.75)", |
|
|
<div className='today_item'> |
|
|
extraCssText: "box-shadow: 2px 2px 4px 0px rgba(0,0,0,0.3);", |
|
|
<div className='column1_alarm2'>14:22</div> |
|
|
textStyle: { |
|
|
<div className='text_blue'><div className='_icon1' />红花岗区大队</div> |
|
|
fontSize: 14, |
|
|
<div className='text_blue'><div className='_icon2' />划龙桥路77号</div> |
|
|
color: "#000", |
|
|
</div> |
|
|
}, |
|
|
<div className='today_item'> |
|
|
formatter: (params) => { |
|
|
<div className='column1_alarm1'>14:22</div> |
|
|
const item = params[0]; |
|
|
<div className='text_blue'><div className='_icon1' />红花岗区大队</div> |
|
|
return item.name + " : " + item.value + " 次"; |
|
|
<div className='text_blue'><div className='_icon2' />划龙桥路77号</div> |
|
|
}, |
|
|
</div> |
|
|
}, |
|
|
<div className='today_item'> |
|
|
legend: { |
|
|
<div className='column1_alarm2'>14:22</div> |
|
|
top: 10, |
|
|
<div className='text_blue'><div className='_icon1' />红花岗区大队</div> |
|
|
itemWidth: 20, |
|
|
<div className='text_blue'><div className='_icon2' />划龙桥路77号</div> |
|
|
itemHeight: 10, |
|
|
</div> |
|
|
left: "center", |
|
|
<div className='today_item'> |
|
|
padding: 0, |
|
|
<div className='column1_alarm2'>14:22</div> |
|
|
textStyle: { |
|
|
<div className='text_blue'><div className='_icon1' />红花岗区大队</div> |
|
|
color: "#E6E6E7", |
|
|
<div className='text_blue'><div className='_icon2' />划龙桥路77号</div> |
|
|
fontSize: 14, |
|
|
</div> |
|
|
padding: [2, 0, 0, 0], |
|
|
<div className='today_item'> |
|
|
}, |
|
|
<div className='column1_alarm2'>14:22</div> |
|
|
}, |
|
|
<div className='text_blue'><div className='_icon1' />红花岗区大队</div> |
|
|
xAxis: [ |
|
|
<div className='text_blue'><div className='_icon2' />划龙桥路77号</div> |
|
|
{ |
|
|
</div> |
|
|
type: "category", |
|
|
<div className='today_item'> |
|
|
axisLabel: { |
|
|
<div className='column1_alarm2'>14:22</div> |
|
|
interval: 0, |
|
|
<div className='text_blue'><div className='_icon1' />红花岗区大队</div> |
|
|
color: "rgba(195, 230, 255, 1)", |
|
|
<div className='text_blue'><div className='_icon2' />划龙桥路77号</div> |
|
|
fontSize: 10, |
|
|
</div> |
|
|
}, |
|
|
</div> |
|
|
axisLine: { |
|
|
} |
|
|
show: true, |
|
|
return <Box title={"今日实时警情"} > |
|
|
lineStyle: { |
|
|
<AutoRollComponent canScroll={true} content={getContent()} divHeight={250} divId={`fire-left-bottom`} /> |
|
|
type: 'solid', |
|
|
|
|
|
color: "rgba(184, 185, 188, 0.5)", |
|
|
|
|
|
width: 1, |
|
|
|
|
|
}, |
|
|
|
|
|
}, |
|
|
|
|
|
data: Xdata, |
|
|
|
|
|
}, |
|
|
|
|
|
], |
|
|
|
|
|
yAxis: [ |
|
|
|
|
|
{ |
|
|
|
|
|
splitNumber: 5, // 刻度段数
|
|
|
|
|
|
type: "value", |
|
|
|
|
|
nameTextStyle: { |
|
|
|
|
|
color: "rgba(195, 230, 255, 1)", |
|
|
|
|
|
fontWeight: 400, |
|
|
|
|
|
fontSize: 14, |
|
|
|
|
|
padding: [-20, 20, 0, 0] |
|
|
|
|
|
}, |
|
|
|
|
|
splitLine: { |
|
|
|
|
|
show: true, |
|
|
|
|
|
lineStyle: { |
|
|
|
|
|
type: 'dashed', |
|
|
|
|
|
color: 'rgba(89, 153, 200, 0.5)' |
|
|
|
|
|
} |
|
|
|
|
|
}, |
|
|
|
|
|
axisLabel: { |
|
|
|
|
|
show: true, |
|
|
|
|
|
fontSize: 12, |
|
|
|
|
|
color: "rgba(195, 230, 255, 1)", |
|
|
|
|
|
}, |
|
|
|
|
|
}, |
|
|
|
|
|
], |
|
|
|
|
|
series: [ |
|
|
|
|
|
{ |
|
|
|
|
|
type: "line", |
|
|
|
|
|
symbol: "none", |
|
|
|
|
|
barWidth: 16, |
|
|
|
|
|
label: { |
|
|
|
|
|
show: false, |
|
|
|
|
|
position: "top", |
|
|
|
|
|
color: "#00A8FF", |
|
|
|
|
|
}, |
|
|
|
|
|
data: Ydata, |
|
|
|
|
|
}, |
|
|
|
|
|
], |
|
|
|
|
|
grid: { |
|
|
|
|
|
x: 50, |
|
|
|
|
|
y: 25, |
|
|
|
|
|
x2: 30, |
|
|
|
|
|
y2: 20 |
|
|
|
|
|
}, |
|
|
|
|
|
}; |
|
|
|
|
|
return <Box title={"火情趋势"} > |
|
|
|
|
|
{ |
|
|
|
|
|
fireTrend.length ? <ReactEcharts |
|
|
|
|
|
option={option} |
|
|
|
|
|
notMerge |
|
|
|
|
|
lazyUpdate |
|
|
|
|
|
style={{ height: 231, width: 423 }} |
|
|
|
|
|
/> : <NoData height={231} /> |
|
|
|
|
|
} |
|
|
</Box> |
|
|
</Box> |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|