Browse Source

项目集大屏

dev
wenlele 1 year ago
parent
commit
dda3cb00d9
  1. 3
      api/app/lib/routes/project/index.js
  2. BIN
      web/client/assets/images/projectGroup/backend.png
  3. 11
      web/client/src/sections/projectGroup/actions/group.js
  4. 8
      web/client/src/sections/projectGroup/components/header.jsx
  5. 9
      web/client/src/sections/projectGroup/containers/bigscreen.jsx
  6. 3
      web/client/src/sections/projectGroup/containers/index.js
  7. 125
      web/client/src/sections/projectGroup/containers/statistic.jsx
  8. 13
      web/client/src/sections/projectGroup/routes.js
  9. 1
      web/client/src/utils/webapi.js

3
api/app/lib/routes/project/index.js

@ -43,9 +43,6 @@ module.exports = function (app, router, opts) {
app.fs.api.logAttr['GET/project/group/statistic'] = { content: '获取项目分组统计信息', visible: true }; app.fs.api.logAttr['GET/project/group/statistic'] = { content: '获取项目分组统计信息', visible: true };
router.get('/project/group/statistic', projectGroup.groupStatistic); router.get('/project/group/statistic', projectGroup.groupStatistic);
app.fs.api.logAttr['GET/project/group/statistic'] = { content: '获取项目分组统计信息', visible: true };
router.get('/project/group/statistic', projectGroup.groupStatistic);
app.fs.api.logAttr['GET/project/group/statistic/online'] = { content: '获取项目分组在线率统计信息', visible: true }; app.fs.api.logAttr['GET/project/group/statistic/online'] = { content: '获取项目分组在线率统计信息', visible: true };
router.get('/project/group/statistic/online', projectGroup.groupStatisticOnline); router.get('/project/group/statistic/online', projectGroup.groupStatisticOnline);
}; };

BIN
web/client/assets/images/projectGroup/backend.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 911 B

11
web/client/src/sections/projectGroup/actions/group.js

@ -33,3 +33,14 @@ export function delProjectGroup (id) {
msg: { option: "删除项目分组" }, msg: { option: "删除项目分组" },
}); });
} }
export function groupStatistic () {
return (dispatch) => basicAction({
type: "get",
dispatch: dispatch,
actionType: "GET_GROPUP_STATISTICS",
url: `${ApiTable.groupStatistic}`,
msg: { error: "获取项目分组统计信息失败" },
reducer: { name: "groupStatistic", params: { noClear: true } },
});
}

8
web/client/src/sections/projectGroup/components/header.jsx

@ -110,6 +110,14 @@ const Header = (props) => {
{weatherMap[weatherRealtime?.skycon]} {weatherMap[weatherRealtime?.skycon]}
</span> </span>
</div> </div>
<div style={lineBetweenStyle} />
<div style={{
display: "flex", alignItems: 'center', justifyContent: "space-around", width: 90,
color: 'color: #5A6685'
}}>
<img src="/assets/images/projectGroup/backend.png" style={{ width: 14, height: 14 }} alt="" />
返回后台
</div>
</span> </span>
</div> </div>
) )

9
web/client/src/sections/projectGroup/containers/bigscreen.jsx

@ -5,7 +5,13 @@ import Body from '../components/body'
import Card from '../components/card' import Card from '../components/card'
import '../style.less' import '../style.less'
const Bigscreen = (props) => { const Bigscreen = ({ dispatch, actions, user, history, clientHeight }) => {
useEffect(() => {
let projectGroupId = localStorage.getItem('project_group_id')
console.log(projectGroupId);
})
return ( return (
<div className='project-group'> <div className='project-group'>
@ -24,6 +30,7 @@ function mapStateToProps (state) {
return { return {
user: auth.user, user: auth.user,
actions: global.actions, actions: global.actions,
clientHeight: global.clientHeight,
}; };
} }

3
web/client/src/sections/projectGroup/containers/index.js

@ -1,4 +1,5 @@
'use strict'; 'use strict';
import Statistic from './statistic' import Statistic from './statistic'
import Bigscreen from './bigscreen'
export { Statistic }; export { Statistic ,Bigscreen};

125
web/client/src/sections/projectGroup/containers/statistic.jsx

@ -1,19 +1,133 @@
import React, { useEffect, useRef, useState } from 'react'; import React, { useEffect, useRef, useState } from 'react';
import { connect } from 'react-redux'; import { connect } from 'react-redux';
import { Skeleton, Button, Pagination, Form, Popconfirm, Table, Tooltip } from '@douyinfe/semi-ui';
import { SkeletonScreen, } from "$components";
import Header from '../components/header'; import Header from '../components/header';
import Body from '../components/body' import Body from '../components/body'
import Card from '../components/card' import Card from '../components/card'
import '../style.less' import '../style.less'
const Statistic = (props) => { const Statistic = ({ dispatch, actions, user, history, loading, groupStatistic, clientHeight }) => {
const { projectGroup } = actions;
const [query, setQuery] = useState({ limit: 10, page: 0 }); //
useEffect(() => {
dispatch(projectGroup.groupStatistic())
}, [])
let columns = [
{
title: '项目集名称',
dataIndex: "name",
key: 'name',
width: "30%",
render: (text, row) => <div style={{ cursor: 'pointer' }} onClick={() => {
localStorage.setItem('project_group_id', row.id)
history.push({
pathname: `/projectGroup/bigscreen`,
})
}}>{text}</div>
}, {
title: '项目集类型',
dataIndex: "name",
key: 'name',
render: (_, row) => '--'
}, {
title: '项目个数',
dataIndex: "pomsProjectIds",
key: 'pomsProjectIds',
render: (_, row) => row?.pomsProjectIds?.length || 0
}, {
title: '结构物数量',
dataIndex: "strucCount",
key: 'strucCount',
}, {
title: '流转工单数',
dataIndex: "name",
key: 'name',
render: (_, row) => Math.floor(Math.random() * 10)
}, {
title: '中断时长',
dataIndex: "maxOffLineTime",
key: 'maxOffLineTime',
}, {
title: '今日告警个数',
dataIndex: "name",
key: 'name',
render: (_, row) => Math.floor(Math.random() * 20)
}
]
const handleRow = (record, index) => {
return {
style: {
background: 'linear-gradient(180deg, #f1f7ff00 0%, #DEEBFF 100%)',
},
};
};
return ( return (
<div className='project-group'> <div className='project-group'>
<Header /> <Header />
<Body> <Body>
<Card title="12312312"> <Card title="重点项目集">
123 <div style={{
marginTop: 10, height: clientHeight - 140,
display: 'flex', flexDirection: 'column', justifyContent: "space-between"
}}>
<Skeleton
loading={loading}
// loading={false}
active={true}
placeholder={SkeletonScreen()}
>
<Table
rowKey="name"
scroll={{ y: clientHeight - 245 }}
columns={columns}
dataSource={groupStatistic}
bordered={false}
hideExpandedColumn={false}
empty="暂无数据"
// expandedRowRender={expandRowRender}
pagination={false}
onRow={handleRow}
/>
</Skeleton>
<div
style={{
display: "flex",
justifyContent: "flex-end",
padding: "20px 20px",
}}
>
<div style={{ display: 'flex', }}>
<span style={{ lineHeight: "30px", fontSize: 13, color: 'rgba(0,90,189,0.8)' }}>
{groupStatistic?.length || 0}条信息
</span>
<Pagination
className=""
total={groupStatistic?.length || 0}
showSizeChanger
currentPage={query.page + 1}
pageSizeOpts={[10, 20, 30, 40]}
onChange={(currentPage, pageSize) => {
setQuery({ limit: pageSize, page: currentPage - 1 });
// page.current = currentPage - 1
// setChange(!change)
}}
/>
</div>
</div>
</div>
</Card> </Card>
</Body> </Body>
</div> </div>
@ -21,10 +135,13 @@ const Statistic = (props) => {
} }
function mapStateToProps (state) { function mapStateToProps (state) {
const { auth, global, } = state; const { auth, global, groupStatistic } = state;
return { return {
clientHeight: global.clientHeight,
user: auth.user, user: auth.user,
actions: global.actions, actions: global.actions,
groupStatistic: groupStatistic?.data || [],
loading: groupStatistic.isRequesting,
}; };
} }

13
web/client/src/sections/projectGroup/routes.js

@ -1,4 +1,4 @@
import { Statistic } from './containers'; import { Statistic, Bigscreen } from './containers';
export default [{ export default [{
type: 'outer', type: 'outer',
@ -8,4 +8,13 @@ export default [{
breadcrumb: '项目集', breadcrumb: '项目集',
component: Statistic, component: Statistic,
} }
}]; }, {
type: 'outer',
route: {
path: '/projectGroup/bigscreen',
key: 'bigscreen',
breadcrumb: '数据大屏 ',
component: Bigscreen,
}
}
];

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

@ -38,6 +38,7 @@ export const ApiTable = {
//项目分组 //项目分组
projectGroup: 'project/group', projectGroup: 'project/group',
groupStatistic:'project/group/statistic',
//告警 //告警
getProjectPoms: 'project/poms', //获取已绑定项目 getProjectPoms: 'project/poms', //获取已绑定项目

Loading…
Cancel
Save