After Width: | Height: | Size: 173 KiB |
After Width: | Height: | Size: 8.4 KiB |
After Width: | Height: | Size: 9.0 KiB |
After Width: | Height: | Size: 4.4 KiB |
After Width: | Height: | Size: 4.4 KiB |
After Width: | Height: | Size: 4.2 KiB |
After Width: | Height: | Size: 41 KiB |
After Width: | Height: | Size: 23 KiB |
After Width: | Height: | Size: 3.5 KiB |
@ -0,0 +1,15 @@ |
|||
'use strict'; |
|||
|
|||
import { basicAction } from '@peace/utils' |
|||
import { ApiTable } from '$utils' |
|||
|
|||
// export function getMembers(orgId) {
|
|||
// return dispatch => basicAction({
|
|||
// type: 'get',
|
|||
// dispatch: dispatch,
|
|||
// actionType: 'GET_MEMBERS',
|
|||
// url: `${ApiTable.getEnterprisesMembers.replace('{enterpriseId}', orgId)}`,
|
|||
// msg: { error: '获取用户列表失败' },
|
|||
// reducer: { name: 'members' }
|
|||
// });
|
|||
// }
|
@ -0,0 +1,7 @@ |
|||
'use strict'; |
|||
|
|||
import * as example from './example' |
|||
|
|||
export default { |
|||
...example, |
|||
} |
@ -0,0 +1,16 @@ |
|||
import React from 'react' |
|||
import Box from './public/table-card'; |
|||
import './style.less' |
|||
function BasicInfo(props) { |
|||
|
|||
return <Box title={"事件概况"} > |
|||
<div className='item_left-container '> |
|||
<div className='end_event' onClick={() => { props.endEvent() }}>结束案件</div> |
|||
</div> |
|||
|
|||
</Box> |
|||
} |
|||
|
|||
export default BasicInfo; |
|||
|
|||
|
@ -0,0 +1,13 @@ |
|||
import React from 'react' |
|||
import Box from './public/table-card'; |
|||
|
|||
function BasicInfo() { |
|||
|
|||
return <Box title={"避难场所"} > |
|||
dd |
|||
</Box> |
|||
} |
|||
|
|||
export default BasicInfo; |
|||
|
|||
|
@ -0,0 +1,14 @@ |
|||
import React from 'react' |
|||
import Box from './public/table-card'; |
|||
|
|||
function Infrastructure(props) { |
|||
|
|||
|
|||
return <Box title={"基础设施"} > |
|||
|
|||
</Box> |
|||
} |
|||
|
|||
export default Infrastructure; |
|||
|
|||
|
@ -0,0 +1,144 @@ |
|||
import React from 'react' |
|||
import Box from './public/table-card'; |
|||
import ReactEcharts from 'echarts-for-react'; |
|||
|
|||
function PopulationDynamics() { |
|||
|
|||
let Ydata = ['火灾扑救', '抢险救援', '公务执勤', '社会救助', '其他出动']; |
|||
let Xdata = [12, 19, 19, 13, 15] |
|||
const options = { |
|||
xAxis: { |
|||
type: 'value', |
|||
show: false, |
|||
}, |
|||
grid: { |
|||
left: -10, |
|||
top: 20, |
|||
bottom: 0, |
|||
right: 20, |
|||
containLabel: true, |
|||
}, |
|||
yAxis: [ |
|||
{ |
|||
type: 'category', |
|||
inverse: true, |
|||
axisLabel: { |
|||
show: true, |
|||
margin: 25, |
|||
// textStyle: {
|
|||
color: '#ECF7FF', |
|||
fontSize: 12, |
|||
// },
|
|||
// 调整左侧文字的3个属性,缺一不可
|
|||
verticalAlign: 'center', |
|||
align: 'left', |
|||
//调整文字上右下左
|
|||
padding: [0, 0, 0, -30], |
|||
|
|||
|
|||
}, |
|||
splitLine: { |
|||
show: false, |
|||
}, |
|||
axisTick: { |
|||
show: false, |
|||
}, |
|||
axisLine: { |
|||
show: false, |
|||
}, |
|||
data: Ydata |
|||
}, |
|||
{ |
|||
inverse: true, |
|||
// y轴最右侧的文字
|
|||
axisTick: "none", |
|||
axisLine: "none", |
|||
type: "category", |
|||
axisLabel: { |
|||
// margin: 10,
|
|||
// textStyle: {
|
|||
color: "#24DCF7", |
|||
fontSize: "12", |
|||
// },
|
|||
rich: { |
|||
|
|||
a1: { |
|||
color: '#24DCF7', |
|||
width: 5, |
|||
height: 5, |
|||
fontSize: 16, |
|||
}, |
|||
a2: { |
|||
color: '#5999C8', |
|||
width: 5, |
|||
height: 5, |
|||
fontSize: 12, |
|||
}, |
|||
}, |
|||
formatter: function (value) { |
|||
return [`{a1|${value}} {a2|次}`]; |
|||
}, |
|||
}, |
|||
data: Xdata, |
|||
}, |
|||
|
|||
|
|||
], |
|||
series: [ |
|||
{ |
|||
type: 'bar', |
|||
barWidth: 12, |
|||
zlevel: 2, |
|||
z: 2, |
|||
showBackground: true, |
|||
backgroundStyle: { |
|||
color: '#2B375C' |
|||
}, |
|||
color: '#005AC6', |
|||
|
|||
label: { |
|||
show: false, |
|||
|
|||
}, |
|||
data: Xdata, |
|||
}, |
|||
{ |
|||
type: "pictorialBar", |
|||
// symbol: 'image://',
|
|||
symbolSize: [15, 15], |
|||
symbolOffset: [0, 0], |
|||
symbolPosition: "right", |
|||
z: 20, |
|||
zlevel: 20, |
|||
itemStyle: { |
|||
// normal: {
|
|||
color: "#fff" |
|||
// }
|
|||
}, |
|||
data: (function () { |
|||
var list = []; |
|||
for (var i = 0; i < Xdata.length; i++) { |
|||
list.push(2.02 * Xdata[i]); |
|||
} |
|||
console.log(list) |
|||
return list; |
|||
})() |
|||
}, |
|||
|
|||
], |
|||
|
|||
}; |
|||
|
|||
return <Box title={"接警类型占比"} subtitle={true} > |
|||
<ReactEcharts |
|||
option={options} |
|||
notMerge |
|||
lazyUpdate |
|||
style={{ height: '100%' }} |
|||
/> |
|||
</Box> |
|||
} |
|||
|
|||
export default PopulationDynamics; |
|||
|
|||
|
@ -0,0 +1,41 @@ |
|||
import React from 'react' |
|||
import Box from './public/table-card'; |
|||
|
|||
function BasicInfo() { |
|||
|
|||
return <Box title={"警情数据分析"} subtitle={true} > |
|||
<div className='alarm_data_analysis'> |
|||
<div className='_item_left'> |
|||
<div className='_img' >65<span style={{ fontSize: 12 }}>%</span></div> |
|||
<div className='_text'>真警占比率</div> |
|||
</div> |
|||
<div className='_item_right'> |
|||
<div className='flex-row flex-item-center'> |
|||
<div className='_iconphone' /> |
|||
<div className='right_item_right'> |
|||
<div className='alarm_title'>电话联系数量</div> |
|||
<div><span className='alarm_number'>479</span><span className='alarm_unit'>个</span></div> |
|||
</div> |
|||
</div> |
|||
<div className='flex-row flex-item-center'> |
|||
<div className='_iconreal' /> |
|||
<div className='right_item_right'> |
|||
<div className='alarm_title'>真警数量</div> |
|||
<div><span className='alarm_number'>273</span><span className='alarm_unit'>个</span></div> |
|||
</div> |
|||
</div> |
|||
<div className='flex-row flex-item-center'> |
|||
<div className='_iconmistake' /> |
|||
<div className='right_item_right'> |
|||
<div className='alarm_title'>误报数量</div> |
|||
<div><span className='alarm_number'>276</span><span className='alarm_unit'>个</span></div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</Box> |
|||
} |
|||
|
|||
export default BasicInfo; |
|||
|
|||
|
@ -0,0 +1,33 @@ |
|||
/* 轮播列表组件 */ |
|||
import React from 'react'; |
|||
import ScrollBoard from './scrollBoard'; |
|||
import NoData from './noData'; |
|||
import './index.less'; |
|||
function CarouselList(props) { |
|||
const { |
|||
header = [], data = [], rowNum = 4, height, columnWidth, multiellipsis, waitTime = 2000, marginTop, ...restProps |
|||
} = props; |
|||
|
|||
const config = { |
|||
header, |
|||
rowNum, |
|||
headerBGC: 'rgba(81, 200, 247, 0.2)', |
|||
oddRowBGC: 'transparent', |
|||
evenRowBGC: 'transparent', |
|||
headerHeight: 30, |
|||
data, |
|||
waitTime, |
|||
columnWidth: columnWidth || [], |
|||
}; |
|||
|
|||
return data.length > 0 ? ( |
|||
<ScrollBoard |
|||
config={config} |
|||
style={{ height }} |
|||
className={multiellipsis ? 'scroll-board-multi' : 'scroll-board'} |
|||
{...restProps} |
|||
/> |
|||
) : <NoData marginTop={marginTop || 0} />; |
|||
} |
|||
|
|||
export default CarouselList; |
@ -0,0 +1,107 @@ |
|||
.opcityBackground { |
|||
background-color: rgba(8, 27, 55, 0.6); |
|||
} |
|||
|
|||
.card-title { |
|||
height: 31px; |
|||
font-family: YouSheBiaoTiHei; |
|||
font-size: 24px; |
|||
color: #FFFFFF; |
|||
letter-spacing: 2px; |
|||
} |
|||
|
|||
/* 滚动列表 */ |
|||
.scroll-board { |
|||
width: 533px; |
|||
height: 220px; |
|||
margin-top: 10px; |
|||
margin-left: 6px; |
|||
|
|||
.header { |
|||
height: 30px; |
|||
border-top: 1px solid #0047ba; |
|||
border-bottom: 1px solid #0047ba; |
|||
|
|||
.header-item { |
|||
// background: rgba(12, 49, 110, 0.3); |
|||
margin-right: 10px; |
|||
} |
|||
} |
|||
|
|||
.rows { |
|||
.row-item { |
|||
font-size: 16px; |
|||
} |
|||
|
|||
.row-item:hover { |
|||
background: linear-gradient(270deg, rgba(17, 183, 247, 0) 0%, rgba(17, 183, 247, 0.85) 100%); |
|||
color: #9ac8fc; |
|||
} |
|||
} |
|||
} |
|||
|
|||
.scroll-board-multi { |
|||
padding: 5px 0px 5px; |
|||
color: rgba(204, 228, 255, 1) !important; |
|||
|
|||
.header { |
|||
display: flex; |
|||
flex-direction: row; |
|||
font-size: 12px !important; |
|||
color: rgba(204, 228, 255, 1) !important; |
|||
// border-bottom: 1px solid #124C79 !important; |
|||
} |
|||
|
|||
.rows { |
|||
color: rgba(204, 228, 255, 1) !important; |
|||
|
|||
.row-item { |
|||
border-bottom: 1px solid #124C79 !important; |
|||
} |
|||
|
|||
.row-item:hover { |
|||
background: linear-gradient(270deg, rgba(17, 183, 247, 0) 0%, rgba(17, 183, 247, 0.85) 100%); |
|||
color: #9ac8fc; |
|||
} |
|||
} |
|||
} |
|||
|
|||
._sorrow { |
|||
display: inline-block; |
|||
width: 15px; |
|||
height: 15px; |
|||
background: url('/assets/images/homePage/bigscreen/sorrow.png'); |
|||
background-repeat: no-repeat; |
|||
background-size: 100% 100%; |
|||
margin-left: 13px; |
|||
} |
|||
|
|||
.subtitle_ { |
|||
float: right; |
|||
margin-top: 12px; |
|||
margin-right: 20px; |
|||
width: 200px; |
|||
text-align: center; |
|||
|
|||
._item_select { |
|||
width: 60px; |
|||
height: 20px; |
|||
display: inline-block; |
|||
font-size: 14px; |
|||
color: #24DCF7; |
|||
border: 1px solid #12B2E5; |
|||
background-color: rgba(91, 193, 255, 0.2); |
|||
margin-right: 3px; |
|||
} |
|||
|
|||
._item { |
|||
width: 60px; |
|||
height: 20px; |
|||
display: inline-block; |
|||
font-size: 14px; |
|||
color: #4C9FFF; |
|||
border: 1px solid #0B6AEA; |
|||
background-color: rgba(35, 108, 254, 0.3); |
|||
margin-right: 3px; |
|||
} |
|||
} |
@ -0,0 +1,18 @@ |
|||
/* 公共模块暂无数据组件 */ |
|||
import React from 'react'; |
|||
import { Empty } from 'antd'; |
|||
|
|||
function NoData({ height = 180, marginTop = 0 }) { |
|||
return ( |
|||
<Empty |
|||
image="/assets/images/homePage/bigscreen/empty.png" |
|||
imageStyle={{ |
|||
height, |
|||
marginTop |
|||
}} |
|||
description={false} |
|||
/> |
|||
); |
|||
} |
|||
|
|||
export default NoData; |
@ -0,0 +1,469 @@ |
|||
import React, { |
|||
useEffect, useState, useRef, useMemo, forwardRef, |
|||
} from 'react'; |
|||
|
|||
import PropTypes from 'prop-types'; |
|||
|
|||
import classnames from 'classnames'; |
|||
|
|||
import { deepMerge } from '@jiaminghi/charts/lib/util/index'; |
|||
|
|||
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'; |
|||
|
|||
import { useAutoResize, co } from '@jiaminghi/data-view-react'; |
|||
|
|||
import './style.less'; |
|||
|
|||
const defaultConfig = { |
|||
/** |
|||
* @description Board header |
|||
* @type {Array<String>} |
|||
* @default header = [] |
|||
* @example header = ['column1', 'column2', 'column3'] |
|||
*/ |
|||
header: [], |
|||
/** |
|||
* @description Board data |
|||
* @type {Array<Array>} |
|||
* @default data = [] |
|||
*/ |
|||
data: [], |
|||
/** |
|||
* @description Row num |
|||
* @type {Number} |
|||
* @default rowNum = 5 |
|||
*/ |
|||
rowNum: 5, |
|||
/** |
|||
* @description Header background color |
|||
* @type {String} |
|||
* @default headerBGC = '#00BAFF' |
|||
*/ |
|||
headerBGC: '#00BAFF', |
|||
/** |
|||
* @description Odd row background color |
|||
* @type {String} |
|||
* @default oddRowBGC = '#003B51' |
|||
*/ |
|||
oddRowBGC: '#003B51', |
|||
/** |
|||
* @description Even row background color |
|||
* @type {String} |
|||
* @default evenRowBGC = '#003B51' |
|||
*/ |
|||
evenRowBGC: '#0A2732', |
|||
/** |
|||
* @description Scroll wait time |
|||
* @type {Number} |
|||
* @default waitTime = 2000 |
|||
*/ |
|||
waitTime: 2000, |
|||
/** |
|||
* @description Header height |
|||
* @type {Number} |
|||
* @default headerHeight = 35 |
|||
*/ |
|||
headerHeight: 35, |
|||
/** |
|||
* @description Column width |
|||
* @type {Array<Number>} |
|||
* @default columnWidth = [] |
|||
*/ |
|||
columnWidth: [], |
|||
/** |
|||
* @description Column align |
|||
* @type {Array<String>} |
|||
* @default align = [] |
|||
* @example align = ['left', 'center', 'right'] |
|||
*/ |
|||
align: [], |
|||
/** |
|||
* @description Show index |
|||
* @type {Boolean} |
|||
* @default index = false |
|||
*/ |
|||
index: false, |
|||
/** |
|||
* @description index Header |
|||
* @type {String} |
|||
* @default indexHeader = '#' |
|||
*/ |
|||
indexHeader: '#', |
|||
/** |
|||
* @description Carousel type |
|||
* @type {String} |
|||
* @default carousel = 'single' |
|||
* @example carousel = 'single' | 'page' |
|||
*/ |
|||
carousel: 'single', |
|||
/** |
|||
* @description Pause scroll when mouse hovered |
|||
* @type {Boolean} |
|||
* @default hoverPause = true |
|||
* @example hoverPause = true | false |
|||
*/ |
|||
hoverPause: true, |
|||
}; |
|||
|
|||
function calcHeaderData({ header, index, indexHeader }) { |
|||
if (!header.length) { |
|||
return []; |
|||
} |
|||
|
|||
header = [...header]; |
|||
|
|||
if (index) header.unshift(indexHeader); |
|||
|
|||
return header; |
|||
} |
|||
|
|||
function calcRows({ |
|||
data, index, headerBGC, rowNum, |
|||
}) { |
|||
if (index) { |
|||
data = data.map((row, i) => { |
|||
row = [...row]; |
|||
|
|||
const indexTag = `<span class="index" style="background-color: ${headerBGC};">${i |
|||
+ 1}</span>`; |
|||
|
|||
row.unshift(indexTag); |
|||
|
|||
return row; |
|||
}); |
|||
} |
|||
|
|||
data = data.map((ceils, i) => ({ ceils, rowIndex: i })); |
|||
|
|||
const rowLength = data.length; |
|||
|
|||
if (rowLength > rowNum && rowLength < 2 * rowNum) { |
|||
data = [...data, ...data]; |
|||
} |
|||
|
|||
return data.map((d, i) => ({ ...d, scroll: i })); |
|||
} |
|||
|
|||
function calcAligns(mergedConfig, header) { |
|||
const columnNum = header.length; |
|||
|
|||
const aligns = new Array(columnNum).fill('left'); |
|||
|
|||
const { align } = mergedConfig; |
|||
|
|||
return deepMerge(aligns, align); |
|||
} |
|||
|
|||
const ScrollBoard = forwardRef(({ |
|||
onClick, config = {}, className, style, onMouseOver, |
|||
}, ref) => { |
|||
const { width, height, domRef } = useAutoResize(ref); |
|||
|
|||
const [state, setState] = useState({ |
|||
mergedConfig: null, |
|||
|
|||
header: [], |
|||
|
|||
rows: [], |
|||
|
|||
rowsShow: [], |
|||
|
|||
widths: [], |
|||
|
|||
heights: [], |
|||
|
|||
aligns: [], |
|||
}); |
|||
|
|||
const { |
|||
mergedConfig, header, rows, widths, heights, aligns, rowsShow, |
|||
} = state; |
|||
|
|||
const stateRef = useRef({ |
|||
...state, |
|||
rowsData: [], |
|||
avgHeight: 0, |
|||
animationIndex: 0, |
|||
}); |
|||
|
|||
Object.assign(stateRef.current, state); |
|||
|
|||
function onResize() { |
|||
if (!mergedConfig) return; |
|||
|
|||
const widths = calcWidths(mergedConfig, stateRef.current.rowsData); |
|||
|
|||
const heights = calcHeights(mergedConfig, header); |
|||
|
|||
const data = { widths, heights }; |
|||
|
|||
Object.assign(stateRef.current, data); |
|||
setState((state) => ({ ...state, ...data })); |
|||
} |
|||
const [init, setInit] = useState(true); |
|||
|
|||
function calcData() { |
|||
// const mergedConfig = deepMerge(
|
|||
// deepClone(defaultConfig, true),
|
|||
// config || {},
|
|||
// );
|
|||
const mergedConfig = { |
|||
...defaultConfig, |
|||
...config, |
|||
}; |
|||
|
|||
const header = calcHeaderData(mergedConfig); |
|||
|
|||
const rows = calcRows(mergedConfig); |
|||
|
|||
const widths = calcWidths(mergedConfig, stateRef.current.rowsData); |
|||
|
|||
const heights = calcHeights(mergedConfig, header); |
|||
|
|||
const aligns = calcAligns(mergedConfig, header); |
|||
|
|||
const data = { |
|||
mergedConfig, |
|||
header, |
|||
rows, |
|||
widths, |
|||
aligns, |
|||
heights: init ? heights : state.heights.concat(heights), |
|||
rowsShow: init ? rows : state.rowsShow, |
|||
}; |
|||
setInit(false); |
|||
Object.assign(stateRef.current, data, { |
|||
rowsData: rows, |
|||
animationIndex: stateRef.current.animationIndex, |
|||
}); |
|||
|
|||
setState((state) => ({ ...state, ...data })); |
|||
} |
|||
|
|||
function calcWidths({ columnWidth, header }, rowsData) { |
|||
const usedWidth = columnWidth.reduce((all, w) => all + w, 0); |
|||
|
|||
let columnNum = 0; |
|||
if (rowsData[0]) { |
|||
columnNum = rowsData[0].ceils.length; |
|||
} else if (header.length) { |
|||
columnNum = header.length; |
|||
} |
|||
|
|||
const avgWidth = (width - usedWidth) / (columnNum - columnWidth.length); |
|||
|
|||
const widths = new Array(columnNum).fill(avgWidth); |
|||
|
|||
return deepMerge(widths, columnWidth); |
|||
} |
|||
|
|||
function calcHeights({ headerHeight, rowNum, data }, header) { |
|||
let allHeight = height; |
|||
|
|||
if (header.length) allHeight -= headerHeight; |
|||
|
|||
const avgHeight = allHeight / rowNum; |
|||
|
|||
Object.assign(stateRef.current, { avgHeight }); |
|||
|
|||
return new Array(data.length).fill(avgHeight); |
|||
} |
|||
|
|||
function* animation(start = false) { |
|||
let { |
|||
avgHeight, |
|||
animationIndex, |
|||
mergedConfig: { waitTime, carousel, rowNum }, |
|||
rowsData, |
|||
} = stateRef.current; |
|||
|
|||
const rowLength = rowsData.length; |
|||
|
|||
if (start) yield new Promise((resolve) => setTimeout(resolve, waitTime)); |
|||
|
|||
const animationNum = carousel === 'single' ? 1 : rowNum; |
|||
|
|||
let rows = rowsData.slice(animationIndex); |
|||
rows.push(...rowsData.slice(0, animationIndex)); |
|||
rows = rows.slice(0, carousel === 'page' ? rowNum * 2 : rowNum + 1); |
|||
|
|||
const heights = new Array(rowLength).fill(avgHeight); |
|||
setState((state) => ({ |
|||
...state, rows, heights, rowsShow: rows, |
|||
})); |
|||
|
|||
yield new Promise((resolve) => setTimeout(resolve, 300)); |
|||
|
|||
animationIndex += animationNum; |
|||
|
|||
const back = animationIndex - rowLength; |
|||
if (back >= 0) animationIndex = back; |
|||
|
|||
const newHeights = [...heights]; |
|||
newHeights.splice(0, animationNum, ...new Array(animationNum).fill(0)); |
|||
|
|||
Object.assign(stateRef.current, { animationIndex }); |
|||
setState((state) => ({ ...state, heights: newHeights })); |
|||
} |
|||
|
|||
function emitEvent(handle, ri, ci, row, ceil) { |
|||
const { ceils, rowIndex } = row; |
|||
|
|||
handle && handle({ |
|||
row: ceils, ceil, rowIndex, columnIndex: ci, |
|||
}); |
|||
} |
|||
|
|||
function handleHover(enter, ri, ci, row, ceil) { |
|||
if (enter) emitEvent(onMouseOver, ri, ci, row, ceil); |
|||
|
|||
if (!mergedConfig.hoverPause) return; |
|||
|
|||
const { pause, resume } = task.current; |
|||
|
|||
enter && pause && resume ? pause() : resume && resume(); |
|||
} |
|||
|
|||
// updateRows(rows, animationIndex) {
|
|||
// const { mergedConfig, animationHandler, animation } = this
|
|||
// this.mergedConfig = {
|
|||
// ...mergedConfig,
|
|||
// data: [...rows]
|
|||
// }
|
|||
// this.needCalc = true
|
|||
// if (typeof animationIndex === 'number') this.animationIndex = animationIndex
|
|||
// if (!animationHandler) animation(true)
|
|||
// }
|
|||
|
|||
const getBackgroundColor = (rowIndex) => mergedConfig[rowIndex % 2 === 0 ? 'evenRowBGC' : 'oddRowBGC']; |
|||
|
|||
const task = useRef({}); |
|||
|
|||
useEffect(() => { |
|||
calcData(); |
|||
|
|||
let start = true; |
|||
|
|||
function* loop() { |
|||
while (true) { |
|||
yield* animation(start); |
|||
|
|||
start = false; |
|||
|
|||
const { waitTime } = stateRef.current.mergedConfig; |
|||
|
|||
yield new Promise((resolve) => setTimeout(resolve, waitTime - 300)); |
|||
} |
|||
} |
|||
|
|||
const { |
|||
mergedConfig: { rowNum }, |
|||
rows: rowsData, |
|||
} = stateRef.current; |
|||
|
|||
const rowLength = rowsData.length; |
|||
|
|||
if (rowNum >= rowLength) { |
|||
setState((prestate) => ({ |
|||
...prestate, rowsShow: state.rows, |
|||
})); |
|||
return; |
|||
} |
|||
|
|||
task.current = co(loop); |
|||
|
|||
return task.current.end; |
|||
}, [config, domRef.current]); |
|||
|
|||
useEffect(onResize, [width, height, domRef.current]); |
|||
|
|||
const classNames = useMemo(() => classnames('dv-scroll-board', className), [ |
|||
className, |
|||
]); |
|||
|
|||
return ( |
|||
<div className={classNames} style={style} ref={domRef}> |
|||
{!!header.length && !!mergedConfig && ( |
|||
<div |
|||
className="header" |
|||
style={{ backgroundColor: `${mergedConfig.headerBGC}` }} |
|||
> |
|||
{header.map((headerItem, i) => ( |
|||
<div |
|||
className="header-item" |
|||
key={`${headerItem}-${i}`} |
|||
style={{ |
|||
height: `${mergedConfig.headerHeight}px`, |
|||
lineHeight: `${mergedConfig.headerHeight}px`, |
|||
width: `${widths[i]}px`, |
|||
}} |
|||
align={aligns[i]} |
|||
dangerouslySetInnerHTML={{ __html: headerItem }} |
|||
/> |
|||
))} |
|||
</div> |
|||
)} |
|||
|
|||
{!!mergedConfig && ( |
|||
<div |
|||
className="rows" |
|||
style={{ |
|||
height: `${height |
|||
- (header.length ? mergedConfig.headerHeight : 0)}px`,
|
|||
}} |
|||
> |
|||
{rowsShow.map((row, ri) => ( |
|||
<div |
|||
className="row-item" |
|||
key={`${row.toString()}-${row.scroll}`} |
|||
style={{ |
|||
height: `${heights[ri]}px`, |
|||
lineHeight: `${heights[ri]}px`, |
|||
backgroundColor: `${getBackgroundColor(row.rowIndex)}`, |
|||
}} |
|||
> |
|||
{row.ceils.map((ceil, ci) => { |
|||
if (typeof (ceil) === 'string') { |
|||
return ( |
|||
<div |
|||
className="ceil" |
|||
key={`${ceil}-${ri}-${ci}`} |
|||
style={{ width: `${widths[ci]}px` }} |
|||
align={aligns[ci]} |
|||
dangerouslySetInnerHTML={{ __html: ceil }} |
|||
onClick={() => emitEvent(onClick, ri, ci, row, ceil)} |
|||
onMouseEnter={() => handleHover(true, ri, ci, row, ceil)} |
|||
onMouseLeave={() => handleHover(false)} |
|||
/> |
|||
); |
|||
} |
|||
return ( |
|||
<div |
|||
className="ceil" |
|||
style={{ width: `${widths[ci]}px` }} |
|||
align={aligns[ci]} |
|||
key={`${ri}-${ci}`} |
|||
onMouseEnter={() => handleHover(true, ri, ci, row, ceil)} |
|||
onMouseLeave={() => handleHover(false)} |
|||
> |
|||
{ceil} |
|||
</div> |
|||
); |
|||
})} |
|||
</div> |
|||
))} |
|||
</div> |
|||
)} |
|||
</div> |
|||
); |
|||
}); |
|||
|
|||
ScrollBoard.propTypes = { |
|||
config: PropTypes.object, |
|||
onClick: PropTypes.func, |
|||
onMouseOver: PropTypes.func, |
|||
className: PropTypes.string, |
|||
style: PropTypes.object, |
|||
}; |
|||
|
|||
export default ScrollBoard; |
@ -0,0 +1,44 @@ |
|||
.dv-scroll-board { |
|||
position: relative; |
|||
width: 100%; |
|||
height: 100%; |
|||
color: #fff; |
|||
|
|||
.text { |
|||
padding: 0 10px; |
|||
box-sizing: border-box; |
|||
white-space: nowrap; |
|||
overflow: hidden; |
|||
text-overflow: ellipsis; |
|||
} |
|||
|
|||
.header { |
|||
display: flex; |
|||
flex-direction: row; |
|||
font-size: 15px; |
|||
|
|||
.header-item { |
|||
.text; |
|||
transition: all 0.3s; |
|||
} |
|||
} |
|||
|
|||
.rows { |
|||
overflow: hidden; |
|||
|
|||
.row-item { |
|||
display: flex; |
|||
font-size: 14px; |
|||
transition: all 0.3s; |
|||
} |
|||
|
|||
.ceil { |
|||
.text; |
|||
} |
|||
|
|||
.index { |
|||
border-radius: 3px; |
|||
padding: 0px 3px; |
|||
} |
|||
} |
|||
} |
@ -0,0 +1,41 @@ |
|||
'use strict' |
|||
|
|||
import React from 'react' |
|||
import './index.less' |
|||
class Box extends React.Component { |
|||
render() { |
|||
const { title, height = '100%', children, bodyPaddingTop = 1, titlePaddingTop, margin, overflow, subtitle } = this.props |
|||
|
|||
const headerbg = { |
|||
background: 'url(/assets/images/homePage/bigscreen/headertitlebg.png) no-repeat', |
|||
backgroundSize: '100% 100%', |
|||
} |
|||
return ( |
|||
<div style={{ height, width: '100%', margin: margin || "0px 0px 28px" }}> |
|||
<div style={{ |
|||
height: height, listStyle: 'none', overflow: overflow || 'hidden', |
|||
|
|||
}}> |
|||
<div style={{ height: 42, paddingTop: '4px', wordBreak: 'keep-all', whiteSpace: 'nowrap', width: '100%', ...headerbg, }}> |
|||
<span className='card-title'>{title}</span> |
|||
|
|||
{subtitle && <div className='subtitle_'> |
|||
<div className='_item_select'>本周</div> |
|||
<div className='_item'>本月</div> |
|||
<div className='_item'>本年</div> |
|||
</div>} |
|||
</div> |
|||
<div style={{ |
|||
height: 'calc(100% - 42px)', |
|||
backgroundImage: 'linear-gradient(180deg, #04377ecc 1%, #001241 100%)', |
|||
}}> |
|||
{children} |
|||
</div> |
|||
|
|||
</div> |
|||
</div> |
|||
) |
|||
} |
|||
} |
|||
export default Box |
|||
|
@ -0,0 +1,29 @@ |
|||
import React, { useEffect, useState } from 'react' |
|||
import Box from './public/table-card'; |
|||
import './style.less'; |
|||
|
|||
|
|||
function DataTop5(props) { |
|||
|
|||
|
|||
return <Box title={"视频监控"} bodyPaddingTop={1} > |
|||
<div className='video_container'> |
|||
<div className='_item'> |
|||
<div className='video_bottom'><span>南昌大道</span><span>14:12:32</span></div> |
|||
</div> |
|||
<div className='_item'> |
|||
<div className='video_bottom'><span>南昌大道</span><span>11:34:12</span></div> |
|||
</div> |
|||
<div className='_item'> |
|||
<div className='video_bottom'><span>南昌大道</span><span>08:34:12</span></div> |
|||
</div> |
|||
<div className='_item'> |
|||
<div className='video_bottom'><span>南昌大道</span><span>09:12:34</span></div> |
|||
</div> |
|||
</div> |
|||
</Box> |
|||
} |
|||
|
|||
export default DataTop5; |
|||
|
|||
|
@ -0,0 +1,15 @@ |
|||
import React, { useEffect, useState } from 'react' |
|||
import Box from './public/table-card'; |
|||
import './style.less'; |
|||
|
|||
function SpecialPerson(props) { |
|||
|
|||
|
|||
return <Box title={"特殊人群统计"}> |
|||
|
|||
</Box> |
|||
} |
|||
|
|||
export default SpecialPerson; |
|||
|
|||
|
@ -0,0 +1,42 @@ |
|||
import React, { useEffect, useState } from 'react' |
|||
import Box from './public/table-card'; |
|||
import './style.less'; |
|||
|
|||
function CitySafty(props) { |
|||
|
|||
return <Box title={"城市安全"} > |
|||
<div className='realtime_data'> |
|||
<div className='realtime_item'> |
|||
<div className='_icon1' /> |
|||
<div className='_text'> |
|||
<div className='_row1'> |
|||
<span>拥堵指数</span> |
|||
<span>平均时速</span> |
|||
</div> |
|||
<div className='_row2'> |
|||
<span><span className='_number'>1.43</span>畅通</span> |
|||
<span><span className='_number'>30.5</span>km/h</span> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<div className='realtime_item'> |
|||
<div className='_icon2' /> |
|||
|
|||
<div className='_text'> |
|||
<div className='_row1'> |
|||
<span>今日接警数</span> |
|||
<span>今日出警数</span> |
|||
</div> |
|||
<div className='_row2' style={{ color: 'rgba(89, 153, 200, 1)' }}> |
|||
<span><span className='_number'>143</span>个</span> |
|||
<span><span className='_number'>86</span>个</span> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</Box> |
|||
} |
|||
|
|||
export default CitySafty; |
|||
|
|||
|
@ -0,0 +1,210 @@ |
|||
.item_left-container { |
|||
display: flex; |
|||
width: 100%; |
|||
height: 100%; |
|||
justify-content: center; |
|||
|
|||
.end_event { |
|||
width: 202px; |
|||
height: 39px; |
|||
background-image: linear-gradient(180deg, #711313 0%, #b3000063 52%, #711313 100%); |
|||
border: 1.5px solid #A20000; |
|||
box-shadow: inset 0 1px 14px 0 #ff525259; |
|||
border-radius: 2px; |
|||
display: flex; |
|||
justify-self: center; |
|||
align-items: center; |
|||
color: #ECF7FF; |
|||
justify-content: center; |
|||
} |
|||
|
|||
} |
|||
|
|||
//警情数据分析 |
|||
.alarm_data_analysis { |
|||
width: 100%; |
|||
height: 100%; |
|||
display: flex; |
|||
justify-content: space-around; |
|||
align-items: center; |
|||
|
|||
._item_left { |
|||
width: 209px; |
|||
height: 100%; |
|||
|
|||
._img { |
|||
width: 209px; |
|||
height: 209px; |
|||
background: url('/assets/images/homepage/fire/realalarmbg.png') no-repeat; |
|||
background-size: 100% 100%; |
|||
display: flex; |
|||
align-items: center; |
|||
justify-content: center; |
|||
font-family: D-DINExp-Italic; |
|||
font-weight: Italic; |
|||
font-size: 48px; |
|||
color: #FFFFFF; |
|||
letter-spacing: 0; |
|||
} |
|||
|
|||
._text { |
|||
font-family: YouSheBiaoTiHei; |
|||
font-size: 20px; |
|||
color: #FFFFFF; |
|||
letter-spacing: 0; |
|||
margin-top: -30px; |
|||
text-align: center; |
|||
} |
|||
} |
|||
|
|||
._item_right { |
|||
width: 200px; |
|||
|
|||
._iconphone { |
|||
width: 50.96px; |
|||
height: 45px; |
|||
background: url('/assets/images/homepage/fire/iconphone.png') no-repeat; |
|||
background-size: 100% 100%; |
|||
} |
|||
|
|||
._iconreal { |
|||
width: 50.96px; |
|||
height: 45px; |
|||
background: url('/assets/images/homepage/fire/iconreal.png') no-repeat; |
|||
background-size: 100% 100%; |
|||
} |
|||
|
|||
._iconmistake { |
|||
width: 50.96px; |
|||
height: 45px; |
|||
background: url('/assets/images/homepage/fire/iconmistake.png') no-repeat; |
|||
background-size: 100% 100%; |
|||
} |
|||
|
|||
.right_item_right { |
|||
width: 155px; |
|||
margin-left: 16px; |
|||
|
|||
.alarm_title { |
|||
font-size: 14px; |
|||
color: #ECF7FF; |
|||
letter-spacing: 0; |
|||
} |
|||
|
|||
.alarm_number { |
|||
font-family: D-DINExp-Italic; |
|||
font-weight: Italic; |
|||
font-size: 28px; |
|||
color: #24DCF7; |
|||
letter-spacing: 0; |
|||
margin-right: 50px; |
|||
} |
|||
|
|||
.alarm_unit { |
|||
font-size: 14px; |
|||
color: #5999C8; |
|||
letter-spacing: 0; |
|||
} |
|||
} |
|||
|
|||
|
|||
} |
|||
} |
|||
|
|||
//实时数据 |
|||
.realtime_data { |
|||
height: 100%; |
|||
padding: 12px 30px 12px 30px; |
|||
|
|||
.realtime_item { |
|||
display: flex; |
|||
background: url('/assets/images/homePage/fire/realtimebg.png') no-repeat; |
|||
background-size: 100% 100%; |
|||
height: 45%; |
|||
width: 100%; |
|||
margin-bottom: 5%; |
|||
align-items: center; |
|||
// padding: 16px 22px 16px 22px; |
|||
|
|||
._icon1 { |
|||
width: 80px; |
|||
height: 80px; |
|||
background: url('/assets/images/homePage/fire/icon1.png') no-repeat; |
|||
background-size: 100% 100%; |
|||
} |
|||
|
|||
._icon2 { |
|||
width: 80px; |
|||
height: 80px; |
|||
background: url('/assets/images/homePage/fire/icon2.png') no-repeat; |
|||
background-size: 100% 100%; |
|||
} |
|||
|
|||
._text { |
|||
width: calc(100% - 100px); |
|||
display: flex; |
|||
flex-direction: column; |
|||
|
|||
._row1 { |
|||
color: #C3E6FF; |
|||
width: 100%; |
|||
height: 22px; |
|||
background: rgba(0, 88, 204, 0.5); |
|||
justify-content: space-around; |
|||
display: flex; |
|||
|
|||
} |
|||
|
|||
._row2 { |
|||
font-size: 14px; |
|||
color: #00FF87; |
|||
justify-content: space-around; |
|||
display: flex; |
|||
height: 42px; |
|||
|
|||
._number { |
|||
font-family: D-DIN-Italic; |
|||
font-weight: Italic; |
|||
font-size: 28px; |
|||
color: #ECF7FF; |
|||
margin-right: 6px; |
|||
} |
|||
} |
|||
} |
|||
} |
|||
} |
|||
|
|||
.realtime_data::-webkit-scrollbar { |
|||
width: 0 !important |
|||
} |
|||
|
|||
.video_container { |
|||
width: 100%; |
|||
height: 100%; |
|||
display: flex; |
|||
flex-wrap: wrap; |
|||
align-items: center; |
|||
justify-content: center; |
|||
|
|||
._item { |
|||
width: 46%; |
|||
height: 45%; |
|||
background: url('/assets/images/homePage/fire/videobg.png') no-repeat; |
|||
background-size: 100% 100%; |
|||
position: relative; |
|||
|
|||
.video_bottom { |
|||
position: absolute; |
|||
bottom: 9%; |
|||
left: 4%; |
|||
width: 91%; |
|||
height: 20px; |
|||
background: rgba(0, 0, 0, 0.4); |
|||
font-size: 12px; |
|||
color: #C3E6FF; |
|||
display: flex; |
|||
justify-content: space-between; |
|||
|
|||
} |
|||
} |
|||
} |
@ -0,0 +1,3 @@ |
|||
export const mathRound = (number) => { |
|||
return number ? Math.round(number / 1000) / 10 : 0 |
|||
} |
@ -0,0 +1,955 @@ |
|||
'use strict'; |
|||
|
|||
export const data = { |
|||
"type": "FeatureCollection", |
|||
"features": [ |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 1 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.882756, 28.515483 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 1 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.876061, 28.534185 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 1 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.897176, 28.545646 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 1 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.940155, 28.559386 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 1 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.874271, 28.412145 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 1 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.866911, 28.416826 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 1 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.835812, 28.597065 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 1 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.853493, 28.596462 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 1 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.965947, 28.445532 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 1 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.908495, 28.521435 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 1 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.861763, 28.530276 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 1 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.871634, 28.534348 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 1 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.90219, 28.55938 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 1 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
116.168147, 28.649128 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 1 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
116.16584, 28.648912 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 1 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
116.169467, 28.646074 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 2 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.92344, 28.561176 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 2 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.870911, 28.536749 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 2 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.876233, 28.512466 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 2 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.920693, 28.499945 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 2 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.958459, 28.511712 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 2 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.955369, 28.508393 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 2 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.954296, 28.560894 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 2 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.943288, 28.560309 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 2 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.868006, 28.41507 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 2 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.861397, 28.411485 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 2 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.840533, 28.595369 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 2 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.852592, 28.597178 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 2 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.970474, 28.448221 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 2 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.9688, 28.447702 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 2 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.865064, 28.557025 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 2 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.879959, 28.526732 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 2 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.881762, 28.562395 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 2 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.923647, 28.558626 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 2 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.856614, 28.595408 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 2 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.9484, 28.504994 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 2 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.941405, 28.502354 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 2 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.954022, 28.511066 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 2 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.953078, 28.520191 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 2 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.929474, 28.506013 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 2 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
116.070607, 28.798914 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 2 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
116.068397, 28.798176 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 2 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
116.143577, 28.657257 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 2 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
116.136303, 28.654546 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 2 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
116.110161, 28.654753 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 2 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
116.151446, 28.650158 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 3 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.939748, 28.551979 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 3 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.949189, 28.572182 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 3 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.92344, 28.561176 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 3 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.930306, 28.541122 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 3 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.949146, 28.559932 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 3 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.940155, 28.559386 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 3 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.864508, 28.41843 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 3 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.840533, 28.595369 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 3 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.860016, 28.61029 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 3 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.971493, 28.449494 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 3 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.881887, 28.559889 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 3 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.874334, 28.541946 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 3 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.864549, 28.553104 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 3 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.908495, 28.521435 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 4 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.950219, 28.55605 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 4 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.836713, 28.606522 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 4 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.899053, 28.538176 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 4 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.89871, 28.556874 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 4 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.884337, 28.522433 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 4 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.868287, 28.524017 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 4 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.868287, 28.524017 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 5 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.945584, 28.573991 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 5 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.896661, 28.520309 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 5 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.844304, 28.577308 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 5 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.927045, 28.540217 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 5 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.901982, 28.539614 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 5 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.949575, 28.558726 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 5 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.845039, 28.601888 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 5 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.851047, 28.605317 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 5 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.867527, 28.595181 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 5 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.857828, 28.594503 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 2 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
116.072222, 28.799295 |
|||
] |
|||
} |
|||
}, |
|||
{ |
|||
"type": "Feature", |
|||
"properties": { |
|||
"count": 5 |
|||
}, |
|||
"geometry": { |
|||
"type": "Point", |
|||
"coordinates": [ |
|||
115.857007, 28.607604 |
|||
] |
|||
} |
|||
}, |
|||
] |
|||
} |
@ -0,0 +1,465 @@ |
|||
import React, { useEffect, useState } from 'react'; |
|||
import { connect } from 'react-redux'; |
|||
import { render } from 'react-dom'; |
|||
import { Row, Col } from 'antd'; |
|||
import { data as heatmapData } from './data' |
|||
import './gis.less' |
|||
const MAPDOMID = 'fs-amap-container'; |
|||
let map = null; |
|||
let heatmap = null; |
|||
let loca = null; |
|||
let interval = null; |
|||
const MARKER_IMG_NAME = { |
|||
markergreen: '回迁房', |
|||
markerblue: '城中村', |
|||
markeryellow: '廉租房', |
|||
} |
|||
function Map(props) { |
|||
const [delay, setDelay] = useState(true) |
|||
const [tab, setTab] = useState('home') |
|||
// 地图初始化
|
|||
const loadMap = () => { |
|||
// 图片图层 实现瓦片地图中国地图样式 bounds 第一个点为左下角 第二个点为右上角
|
|||
const imageLayer = new AMap.ImageLayer({ |
|||
url: '/assets/images/map.svg', |
|||
bounds: new AMap.Bounds( |
|||
[115.800221, 28.265659], |
|||
[116.334849, 28.973298], |
|||
), |
|||
zooms: [3, 14], |
|||
}); |
|||
|
|||
map = new AMap.Map(MAPDOMID, { |
|||
center: [116.054664, 28.538966], |
|||
zoomEnable: true, |
|||
dragEnable: true, |
|||
viewMode: '3D', |
|||
pitch: 22.9, |
|||
labelzIndex: 130, |
|||
zoom: 10.3, |
|||
cursor: 'pointer', |
|||
mapStyle: 'amap://styles/4eb48d1ef0a024c73376fd2256d0b5a5', |
|||
layers: [ |
|||
AMap.createDefaultLayer(), |
|||
imageLayer, |
|||
], |
|||
}); |
|||
|
|||
|
|||
map.on('complete', () => { |
|||
map.setZoom(17.4) |
|||
map.setCenter([115.922069, 28.554867]) |
|||
map.setPitch(47.30) |
|||
map.setRotation(1.7000) |
|||
setTimeout(() => { |
|||
setDelay(false) |
|||
}, 1000); |
|||
|
|||
}); |
|||
|
|||
map.on('click', (e) => { |
|||
if (!e && !e.lnglat) { |
|||
return |
|||
} |
|||
|
|||
const zoom = map.getZoom(); |
|||
const pitch = map.getPitch(); |
|||
const center = map.getCenter(); |
|||
const Rotation = map.getRotation(); |
|||
console.log('zoom' + zoom) |
|||
console.log('pitch' + pitch) |
|||
console.log('center' + center) |
|||
console.log('Rotation' + Rotation) |
|||
console.log('e.lnglat' + e.lnglat) |
|||
}) |
|||
|
|||
loca = new Loca.Container({ map: map }) |
|||
|
|||
}; |
|||
|
|||
|
|||
// 初始化GIS 组件销毁清空定时器
|
|||
useEffect(() => { |
|||
loadMap(); |
|||
}, []); |
|||
|
|||
const renderMarkers = () => { |
|||
map.clearMap(); |
|||
map.setZoom(10.3) |
|||
map.setCenter([116.054664, 28.538966]) |
|||
map.setPitch(22.9) |
|||
map.setRotation(1.7000) |
|||
if (loca && heatmap) loca.remove(heatmap) |
|||
if (tab == 'person') { |
|||
|
|||
var geo = new Loca.GeoJSONSource({ |
|||
data: heatmapData |
|||
}); |
|||
|
|||
heatmap = new Loca.HeatMapLayer({ |
|||
// loca,
|
|||
zIndex: 10, |
|||
opacity: 1, |
|||
visible: true, |
|||
zooms: [2, 22], |
|||
}); |
|||
|
|||
heatmap.setSource(geo, { |
|||
radius: 20, |
|||
unit: 'px', |
|||
height: 10, |
|||
// radius: 10,
|
|||
// unit: 'px',
|
|||
// height: 10,
|
|||
gradient: { |
|||
0.1: 'rgba(50,48,118,1)', |
|||
0.2: 'rgba(127,60,255,1)', |
|||
0.4: 'rgba(166,53,219,1)', |
|||
0.6: 'rgba(254,64,95,1)', |
|||
0.8: 'rgba(255,98,4,1)', |
|||
1: 'rgba(236,220,79,1)', |
|||
}, |
|||
value: function (index, feature) { |
|||
return feature.properties.count; |
|||
}, |
|||
min: 0, |
|||
max: 10, //4.6
|
|||
heightBezier: [0, .53, .37, .98], |
|||
}); |
|||
loca.add(heatmap); |
|||
|
|||
map.on('click', (e) => { |
|||
const feat = heatmap.queryFeature(e.pixel.toArray()); |
|||
const random = Math.random() |
|||
if (feat) { |
|||
let infowindow = new AMap.InfoWindow({ |
|||
isCustom: true, //使用自定义窗体
|
|||
content: `<div id="map-content" class="gis-infowindow">
|
|||
<div style="height:${330}px;" id="contentidheatmap${random}"></div></div>`, |
|||
offset: new AMap.Pixel(133, 260) |
|||
}); |
|||
|
|||
let position = map.getCenter(); |
|||
infowindow.open(map, position); |
|||
setTimeout(() => { |
|||
if (document.getElementById(`contentidheatmap${random}`)) { |
|||
render(<div> |
|||
<div className='gis_exit' onClick={() => { |
|||
map.clearInfoWindow(); |
|||
}} /> |
|||
<div className='gis_item'> |
|||
<span className='gis_title'>小区名称</span> |
|||
<span className='gis_text'>小区名称</span> |
|||
</div> |
|||
<div className='gis_item'> |
|||
<span className='gis_title'>人口</span> |
|||
<span className='gis_text'>2344人</span> |
|||
</div> |
|||
<div className='gis_item'> |
|||
<span className='gis_title'>新生儿</span> |
|||
<span className='gis_text'>23人</span> |
|||
</div> |
|||
<div className='gis_item'> |
|||
<span className='gis_title'>老人</span> |
|||
<span className='gis_text'>342人</span> |
|||
</div> |
|||
</div>, |
|||
document.getElementById(`contentidheatmap${random}`)); |
|||
} |
|||
}, 50) |
|||
|
|||
} |
|||
}); |
|||
} else { |
|||
//初始层级 zoom14以下显示聚合点
|
|||
const data = [ |
|||
{ lng: 116.117906, lat: 28.678096, type: 'home', name: '廉租房1', kind: 'markergreen' }, |
|||
{ lng: 116.195238, lat: 28.842114, type: 'home', name: '廉租房2', kind: 'markerblue' }, |
|||
{ lng: 116.037227, lat: 28.558811, type: 'home', name: '廉租房3', kind: 'markeryellow' }, |
|||
{ lng: 115.925856, lat: 28.558811, type: 'home', name: '廉租房4', kind: 'markergreen' }, |
|||
{ lng: 115.989847, lat: 28.484411, type: 'home', name: '廉租房5', kind: 'markergreen' }, |
|||
|
|||
{ lng: 116.054664, lat: 28.538966, type: 'device', name: '廉租房1', kind: 'markergreen' }, |
|||
{ lng: 116.074711, lat: 28.746745, type: 'device', name: '廉租房2', kind: 'markerblue' }, |
|||
{ lng: 116.111632, lat: 28.56532, type: 'device', name: '廉租房3', kind: 'markeryellow' }, |
|||
{ lng: 115.978519, lat: 28.56532, type: 'device', name: '廉租房4', kind: 'markergreen' }, |
|||
{ lng: 115.95792, lat: 28.417395, type: 'device', name: '廉租房5', kind: 'markergreen' }, |
|||
] |
|||
|
|||
//zoom14以上显示详情
|
|||
const databig = [ |
|||
{ lng: 115.924246, lat: 28.554835, type: 'device', name: '廉租房1', kind: 'markergreenbig' }, |
|||
{ lng: 115.921495, lat: 28.553053, type: 'device', name: '廉租房2', kind: 'markerbluebig' }, |
|||
{ lng: 115.919115, lat: 28.557256, type: 'device', name: '廉租房3', kind: 'markeryellowbig' }, |
|||
] |
|||
//初始点位显示
|
|||
data.filter(s => s.type == tab).map((x, index) => { |
|||
var marker = new AMap.Marker({ |
|||
position: new AMap.LngLat(x.lng, x.lat), |
|||
// 将一张图片的地址设置为 icon
|
|||
icon: '/assets/images/homepage/communtity/' + x.kind + '.png', |
|||
// 设置了 icon 以后,设置 icon 的偏移量,以 icon 的 [center bottom] 为原点
|
|||
offset: new AMap.Pixel(-13, -30), |
|||
zooms: [3, 14], |
|||
}); |
|||
marker.setTitle(x.name); |
|||
map.add(marker); |
|||
marker.on('click', () => { |
|||
map.setZoom(17.4) |
|||
map.setCenter([115.922069, 28.554867]) |
|||
map.setPitch(47.30) |
|||
map.setRotation(1.7000) |
|||
}) |
|||
}) |
|||
//下钻点位显示
|
|||
databig.map((x, index) => { |
|||
var marker = new AMap.Marker({ |
|||
position: new AMap.LngLat(x.lng, x.lat), |
|||
// 将一张图片的地址设置为 icon
|
|||
icon: '/assets/images/homepage/communtity/' + x.kind + '.png', |
|||
// 设置了 icon 以后,设置 icon 的偏移量,以 icon 的 [center bottom] 为原点
|
|||
offset: new AMap.Pixel(-13, -30), |
|||
zooms: [15, 19], |
|||
}); |
|||
marker.setTitle(x.name); |
|||
map.add(marker); |
|||
|
|||
let infowindow = new AMap.InfoWindow({ |
|||
isCustom: true, //使用自定义窗体
|
|||
content: `<div id="map-content" class="gis-infowindow">
|
|||
<div style="height:${360}px;" id="contentid${x.name}"></div></div>`, |
|||
offset: new AMap.Pixel(233, 260) |
|||
}); |
|||
|
|||
marker.on('click', () => { |
|||
let position = marker.getPosition ? marker.getPosition() : marker.getCenter(); |
|||
infowindow.open(map, position); |
|||
map.setCenter(position) |
|||
setTimeout(() => { |
|||
if (document.getElementById(`contentid${x.name}`)) { |
|||
render(<div> |
|||
<div className='gis_exit' onClick={() => { |
|||
map.setCenter([115.922069, 28.554867]) |
|||
map.clearInfoWindow(); |
|||
}} /> |
|||
<div className='gis_item'> |
|||
<span className='gis_title'>小区名称</span> |
|||
<span className='gis_text'>{x.name}</span> |
|||
</div> |
|||
<div className='gis_item'> |
|||
<span className='gis_title'>人流量</span> |
|||
<span className='gis_text'>123次</span> |
|||
<span className='gis_title' style={{ marginLeft: 20 }}>房龄</span> |
|||
<span className='gis_text'>9年</span> |
|||
</div> |
|||
<div className='gis_item'> |
|||
<span className='gis_title'>租赁中房屋</span> |
|||
<span className='gis_text'>165套</span> |
|||
</div> |
|||
<div className='gis_item'> |
|||
<span className='gis_title'>网格员</span> |
|||
<span className='gis_text'>张三</span> |
|||
</div> |
|||
<div className='gis_item'> |
|||
<span className='gis_title'>手机号码</span> |
|||
<span className='gis_text'>15765845845</span> |
|||
</div> |
|||
</div>, |
|||
document.getElementById(`contentid${x.name}`)); |
|||
} |
|||
}, 50) |
|||
}) |
|||
}) |
|||
|
|||
if (tab == 'device') { |
|||
const data = [ |
|||
{ lng: 115.921895, lat: 28.556351, type: 'device', name: '廉租房1', kind: 'devicemarker' }, |
|||
{ lng: 115.920839, lat: 28.555323, type: 'device', name: '廉租房2', kind: 'devicemarker' }, |
|||
{ lng: 115.918329, lat: 28.55445, type: 'device', name: '廉租房3', kind: 'devicemarker' }, |
|||
{ lng: 115.919309, lat: 28.553166, type: 'device', name: '廉租房1', kind: 'devicemarker' }, |
|||
{ lng: 115.921585, lat: 28.553925, type: 'device', name: '廉租房2', kind: 'devicemarker' }, |
|||
{ lng: 115.92565, lat: 28.556996, type: 'device', name: '廉租房3', kind: 'devicemarker' }, |
|||
{ lng: 115.922671, lat: 28.558769, type: 'device', name: '廉租房1', kind: 'devicemarker' }, |
|||
] |
|||
|
|||
data.filter(s => s.type == tab).map((x, index) => { |
|||
var marker = new AMap.Marker({ |
|||
position: new AMap.LngLat(x.lng, x.lat), |
|||
// 将一张图片的地址设置为 icon
|
|||
icon: '/assets/images/homepage/communtity/' + x.kind + '.png', |
|||
// 设置了 icon 以后,设置 icon 的偏移量,以 icon 的 [center bottom] 为原点
|
|||
offset: new AMap.Pixel(-13, -30), |
|||
zooms: [15, 19], |
|||
}); |
|||
marker.setTitle(x.name); |
|||
map.add(marker); |
|||
}) |
|||
} |
|||
} |
|||
|
|||
} |
|||
|
|||
const renderAlarms = () => { |
|||
|
|||
const alarms = [ |
|||
{ lng: 115.92365, lat: 28.557404, type: 'device', name: '廉租房1', kind: 'markeralarm' }, |
|||
] |
|||
|
|||
alarms.map((x, index) => { |
|||
var marker = new AMap.Marker({ |
|||
position: new AMap.LngLat(x.lng, x.lat), |
|||
// 将一张图片的地址设置为 icon
|
|||
icon: '/assets/images/homepage/communtity/' + x.kind + '.png', |
|||
// 设置了 icon 以后,设置 icon 的偏移量,以 icon 的 [center bottom] 为原点
|
|||
offset: new AMap.Pixel(-13, -30), |
|||
zooms: [15, 19], |
|||
}); |
|||
marker.setTitle(x.name); |
|||
map.add(marker); |
|||
|
|||
let infowindow = new AMap.InfoWindow({ |
|||
isCustom: true, //使用自定义窗体
|
|||
content: `<div id="map-content" class="gis-infowindow gis-infowindow-alarm">
|
|||
<div style="height:${360}px;" id="alarmcontentid${x.name}"></div></div>`, |
|||
offset: new AMap.Pixel(233, 260) |
|||
}); |
|||
|
|||
let alarmOk = new AMap.InfoWindow({ |
|||
isCustom: true, //使用自定义窗体
|
|||
// content: `<div id="map-content" class="gis-infowindow gis-infowindow-alarm">
|
|||
// <div style="height:${360}px;" id="contentid${x.name}"></div></div>`,
|
|||
offset: new AMap.Pixel(233, 440) |
|||
}); |
|||
|
|||
marker.on('click', () => { |
|||
let position = marker.getPosition ? marker.getPosition() : marker.getCenter(); |
|||
infowindow.open(map, position); |
|||
map.setCenter(position) |
|||
setTimeout(() => { |
|||
if (document.getElementById(`alarmcontentid${x.name}`)) { |
|||
render(<div> |
|||
<div className='gis_exit' onClick={() => { |
|||
map.setCenter([115.922069, 28.554867]) |
|||
map.clearInfoWindow(); |
|||
}} /> |
|||
|
|||
<div className='gis_item'> |
|||
<span className='gis_title'>地址信息:</span> |
|||
<span className='gis_text'>南湖大道</span> |
|||
</div> |
|||
<div className='gis_item'> |
|||
<span className='gis_title'>告警来源:</span> |
|||
<span className='gis_text'>烟雾报警</span> |
|||
</div> |
|||
<div className='gis_item'> |
|||
<span className='gis_title'>告警内容</span> |
|||
<span className='gis_text'>火情</span> |
|||
</div> |
|||
|
|||
|
|||
<div><span className='confirm_text'>请根据火灾态势,选择应急预案等级</span></div> |
|||
<Row> |
|||
<Col span={6}>I级</Col> |
|||
<Col span={6}>II级</Col> |
|||
<Col span={6}>III级</Col> |
|||
<Col span={6}>IV级</Col> |
|||
</Row> |
|||
<div className='alarm_confirm'> |
|||
<div className='alarm_cancel'>否</div> |
|||
<div className='alarm_ok' onClick={() => { props.alarmOk() }}>是</div> |
|||
</div> |
|||
</div>, |
|||
document.getElementById(`alarmcontentid${x.name}`)); |
|||
} |
|||
}, 50) |
|||
}) |
|||
}) |
|||
} |
|||
|
|||
const renderLeftTop = () => { |
|||
return tab == 'person' ? |
|||
<div className='home_left'> |
|||
<div className='hometotalbg'>区域总人数</div> |
|||
<div className='home_total_number'>455 <span style={{ fontSize: 12 }}>万</span></div> |
|||
|
|||
<div className='hqtotal'>新生儿总数</div> |
|||
<div className='home_total_number'>45<span style={{ fontSize: 12 }}>万</span></div> |
|||
|
|||
<div className='cztotal'>老人总数</div> |
|||
<div className='home_total_number'>45<span style={{ fontSize: 12 }}>万</span></div> |
|||
</div> : |
|||
<div className='home_left'> |
|||
<div className='hometotalbg'>租赁房屋总数</div> |
|||
<div className='home_total_number'>4556</div> |
|||
|
|||
<div className='hqtotal'>回迁房总数</div> |
|||
<div className='home_total_number'>4556</div> |
|||
|
|||
<div className='cztotal'>城中村总数</div> |
|||
<div className='home_total_number'>4556</div> |
|||
|
|||
<div className='lztotal'>廉租房</div> |
|||
<div className='home_total_number'>4556</div> |
|||
|
|||
</div> |
|||
} |
|||
|
|||
const renderRightBottom = () => { |
|||
return <div className='home_right'> |
|||
<div className='_lz'> |
|||
<div className='_icon' /> |
|||
<span>廉租房</span> |
|||
</div> |
|||
<div className='_hq'> |
|||
<div className='_icon' /> |
|||
<span>回迁房</span> |
|||
</div> |
|||
<div className='_cz'> |
|||
<div className='_icon' /> |
|||
<span>城中村</span> |
|||
</div> |
|||
</div> |
|||
} |
|||
|
|||
return ( |
|||
<> |
|||
{/* 延缓加载遮罩 */} |
|||
{delay && <div style={{ |
|||
width: '100%', height: '100%', left: 0, top: 0, zIndex: 1000, background: '#02152f', position: 'absolute', |
|||
display: 'flex', alignItems: 'center', justifyContent: 'center' |
|||
}}> |
|||
</div>} |
|||
|
|||
{/* 地图容器 */} |
|||
<div className="gis" id={MAPDOMID} /> |
|||
{/* {map && renderMarkers()} */} |
|||
{map && renderAlarms()} |
|||
|
|||
{/* 底部按钮 */} |
|||
{/* {!delay && [ |
|||
{ name: '房屋分布', tab: 'home' }, |
|||
{ name: '人口分布', tab: 'person' }, |
|||
{ name: '基础设施', tab: 'device' } |
|||
].map((s, index) => { |
|||
return <div className={'gis-button' + (index + 1)} |
|||
onClick={() => { setTab(s.tab) }} |
|||
> |
|||
<div className={`button_img ${tab == s.tab ? 'button_img_select' : ''}`} /> |
|||
<div>{s.name}</div> |
|||
</div> |
|||
}) |
|||
} */} |
|||
|
|||
{/* 左上角图例 */} |
|||
{/* {renderLeftTop()} |
|||
{renderRightBottom()} */} |
|||
{/* 四周遮罩 */} |
|||
<div className='gis-left'></div> |
|||
<div className='gis-right'></div> |
|||
<div className='gis-top'></div> |
|||
<div className='gis-bottom'></div> |
|||
</> |
|||
); |
|||
} |
|||
|
|||
export default connect()(Map); |
@ -0,0 +1,408 @@ |
|||
.gis-left { |
|||
position: absolute; |
|||
left: 0; |
|||
top: 0; |
|||
height: 100%; |
|||
width: 20%; |
|||
background: linear-gradient(270deg, rgba(0, 19, 46, 0) 0%, #000000 100%); |
|||
} |
|||
|
|||
.gis-right { |
|||
position: absolute; |
|||
right: 0; |
|||
top: 0; |
|||
height: 100%; |
|||
width: 20%; |
|||
background: linear-gradient(90deg, rgba(0, 19, 46, 0) 0%, #000000 100%); |
|||
} |
|||
|
|||
.gis-top { |
|||
position: absolute; |
|||
left: 0; |
|||
top: 0; |
|||
height: 10%; |
|||
width: 100%; |
|||
background: linear-gradient(0deg, rgba(0, 19, 46, 0) 0%, #000000 100%); |
|||
} |
|||
|
|||
.gis-bottom { |
|||
position: absolute; |
|||
left: 0; |
|||
bottom: 0; |
|||
height: 10%; |
|||
width: 100%; |
|||
background: linear-gradient(180deg, rgba(0, 19, 46, 0) 0%, #000000 100%); |
|||
} |
|||
|
|||
.gis-button1 { |
|||
position: absolute; |
|||
left: 39%; |
|||
bottom: -5%; |
|||
font-family: YouSheBiaoTiHei; |
|||
font-size: 12px; |
|||
color: #ECF7FF; |
|||
letter-spacing: 0; |
|||
width: 76.95px; |
|||
text-align: center; |
|||
cursor: pointer; |
|||
z-index: 999; |
|||
|
|||
.button_img { |
|||
background: url('/assets/images/homePage/communtity/home.png'); |
|||
background-repeat: no-repeat; |
|||
background-size: 100% 100%; |
|||
width: 76.95px; |
|||
height: 64px; |
|||
} |
|||
|
|||
.button_img_select { |
|||
background: url('/assets/images/homePage/communtity/homeselect.png'); |
|||
} |
|||
|
|||
|
|||
} |
|||
|
|||
.gis-button2 { |
|||
position: absolute; |
|||
left: 48%; |
|||
bottom: -3%; |
|||
font-family: YouSheBiaoTiHei; |
|||
font-size: 12px; |
|||
color: #ECF7FF; |
|||
letter-spacing: 0; |
|||
width: 76.95px; |
|||
text-align: center; |
|||
cursor: pointer; |
|||
z-index: 999; |
|||
|
|||
.button_img { |
|||
background: url('/assets/images/homePage/communtity/personbutton.png'); |
|||
background-repeat: no-repeat; |
|||
background-size: 100% 100%; |
|||
width: 76.95px; |
|||
height: 64px; |
|||
} |
|||
|
|||
.button_img_select { |
|||
background: url('/assets/images/homePage/communtity/personbuttonselect.png'); |
|||
} |
|||
} |
|||
|
|||
.gis-button3 { |
|||
position: absolute; |
|||
left: 57%; |
|||
bottom: -5%; |
|||
font-family: YouSheBiaoTiHei; |
|||
font-size: 12px; |
|||
color: #ECF7FF; |
|||
letter-spacing: 0; |
|||
width: 76.95px; |
|||
text-align: center; |
|||
cursor: pointer; |
|||
z-index: 999; |
|||
|
|||
.button_img { |
|||
background: url('/assets/images/homePage/communtity/devicebutton.png'); |
|||
background-repeat: no-repeat; |
|||
background-size: 100% 100%; |
|||
width: 76.95px; |
|||
height: 64px; |
|||
} |
|||
|
|||
.button_img_select { |
|||
background: url('/assets/images/homePage/communtity/devicebuttonselect.png'); |
|||
} |
|||
|
|||
|
|||
} |
|||
|
|||
.gis-infowindow { |
|||
width: 302px; |
|||
height: 420px; |
|||
background: url('/assets/images/homepage/communtity/infowindowbg.png') no-repeat; |
|||
background-size: 100% 100%; |
|||
opacity: 0.8; |
|||
padding-left: 69px; |
|||
padding-left: 22px; |
|||
padding-top: 157px; |
|||
color: #fff; |
|||
|
|||
.gis_exit { |
|||
cursor: pointer; |
|||
position: absolute; |
|||
right: 9px; |
|||
top: 42px; |
|||
width: 30.75px; |
|||
height: 23px; |
|||
background: url('/assets/images/homepage/communtity/exit.png') no-repeat; |
|||
background-size: 100% 100%; |
|||
} |
|||
|
|||
.gis_item { |
|||
height: 35px; |
|||
background-image: linear-gradient(180deg, #0555a791 0%, #022a6f91 100%); |
|||
width: 93%; |
|||
display: flex; |
|||
align-items: center; |
|||
padding-left: 20px; |
|||
|
|||
.gis_title { |
|||
font-family: SourceHanSansCN-Regular; |
|||
font-weight: 400; |
|||
font-size: 14px; |
|||
color: #C3E6FF; |
|||
letter-spacing: 0; |
|||
margin-right: 12px; |
|||
} |
|||
|
|||
.gis_text { |
|||
font-family: SourceHanSansCN-Regular; |
|||
font-weight: 400; |
|||
font-size: 14px; |
|||
color: #FFFFFF; |
|||
letter-spacing: 0; |
|||
line-height: 21px; |
|||
} |
|||
} |
|||
} |
|||
|
|||
.gis-infowindow-alarm { |
|||
background: url('/assets/images/homepage/communtity/alarminfowindow.png') no-repeat; |
|||
height: 432px; |
|||
width: 311px; |
|||
padding-top: 107px; |
|||
|
|||
.gis_exit { |
|||
cursor: pointer; |
|||
position: absolute; |
|||
right: 2px; |
|||
top: 15px; |
|||
width: 30.75px; |
|||
height: 23px; |
|||
background: url('/assets/images/homepage/communtity/exitalarm.png') no-repeat; |
|||
background-size: 100% 100%; |
|||
} |
|||
|
|||
.gis_item { |
|||
margin-bottom: 10px; |
|||
height: 35px; |
|||
background-image: linear-gradient(180deg, #a7050591 0%, #48010191 100%); |
|||
; |
|||
|
|||
} |
|||
|
|||
.confirm_text { |
|||
font-family: SourceHanSansCN-Medium; |
|||
font-weight: 500; |
|||
font-size: 16px; |
|||
color: #FFFFFF; |
|||
letter-spacing: 0; |
|||
line-height: 21px; |
|||
} |
|||
|
|||
.alarm_confirm { |
|||
width: 100%; |
|||
display: flex; |
|||
justify-content: space-around; |
|||
margin-top: 15px; |
|||
|
|||
.alarm_cancel { |
|||
width: 81px; |
|||
height: 30px; |
|||
background-image: linear-gradient(180deg, #C50000 1%, #b600006e 52%, #C50000 100%); |
|||
box-shadow: inset 0 1px 14px 0 #ff2b2b59; |
|||
border-radius: 4px; |
|||
|
|||
font-family: SourceHanSansCN-Medium; |
|||
font-weight: 500; |
|||
font-size: 14px; |
|||
color: #FFE8E8; |
|||
text-align: center; |
|||
line-height: 30px; |
|||
|
|||
background: url('/assets/images/homepage/communtity/alarmcancel.png') no-repeat; |
|||
background-size: 100% 100%; |
|||
cursor: pointer; |
|||
} |
|||
|
|||
.alarm_ok { |
|||
text-align: center; |
|||
line-height: 30px; |
|||
width: 81px; |
|||
height: 30px; |
|||
background-image: linear-gradient(180deg, #C50000 1%, #b600006e 52%, #C50000 100%); |
|||
box-shadow: inset 0 1px 14px 0 #ff2b2b59; |
|||
border-radius: 4px; |
|||
font-family: SourceHanSansCN-Medium; |
|||
font-weight: 500; |
|||
font-size: 14px; |
|||
color: #FFFFFF; |
|||
cursor: pointer; |
|||
} |
|||
} |
|||
|
|||
.alarm_button { |
|||
width: 103px; |
|||
height: 30px; |
|||
margin-top: 24px; |
|||
display: flex; |
|||
align-items: center; |
|||
justify-content: center; |
|||
font-family: SourceHanSansCN-Medium; |
|||
font-weight: 500; |
|||
font-size: 14px; |
|||
color: #FFFFFF; |
|||
letter-spacing: 0; |
|||
background: url('/assets/images/homepage/communtity/alarmbutton.png') no-repeat; |
|||
background-size: 100% 100%; |
|||
margin-left: 89px; |
|||
cursor: pointer; |
|||
|
|||
.alarm_icon { |
|||
width: 18px; |
|||
height: 18px; |
|||
background: url('/assets/images/homepage/communtity/alarmicon.png') no-repeat; |
|||
background-size: 100% 100%; |
|||
} |
|||
} |
|||
} |
|||
|
|||
|
|||
.home_left { |
|||
position: absolute; |
|||
left: 26%; |
|||
top: 3%; |
|||
z-index: 999; |
|||
font-family: YouSheBiaoTiHei; |
|||
font-size: 16px; |
|||
color: #FFFFFF; |
|||
letter-spacing: 1.33px; |
|||
text-shadow: -2px 0 0 #0C5FA6; |
|||
|
|||
.hometotalbg { |
|||
width: 126.45px; |
|||
height: 26.23px; |
|||
padding-left: 24px; |
|||
background: url('/assets/images/homepage/communtity/total.png') no-repeat; |
|||
background-size: 100% 100%; |
|||
} |
|||
|
|||
.home_total_number { |
|||
font-family: D-DIN-Italic; |
|||
font-weight: Italic; |
|||
font-size: 28px; |
|||
color: #EAF2FF; |
|||
letter-spacing: 0; |
|||
margin-left: 40px; |
|||
} |
|||
|
|||
.hqtotal { |
|||
width: 126.45px; |
|||
height: 26.23px; |
|||
padding-left: 24px; |
|||
background: url('/assets/images/homepage/communtity/hqtotal.png') no-repeat; |
|||
background-size: 100% 100%; |
|||
} |
|||
|
|||
.cztotal { |
|||
width: 126.45px; |
|||
height: 26.23px; |
|||
padding-left: 24px; |
|||
background: url('/assets/images/homepage/communtity/cztotal.png') no-repeat; |
|||
background-size: 100% 100%; |
|||
} |
|||
|
|||
.lztotal { |
|||
width: 126.45px; |
|||
height: 26.23px; |
|||
padding-left: 24px; |
|||
background: url('/assets/images/homepage/communtity/lztotal.png') no-repeat; |
|||
background-size: 100% 100%; |
|||
} |
|||
|
|||
} |
|||
|
|||
.home_right { |
|||
position: absolute; |
|||
right: 26%; |
|||
bottom: 7%; |
|||
z-index: 999; |
|||
font-family: YouSheBiaoTiHei; |
|||
font-size: 14px; |
|||
background: #021d33ad; |
|||
// border: 1px solid rgba(2, 29, 51, 0.68); |
|||
padding: 7px 14px 7px 14px; |
|||
border: 1px solid; |
|||
border-image: linear-gradient(133deg, rgba(0, 197, 255, 0.53) 0%, rgba(0, 138, 255, 0.62)) 1; |
|||
|
|||
._lz { |
|||
display: flex; |
|||
align-items: center; |
|||
|
|||
._icon { |
|||
display: inline-block; |
|||
width: 15px; |
|||
height: 15px; |
|||
background: url('/assets/images/homepage/communtity/lzicon.png') no-repeat; |
|||
background-size: 100% 100%; |
|||
margin-right: 4px; |
|||
} |
|||
|
|||
span { |
|||
font-family: YouSheBiaoTiHei; |
|||
font-size: 14px; |
|||
letter-spacing: 0; |
|||
background: linear-gradient(180deg, rgba(255, 255, 255, 1) 1%, rgba(250, 196, 110, 1) 100%); |
|||
-webkit-background-clip: text; |
|||
-webkit-text-fill-color: transparent; |
|||
} |
|||
} |
|||
|
|||
._hq { |
|||
display: flex; |
|||
align-items: center; |
|||
margin-top: 10px; |
|||
|
|||
._icon { |
|||
display: inline-block; |
|||
width: 15px; |
|||
height: 15px; |
|||
background: url('/assets/images/homepage/communtity/hqicon.png') no-repeat; |
|||
background-size: 100% 100%; |
|||
margin-right: 4px; |
|||
} |
|||
|
|||
span { |
|||
font-family: YouSheBiaoTiHei; |
|||
font-size: 14px; |
|||
background: linear-gradient(180deg, rgba(255, 255, 255, 1) 1%, rgba(36, 220, 247, 1) 100%); |
|||
-webkit-background-clip: text; |
|||
-webkit-text-fill-color: transparent; |
|||
letter-spacing: 0; |
|||
} |
|||
} |
|||
|
|||
._cz { |
|||
display: flex; |
|||
align-items: center; |
|||
margin-top: 10px; |
|||
|
|||
._icon { |
|||
display: inline-block; |
|||
width: 15px; |
|||
height: 15px; |
|||
background: url('/assets/images/homepage/communtity/czicon.png') no-repeat; |
|||
background-size: 100% 100%; |
|||
margin-right: 4px; |
|||
} |
|||
|
|||
span { |
|||
font-family: YouSheBiaoTiHei; |
|||
font-size: 14px; |
|||
background: linear-gradient(180deg, rgba(255, 255, 255, 1) 1%, rgba(1, 140, 255, 1) 100%); |
|||
-webkit-background-clip: text; |
|||
-webkit-text-fill-color: transparent; |
|||
letter-spacing: 0; |
|||
} |
|||
} |
|||
} |
@ -0,0 +1,98 @@ |
|||
import React, { useEffect, useState } from 'react' |
|||
import { connect } from 'react-redux'; |
|||
import { push } from 'react-router-redux'; |
|||
import Left from '../components/item-left' |
|||
import Right from '../components/item-right' |
|||
import LeftTop from '../components/left-top' |
|||
import LeftMiddle from '../components/left-middle' |
|||
import LeftBottom from '../components/left-bottom' |
|||
import RightTop from '../components/right-top' |
|||
import RightMiddle from '../components/right-middle' |
|||
import RightBottom from '../components/right-bottom' |
|||
import Gis from './gis'; |
|||
import './style.less' |
|||
|
|||
function homePage(props) { |
|||
const { dispatch } = props; |
|||
const childStyle = { height: '32%', color: '#fff', marginBottom: 17 } |
|||
const cardHeight = document.body.clientHeight * 0.896 * 0.32 |
|||
const cardContentHeight = cardHeight - 42 - 13 |
|||
const [tab, setTab] = useState('overview') |
|||
return <> |
|||
<div className='homepage'> |
|||
<div className='_title'> |
|||
<div className='_title_text'> |
|||
<span>智慧消防</span> |
|||
<div className='_title_dot'></div> |
|||
<span>一键护航</span> |
|||
</div> |
|||
<div onClick={() => { dispatch(push('/metadataManagement/latestMetadata')) }} className='_exit' >返回平台</div> |
|||
</div> |
|||
<div className='homepage-left homepage-left-left'> |
|||
<div div className="list"> |
|||
{tab == 'overview' ? |
|||
<> |
|||
<div className='child' style={childStyle}> |
|||
<LeftTop /> |
|||
</div> |
|||
<div className='child' style={childStyle}> |
|||
<LeftMiddle /> |
|||
</div> |
|||
<div className='child' style={childStyle}> |
|||
<LeftBottom cardContentHeight={cardContentHeight} /> |
|||
</div> |
|||
</> |
|||
: |
|||
<div className='child' style={{ height: '100%' }} > |
|||
<Left endEvent={() => { |
|||
setTab('overview') |
|||
}} cardContentHeight={document.body.clientHeight * 0.896} /> |
|||
</div> |
|||
} |
|||
</div> |
|||
</div> |
|||
<div className='homepage-center'> |
|||
<Gis |
|||
alarmOk={() => { |
|||
setTab('item') |
|||
}} |
|||
/> |
|||
</div> |
|||
<div className='homepage-left homepage-left-right'> |
|||
{tab == 'overview' ? <div className="list"> |
|||
<div className='child-right' style={childStyle}> |
|||
<RightTop /> |
|||
</div> |
|||
<div className='child-right' style={childStyle}> |
|||
<RightMiddle cardContentHeight={cardContentHeight} /> |
|||
</div> |
|||
<div className='child-right' style={childStyle}> |
|||
<RightBottom /> |
|||
</div> |
|||
</div> : |
|||
<div className='child' style={{ height: '100%' }} > |
|||
<Right cardContentHeight={document.body.clientHeight * 0.896} /> |
|||
</div> |
|||
} |
|||
</div> |
|||
|
|||
</div > |
|||
</> |
|||
|
|||
|
|||
} |
|||
|
|||
function mapStateToProps(state) { |
|||
const { |
|||
auth, global |
|||
} = state; |
|||
return { |
|||
clientHeight: global.clientHeight, |
|||
actions: global.actions, |
|||
|
|||
}; |
|||
} |
|||
|
|||
export default connect(mapStateToProps)(homePage); |
|||
|
|||
|
@ -0,0 +1,6 @@ |
|||
'use strict'; |
|||
|
|||
import homePage from './homePage'; |
|||
|
|||
|
|||
export default homePage ; |
@ -0,0 +1,303 @@ |
|||
.homepage { |
|||
width: 100%; |
|||
height: 100%; |
|||
position: absolute; |
|||
top: 0; |
|||
left: 0; |
|||
background: url('/assets/images/homePage/communtity/bg.png'); |
|||
background-repeat: no-repeat; |
|||
background-size: 100% 100%; |
|||
overflow: hidden; |
|||
// display: flex; |
|||
// flex-direction: column; |
|||
// justify-content: center; |
|||
// align-items: center; |
|||
padding-top: 5%; |
|||
|
|||
._title_text { |
|||
position: absolute; |
|||
top: 0%; |
|||
width: 100%; |
|||
height: 62px; |
|||
font-family: YouSheBiaoTiHei; |
|||
font-size: 48px; |
|||
color: #FFFFFF; |
|||
letter-spacing: 12px; |
|||
z-index: 300; |
|||
display: flex; |
|||
align-items: center; |
|||
justify-content: center; |
|||
|
|||
._title_dot { |
|||
display: inline-block; |
|||
width: 8px; |
|||
height: 8px; |
|||
background-image: linear-gradient(180deg, #FFFFFF 0%, #0d71ef00 100%); |
|||
margin-left: 14px; |
|||
margin-right: 14px; |
|||
border-radius: 4px; |
|||
} |
|||
|
|||
} |
|||
|
|||
._exit { |
|||
position: absolute; |
|||
right: 60px; |
|||
top: 38px; |
|||
cursor: pointer; |
|||
color: #C8F0FF; |
|||
display: flex; |
|||
width: 102px; |
|||
height: 33px; |
|||
background: url('/assets/images/homePage/bigscreen/exit.png'); |
|||
background-repeat: no-repeat; |
|||
background-size: 100% 100%; |
|||
padding-left: 35px; |
|||
align-items: center; |
|||
z-index: 400; |
|||
} |
|||
|
|||
.homepage-left { |
|||
width: 21.8%; |
|||
height: 84.6%; |
|||
position: absolute; |
|||
top: 10.1%; |
|||
z-index: 300; |
|||
} |
|||
|
|||
.homepage-center { |
|||
width: 93.9%; |
|||
height: 84%; |
|||
position: absolute; |
|||
top: 10.4%; |
|||
left: 58px; |
|||
padding-left: 16px; |
|||
padding-right: 16px; |
|||
z-index: 200; |
|||
|
|||
._top { |
|||
margin-top: 5%; |
|||
height: calc(100% - 200px); |
|||
background: url('/assets/images/homePage/bigscreen/centerbg.png'); |
|||
background-repeat: no-repeat; |
|||
background-size: 100% 100%; |
|||
position: relative; |
|||
} |
|||
} |
|||
|
|||
.homepage-left-left { |
|||
left: 58px; |
|||
} |
|||
|
|||
.homepage-left-right { |
|||
right: 58px; |
|||
} |
|||
|
|||
} |
|||
|
|||
|
|||
.list { |
|||
list-style: none; |
|||
height: 100%; |
|||
} |
|||
|
|||
.list .child { |
|||
box-sizing: border-box; |
|||
opacity: 0; |
|||
transform: translateX(-300px); |
|||
animation: show .5s forwards; |
|||
} |
|||
|
|||
.list .child.show { |
|||
animation-delay: 0s !important; |
|||
} |
|||
|
|||
.list .child.hide { |
|||
opacity: 1; |
|||
transform: translateX(0); |
|||
animation-name: hide; |
|||
animation-delay: 0s; |
|||
} |
|||
|
|||
/*animation-delay*/ |
|||
.list .child:not(.hide):nth-child(5n + 1) { |
|||
animation-delay: .3s; |
|||
} |
|||
|
|||
.list .child:not(.hide):nth-child(5n + 2) { |
|||
animation-delay: .6s; |
|||
} |
|||
|
|||
.list .child:not(.hide):nth-child(5n + 3) { |
|||
animation-delay: .9s; |
|||
} |
|||
|
|||
.list .child:not(.hide):nth-child(5n + 4) { |
|||
animation-delay: 1.2s; |
|||
} |
|||
|
|||
.list .child:not(.hide):nth-child(5n + 5) { |
|||
animation-delay: 1.5s; |
|||
} |
|||
|
|||
.list .child-right { |
|||
box-sizing: border-box; |
|||
opacity: 0; |
|||
transform: translateX(300px); |
|||
animation: show .5s forwards; |
|||
} |
|||
|
|||
.list .child-right.show { |
|||
animation-delay: 0s !important; |
|||
} |
|||
|
|||
.list .child-right.hide { |
|||
opacity: 1; |
|||
transform: translateX(0); |
|||
animation-name: hide; |
|||
animation-delay: 0s; |
|||
} |
|||
|
|||
/*animation-delay*/ |
|||
.list .child-right:not(.hide):nth-child(5n + 1) { |
|||
animation-delay: .3s; |
|||
} |
|||
|
|||
.list .child-right:not(.hide):nth-child(5n + 2) { |
|||
animation-delay: .6s; |
|||
} |
|||
|
|||
.list .child-right:not(.hide):nth-child(5n + 3) { |
|||
animation-delay: .9s; |
|||
} |
|||
|
|||
.list .child-right:not(.hide):nth-child(5n + 4) { |
|||
animation-delay: 1.2s; |
|||
} |
|||
|
|||
.list .child-right:not(.hide):nth-child(5n + 5) { |
|||
animation-delay: 1.5s; |
|||
} |
|||
|
|||
.list .child-top { |
|||
box-sizing: border-box; |
|||
opacity: 0; |
|||
transform: translateY(300px); |
|||
animation: show 1s forwards; |
|||
} |
|||
|
|||
.list .child-top.show { |
|||
animation-delay: 0s !important; |
|||
} |
|||
|
|||
.list .child-top.hide { |
|||
opacity: 1; |
|||
transform: translateY(0); |
|||
animation-name: hide; |
|||
animation-delay: 0s; |
|||
} |
|||
|
|||
|
|||
@keyframes show { |
|||
to { |
|||
opacity: 1; |
|||
transform: translateX(0); |
|||
} |
|||
} |
|||
|
|||
@keyframes hide { |
|||
to { |
|||
opacity: 0; |
|||
transform: translateX(100px); |
|||
max-height: 0; |
|||
margin: 0; |
|||
} |
|||
} |
|||
|
|||
.center-card-title { |
|||
height: 31px; |
|||
font-family: YouSheBiaoTiHei; |
|||
font-size: 24px; |
|||
color: #FFFFFF; |
|||
display: flex; |
|||
align-items: center; |
|||
margin-top: 5px; |
|||
|
|||
._icon_left { |
|||
width: 32px; |
|||
height: 17px; |
|||
background: url('/assets/images/homePage/bigscreen/center-left.png'); |
|||
background-repeat: no-repeat; |
|||
background-size: 100% 100%; |
|||
margin-right: 11px; |
|||
margin-left: 10px; |
|||
} |
|||
|
|||
._icon_right { |
|||
width: 32px; |
|||
height: 17px; |
|||
background: url('/assets/images/homePage/bigscreen/center-right.png'); |
|||
background-repeat: no-repeat; |
|||
background-size: 100% 100%; |
|||
margin-right: 11px; |
|||
margin-left: 10px; |
|||
} |
|||
} |
|||
|
|||
.gis { |
|||
position: absolute; |
|||
width: 100vw; |
|||
height: calc(~"100% - 114px"); |
|||
left: 0; |
|||
top: 114px; |
|||
z-index: 0; |
|||
display: flex; |
|||
justify-content: center; |
|||
top: 0; |
|||
left: 0; |
|||
width: 100%; |
|||
height: 100%; |
|||
} |
|||
|
|||
/* flex 基本布局样式 */ |
|||
.flex-column { |
|||
display: flex; |
|||
flex-direction: column; |
|||
} |
|||
|
|||
.flex-row { |
|||
display: flex; |
|||
flex-direction: row; |
|||
} |
|||
|
|||
.flex-content-between { |
|||
justify-content: space-between; |
|||
} |
|||
|
|||
.flex-content-around { |
|||
justify-content: space-around; |
|||
} |
|||
|
|||
.flex-content-start { |
|||
justify-content: flex-start; |
|||
} |
|||
|
|||
.flex-content-end { |
|||
justify-content: flex-end; |
|||
} |
|||
|
|||
.flex-item-center { |
|||
align-items: center; |
|||
} |
|||
|
|||
.flex-item-start { |
|||
align-items: flex-start; |
|||
} |
|||
|
|||
.flex-item-end { |
|||
align-items: flex-end; |
|||
} |
|||
|
|||
.flex-item-stretch { |
|||
align-items: stretch; |
|||
} |
@ -0,0 +1,15 @@ |
|||
'use strict'; |
|||
|
|||
import reducers from './reducers'; |
|||
import routes from './routes'; |
|||
import actions from './actions'; |
|||
import { getNavItem } from './nav-item'; |
|||
|
|||
export default { |
|||
key: 'communitysafty', |
|||
name: '首页', |
|||
reducers: reducers, |
|||
routes: routes, |
|||
actions: actions, |
|||
getNavItem: getNavItem |
|||
}; |
@ -0,0 +1,11 @@ |
|||
import React from 'react'; |
|||
import { Link } from 'react-router-dom'; |
|||
import { Menu } from 'antd'; |
|||
import { HomeOutlined } from '@ant-design/icons'; |
|||
export function getNavItem(user) { |
|||
return ( |
|||
<Menu.Item key="firecontrol" icon={<HomeOutlined />}> |
|||
<Link to="/firecontrol">社区安全</Link> |
|||
</Menu.Item> |
|||
); |
|||
} |
@ -0,0 +1,5 @@ |
|||
'use strict'; |
|||
|
|||
export default { |
|||
|
|||
} |
@ -0,0 +1,13 @@ |
|||
'use strict'; |
|||
import homePage from './containers/index'; |
|||
|
|||
export default [{ |
|||
type: 'outer', |
|||
route: { |
|||
path: '/firecontrol', |
|||
key: 'firecontrol', |
|||
breadcrumb: '智慧消防', |
|||
// 不设置 component 则面包屑禁止跳转
|
|||
component: homePage |
|||
} |
|||
}]; |