|
@ -200,7 +200,6 @@ const Control = ({ dispatch, actions, user, history, loading, socket, pepProject |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
useEffect(() => { |
|
|
useEffect(() => { |
|
|
consoleToollink() |
|
|
|
|
|
|
|
|
|
|
|
//初始化表格显示设置 |
|
|
//初始化表格显示设置 |
|
|
let data = ['overall', 'workbench', 'statistical', 'analyse', 'dynamic'] |
|
|
let data = ['overall', 'workbench', 'statistical', 'analyse', 'dynamic'] |
|
@ -218,12 +217,7 @@ const Control = ({ dispatch, actions, user, history, loading, socket, pepProject |
|
|
}); |
|
|
}); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
const domProject2 = document.getElementById("member"); |
|
|
|
|
|
if (domProject2) { |
|
|
|
|
|
memberScrollbar = new PerfectScrollbar("#member", { |
|
|
|
|
|
suppressScrollX: true, |
|
|
|
|
|
}); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
const domProject3 = document.getElementById("equipment"); |
|
|
const domProject3 = document.getElementById("equipment"); |
|
|
if (domProject3) { |
|
|
if (domProject3) { |
|
@ -259,32 +253,45 @@ const Control = ({ dispatch, actions, user, history, loading, socket, pepProject |
|
|
} |
|
|
} |
|
|
}, []) |
|
|
}, []) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
useEffect(() => { |
|
|
useEffect(() => { |
|
|
async function concentration1 () { |
|
|
if (pepProjectId) setProjectId(pepProjectId) |
|
|
if (pepProjectId) setProjectId(pepProjectId) |
|
|
// 工作台数据请求 |
|
|
// 工作台数据请求 |
|
|
dispatch(control.getConsoleCount({ pepProjectId: pepProjectId })).then(res => { |
|
|
await dispatch(control.getConsoleCount({ pepProjectId: pepProjectId })).then(res => { |
|
|
if (res.success) setWorkData(res.payload.data) |
|
|
if (res.success) setWorkData(res.payload.data) |
|
|
}) |
|
|
}) |
|
|
|
|
|
// 查询BI分析数据-数据 |
|
|
|
|
|
await dispatch(control.getDataAlarmsAggDay({ pepProjectId: pepProjectId })).then(res => { |
|
|
|
|
|
if (res.success) setDataBI(res.payload.data) |
|
|
|
|
|
}) |
|
|
|
|
|
// 查询BI分析数据-视频异常 |
|
|
|
|
|
await dispatch(control.getVideoAlarmsAggDay({ pepProjectId: pepProjectId })).then(res => { |
|
|
|
|
|
if (res.success) setVideoBI(res.payload.data) |
|
|
|
|
|
}) |
|
|
|
|
|
// 查询BI分析数据-应用 |
|
|
|
|
|
await dispatch(control.getAppAlarmsAggDay({ pepProjectId: pepProjectId })).then(res => { |
|
|
|
|
|
if (res.success) setAppBI(res.payload.data) |
|
|
|
|
|
}) |
|
|
|
|
|
await dispatch(control.getAlarmsHandleStatistics({ projectCorrelationId: pepProjectId })).then(res => { |
|
|
|
|
|
if (res.success) setEfficiencyBI(res.payload.data[0]) |
|
|
|
|
|
}) |
|
|
|
|
|
} |
|
|
|
|
|
concentration1() |
|
|
|
|
|
}, [pepProjectId]) |
|
|
}, [pepProjectId]) |
|
|
|
|
|
|
|
|
|
|
|
useEffect(() => { |
|
|
|
|
|
if (exhibition.current?.overall?.find(v => v.key == 'tool')) { |
|
|
|
|
|
consoleToollink() |
|
|
|
|
|
} |
|
|
|
|
|
}, [exhibition.current]) |
|
|
|
|
|
|
|
|
|
|
|
useEffect(() => { |
|
|
|
|
|
async function concentration2 () { |
|
|
|
|
|
if (exhibition.current?.overall?.find(v => v.key == 'analyse')) { |
|
|
|
|
|
// 查询BI分析数据-数据 |
|
|
|
|
|
await dispatch(control.getDataAlarmsAggDay({ pepProjectId: pepProjectId })).then(res => { |
|
|
|
|
|
if (res.success) setDataBI(res.payload.data) |
|
|
|
|
|
}) |
|
|
|
|
|
// 查询BI分析数据-视频异常 |
|
|
|
|
|
await dispatch(control.getVideoAlarmsAggDay({ pepProjectId: pepProjectId })).then(res => { |
|
|
|
|
|
if (res.success) setVideoBI(res.payload.data) |
|
|
|
|
|
}) |
|
|
|
|
|
// 查询BI分析数据-应用 |
|
|
|
|
|
await dispatch(control.getAppAlarmsAggDay({ pepProjectId: pepProjectId })).then(res => { |
|
|
|
|
|
if (res.success) setAppBI(res.payload.data) |
|
|
|
|
|
}) |
|
|
|
|
|
await dispatch(control.getAlarmsHandleStatistics({ projectCorrelationId: pepProjectId })).then(res => { |
|
|
|
|
|
if (res.success) setEfficiencyBI(res.payload.data[0]) |
|
|
|
|
|
}) |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
concentration2() |
|
|
|
|
|
}, [pepProjectId, exhibition.current]) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
useEffect(() => { |
|
|
useEffect(() => { |
|
|
async function concentration4 () { |
|
|
async function concentration4 () { |
|
@ -316,53 +323,54 @@ const Control = ({ dispatch, actions, user, history, loading, socket, pepProject |
|
|
// 统计概览--相关成员与web应用 |
|
|
// 统计概览--相关成员与web应用 |
|
|
await dispatch(control.getConsoleUser({ pepId: pepProjectId || projectId })).then(res => { |
|
|
await dispatch(control.getConsoleUser({ pepId: pepProjectId || projectId })).then(res => { |
|
|
if (res.success) { |
|
|
if (res.success) { |
|
|
if (res.payload.data?.personnel?.length > 5) { |
|
|
// if (res.payload.data?.personnel?.length > 5) { |
|
|
setMemberList([...res.payload.data?.personnel, ...res.payload.data?.personnel]) |
|
|
// setMemberList([...res.payload.data?.personnel, ...res.payload.data?.personnel]) |
|
|
|
|
|
|
|
|
let membertop = 0 |
|
|
// let membertop = 0 |
|
|
let memberId = document.getElementById('member'); |
|
|
// let memberId = document.getElementById('member'); |
|
|
if (member) clearInterval(member) |
|
|
// if (member) clearInterval(member) |
|
|
if (memberId) { |
|
|
// if (memberId) { |
|
|
function startmember () { |
|
|
// function startmember () { |
|
|
member = setInterval(() => { |
|
|
// member = setInterval(() => { |
|
|
membertop += 5 |
|
|
// membertop += 5 |
|
|
memberId.scrollTop = membertop |
|
|
// memberId.scrollTop = membertop |
|
|
if (memberId.scrollTop >= memberId.scrollHeight / 2) membertop = 0, memberId.scrollTop = membertop |
|
|
// if (memberId.scrollTop >= memberId.scrollHeight / 2) membertop = 0, memberId.scrollTop = membertop |
|
|
}, 500); |
|
|
// }, 500); |
|
|
memberId.onmouseover = () => clearInterval(member) |
|
|
// memberId.onmouseover = () => clearInterval(member) |
|
|
} |
|
|
// } |
|
|
memberId.onmouseout = () => startmember() |
|
|
// memberId.onmouseout = () => startmember() |
|
|
setTimeout(startmember(), 1000); |
|
|
// setTimeout(startmember(), 1000); |
|
|
} |
|
|
// } |
|
|
} else { |
|
|
// } else { |
|
|
setMemberList(res.payload.data?.personnel) |
|
|
setMemberList(res.payload.data?.personnel) |
|
|
} |
|
|
// } |
|
|
if (res.payload.data?.webApp?.length > 3) { |
|
|
// if (res.payload.data?.webApp?.length > 3) { |
|
|
setWebList([...res.payload.data?.webApp, ...res.payload.data?.webApp]) |
|
|
// setWebList([...res.payload.data?.webApp, ...res.payload.data?.webApp]) |
|
|
let webtop = 0 |
|
|
// let webtop = 0 |
|
|
let webId = document.getElementById('web'); |
|
|
// let webId = document.getElementById('web'); |
|
|
if (web) clearInterval(web) |
|
|
// if (web) clearInterval(web) |
|
|
let memberId = document.getElementById('member'); |
|
|
// if (webId) { |
|
|
if (memberId) { |
|
|
// function webstart () { |
|
|
function webstart () { |
|
|
// member = setInterval(() => { |
|
|
member = setInterval(() => { |
|
|
// webtop += 5 |
|
|
webtop += 5 |
|
|
// webId.scrollTop = webtop |
|
|
webId.scrollTop = webtop |
|
|
// if (webId.scrollTop >= webId.scrollHeight / 2) webtop = 0, webId.scrollTop = webtop |
|
|
if (webId.scrollTop >= webId.scrollHeight / 2) webtop = 0, webId.scrollTop = webtop |
|
|
// }, 500); |
|
|
}, 500); |
|
|
// webId.onmouseover = () => clearInterval(web) |
|
|
webId.onmouseover = () => clearInterval(web) |
|
|
// } |
|
|
} |
|
|
// webId.onmouseout = () => webstart() |
|
|
webId.onmouseout = () => webstart() |
|
|
// setTimeout(webstart(), 1000); |
|
|
setTimeout(webstart(), 1000); |
|
|
// } |
|
|
} |
|
|
// } else { |
|
|
} else { |
|
|
setWebList(res.payload.data?.webApp) |
|
|
setWebList(res.payload.data?.webApp) |
|
|
// } |
|
|
} |
|
|
|
|
|
} |
|
|
} |
|
|
}) |
|
|
}) |
|
|
} |
|
|
} |
|
|
// concentration4() |
|
|
if (exhibition.current?.overall?.find(v => v.key == 'statistical')) { |
|
|
}, [projectId]) |
|
|
concentration4() |
|
|
|
|
|
} |
|
|
|
|
|
}, [projectId, exhibition.current]) |
|
|
|
|
|
|
|
|
useEffect(() => { |
|
|
useEffect(() => { |
|
|
//查询最新动态 |
|
|
//查询最新动态 |
|
@ -420,7 +428,10 @@ const Control = ({ dispatch, actions, user, history, loading, socket, pepProject |
|
|
}) |
|
|
}) |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
// concentration3() |
|
|
|
|
|
|
|
|
if (exhibition.current?.overall?.find(v => v.key == 'dynamic')) { |
|
|
|
|
|
concentration3() |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
const domProject1 = document.getElementById("overviewCalc"); |
|
|
const domProject1 = document.getElementById("overviewCalc"); |
|
|
if (domProject1) { |
|
|
if (domProject1) { |
|
@ -529,12 +540,7 @@ const Control = ({ dispatch, actions, user, history, loading, socket, pepProject |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
const domProject1 = document.getElementById("overviewCalc"); |
|
|
|
|
|
if (domProject1) { |
|
|
|
|
|
if (domProject1 && overviewScrollbar) { |
|
|
|
|
|
overviewScrollbar.update(); |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
const domProject2 = document.getElementById("member"); |
|
|
const domProject2 = document.getElementById("member"); |
|
|
if (domProject2) { |
|
|
if (domProject2) { |
|
@ -582,35 +588,6 @@ const Control = ({ dispatch, actions, user, history, loading, socket, pepProject |
|
|
}) |
|
|
}) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
//轮播 |
|
|
|
|
|
function startmarquee (name) { |
|
|
|
|
|
/* |
|
|
|
|
|
函数startmarquee的参数: |
|
|
|
|
|
lh:文字一次向上滚动的距离或高度; |
|
|
|
|
|
speed:滚动速度; |
|
|
|
|
|
delay:滚动停顿的时间间隔; |
|
|
|
|
|
index:可以使封装后的函数应用于页面当中不同的元素; |
|
|
|
|
|
*/ |
|
|
|
|
|
let t; |
|
|
|
|
|
let p = false |
|
|
|
|
|
let top = 0 |
|
|
|
|
|
let o = document.getElementById(name); |
|
|
|
|
|
if (t) clearInterval(t) |
|
|
|
|
|
if (o) { |
|
|
|
|
|
function start () { |
|
|
|
|
|
t = setInterval(() => { |
|
|
|
|
|
top += 5 |
|
|
|
|
|
o.scrollTop = top |
|
|
|
|
|
if (o.scrollTop >= o.scrollHeight / 2) top = 0, o.scrollTop = top |
|
|
|
|
|
}, 500); |
|
|
|
|
|
o.onmouseover = () => clearInterval(t) |
|
|
|
|
|
} |
|
|
|
|
|
o.onmouseout = () => start() |
|
|
|
|
|
setTimeout(start(), 1000); |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
let Select = { |
|
|
let Select = { |
|
|
overall: ['workbench', 'statistical', 'dataAnalyse', 'analyse', 'dynamic', 'tool'], |
|
|
overall: ['workbench', 'statistical', 'dataAnalyse', 'analyse', 'dynamic', 'tool'], |
|
@ -759,7 +736,7 @@ const Control = ({ dispatch, actions, user, history, loading, socket, pepProject |
|
|
</div> |
|
|
</div> |
|
|
</div> |
|
|
</div> |
|
|
{/* 循环类型 */} |
|
|
{/* 循环类型 */} |
|
|
<div id='alarm' style={{ width: 'calc(100% - 200px)', position: 'relative', whiteSpace: 'nowrap', }}> |
|
|
<SimpleBar style={{ width: 'calc(100% - 200px)', whiteSpace: 'nowrap', }} forceVisible="x" > |
|
|
{exhibition.current['workbench']?.map((item, index) => { |
|
|
{exhibition.current['workbench']?.map((item, index) => { |
|
|
return ( |
|
|
return ( |
|
|
pepProjectId && item.name == '关注的项目' ? '' : <div key={item.name} style={{ background: item.img, backgroundSize: "100% 100%", display: "inline-block", width: 270, height: 135, marginRight: 26 }}> |
|
|
pepProjectId && item.name == '关注的项目' ? '' : <div key={item.name} style={{ background: item.img, backgroundSize: "100% 100%", display: "inline-block", width: 270, height: 135, marginRight: 26 }}> |
|
@ -777,7 +754,7 @@ const Control = ({ dispatch, actions, user, history, loading, socket, pepProject |
|
|
) |
|
|
) |
|
|
}) |
|
|
}) |
|
|
} |
|
|
} |
|
|
</div> |
|
|
</SimpleBar> |
|
|
</div> |
|
|
</div> |
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -800,7 +777,7 @@ const Control = ({ dispatch, actions, user, history, loading, socket, pepProject |
|
|
</div> |
|
|
</div> |
|
|
</div> |
|
|
</div> |
|
|
{/* 统计概览 */} |
|
|
{/* 统计概览 */} |
|
|
<SimpleBar style={{ width: 'calc(100%)', height: 240 }} forceVisible="x" > |
|
|
<div id='overviewCalc' style={{ width: 'calc(100%)', position: 'relative' }}> |
|
|
|
|
|
|
|
|
<div style={{ display: 'inline-flex', marginTop: 16 }}> |
|
|
<div style={{ display: 'inline-flex', marginTop: 16 }}> |
|
|
{/* 项目 */} |
|
|
{/* 项目 */} |
|
@ -893,7 +870,8 @@ const Control = ({ dispatch, actions, user, history, loading, socket, pepProject |
|
|
<div style={{ margin: '20px 0px 17px 0px', color: '#4A4A4A', fontSize: 16, fontWeight: 'bold' }}> |
|
|
<div style={{ margin: '20px 0px 17px 0px', color: '#4A4A4A', fontSize: 16, fontWeight: 'bold' }}> |
|
|
相关成员 |
|
|
相关成员 |
|
|
</div> |
|
|
</div> |
|
|
<div id='member' style={{ position: 'relative', height: 161 }}> |
|
|
<SimpleBar id='member' style={{ height: 160, }} forceVisible="y"> |
|
|
|
|
|
{/* <div id='member' style={{ position: 'relative', height: 161 }}> */} |
|
|
{memberList?.map((item, index) => { |
|
|
{memberList?.map((item, index) => { |
|
|
return ( |
|
|
return ( |
|
|
<div key={index + 'member'} style={{ display: 'flex', justifyContent: 'space-between', marginBottom: 15 }}> |
|
|
<div key={index + 'member'} style={{ display: 'flex', justifyContent: 'space-between', marginBottom: 15 }}> |
|
@ -918,7 +896,9 @@ const Control = ({ dispatch, actions, user, history, loading, socket, pepProject |
|
|
</div> |
|
|
</div> |
|
|
) |
|
|
) |
|
|
})} |
|
|
})} |
|
|
</div> |
|
|
{/* </div> */} |
|
|
|
|
|
</SimpleBar> |
|
|
|
|
|
|
|
|
</div> |
|
|
</div> |
|
|
: ""} |
|
|
: ""} |
|
|
{/* 平台设备接入 */} |
|
|
{/* 平台设备接入 */} |
|
@ -961,15 +941,13 @@ const Control = ({ dispatch, actions, user, history, loading, socket, pepProject |
|
|
<div style={{ margin: '20px 0px 17px 0px', color: '#4A4A4A', fontSize: 16, fontWeight: 'bold', marginBottom: 15 }}> |
|
|
<div style={{ margin: '20px 0px 17px 0px', color: '#4A4A4A', fontSize: 16, fontWeight: 'bold', marginBottom: 15 }}> |
|
|
关联web应用 |
|
|
关联web应用 |
|
|
</div> |
|
|
</div> |
|
|
<div id='web' style={{ position: 'relative', height: 161 }}> |
|
|
<SimpleBar id='member' style={{ height: 160, paddindRight: 20 }} forceVisible="y"> |
|
|
{ |
|
|
{ |
|
|
webList.map((item, index) => { |
|
|
webList.map((item, index) => { |
|
|
return ( |
|
|
return ( |
|
|
<div key={index + 'webb'} style={{ marginBottom: 15, }}> |
|
|
<div key={index + 'webb'} style={{ marginBottom: 15, }}> |
|
|
<div style={{ display: 'flex' }}> |
|
|
<div style={{ display: 'flex' }}> |
|
|
<div style={{ width: 18, height: 18, marginRight: 8 }}> |
|
|
<img style={{ width: 18, height: 18, marginRight: 8 }} src="/assets/images/console/icon_webpage.png" alt="web应用" /> |
|
|
<img src="/assets/images/console/icon_webpage.png" alt="web应用" style={{ width: '100%', height: '100%' }} /> |
|
|
|
|
|
</div> |
|
|
|
|
|
<div style={{ color: '#646566', fontSize: 14, borderBottom: '1px dotted #0F7EFB' }}> |
|
|
<div style={{ color: '#646566', fontSize: 14, borderBottom: '1px dotted #0F7EFB' }}> |
|
|
<a href={item.url} target="_blank"> |
|
|
<a href={item.url} target="_blank"> |
|
|
{item.url} |
|
|
{item.url} |
|
@ -983,7 +961,8 @@ const Control = ({ dispatch, actions, user, history, loading, socket, pepProject |
|
|
) |
|
|
) |
|
|
}) |
|
|
}) |
|
|
} |
|
|
} |
|
|
</div> |
|
|
</SimpleBar> |
|
|
|
|
|
|
|
|
</div> |
|
|
</div> |
|
|
: ""} |
|
|
: ""} |
|
|
{/* 异常&问题 */} |
|
|
{/* 异常&问题 */} |
|
@ -1020,8 +999,7 @@ const Control = ({ dispatch, actions, user, history, loading, socket, pepProject |
|
|
: ""} |
|
|
: ""} |
|
|
</div> |
|
|
</div> |
|
|
|
|
|
|
|
|
</SimpleBar> |
|
|
</div></> : ""} |
|
|
</> : ""} |
|
|
|
|
|
</div> |
|
|
</div> |
|
|
|
|
|
|
|
|
{/* 图表 */} |
|
|
{/* 图表 */} |
|
|