Browse Source

feat:用户权限的修改+任务指派

dev
zhaobing 2 years ago
parent
commit
2d15b451b9
  1. 24
      api/app/lib/controllers/data/appointed.js
  2. 51
      api/app/lib/controllers/organization/department.js
  3. 40
      api/app/lib/models/project.js
  4. 20
      api/app/lib/models/report.js
  5. 3
      api/app/lib/routes/organization/index.js
  6. 17
      scripts/1.2.3/schema/2.alter_project.sql
  7. 4
      scripts/1.2.3/schema/3.alter_report.sql
  8. 13
      web/client/src/sections/fillion/actions/appointTask.js
  9. 379
      web/client/src/sections/fillion/components/buildingTable.js
  10. 152
      web/client/src/sections/fillion/components/feedback/nominateModal.js
  11. 19
      web/client/src/sections/fillion/components/patrolTable.js
  12. 37
      web/client/src/sections/fillion/components/project/project.js
  13. 59
      web/client/src/sections/fillion/containers/building.js
  14. 13
      web/client/src/sections/fillion/nav-item.js
  15. 6
      web/client/src/sections/fillion/routes.js
  16. 12
      web/client/src/sections/organization/actions/user.js
  17. 35
      web/client/src/sections/organization/containers/authority.js
  18. 30
      web/client/src/sections/organization/containers/user.js
  19. 9
      web/client/src/utils/webapi.js

24
api/app/lib/controllers/data/appointed.js

@ -0,0 +1,24 @@
'use strict';
const moment = require('moment')
async function appoint(ctx) {
try {
const models = ctx.fs.dc.models
const { recordId, performerId } = ctx.request.body
await models.Report.update({
performerId
}, { where: { id: recordId } })
ctx.status = 204;
} catch (error) {
ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`);
ctx.status = 400;
ctx.body = {
message: typeof error == 'string' ? error : undefined
}
}
}
module.exports = {
appoint
};

51
api/app/lib/controllers/organization/department.js

@ -185,7 +185,56 @@ async function delDep(ctx) {
} }
} }
} }
async function getDepById(ctx) {
try {
const models = ctx.fs.dc.models;
const { deptId } = ctx.query
console.log('deptId1', deptId)
let depLevel0 = await models.Department.findAll({
order: [['id', 'asc']],
where: {
// id: userInfo.departmentId
delete: false,
id: deptId
},
})
let depRslt = []
const getDep = async (d) => {
let subordinate = []
let depRes = await models.Department.findAll({
order: [['id', 'asc']],
where: {
dependence: d.id,
delete: false,
id: { $ne: 1 }
},
})
if (depRes.length)
for (let d of depRes) {
let dep = d.dataValues
dep.subordinate = await getDep(d.dataValues)
subordinate.push(dep)
}
return subordinate
}
for (let d of depLevel0) {
let dep0 = d.dataValues
dep0.subordinate = await getDep(d.dataValues)
depRslt.push(dep0)
}
ctx.status = 200;
console.log('depRslt', depRslt)
ctx.body = depRslt
} catch (error) {
ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`);
ctx.status = 400;
ctx.body = {
message: typeof error == 'string' ? error : undefined
}
}
}
module.exports = { module.exports = {
getdep, editDep, delDep, getdep, editDep, delDep, getDepById
}; };

40
api/app/lib/models/project.js

@ -1,4 +1,5 @@
/* eslint-disable*/ /* eslint-disable*/
'use strict'; 'use strict';
module.exports = dc => { module.exports = dc => {
@ -6,7 +7,6 @@ module.exports = dc => {
const sequelize = dc.orm; const sequelize = dc.orm;
const Project = sequelize.define("project", { const Project = sequelize.define("project", {
id: { id: {
index: 1,
type: DataTypes.INTEGER, type: DataTypes.INTEGER,
allowNull: false, allowNull: false,
defaultValue: null, defaultValue: null,
@ -17,7 +17,6 @@ module.exports = dc => {
unique: "project_id_uindex" unique: "project_id_uindex"
}, },
entryName: { entryName: {
index: 2,
type: DataTypes.STRING, type: DataTypes.STRING,
allowNull: true, allowNull: true,
defaultValue: null, defaultValue: null,
@ -27,7 +26,6 @@ module.exports = dc => {
autoIncrement: false autoIncrement: false
}, },
projectMileage: { projectMileage: {
index: 3,
type: DataTypes.STRING, type: DataTypes.STRING,
allowNull: true, allowNull: true,
defaultValue: null, defaultValue: null,
@ -37,7 +35,6 @@ module.exports = dc => {
autoIncrement: false autoIncrement: false
}, },
investment: { investment: {
index: 4,
type: DataTypes.STRING, type: DataTypes.STRING,
allowNull: true, allowNull: true,
defaultValue: null, defaultValue: null,
@ -47,7 +44,6 @@ module.exports = dc => {
autoIncrement: false autoIncrement: false
}, },
buildUnit: { buildUnit: {
index: 5,
type: DataTypes.STRING, type: DataTypes.STRING,
allowNull: true, allowNull: true,
defaultValue: null, defaultValue: null,
@ -57,7 +53,6 @@ module.exports = dc => {
autoIncrement: false autoIncrement: false
}, },
constructionControlUnit: { constructionControlUnit: {
index: 6,
type: DataTypes.STRING, type: DataTypes.STRING,
allowNull: true, allowNull: true,
defaultValue: null, defaultValue: null,
@ -67,7 +62,6 @@ module.exports = dc => {
autoIncrement: false autoIncrement: false
}, },
designUnit: { designUnit: {
index: 7,
type: DataTypes.STRING, type: DataTypes.STRING,
allowNull: true, allowNull: true,
defaultValue: null, defaultValue: null,
@ -77,7 +71,6 @@ module.exports = dc => {
autoIncrement: false autoIncrement: false
}, },
constructionUnit: { constructionUnit: {
index: 8,
type: DataTypes.STRING, type: DataTypes.STRING,
allowNull: true, allowNull: true,
defaultValue: null, defaultValue: null,
@ -87,7 +80,6 @@ module.exports = dc => {
autoIncrement: false autoIncrement: false
}, },
supervisorAndSupervisor: { supervisorAndSupervisor: {
index: 9,
type: DataTypes.STRING, type: DataTypes.STRING,
allowNull: true, allowNull: true,
defaultValue: null, defaultValue: null,
@ -97,7 +89,6 @@ module.exports = dc => {
autoIncrement: false autoIncrement: false
}, },
projectProgress: { projectProgress: {
index: 10,
type: DataTypes.STRING, type: DataTypes.STRING,
allowNull: true, allowNull: true,
defaultValue: null, defaultValue: null,
@ -107,7 +98,6 @@ module.exports = dc => {
autoIncrement: false autoIncrement: false
}, },
done: { done: {
index: 11,
type: DataTypes.BOOLEAN, type: DataTypes.BOOLEAN,
allowNull: false, allowNull: false,
defaultValue: null, defaultValue: null,
@ -117,7 +107,6 @@ module.exports = dc => {
autoIncrement: false autoIncrement: false
}, },
type: { type: {
index: 12,
type: DataTypes.STRING, type: DataTypes.STRING,
allowNull: false, allowNull: false,
defaultValue: null, defaultValue: null,
@ -125,6 +114,33 @@ module.exports = dc => {
primaryKey: false, primaryKey: false,
field: "type", field: "type",
autoIncrement: false autoIncrement: false
},
startTime: {
type: DataTypes.DATE,
allowNull: true,
defaultValue: null,
comment: "开工时间",
primaryKey: false,
field: "start_time",
autoIncrement: false
},
remark: {
type: DataTypes.STRING,
allowNull: true,
defaultValue: null,
comment: "备注",
primaryKey: false,
field: "remark",
autoIncrement: false
},
qutityUnit: {
type: DataTypes.STRING,
allowNull: true,
defaultValue: null,
comment: "质量检测单位",
primaryKey: false,
field: "qutity_unit",
autoIncrement: false
} }
}, { }, {
tableName: "project", tableName: "project",

20
api/app/lib/models/report.js

@ -1,4 +1,5 @@
/* eslint-disable*/ /* eslint-disable*/
'use strict'; 'use strict';
module.exports = dc => { module.exports = dc => {
@ -186,16 +187,25 @@ module.exports = dc => {
field: "handle_state", field: "handle_state",
autoIncrement: false autoIncrement: false
}, },
codeRoad: { routeCode: {
index: 19,
type: DataTypes.STRING, type: DataTypes.STRING,
allowNull: true, allowNull: true,
defaultValue: "", defaultValue: null,
// comment: "路线代码", comment: null,
primaryKey: false, primaryKey: false,
field: "code_road", field: "route_code",
autoIncrement: false autoIncrement: false
}, },
performerId: {
type: DataTypes.INTEGER,
allowNull: true,
defaultValue: null,
comment: "执行者",
primaryKey: false,
field: "performer_id",
autoIncrement: false
}
}, { }, {
tableName: "report", tableName: "report",
comment: "", comment: "",

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

@ -8,6 +8,9 @@ module.exports = function (app, router, opts) {
app.fs.api.logAttr['GET/department'] = { content: '获取部门列表', visible: false }; app.fs.api.logAttr['GET/department'] = { content: '获取部门列表', visible: false };
router.get('/department', Department.getdep); router.get('/department', Department.getdep);
app.fs.api.logAttr['GET/departmentById'] = { content: '根据id获取部门', visible: false };
router.get('/departmentById', Department.getDepById);
app.fs.api.logAttr['PUT/department'] = { content: '编辑部门信息', visible: false }; app.fs.api.logAttr['PUT/department'] = { content: '编辑部门信息', visible: false };
router.put('/department', Department.editDep); router.put('/department', Department.editDep);

17
scripts/1.2.3/schema/2.alter_project.sql

@ -0,0 +1,17 @@
alter table project
add start_time timestamp with time zone;
comment on column project.start_time is '开工时间';
alter table project
add remark varchar(300);
comment on column project.remark is '备注';
alter table project
add qutity_unit varchar(1024);
comment on column project.qutity_unit is '质量检测单位';

4
scripts/1.2.3/schema/3.alter_report.sql

@ -0,0 +1,4 @@
alter table report
add performer_id integer;
comment on column report.performer_id is '处理人';

13
web/client/src/sections/fillion/actions/appointTask.js

@ -0,0 +1,13 @@
import { basicAction } from '@peace/utils'
import { ApiTable } from '$utils'
export function appointTask(query) {
return dispatch => basicAction({
type: 'put',
dispatch: dispatch,
data: query,
actionType: 'PUT_APPOINT_TASK',
url: ApiTable.appointTask,
msg: { option: '指派任务' },
});
}

379
web/client/src/sections/fillion/components/buildingTable.js

@ -0,0 +1,379 @@
'use strict';
import React, { useState, useEffect, useRef } from 'react';
import { connect } from 'react-redux';
import { Spin, Button, Popconfirm } from 'antd';
import ProTable from '@ant-design/pro-table';
import './protable.less'
import ProjectModal from './project/project';
import { getProject, delProject } from "../actions/infor"
import moment from 'moment';
// import UserModal from './infor/details';
const BuildingTable = (props) => {
const { dispatch, user, depData, depMessage, depLoading } = props
const [rowSelected, setRowSelected] = useState([])
const [sitename, setSitename] = useState()//名称
const [counts, setCounts] = useState()//shuju
const [modalVisible, setModalVisible] = useState(false);
const [modalVisibleyilan, setModalVisibleyilan] = useState(false);
const [modalRecord, setModalRecord] = useState();
const [typecard, setTypecard] = useState();
const [recortd, setRecortd] = useState()
const [whichofits, setWhichofits] = useState('在建项目')
const [delet, setDelet] = useState()
const [differentiate, setDifferentiate] = useState('road')
const [grade, setGrade] = useState('project')
const [departmentInfo, setDepartment] = useState('')
const [editAble, setEditAble] = useState(user?.username !== 'SuperAdmin' && user?.userResources?.filter(i => i.resourceId === 'ROADMANAGE')[0].isshow === "true" ? true : '')
const ref = useRef()
const [activeKey, setActiveKey] = useState('tab1');
//打开弹窗
const yilanModal = (type, record) => {
setModalVisibleyilan(true);
// setModalType(type);
if (type == 'edit') {
setModalRecord(record);
} else {
setModalRecord(null);
}
}
const getData = async () => {
const res = await dispatch(getProject({
entryName: sitename
}));
setCounts(res.payload.data)
}
const deldatas = async (id) => { // 工程
const query = {
projectId: id
}
dispatch(delProject(query)).then((res) => {
setDelet(res)
})
const res = await dispatch(getProject({
entryName: sitename
}));
setCounts(res.payload.data)
}
const columns = {
tab1: [
{
title: '项目名称',
dataIndex: 'placeName',
fixed: 'left',
width: 120,
options: 1,
backgroundColor: "#ffffff",
fieldProps: {
onChange: (value, cs) => {
setSitename(value.currentTarget.value)
},
placeholder: '请输入项目名称进行搜索',
getPopupContainer: (triggerNode) => triggerNode.parentNode,
},
render: (dom, record) => {
return record.entryName
},
},
{
title: '项目规模(公里)',
search: false,
dataIndex: 'containers',
fixed: 'left',
width: 120,
render: (dom, record) => {
return record.projectMileage
},
fieldProps: {
getPopupContainer: (triggerNode) => triggerNode.parentNode,
}
},
{
title: '项目投资(万元)',
search: false,
dataIndex: 'time2',
valueType: 'dateRange',
// align: 'right',
width: 120,
render: (dom, record) => {
return record.investment
},
fieldProps: {
getPopupContainer: (triggerNode) => triggerNode.parentNode,
}
},
{
title: '业主单位',
search: false,
dataIndex: 'time3',
valueType: 'dateRange',
width: 120,
render: (dom, record) => {
return record.buildUnit
},
fieldProps: {
getPopupContainer: (triggerNode) => triggerNode.parentNode,
}
},
{
title: '质量监督单位',
search: false,
dataIndex: 'time3',
valueType: 'dateRange',
width: 120,
render: (dom, record) => {
return record.qutityUnit
},
fieldProps: {
getPopupContainer: (triggerNode) => triggerNode.parentNode,
}
}, {
title: '施工单位',
search: false,
dataIndex: 'time6',
valueType: 'dateRange',
width: 120,
render: (dom, record) => {
return record.constructionUnit
},
fieldProps: {
getPopupContainer: (triggerNode) => triggerNode.parentNode,
}
}, {
title: '设计单位',
search: false,
dataIndex: 'time5',
valueType: 'dateRange',
width: 120,
render: (dom, record) => {
return record.designUnit
},
fieldProps: {
getPopupContainer: (triggerNode) => triggerNode.parentNode,
}
}, {
title: '监理单位',
search: false,
dataIndex: 'time4',
valueType: 'dateRange',
width: 120,
render: (dom, record) => {
return record.constructionControlUnit
},
fieldProps: {
getPopupContainer: (triggerNode) => triggerNode.parentNode,
}
},
{
title: '开工时间',
search: false,
dataIndex: 'time7',
valueType: 'dateRange',
width: 120,
render: (dom, record) => {
return record.startTime ? moment(record.startTime).format('YYYY-MM-DD') : ''
},
fieldProps: {
getPopupContainer: (triggerNode) => triggerNode.parentNode,
}
},
{
title: '是否完成',
search: false,
dataIndex: 'time8',
valueType: 'dateRange',
width: 120,
render: (dom, record) => {
return record.done === true ? '已完成' : '未完成'
},
fieldProps: {
getPopupContainer: (triggerNode) => triggerNode.parentNode,
}
},
{
title: '备注',
search: false,
dataIndex: 'time9',
valueType: 'dateRange',
width: 120,
render: (dom, record) => {
return record.remark
},
fieldProps: {
getPopupContainer: (triggerNode) => triggerNode.parentNode,
}
},
{
title: '操作',
dataIndex: 'creatTime',
valueType: 'dateTimeRange',
hideInSearch: true,
width: 160,
fixed: 'right',
render: (dom, record) => {
return <div><Button type="link"
onClick={() => {
yilanModal('edit', record)
setTypecard('compile')
setRecortd(record)
}}
disabled={editAble}
>编辑</Button><Popconfirm title='' onConfirm={() => { deldatas(record.id) }} disabled={editAble}>
<Button type="link" disabled={editAble}>删除</Button>
</Popconfirm></div>
}
},
{
key: "direction",
hideInTable: true,
dataIndex: "direction",
order: 6,
renderFormItem: (item, { type, defaultRender, ...rest }, form, record) => {
return (
<div> <Button
type="primary"
style={{ width: "100px" }}
onClick={() => {
yilanModal('edit', record)
setTypecard('')
}}
disabled={editAble}
>
新增
</Button>
{/* <Button
type="primary"
style={{ width: "100px", marginLeft: 20 }}
>
导入
</Button> */}
</div>
);
},
},
]
}
return (
<Spin spinning={false}>
<div className='protable-transpor'>
<ProTable
actionRef={ref}
toolbar={{
multipleLine: true,
menu: {
activeKey,
onChange: (key) => setActiveKey(key),
items: [
{
key: 'tab1',
label: <span onClick={() => {
setWhichofits('在建项目')
setDifferentiate('project')
setGrade('在建项目')
}}>在建项目{activeKey === 'tab1'}</span>,
},
],
},
}}
scroll={{ x: 800 }}
options={false}
ref={c => { finishedProductTable = c; }}
style={{ width: "100% ", overflow: "auto", height: '760px' }}
rowKey='id'
onReset={(v) => {
setSitename('')
}}
rowSelection={{
selectedRowKeys: rowSelected,
onChange: (selectedRowKeys) => {
setRowSelected(selectedRowKeys);
},
}}
columns={columns[activeKey]}
dataSource={counts || []}
request={async (params) => {
console.log(whichofits)
if (whichofits == '在建项目') {
const query = {
entryName: sitename
}
setRowSelected([]);
const res = await dispatch(getProject(query));
setCounts(res.payload.data)
return {
...res,
total: res.payload.data ? res.payload.data.count : 0
}
}
}}
search={{
defaultCollapsed: false,
optionRender: (searchConfig, formProps, dom) => [
...dom.reverse(),
<Popconfirm title="确认导出?" onConfirm={() => { props.exports(rowSelected, grade, differentiate) }}
disabled={user?.username !== 'SuperAdmin' && user?.userResources?.filter(i => i.resourceId === 'ROADMANAGE')[0].isshow === "true" ? true : ''}
>
<Button
disabled={user?.username !== 'SuperAdmin' && user?.userResources?.filter(i => i.resourceId === 'ROADMANAGE')[0].isshow === "true" ? true : ''}
>
导出
</Button>
</Popconfirm>
],
}}
>
</ProTable>
</div>
{modalVisibleyilan ? <ProjectModal
visible={modalVisibleyilan}
onVisibleChange={setModalVisibleyilan}
modalRecord={modalRecord}
typecard={typecard}
getData={getData}
rewkeys={'road'}
recortd={recortd}
setRecortd={setRecortd}
setDelet={setDelet}
/> : ''}
</Spin >
)
}
function mapStateToProps(state) {
const { auth, depMessage } = state;
const pakData = (dep) => {
return dep.map((d) => {
return {
title: d.name,
value: d.id,
// children: d.type >= 2 ? [] : pakData(d.subordinate)
children: pakData(d.subordinate)
}
})
}
let depData = pakData(depMessage.data || [])
return {
user: auth.user,
depMessage: depMessage.data || [],
depLoading: depMessage.isRequesting,
depData,
};
}
export default connect(mapStateToProps)(BuildingTable);

152
web/client/src/sections/fillion/components/feedback/nominateModal.js

@ -0,0 +1,152 @@
'use strict';
import React, { useState, useEffect, useCallback, useRef } from 'react';
import { connect } from 'react-redux';
import { Spin } from 'antd';
import ProForm, { ProFormText, ModalForm, ProFormSwitch, ProFormTreeSelect, ProFormSelect } from '@ant-design/pro-form';
import { getDepUser } from '../../../organization/actions/user'
import { appointTask } from '../../actions/appointTask'
import moment from 'moment';
const NominateModal = (props) => {
const { recordId, visible, user, onCancel, depMessage, loading, depUser, clientHeight, depData, onVisibleChange, dispatch } = props
const [depId, setDepId] = useState(null)
const [depUsers, setDepUsers] = useState()
const selectRef = useRef(null);
const handleTreeSelectChange = async (value) => {
console.log('recordId', recordId)
setDepId(value)
// 根据选择的部门ID获取对应的用户数据
setDepUsers(null)
const res = await dispatch(getDepUser(value));
setDepUsers(res?.payload.data);
// 清空第二个输入框的值
if (selectRef.current) {
selectRef.current.value = '';
}
}
const handleFinish = async (values) => {
const { name } = values;
// 在这里使用第二个框的值进行网络请求或其他操作
// await dispatch(yourAction(name));
// 其他操作...
// 取消弹窗
onCancel();
};
const dispatchGetDepUser = useCallback(async () => {
if (depId) {
const res = await dispatch(getDepUser(depId));
setDepUsers(res?.payload.data);
}
}, [depId, dispatch]);
useEffect(() => {
dispatchGetDepUser()
}, [dispatchGetDepUser])
const [depMessagedata, setdepMessagedata] = useState(depMessage)
return (
<Spin spinning={false}>
<ModalForm
title='指派'
visible={visible}
onVisibleChange={onVisibleChange}
onFinish={handleFinish}
destroyOnClose
>
<ProForm.Group>
<ProFormTreeSelect
name={['contract', 'departmentId']}
placeholder="请选择所属部门"
width="md"
label="所属部门"
required
fieldNames={{
title: 'name',
key: 'id',
children: 'subordinate'
}}
onSelect={(selectedKeys, { selected, selectedNodes }) => {
console.log('selected', selectedKeys)
if (selected) {
setDepSelectedKeys(selectedKeys)
setDepSelected(selectedNodes[0].name || "")
dispatch(getDepUser(selectedKeys[0]))
}
}}
fieldProps={{
onChange: handleTreeSelectChange,
fieldNames: {
label: 'title',
},
treeDefaultExpandAll: false,
}}
rules={[{ required: true, message: '请选择所属部门' }]}
request={async () => {
return depData
}}
expandedKeys={["title"]}
/>
{depUsers ? <ProFormSelect
ref={selectRef}
value={null} // 设置输入框的值为null
onValuesChange={(values) => { console.log('values1', values) }}
name="name"
label="指派人"
request={async () => {
if (depId) {
const res = await dispatch(getDepUser(depId));
const processedUsers = res?.payload.data.map((user) => ({
label: user.name, // 使用用户的名字作为选项的显示文本
value: user.id, // 使用用户的id作为选项的值
}));
return Promise.resolve(processedUsers)
}
}}
placeholder="请选择指派人"
rules={[{ required: true, message: '请选择指派人' }]}
/> : ''}
</ProForm.Group>
</ModalForm>
</Spin>
)
}
function mapStateToProps(state) {
const { auth, depMessage, depUser, global } = state
const pakData = (dep) => {
// console.log(dep);
return dep.map((d) => {
return {
title: d.name,
value: d.id,
// key: d.id,
children: pakData(d.subordinate)
}
})
}
let depData = pakData(depMessage.data || [])
// return {
// loading: depMessage.isRequesting,
// depData,
// };
return {
user: auth.user,
clientHeight: global.clientHeight,
loading: depMessage.isRequesting,
//depMessage: depMessage.data || [],
depUser: depUser.data || [],
depData
}
}
export default connect(mapStateToProps)(NominateModal);

19
web/client/src/sections/fillion/components/patrolTable.js

@ -9,6 +9,7 @@ import { getAllDepUsers } from '../actions/allDepUsers'
import { httpDel } from '@peace/utils' import { httpDel } from '@peace/utils'
import { PinyinHelper } from '@peace/utils'; import { PinyinHelper } from '@peace/utils';
import PatrolGis from './gis/patrolGis'; import PatrolGis from './gis/patrolGis';
import NominateModal from '../components/feedback/nominateModal' //指派的模块
// @ts-ignore // @ts-ignore
import styles from './protable.less'; import styles from './protable.less';
import moment from 'moment'; import moment from 'moment';
@ -118,10 +119,15 @@ const DetailList = (props) => {
const [selectRecord, setSelectRecord] = useState(); const [selectRecord, setSelectRecord] = useState();
const [noProcessingPopVisible, setNoProcessingPopVisible] = useState(false); const [noProcessingPopVisible, setNoProcessingPopVisible] = useState(false);
const [noProcessingSelectRecord, setNoProcessingSelectRecord] = useState(); const [noProcessingSelectRecord, setNoProcessingSelectRecord] = useState();
const [vis, setVis] = useState(false)//指派任务的弹窗显示与隐藏
const [recordId, setRecordId] = useState(0)//默认指派任务id
const checkDetail = (record) => { const checkDetail = (record) => {
dispatch(getReportDetail(record.id)) dispatch(getReportDetail(record.id))
} }
//modal取消的事件
const onCancel = () => {
setVis(false)
}
const handleRemove = (record) => { const handleRemove = (record) => {
let url = 'report/{reportId}'; let url = 'report/{reportId}';
const actionType = "DEL_REPORT_RECORD"; const actionType = "DEL_REPORT_RECORD";
@ -140,7 +146,8 @@ const DetailList = (props) => {
} }
let basicDate = null; let basicDate = null;
let counter = 0; let counter = 0;
//指派任务
console.log('vis', vis)
const columns = [ const columns = [
isPatrol ? { isPatrol ? {
title: '编号', title: '编号',
@ -242,7 +249,8 @@ const DetailList = (props) => {
<Button <Button
onClick={() => { checkDetail(record); handleOpen(); }} onClick={() => { checkDetail(record); handleOpen(); }}
style={{ marginRight: 10 }}>查看</Button>, style={{ marginRight: 10 }}>查看</Button>,
isAnomaly && record.handleState != '已处理' ? <Button disabled={user?.username !== 'SuperAdmin' && user?.userResources?.filter(i => i.resourceId === 'FEEDBACKMANAGE' || 'FEEDBACKMANAGE')[0].isshow === "true" ? true : ''}>指派</Button> : null, isAnomaly && record.handleState != '已处理' ?
<Button disabled={user?.username !== 'SuperAdmin' && user?.userResources?.filter(i => i.resourceId === 'FEEDBACKMANAGE' || 'FEEDBACKMANAGE')[0].isshow === "true" ? true : ''} onClick={() => { setVis(true); setRecordId(record.id) }}>指派</Button> : null,
isAnomaly && record.handleState != '已处理' ? isAnomaly && record.handleState != '已处理' ?
<Popover <Popover
content={[ content={[
@ -285,6 +293,7 @@ const DetailList = (props) => {
}, },
].filter(s => s); ].filter(s => s);
return ( return (
<div>
<ProTable <ProTable
columns={columns} columns={columns}
dataSource={reportList} dataSource={reportList}
@ -298,7 +307,9 @@ const DetailList = (props) => {
toolBarRender={false} toolBarRender={false}
search={false} search={false}
/> />
); <NominateModal recordId={recordId} dispatch={dispatch} visible={vis} onCancel={onCancel} onVisibleChange={setVis}></NominateModal>
</div>
)
}; };

37
web/client/src/sections/fillion/components/project/project.js

@ -1,23 +1,25 @@
import React, { useEffect, useState } from 'react'; import React, { useEffect, useState } from 'react';
import { connect } from 'react-redux'; import { connect } from 'react-redux';
import { Form, Spin, Table } from 'antd'; import { Form, Spin, Table } from 'antd';
import { DrawerForm, ProForm, ProFormText, ProFormSelect } from '@ant-design/pro-form'; import { DrawerForm, ProForm, ProFormText, ProFormSelect, ProFormDatePicker, ProFormTextArea } from '@ant-design/pro-form';
import { putProject } from "../../actions/infor" import { putProject } from "../../actions/infor"
import _ from 'lodash' import _ from 'lodash'
const data = { const data = {
"entryName": "项目名称", "entryName": "项目名称",
"projectMileage": "工程里程", "projectMileage": "项目规模(公里)",
"investment": "投资", "investment": " 项目投资(万元)",
"buildUnit": "建设单位", "buildUnit": "业主单位",
"constructionControlUnit": "监理单位", "qutityUnit": "质量监督单位",
"designUnit": "设计单位",
"constructionUnit": "施工单位", "constructionUnit": "施工单位",
"supervisorAndSupervisor": "监督负责人及监督人员", "designUnit": "设计单位",
"projectProgress": "项目进展情况" "constructionControlUnit": "监理单位",
//"startTime": "开工时间",
//"remark": "备注"
} }
const ProjectModal = (props) => { const ProjectModal = (props) => {
const { visible, onVisibleChange, typecard, rewkeys, recortd, dispatch, setRecortd, setDelet } = props const { visible, onVisibleChange, typecard, rewkeys, recortd, dispatch, setRecortd, setDelet, getData } = props
console.log('typecard', newlysay)
const [newlys, setNewlys] = useState() //必填数据 const [newlys, setNewlys] = useState() //必填数据
const [newlysay, setNewlysay] = useState() //处理hou const [newlysay, setNewlysay] = useState() //处理hou
const [records, setRecords] = useState()//处理 const [records, setRecords] = useState()//处理
@ -83,37 +85,39 @@ const ProjectModal = (props) => {
setDelet(values) setDelet(values)
const query = { ...values, type: rewkeys, projectId: records?.[0]?.value || '', done: values.done === 'true' ? true : false } const query = { ...values, type: rewkeys, projectId: records?.[0]?.value || '', done: values.done === 'true' ? true : false }
dispatch(putProject(query)).then((res) => { dispatch(putProject(query)).then((res) => {
}) })
getData()
return true return true
} else { } else {
setDelet(values) setDelet(values)
const query = { ...values, type: rewkeys,done: values.done === 'true' ? true : false } const query = { ...values, type: rewkeys, done: values.done === 'true' ? true : false }
dispatch(putProject(query)).then((res) => { dispatch(putProject(query)).then((res) => {
}) })
getData()
return true return true
} }
} }
if (rewkeys === 'bridge') { if (rewkeys === 'bridge') {
if (typecard == 'compile') { if (typecard == 'compile') {
setDelet(values) setDelet(values)
const query = { ...values, type: rewkeys, projectId: records?.[0]?.value || '',done: values.done === 'true' ? true : false } const query = { ...values, type: rewkeys, projectId: records?.[0]?.value || '', done: values.done === 'true' ? true : false }
dispatch(putProject(query)).then((res) => { dispatch(putProject(query)).then((res) => {
}) })
getData()
return true return true
} else { } else {
setDelet(values) setDelet(values)
const query = { ...values, type: rewkeys,done: values.done === 'true' ? true : false } const query = { ...values, type: rewkeys, done: values.done === 'true' ? true : false }
dispatch(putProject(query)).then((res) => { dispatch(putProject(query)).then((res) => {
}) })
getData()
return true return true
} }
} }
}} }}
initialValues={{ ...recortd, done: typecard == 'compile'?recortd?.done ? 'true' : 'false':'' }} initialValues={{ ...recortd, done: typecard == 'compile' ? recortd?.done ? 'true' : 'false' : '' }}
> >
{typecard == 'compile' ? {typecard == 'compile' ?
<ProForm.Group <ProForm.Group
@ -197,6 +201,9 @@ const ProjectModal = (props) => {
/> />
})} })}
<ProFormDatePicker width="md" name='startTime' label='开工时间' key={10}></ProFormDatePicker>
<ProFormTextArea width="md" name='remark' label='备注' key={11}></ProFormTextArea>
</ProForm.Group>} </ProForm.Group>}
</DrawerForm> </DrawerForm>

59
web/client/src/sections/fillion/containers/building.js

@ -1,41 +1,38 @@
'use strict'; import React, { useEffect, useState } from 'react';
import React, { useState, useEffect } from 'react';
import { connect } from 'react-redux'; import { connect } from 'react-redux';
// import { Spin, Button, Popconfirm } from 'antd'; import '../style.less';
// import ProTable from '@ant-design/pro-table'; import BuildingTable from '../components/buildingTable';
// //import './protable.less' const superagent = require('superagent');
import moment from 'moment'; const building = (props) => {
// import { getRoadway, getProject, delRoadway, delProject } from "../actions/infor" const { dispatch, user } = props
// import UserModal from './infor/details'; const [data, setData] = useState()
// import ProjectModal from './project/project'; useEffect(() => {
// dispatch(getDepMessage())
setData(props)
}, []);
const exports = (ids, differentiate) => {
console.log('sssss1', ids, differentiate)
let idas = ids.toString()
if (differentiate == 'bridge') {
window.open(
'/_api/' + `data/export/?ids=${idas || ''}&exp=${differentiate}&token=${user.token}`)
} if (differentiate == 'project') {
window.open(
'/_api/' + `data/export/?ids=${idas || ''}&exp=${differentiate}&token=${user.token}`)
}
const Building = (props) => {
}
return ( return (
<div> <> <BuildingTable data={data} exports={exports} />
hha </>
</div>
) )
} }
function mapStateToProps(state) { function mapStateToProps(state) {
const { auth, depMessage } = state; const { auth } = state
// const pakData = (dep) => {
// return dep.map((d) => {
// return {
// title: d.name,
// value: d.id,
// // children: d.type >= 2 ? [] : pakData(d.subordinate)
// children: pakData(d.subordinate)
// }
// })
// }
// let depData = pakData(depMessage.data || [])
return { return {
user: auth.user, user: auth.user,
// depMessage: depMessage.data || [], }
// depLoading: depMessage.isRequesting,
// depData,
};
} }
export default connect(mapStateToProps)(Building); export default connect(mapStateToProps)(building);

13
web/client/src/sections/fillion/nav-item.js

@ -59,11 +59,17 @@ export function getNavItem(user, dispatch) {
<Menu.Item key="fillionpatrolanomaly"> <Menu.Item key="fillionpatrolanomaly">
<Link to="/fillion/patrol_anomaly">异常反馈</Link> <Link to="/fillion/patrol_anomaly">异常反馈</Link>
</Menu.Item> : ''} </Menu.Item> : ''}
{user?.username == 'SuperAdmin' || user?.userResources?.filter(i => i.resourceId === 'REPORTMANAGE')?.length !== 0 ?
<Menu.Item key="fillionpatrolroad">
<Link to="/fillion/patrol_road">建设上报</Link>
</Menu.Item> : ''}
{/* {user?.username == 'SuperAdmin' || user?.userResources?.filter(i => i.resourceId === 'FEEDBACKMANAGE')?.length !== 0 ? {/* {user?.username == 'SuperAdmin' || user?.userResources?.filter(i => i.resourceId === 'FEEDBACKMANAGE')?.length !== 0 ?
: ''} */} : ''} */}
<Menu.Item key="fillionbuilding"> <Menu.Item key="fillionbuilding">
<Link to="/fillion/building">在建项目</Link> <Link to="/fillion/processsing">在建项目</Link>
</Menu.Item> </Menu.Item>
{user?.username == 'SuperAdmin' || user?.userResources?.filter(i => i.resourceId === 'PUBLICTRANSPORTMANAGE')?.length !== 0 ? {user?.username == 'SuperAdmin' || user?.userResources?.filter(i => i.resourceId === 'PUBLICTRANSPORTMANAGE')?.length !== 0 ?
<Menu.Item key="fillionpublic"> <Menu.Item key="fillionpublic">
@ -85,11 +91,6 @@ export function getNavItem(user, dispatch) {
<Link to="/fillion/promotional">宣传视频</Link> <Link to="/fillion/promotional">宣传视频</Link>
</Menu.Item> : ''} </Menu.Item> : ''}
{user?.username == 'SuperAdmin' || user?.userResources?.filter(i => i.resourceId === 'REPORTMANAGE')?.length !== 0 ?
<Menu.Item key="fillionpatrolroad">
<Link to="/fillion/patrol_road">建设上报</Link>
</Menu.Item> : ''}
<Menu.Item key="fillionassess"> <Menu.Item key="fillionassess">
<Link to="/fillion/assess">考核评分</Link> <Link to="/fillion/assess">考核评分</Link>

6
web/client/src/sections/fillion/routes.js

@ -47,9 +47,9 @@ export default [{
}, },
{ {
path: '/building', path: '/processsing',
key: 'fillionbuilding', key: 'fillionprocesssing',
menuSelectKeys: ['fillionbuilding'], menuSelectKeys: ['fillionprocesssing'],
component: Building, component: Building,
breadcrumb: '在建项目', breadcrumb: '在建项目',
//authCode: 'ROADMANAGE' //authCode: 'ROADMANAGE'

12
web/client/src/sections/organization/actions/user.js

@ -14,6 +14,18 @@ export function getDepMessage() {
}); });
} }
export function getDepById(query) {
return dispatch => basicAction({
type: 'get',
dispatch: dispatch,
query,
actionType: 'GET_DEP_BY_ID',
url: ApiTable.getDepById,
msg: { error: '根据id获取部门失败失败' },
reducer: { name: 'depByIdInfo' }
});
}
export function getDepUser(depId) { export function getDepUser(depId) {
return dispatch => basicAction({ return dispatch => basicAction({
type: 'get', type: 'get',

35
web/client/src/sections/organization/containers/authority.js

@ -3,6 +3,8 @@ import { connect } from 'react-redux';
import { Spin, Row, Col, Card, Button, Tree, Empty, Checkbox } from 'antd'; import { Spin, Row, Col, Card, Button, Tree, Empty, Checkbox } from 'antd';
import { getDepMessage, getDepUser } from '../actions/user'; import { getDepMessage, getDepUser } from '../actions/user';
import { getResource, getUserResource, postUserRes, postUserReso } from '../actions/authority'; import { getResource, getUserResource, postUserRes, postUserReso } from '../actions/authority';
import { getDepById } from '../actions/user';
import Resource from '../components/resource'; import Resource from '../components/resource';
import user from './user'; import user from './user';
@ -43,6 +45,7 @@ const Authority = (props) => {
// setUseName('全部用户') // setUseName('全部用户')
// } // }
}; };
// console.log(userSelectedKeys,'当前1') // console.log(userSelectedKeys,'当前1')
const onresChange = (d) => { const onresChange = (d) => {
setResCode(d) setResCode(d)
@ -66,6 +69,8 @@ const Authority = (props) => {
const onshowchange = (e) => { const onshowchange = (e) => {
setisshow(e.target.checked) setisshow(e.target.checked)
} }
console.log('depMessagedata', depMessagedata)
useEffect(() => { useEffect(() => {
dispatch(getResource()) dispatch(getResource())
if (!(depMessage && depMessage.length)) { if (!(depMessage && depMessage.length)) {
@ -80,7 +85,7 @@ const Authority = (props) => {
setisshow(userResource.some(i => i.isshow === "true")) setisshow(userResource.some(i => i.isshow === "true"))
setrescheckAll(userResource.map(i => i.resourceId).length === 14) setrescheckAll(userResource.map(i => i.resourceId).length === 14)
}, [userResource]) }, [userResource])
useEffect(() => { useEffect(async () => {
if (depMessage.length) { if (depMessage.length) {
console.log('depMessage', depMessage) console.log('depMessage', depMessage)
//超级管理员展示所有部门 //超级管理员展示所有部门
@ -91,18 +96,15 @@ const Authority = (props) => {
setDepSelected([depMessage[0]?.name]) setDepSelected([depMessage[0]?.name])
} else { } else {
//不是超级管理员,展示相应部门的数据 //不是超级管理员,展示相应部门的数据
let authDep = [] dispatch(getDepUser(user.departmentId))
depMessage.map((item) => { const res = await dispatch(getDepById({ deptId: parseInt(user.departmentId) }))
if (item.id === user?.departmentId) { console.log('resssss', res)
authDep.push(item) setdepMessagedata(res.payload.data)
} // if (authDep.length > 0) {
}) // dispatch(getDepUser(authDep[0]?.id))
setdepMessagedata(authDep) // setDepSelectedKeys([authDep[0]?.id])
if (authDep.length > 0) { // setDepSelected([authDep[0]?.name])
dispatch(getDepUser(authDep[0]?.id)) // }
setDepSelectedKeys([authDep[0]?.id])
setDepSelected([authDep[0]?.name])
}
} }
@ -110,9 +112,14 @@ const Authority = (props) => {
}, [depMessage]) }, [depMessage])
// useEffect(() => {
// if(user.username!=='SuperAdmin'){
// dispatch(getDepMessage(user.departmentId))
// }
// }, [depMessage])
useEffect(() => { useEffect(() => {
const copy = depUser.filter((item) => { const copy = depUser.filter((item) => {
return item.name !== user.name//把自己筛选出去 return item.id !== user.id//把自己筛选出去
}) })
setDepUserCopy(copy) setDepUserCopy(copy)
if (copy.length) { if (copy.length) {

30
web/client/src/sections/organization/containers/user.js

@ -3,6 +3,7 @@ import { connect } from 'react-redux';
import { DeleteOutlined, EllipsisOutlined, FormOutlined } from '@ant-design/icons'; import { DeleteOutlined, EllipsisOutlined, FormOutlined } from '@ant-design/icons';
import { Spin, Space, Button, Popconfirm, Row, Col, Tree, Table, Card, Switch, Tooltip, Breadcrumb } from 'antd'; import { Spin, Space, Button, Popconfirm, Row, Col, Tree, Table, Card, Switch, Tooltip, Breadcrumb } from 'antd';
import ProTable from '@ant-design/pro-table'; import ProTable from '@ant-design/pro-table';
import { getDepById } from '../actions/user';
import { getDepMessage, getDepUser, createUser, updateUser, delUser, resetPwd, createDep, delDep, updateDep } from '../actions/user' import { getDepMessage, getDepUser, createUser, updateUser, delUser, resetPwd, createDep, delDep, updateDep } from '../actions/user'
import { postUserRes } from '../actions/authority' import { postUserRes } from '../actions/authority'
import UserModal from '../components/userModal'; import UserModal from '../components/userModal';
@ -28,7 +29,8 @@ const UserManage = (props) => {
const [uid, setuid] = useState() const [uid, setuid] = useState()
const [editAble, setEditAble] = useState(user?.username !== 'SuperAdmin' && user?.userResources?.filter(i => i.resourceId === 'USERMANAGE')[0].isshow === "true" ? true : '')//控制操作(新增删除等操作,对应权限的'不可编辑')是否可操作 const [editAble, setEditAble] = useState(user?.username !== 'SuperAdmin' && user?.userResources?.filter(i => i.resourceId === 'USERMANAGE')[0].isshow === "true" ? true : '')//控制操作(新增删除等操作,对应权限的'不可编辑')是否可操作
const [depMessagedata, setdepMessagedata] = useState(depMessage) const [depMessagedata, setdepMessagedata] = useState(depMessage)
useEffect(() => { console.log('depMessagedata', depMessagedata)
useEffect(async () => {
if (depMessage.length) { if (depMessage.length) {
console.log('depMessage', depMessage) console.log('depMessage', depMessage)
//超级管理员展示所有部门 //超级管理员展示所有部门
@ -38,18 +40,12 @@ const UserManage = (props) => {
dispatch(getDepUser(depMessage[0].id)) dispatch(getDepUser(depMessage[0].id))
} else { } else {
//不是超级管理员,展示相应部门的数据 //不是超级管理员,展示相应部门的数据
let authDep = [] dispatch(getDepUser(user.departmentId))
depMessage.map((item) => { const res = await dispatch(getDepById({ deptId: parseInt(user.departmentId) }))
if (item.id === user?.departmentId) { console.log('resssss', res)
authDep.push(item) setdepMessagedata(res.payload.data)
} // setDepSelectedKeys([res.payload.data[0].id])
}) // dispatch(getDepUser(res.payload.data[0].id))
setdepMessagedata(authDep)
if (authDep.length > 0) {
setDepSelectedKeys([authDep[0].id])
dispatch(getDepUser(authDep[0].id))
}
} }
} }
@ -68,13 +64,14 @@ const UserManage = (props) => {
}, [uid]) }, [uid])
useEffect(() => { useEffect(() => {
dispatch(getDepMessage()) dispatch(getDepMessage())
}, []) }, [])
useEffect(() => { useEffect(() => {
console.log('depuser', depUser) console.log('depuser', depUser, user)
const copy = depUser.filter((item) => { const copy = depUser.filter((item) => {
return item.name !== user.name//把自己筛选出去 console.log('item1', item)
return item.id !== user.id//把自己筛选出去
}) })
console.log('copy', copy)
setDepUserCopy(copy) setDepUserCopy(copy)
}, [depUser]) }, [depUser])
useEffect(() => { useEffect(() => {
@ -408,6 +405,7 @@ const UserManage = (props) => {
{ {
depMessage.length && modalVisible ? depMessage.length && modalVisible ?
<UserModal <UserModal
dispatch={dispatch}
visible={modalVisible} visible={modalVisible}
onVisibleChange={setModalVisible} onVisibleChange={setModalVisible}
modalType={modalType} modalType={modalType}

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

@ -118,6 +118,7 @@ export const ApiTable = {
getEnterprisesMembers: 'enterprises/{enterpriseId}/members', getEnterprisesMembers: 'enterprises/{enterpriseId}/members',
getDepById: 'departmentById',
//组织管理-用户管理-部门 //组织管理-用户管理-部门
getDepMessage: 'department', getDepMessage: 'department',
createDepMessage: 'department', createDepMessage: 'department',
@ -172,10 +173,10 @@ export const ApiTable = {
getAssess: 'assess', getAssess: 'assess',
editAssess: 'assess', editAssess: 'assess',
delAssess: 'assess/{assessId}', delAssess: 'assess/{assessId}',
nearestAssessData:'assess/nearest', nearestAssessData: 'assess/nearest',
// 视频中心 // 视频中心
videoCenterList:'videoCenter/list', videoCenterList: 'videoCenter/list',
//工程数据 //工程数据
getProject: 'project', getProject: 'project',
@ -297,7 +298,9 @@ export const ApiTable = {
//任务信息 //任务信息
getTask: 'task', delTask: 'task/{taskId}', editTask: 'task', getTask: 'task', delTask: 'task/{taskId}', editTask: 'task',
//部门下所有员工 //部门下所有员工
getAllDepUsers: 'allDepUsers' getAllDepUsers: 'allDepUsers',
//指派任务
appointTask: 'appointTask'
}; };

Loading…
Cancel
Save