ww664853070 2 years ago
parent
commit
c01d09697e
  1. 2
      api/app/lib/controllers/report/index.js
  2. 6
      api/app/lib/routes/data/index.js
  3. 2
      api/sequelize-automate.config.js
  4. 7
      scripts/1.2.3/schema/5.alter_resource.sql
  5. 2
      web/client/src/layout/index.js
  6. 6
      web/client/src/sections/auth/containers/login.js
  7. 6
      web/client/src/sections/fillion/components/buildingTable.js
  8. 2
      web/client/src/sections/fillion/components/datajuji.js
  9. 2
      web/client/src/sections/fillion/components/editGuanlang.js
  10. 40
      web/client/src/sections/fillion/components/feedback/nominateModal.js
  11. 2
      web/client/src/sections/fillion/components/highwaysTable.js
  12. 10
      web/client/src/sections/fillion/components/maintenanceTable.js
  13. 2
      web/client/src/sections/fillion/components/operationalTable.js
  14. 29
      web/client/src/sections/fillion/components/patrolTable.js
  15. 2
      web/client/src/sections/fillion/components/project/project.js
  16. 4
      web/client/src/sections/fillion/components/transportationTable.js
  17. 8
      web/client/src/sections/fillion/containers/assess.js
  18. 2
      web/client/src/sections/fillion/containers/building.js
  19. 2
      web/client/src/sections/fillion/containers/highways.js
  20. 2
      web/client/src/sections/fillion/containers/task.js
  21. 2
      web/client/src/sections/fillion/containers/transportation.js
  22. 47
      web/client/src/sections/fillion/nav-item.js
  23. 5
      web/client/src/sections/fillion/routes.js
  24. 13
      web/client/src/sections/organization/containers/authority.js
  25. 29
      web/client/src/sections/organization/containers/user.js
  26. 6
      web/client/src/sections/organization/nav-item.js

2
api/app/lib/controllers/report/index.js

@ -43,7 +43,7 @@ async function reportList (ctx) {
where: { where: {
}, },
attributes: ['id', 'road', 'time', 'projectType', 'roadSectionStart', 'roadSectionEnd', 'reportType', 'content', 'longitude', 'latitude', 'projectName', 'handleState'], attributes: ['id', 'road', 'time', 'projectType', 'roadSectionStart', 'performerId', 'roadSectionEnd', 'reportType', 'content', 'longitude', 'latitude', 'projectName', 'handleState'],
include: [{ include: [{
model: models.User, model: models.User,
attributes: ['name'] attributes: ['name']

6
api/app/lib/routes/data/index.js

@ -11,7 +11,7 @@ const dataIndex = require('../../controllers/data/index');
const task = require('../../controllers/data/task') const task = require('../../controllers/data/task')
const assess = require('../../controllers/data/assess') const assess = require('../../controllers/data/assess')
const videoCenter = require('../../controllers/data/videoCenter') const videoCenter = require('../../controllers/data/videoCenter')
const appointTask = require('../../controllers/data/appointed')
module.exports = function (app, router, opts) { module.exports = function (app, router, opts) {
// 数据导出 // 数据导出
@ -202,4 +202,8 @@ module.exports = function (app, router, opts) {
app.fs.api.logAttr['GET/videoCenter/list'] = { content: '获取萤石设备列表', visible: true }; app.fs.api.logAttr['GET/videoCenter/list'] = { content: '获取萤石设备列表', visible: true };
router.get('/videoCenter/list', videoCenter.videoList(opts)); router.get('/videoCenter/list', videoCenter.videoList(opts));
// 视频中心 END // 视频中心 END
// 指派任务
app.fs.api.logAttr['PUT/appointTask'] = { content: '指派任务', visible: true };
router.put('/appointTask', appointTask.appoint);
// 指派任务 END
}; };

2
api/sequelize-automate.config.js

@ -27,7 +27,7 @@ module.exports = {
dir: './app/lib/models', // 指定输出 models 文件的目录 dir: './app/lib/models', // 指定输出 models 文件的目录
typesDir: 'models', // 指定输出 TypeScript 类型定义的文件目录,只有 TypeScript / Midway 等会有类型定义 typesDir: 'models', // 指定输出 TypeScript 类型定义的文件目录,只有 TypeScript / Midway 等会有类型定义
emptyDir: false, // !!! 谨慎操作 生成 models 之前是否清空 `dir` 以及 `typesDir` emptyDir: false, // !!! 谨慎操作 生成 models 之前是否清空 `dir` 以及 `typesDir`
tables: ['assess'], // 指定生成哪些表的 models,如 ['user', 'user_post'];如果为 null,则忽略改属性 tables: ['user_resource'], // 指定生成哪些表的 models,如 ['user', 'user_post'];如果为 null,则忽略改属性
skipTables: [], // 指定跳过哪些表的 models,如 ['user'];如果为 null,则忽略改属性 skipTables: [], // 指定跳过哪些表的 models,如 ['user'];如果为 null,则忽略改属性
tsNoCheck: false, // 是否添加 `@ts-nocheck` 注释到 models 文件中 tsNoCheck: false, // 是否添加 `@ts-nocheck` 注释到 models 文件中
ignorePrefix: [], // 生成的模型名称忽略的前缀,因为 项目中有以下表名是以 t_ 开头的,在实际模型中不需要, 可以添加多个 [ 't_data_', 't_',] ,长度较长的 前缀放前面 ignorePrefix: [], // 生成的模型名称忽略的前缀,因为 项目中有以下表名是以 t_ 开头的,在实际模型中不需要, 可以添加多个 [ 't_data_', 't_',] ,长度较长的 前缀放前面

7
scripts/1.2.3/schema/5.alter_resource.sql

@ -0,0 +1,7 @@
INSERT INTO resource (code, name, parent_resource) VALUES ('VIDEOCENTER', '视频中心', 'ALLSELECT')
INSERT INTO resource (code, name, parent_resource) VALUES ('ASSESSMANAGE', '考核评分', 'ALLSELECT')
INSERT INTO resource (code, name, parent_resource) VALUES ('BUILDINGPROJECT', '在建项目', 'ALLSELECT')
INSERT INTO resource (code, name, parent_resource) VALUES ('WXTODOLIST', '小程序待办事项', 'ALLSELECT')

2
web/client/src/layout/index.js

@ -61,7 +61,7 @@ const Root = props => {
flat(routes); flat(routes);
//将路由信息全部放在session,方便后面拿了用(权限控制的时候) //将路由信息全部放在session,方便后面拿了用(权限控制的时候)
console.log('combineRoutes1', combineRoutes) //console.log('combineRoutes1', combineRoutes)
sessionStorage.setItem('allRoutes', JSON.stringify(combineRoutes)); sessionStorage.setItem('allRoutes', JSON.stringify(combineRoutes));
return combineRoutes; return combineRoutes;
} }

6
web/client/src/sections/auth/containers/login.js

@ -35,7 +35,7 @@ const Login = props => {
} }
else if (hasAuth && hasAuth.length > 0) { else if (hasAuth && hasAuth.length > 0) {
const path = hasAuth[0].path const path = hasAuth[0].path
console.log('sasa', `${path}`) //console.log('sasa', `${path}`)
dispatch(push(path)) dispatch(push(path))
} else { } else {
dispatch(push('/noContent')) dispatch(push('/noContent'))
@ -86,7 +86,7 @@ const Login = props => {
value={username} value={username}
maxlength={11} maxlength={11}
onChange={e => { onChange={e => {
console.log('e.target.value', e.target.value) //('e.target.value', e.target.value)
setUserName(e.target.value) setUserName(e.target.value)
setInputChanged(true) setInputChanged(true)
}} }}
@ -100,7 +100,7 @@ const Login = props => {
value={password} value={password}
onChange={e => { onChange={e => {
console.log('setPassword', e.target.value) //console.log('setPassword', e.target.value)
setPassword(e.target.value) setPassword(e.target.value)
setInputChanged(true) setInputChanged(true)
}} }}

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

@ -25,8 +25,8 @@ const BuildingTable = (props) => {
const [differentiate, setDifferentiate] = useState('road') const [differentiate, setDifferentiate] = useState('road')
const [grade, setGrade] = useState('project') const [grade, setGrade] = useState('project')
const [departmentInfo, setDepartment] = useState('') const [departmentInfo, setDepartment] = useState('')
const [editAble, setEditAble] = useState(user?.username !== 'SuperAdmin' && user?.userResources?.filter(i => i.resourceId === 'ROADMANAGE')[0].isshow === "true" ? true : '') const [editAble, setEditAble] = useState(user?.username !== 'SuperAdmin' && user?.userResources?.find(i => i.resourceId === 'BUILDINGPROJECT')?.isshow === "true" ? true : '')
console.log('user111', user)
const ref = useRef() const ref = useRef()
const [activeKey, setActiveKey] = useState('tab1'); const [activeKey, setActiveKey] = useState('tab1');
//打开弹窗 //打开弹窗
@ -309,7 +309,7 @@ const BuildingTable = (props) => {
columns={columns[activeKey]} columns={columns[activeKey]}
dataSource={counts || []} dataSource={counts || []}
request={async (params) => { request={async (params) => {
console.log(whichofits) //console.log(whichofits)
if (whichofits == '在建项目') { if (whichofits == '在建项目') {
const query = { const query = {
entryName: sitename entryName: sitename

2
web/client/src/sections/fillion/components/datajuji.js

@ -60,7 +60,7 @@ const EditGuanlang = (props) => {
const handleSave = () => { const handleSave = () => {
const data = form.getFieldsValue(true); const data = form.getFieldsValue(true);
console.log(data, 'data') //console.log(data, 'data')
handleSaveScore(); handleSaveScore();
} }

2
web/client/src/sections/fillion/components/editGuanlang.js

@ -60,7 +60,7 @@ const EditGuanlang = (props) => {
const handleSave = () => { const handleSave = () => {
const data = form.getFieldsValue(true); const data = form.getFieldsValue(true);
console.log(data,'data') //console.log(data,'data')
handleSaveScore(); handleSaveScore();
} }

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

@ -2,40 +2,49 @@
import React, { useState, useEffect, useCallback, useRef } from 'react'; import React, { useState, useEffect, useCallback, useRef } from 'react';
import { connect } from 'react-redux'; import { connect } from 'react-redux';
import { Spin } from 'antd'; import { Spin } from 'antd';
import ProForm, { ProFormText, ModalForm, ProFormSwitch, ProFormTreeSelect, ProFormSelect } from '@ant-design/pro-form'; import ProForm, { ProFormText, ModalForm, ProFormSwitch, ProFormTreeSelect, ProFormSelect, Form } from '@ant-design/pro-form';
import { getDepUser } from '../../../organization/actions/user' import { getDepUser } from '../../../organization/actions/user'
import { appointTask } from '../../actions/appointTask' import { appointTask } from '../../actions/appointTask'
import { getReportList, } from '../../../fillion/actions/patrol';
import moment from 'moment'; import moment from 'moment';
import { v4 as uuidv4 } from 'uuid';
const NominateModal = (props) => { const NominateModal = (props) => {
const { recordId, visible, user, onCancel, depMessage, loading, depUser, clientHeight, depData, onVisibleChange, dispatch } = props const { queryData, recordId, visible, user, onCancel, depMessage, loading, depUser, clientHeight, depData, onVisibleChange, dispatch } = props
const [depId, setDepId] = useState(null) const [depId, setDepId] = useState(null)
const [depUsers, setDepUsers] = useState() const [depUsers, setDepUsers] = useState()
const selectRef = useRef(null); const selectRef = useRef(null);
const formRef = useRef();
const [selectKey, setSelectKey] = useState(0);
const handleTreeSelectChange = async (value) => { const handleTreeSelectChange = async (value) => {
console.log('recordId', recordId) //console.log('recordId', recordId)
setDepId(value) setDepId(value)
// 根据选择的部门ID获取对应的用户数据 // 根据选择的部门ID获取对应的用户数据
setDepUsers(null) setDepUsers(null)
const res = await dispatch(getDepUser(value)); const res = await dispatch(getDepUser(value));
setDepUsers(res?.payload.data); setDepUsers(res?.payload.data);
//setSelectKey(selectKey + 1)
// 清空第二个输入框的值 // 清空第二个输入框的值
if (selectRef.current) { if (selectRef.current) {
selectRef.current.value = ''; selectRef.current.reset();
} }
} }
useEffect(() => {
setSelectKey(selectKey + 1)
}, [depUsers])
const handleFinish = async (values) => { const handleFinish = async (values) => {
const { name } = values; const { name } = values;
// 在这里使用第二个框的值进行网络请求或其他操作 // 在这里使用第二个框的值进行网络请求或其他操作
await dispatch(appointTask({ recordId, performerId: name }))
//form.resetFields(); // 重置表单字段
//formRef.current.resetFields();
queryData()
onCancel()
// await dispatch(yourAction(name));
// 其他操作...
// 取消弹窗
onCancel();
}; };
const dispatchGetDepUser = useCallback(async () => { const dispatchGetDepUser = useCallback(async () => {
if (depId) { if (depId) {
@ -51,15 +60,17 @@ const NominateModal = (props) => {
return ( return (
<Spin spinning={false}> <Spin spinning={false}>
<ModalForm <ModalForm
ref={formRef}
title='指派' title='指派'
visible={visible} visible={visible}
onVisibleChange={onVisibleChange} onVisibleChange={onVisibleChange}
onFinish={handleFinish} onFinish={handleFinish}
destroyOnClose destroyOnClose={true}
initialValues={{ departmentId: null, name: null }}
> >
<ProForm.Group> <ProForm.Group>
<ProFormTreeSelect <ProFormTreeSelect
name={['contract', 'departmentId']} name={'departmentId'}
placeholder="请选择所属部门" placeholder="请选择所属部门"
width="md" width="md"
label="所属部门" label="所属部门"
@ -70,7 +81,7 @@ const NominateModal = (props) => {
children: 'subordinate' children: 'subordinate'
}} }}
onSelect={(selectedKeys, { selected, selectedNodes }) => { onSelect={(selectedKeys, { selected, selectedNodes }) => {
console.log('selected', selectedKeys) //console.log('selected', selectedKeys)
if (selected) { if (selected) {
setDepSelectedKeys(selectedKeys) setDepSelectedKeys(selectedKeys)
@ -92,11 +103,12 @@ const NominateModal = (props) => {
}} }}
expandedKeys={["title"]} expandedKeys={["title"]}
/> />
{depUsers ? <ProFormSelect {depUsers && depUsers.length ? <ProFormSelect
key={selectKey} // 改变 key 值
ref={selectRef} ref={selectRef}
value={null} // 设置输入框的值为null value={null} // 设置输入框的值为null
onValuesChange={(values) => { console.log('values1', values) }} //onValuesChange={(values) => { console.log('values1', values) }}
name="name" name={'name'}
label="指派人" label="指派人"
request={async () => { request={async () => {
if (depId) { if (depId) {

2
web/client/src/sections/fillion/components/highwaysTable.js

@ -310,7 +310,7 @@ const TransporTationTable = (props) => {
columns={columns[activeKey]} columns={columns[activeKey]}
dataSource={counts || []} dataSource={counts || []}
request={async (params) => { request={async (params) => {
console.log(whichofits) //console.log(whichofits)
if (whichofits == 'sheshi') { if (whichofits == 'sheshi') {
const query = { const query = {
} }

10
web/client/src/sections/fillion/components/maintenanceTable.js

@ -158,7 +158,7 @@ const DetailList = (props) => {
align: 'center' align: 'center'
}, },
{ {
title: '养护人', title: '上报人',
width: 100, width: 100,
key: 'userName', key: 'userName',
dataIndex: 'userName', dataIndex: 'userName',
@ -235,7 +235,7 @@ const PatrolNameList = (props) => {
const [autoExpandParent, setAutoExpandParent] = useState(true); const [autoExpandParent, setAutoExpandParent] = useState(true);
const [defaultData, setDefaultData] = useState([]); const [defaultData, setDefaultData] = useState([]);
const [dataList, setDataList] = useState([]); const [dataList, setDataList] = useState([]);
console.log('record', record) //console.log('record', record)
useEffect(() => { useEffect(() => {
let departments = [] let departments = []
const generateData = (data, _preKey, _tns) => { const generateData = (data, _preKey, _tns) => {
@ -419,12 +419,12 @@ const PatrolNameList = (props) => {
if (selected) { if (selected) {
if (selectedKeys[0].split("-").length - 1 >= 2) { if (selectedKeys[0].split("-").length - 1 >= 2) {
let id = selectedKeys[0].split('-')[selectedKeys[0].split('-').length - 1] let id = selectedKeys[0].split('-')[selectedKeys[0].split('-').length - 1]
console.log('id', id) //console.log('id', id)
onChange(id); onChange(id);
} }
} }
console.log('selectedKeys', selectedKeys, selected, selectedNodes, node) //('selectedKeys', selectedKeys, selected, selectedNodes, node)
}; };
@ -435,7 +435,7 @@ const PatrolNameList = (props) => {
return ( return (
<div className='spilce' style={{ height: '600px', width: '100%', overflow: 'auto' }} > <div className='spilce' style={{ height: '600px', width: '100%', overflow: 'auto' }} >
<Search <Search
placeholder="请输入养护人名称" placeholder="请输入养上报人"
value={searchValue} value={searchValue}
onChange={(e) => handleSearch(e.target.value)} onChange={(e) => handleSearch(e.target.value)}
/> />

2
web/client/src/sections/fillion/components/operationalTable.js

@ -1983,7 +1983,7 @@ const OperaTionalTable = (props) => {
dataSource={counts || []} dataSource={counts || []}
request={async (params, sort, filter) => { request={async (params, sort, filter) => {
console.log(rewkeys) // console.log(rewkeys)
if (rewkeys == 'keyun') { if (rewkeys == 'keyun') {
const query = {} const query = {}
setRowSelected([]); setRowSelected([]);

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

@ -35,7 +35,7 @@ export const reportTypeText = (text) => {
const DetailForm = (props) => { const DetailForm = (props) => {
const { visible, data, handleClose, loading, isAnomaly, isRoad, isPatrol } = props; const { visible, data, handleClose, loading, isAnomaly, isRoad, isPatrol } = props;
//('record12s', isAnomaly)
const [qndmn] = useState(localStorage.getItem('qndmn')); const [qndmn] = useState(localStorage.getItem('qndmn'));
const keyList = [ const keyList = [
@ -121,6 +121,7 @@ const DetailList = (props) => {
const [noProcessingSelectRecord, setNoProcessingSelectRecord] = useState(); const [noProcessingSelectRecord, setNoProcessingSelectRecord] = useState();
const [vis, setVis] = useState(false)//指派任务的弹窗显示与隐藏 const [vis, setVis] = useState(false)//指派任务的弹窗显示与隐藏
const [recordId, setRecordId] = useState(0)//默认指派任务id const [recordId, setRecordId] = useState(0)//默认指派任务id
const [btnVis, setBtnVis] = useState(true)//指派按钮和不处理按钮的是否禁用
const checkDetail = (record) => { const checkDetail = (record) => {
dispatch(getReportDetail(record.id)) dispatch(getReportDetail(record.id))
} }
@ -224,7 +225,7 @@ const DetailList = (props) => {
align: 'center' align: 'center'
}, },
{ {
title: isRoad ? '上报人' : '巡查人', title: '上报人',
width: 100, width: 100,
key: 'userName', key: 'userName',
dataIndex: 'userName', dataIndex: 'userName',
@ -245,15 +246,18 @@ const DetailList = (props) => {
valueType: 'option', valueType: 'option',
align: 'center', align: 'center',
render: (text, record) => { render: (text, record) => {
//('record12s', record)
return [ return [
<Button <Button
onClick={() => { checkDetail(record); handleOpen(); }} onClick={() => { checkDetail(record); handleOpen(); }}
style={{ marginRight: 10 }}>查看</Button>, style={{ marginRight: 10 }}>查看</Button>,
isAnomaly && record.handleState != '已处理' ? isAnomaly && record.handleState != '已处理' && record.performerId === null ?
<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, <Button disabled={user?.username !== 'SuperAdmin' && user?.userResources?.filter(i => i.resourceId === 'FEEDBACKMANAGE' || 'FEEDBACKMANAGE')[0].isshow === "true" ? true : ''}
isAnomaly && record.handleState != '已处理' ? onClick={() => { setVis(true); setRecordId(record.id) }}>指派</Button> : null,
isAnomaly && record.handleState != '已处理' && record.performerId === null ?
< Popover < Popover
content={[ content={
[
<div style={{ width: '100%', height: 30 }}> <div style={{ width: '100%', height: 30 }}>
<Button onClick={() => setNoProcessingPopVisible(false)} style={{ float: "right" }} ></Button> <Button onClick={() => setNoProcessingPopVisible(false)} style={{ float: "right" }} ></Button>
<Button type="primary" onClick={() => dispatch(handleReport(record.id, { handleState: '已处理' })).then(res => { <Button type="primary" onClick={() => dispatch(handleReport(record.id, { handleState: '已处理' })).then(res => {
@ -307,7 +311,7 @@ const DetailList = (props) => {
toolBarRender={false} toolBarRender={false}
search={false} search={false}
/> />
<NominateModal recordId={recordId} dispatch={dispatch} visible={vis} onCancel={onCancel} onVisibleChange={setVis}></NominateModal> <NominateModal queryData={queryData} hanldeChange={setBtnVis} recordId={recordId} dispatch={dispatch} visible={vis} onCancel={onCancel} onVisibleChange={setVis}></NominateModal>
</div> </div>
) )
}; };
@ -500,7 +504,7 @@ const PatrolNameList = (props) => {
} }
} }
console.log('selectedKeys', selectedKeys, selected, selectedNodes, node) // console.log('selectedKeys', selectedKeys, selected, selectedNodes, node)
}; };
@ -528,7 +532,7 @@ const PatrolNameList = (props) => {
<div className='spilce'> <div className='spilce'>
<div className='spilce' style={{ height: '600px', width: '100%', overflow: 'auto' }} > <div className='spilce' style={{ height: '600px', width: '100%', overflow: 'auto' }} >
<Search <Search
placeholder="请输入巡查人名称" placeholder="请输入上报人员"
value={searchValue} value={searchValue}
onChange={(e) => handleSearch(e.target.value)} onChange={(e) => handleSearch(e.target.value)}
/> />
@ -612,7 +616,7 @@ const PatrolTable = (props) => {
}, [record, dateRange, selectProjectType]) }, [record, dateRange, selectProjectType])
const queryData = () => { const queryData = () => {
console.log(record, 'idididid') //console.log(record, 'idididid')
let userId = null let userId = null
if (user?.username === 'SuperAdmin' && record === 1) { if (user?.username === 'SuperAdmin' && record === 1) {
userId = undefined userId = undefined
@ -628,7 +632,7 @@ const PatrolTable = (props) => {
userId, userId,
reportType: reportType, projectType: selectProjectType, asc: true reportType: reportType, projectType: selectProjectType, asc: true
} }
console.log(query, 'query1') //console.log(query, 'query1')
if ((dateRange && dateRange instanceof Array && dateRange[0] != '')) { if ((dateRange && dateRange instanceof Array && dateRange[0] != '')) {
query.startTime = moment(dateRange[0]).startOf('day').format('YYYY-MM-DD HH:mm:ss') query.startTime = moment(dateRange[0]).startOf('day').format('YYYY-MM-DD HH:mm:ss')
query.endTime = moment(dateRange[1]).endOf('day').format('YYYY-MM-DD HH:mm:ss') query.endTime = moment(dateRange[1]).endOf('day').format('YYYY-MM-DD HH:mm:ss')
@ -708,7 +712,8 @@ const PatrolTable = (props) => {
record={record} record={record}
activeTabKey1={activeTabKey1} activeTabKey1={activeTabKey1}
userList={userList} userList={userList}
loading={userLoading} /> loading={userLoading}
/>
</Card> </Card>
<Card <Card
style={{ flex: 1 }} style={{ flex: 1 }}

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

@ -19,7 +19,7 @@ const data = {
} }
const ProjectModal = (props) => { const ProjectModal = (props) => {
const { visible, onVisibleChange, typecard, rewkeys, recortd, dispatch, setRecortd, setDelet, getData } = props const { visible, onVisibleChange, typecard, rewkeys, recortd, dispatch, setRecortd, setDelet, getData } = props
console.log('typecard', newlysay) //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()//处理

4
web/client/src/sections/fillion/components/transportationTable.js

@ -44,7 +44,7 @@ const TransporTationTable = (props) => {
}) })
setDepartment(departmentInfo) setDepartment(departmentInfo)
}, [user, depMessage]) }, [user, depMessage])
console.log('sad', departmentInfo) //console.log('sad', departmentInfo)
// useEffect(() => { // useEffect(() => {
// console.log('11111', depMessage) // console.log('11111', depMessage)
// }, [depMessage]) // }, [depMessage])
@ -3809,7 +3809,7 @@ const TransporTationTable = (props) => {
columns={columns[activeKey]} columns={columns[activeKey]}
dataSource={counts || []} dataSource={counts || []}
request={async (params) => { request={async (params) => {
console.log(whichofits) //console.log(whichofits)
if (whichofits == '县') { if (whichofits == '县') {
console.log('differentiate', '我我我我吧') console.log('differentiate', '我我我我吧')

8
web/client/src/sections/fillion/containers/assess.js

@ -33,7 +33,7 @@ function Assess (props) {
const [query, setQuery] = useState({ page: 1, pageSize: 10 }) const [query, setQuery] = useState({ page: 1, pageSize: 10 })
const [loading, setLoading] = useState(false); const [loading, setLoading] = useState(false);
const [isCheck, setIsCheck] = useState(false) const [isCheck, setIsCheck] = useState(false)
const [editAble, setEditAble] = useState(user?.username !== 'SuperAdmin' && user?.userResources?.find(i => i.resourceId === 'ASSESSMANAGE')?.isshow === "true" ? true : '')
useEffect(() => { useEffect(() => {
return () => { }; return () => { };
}, []); }, []);
@ -74,7 +74,8 @@ function Assess (props) {
</Form.Item> </Form.Item>
</Form> </Form>
<Button type="primary" onClick={() => { <Button type="primary" disabled={editAble}
onClick={() => {
setAssessModalVisible(true) setAssessModalVisible(true)
}}>新增</Button> }}>新增</Button>
</div> </div>
@ -110,6 +111,7 @@ function Assess (props) {
<Button type="link" onClick={() => { <Button type="link" onClick={() => {
setAssessModalVisible(true) setAssessModalVisible(true)
setEditData(record) setEditData(record)
disabled = { editAble }
}}>编辑</Button> }}>编辑</Button>
<Popconfirm <Popconfirm
title="确定删除此条数据吗?" title="确定删除此条数据吗?"
@ -123,7 +125,7 @@ function Assess (props) {
}) })
}} }}
> >
<Button type="link" danger>删除</Button> <Button type="link" danger disabled={editAble}>删除</Button>
</Popconfirm> </Popconfirm>
</span> </span>
), ),

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

@ -12,7 +12,7 @@ const building = (props) => {
setData(props) setData(props)
}, []); }, []);
const exports = (ids, differentiate) => { const exports = (ids, differentiate) => {
console.log('sssss1', ids, differentiate) //console.log('sssss1', ids, differentiate)
let idas = ids.toString() let idas = ids.toString()
if (differentiate == 'bridge') { if (differentiate == 'bridge') {
window.open( window.open(

2
web/client/src/sections/fillion/containers/highways.js

@ -13,7 +13,7 @@ const highways = (props) => {
setData(props) setData(props)
}, []); }, []);
const exports = (ids, counts) => { const exports = (ids, counts) => {
console.log(counts); //console.log(counts);
let idas = ids.toString() let idas = ids.toString()
window.open( window.open(
'/_api/' + `data/export/?ids=${idas || ''}&exp=${'overspeed'}&token=${user.token}`) '/_api/' + `data/export/?ids=${idas || ''}&exp=${'overspeed'}&token=${user.token}`)

2
web/client/src/sections/fillion/containers/task.js

@ -38,7 +38,7 @@ const Task = (props) => {
} }
//选择安全是否消除 //选择安全是否消除
const changeSelect = async (value) => { const changeSelect = async (value) => {
console.log('value', value) //console.log('value', value)
const task1 = await dispatch(getTask({ id: inputVal, isdanger: value === 'all' ? undefined : value === 'y' ? true : false })) const task1 = await dispatch(getTask({ id: inputVal, isdanger: value === 'all' ? undefined : value === 'y' ? true : false }))
setTaskRes(task1.payload?.data) setTaskRes(task1.payload?.data)
setSelectVal(value) setSelectVal(value)

2
web/client/src/sections/fillion/containers/transportation.js

@ -14,7 +14,7 @@ const transportation = (props) => {
}, []); }, []);
//批量导出 //批量导出
const exports = (ids, grade, differentiate) => { const exports = (ids, grade, differentiate) => {
console.log(differentiate); //console.log(differentiate);
let idas = ids.toString() let idas = ids.toString()
if (differentiate == 'road') { if (differentiate == 'road') {
window.open( window.open(

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

@ -5,7 +5,7 @@ import { ReadOutlined } from '@ant-design/icons';
const SubMenu = Menu.SubMenu; const SubMenu = Menu.SubMenu;
export function getNavItem(user, dispatch) { export function getNavItem(user, dispatch) {
const isshow = user?.userResources?. const isshow = user?.userResources?.
filter(i => i.resourceId === 'OVERLOADMANAGE' || some(i => i.resourceId === 'OVERLOADMANAGE' ||
i.resourceId === 'ROADMANAGE' || i.resourceId === 'ROADMANAGE' ||
i.resourceId === 'BRIDGEMANAGE' || i.resourceId === 'BRIDGEMANAGE' ||
i.resourceId === 'MAINTENANCEMANAGE' || i.resourceId === 'MAINTENANCEMANAGE' ||
@ -16,66 +16,67 @@ export function getNavItem(user, dispatch) {
i.resourceId === 'PUBLICITYVIDEO' || i.resourceId === 'PUBLICITYVIDEO' ||
i.resourceId === 'FEEDBACKMANAGE' || i.resourceId === 'FEEDBACKMANAGE' ||
i.resourceId === 'REPORTMANAGE' || i.resourceId === 'REPORTMANAGE' ||
i.resourceId === 'PATROLMANAGE')?.length !== 0 i.resourceId === 'PATROLMANAGE' ||
i.resourceId === 'ASSESSMANAGE' ||
i.resourceId === 'VIDEOCENTER' ||
i.resourceId === 'BUILDINGPROJECT'
)
return ( return (
user?.username == 'SuperAdmin' || isshow ? user?.username == 'SuperAdmin' || isshow ?
<SubMenu key="fillion" icon={<ReadOutlined />} title={'数据管理'}> <SubMenu key="fillion" icon={<ReadOutlined />} title={'数据管理'}>
{user?.username == 'SuperAdmin' || user?.userResources?.filter(i => i.resourceId === 'OVERLOADMANAGE')?.length !== 0 ? {user?.username == 'SuperAdmin' || user?.userResources?.some(i => i.resourceId === 'OVERLOADMANAGE') ?
<Menu.Item key="fillioninfor"> <Menu.Item key="fillioninfor">
<Link to="/fillion/infor">治超管理</Link> <Link to="/fillion/infor">治超管理</Link>
</Menu.Item> : ''} </Menu.Item> : ''}
{/* <Menu.Item key="filliontask"> {/* <Menu.Item key="filliontask">
<Link to="/fillion/task">任务管理</Link> <Link to="/fillion/task">任务管理</Link>
</Menu.Item> */} </Menu.Item> */}
{user?.username == 'SuperAdmin' || user?.userResources?.filter(i => i.resourceId === 'ROADMANAGE')?.length !== 0 ? {user?.username == 'SuperAdmin' || user?.userResources?.some(i => i.resourceId === 'ROADMANAGE') ?
<Menu.Item key="filliontransportation"> <Menu.Item key="filliontransportation">
<Link to="/fillion/transportation">道路管理</Link> <Link to="/fillion/transportation">道路管理</Link>
</Menu.Item> : ''} </Menu.Item> : ''}
{user?.username == 'SuperAdmin' || user?.userResources?.filter(i => i.resourceId === 'BRIDGEMANAGE')?.length !== 0 ? {user?.username == 'SuperAdmin' || user?.userResources?.some(i => i.resourceId === 'BRIDGEMANAGE') ?
<Menu.Item key="fillionbridge"> <Menu.Item key="fillionbridge">
<Link to="/fillion/bridge">桥梁管理</Link> <Link to="/fillion/bridge">桥梁管理</Link>
</Menu.Item> : ''} </Menu.Item> : ''}
{user?.username == 'SuperAdmin' || user?.userResources?.filter(i => i.resourceId === 'MAINTENANCEMANAGE')?.length !== 0 ? {user?.username == 'SuperAdmin' || user?.userResources?.some(i => i.resourceId === 'MAINTENANCEMANAGE') ?
<Menu.Item key="fillionhighways"> <Menu.Item key="fillionhighways">
<Link to="/fillion/highways">管养管理</Link> <Link to="/fillion/highways">管养管理</Link>
</Menu.Item> : ''} </Menu.Item> : ''}
{user?.username == 'SuperAdmin' || user?.userResources?.filter(i => i.resourceId === 'TRANSPORTATIONMANAGE')?.length !== 0 ? {user?.username == 'SuperAdmin' || user?.userResources?.some(i => i.resourceId === 'TRANSPORTATIONMANAGE') ?
<Menu.Item key="fillionoperational"> <Menu.Item key="fillionoperational">
<Link to="/fillion/operational">运政管理</Link> <Link to="/fillion/operational">运政管理</Link>
</Menu.Item> : ''} </Menu.Item> : ''}
{/* <Menu.Item key="fillionenforce"> {/* <Menu.Item key="fillionenforce">
<Link to="/fillion/enforce">执法管理</Link> <Link to="/fillion/enforce">执法管理</Link>
</Menu.Item> */} </Menu.Item> */}
{user?.username == 'SuperAdmin' || user?.userResources?.filter(i => i.resourceId === 'CONSERVATIONMANAGE')?.length !== 0 ? {user?.username == 'SuperAdmin' || user?.userResources?.some(i => i.resourceId === 'CONSERVATIONMANAGE') ?
<Menu.Item key="fillionmaintenance"> <Menu.Item key="fillionmaintenance">
<Link to="/fillion/maintenance">养护管理</Link> <Link to="/fillion/maintenance">养护管理</Link>
</Menu.Item> : ''} </Menu.Item> : ''}
{user?.username == 'SuperAdmin' || user?.userResources?.filter(i => i.resourceId === 'PATROLMANAGE')?.length !== 0 ? {user?.username == 'SuperAdmin' || user?.userResources?.some(i => i.resourceId === 'PATROLMANAGE') ?
<Menu.Item key="fillionpatrol"> <Menu.Item key="fillionpatrol">
<Link to="/fillion/patrol">巡查管理</Link> <Link to="/fillion/patrol">巡查管理</Link>
</Menu.Item> : ''} </Menu.Item> : ''}
{user?.username == 'SuperAdmin' || user?.userResources?.filter(i => i.resourceId === 'FEEDBACKMANAGE')?.length !== 0 ? {user?.username == 'SuperAdmin' || user?.userResources?.some(i => i.resourceId === 'FEEDBACKMANAGE') ?
<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 ? {user?.username == 'SuperAdmin' || user?.userResources?.some(i => i.resourceId === 'REPORTMANAGE') ?
<Menu.Item key="fillionpatrolroad"> <Menu.Item key="fillionpatrolroad">
<Link to="/fillion/patrol_road">建设上报</Link> <Link to="/fillion/patrol_road">建设上报</Link>
</Menu.Item> : ''} </Menu.Item> : ''}
{user?.username == 'SuperAdmin' || user?.userResources?.filter(i => i.resourceId === 'BUILDINGPROJECT') ?
{/* {user?.username == 'SuperAdmin' || user?.userResources?.filter(i => i.resourceId === 'FEEDBACKMANAGE')?.length !== 0 ?
: ''} */}
<Menu.Item key="fillionbuilding"> <Menu.Item key="fillionbuilding">
<Link to="/fillion/processsing">在建项目</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?.some(i => i.resourceId === 'PUBLICTRANSPORTMANAGE') ?
<Menu.Item key="fillionpublic"> <Menu.Item key="fillionpublic">
<Link to="/fillion/public">公交管理</Link> <Link to="/fillion/public">公交管理</Link>
</Menu.Item> : ''} </Menu.Item> : ''}
{user?.username == 'SuperAdmin' || user?.userResources?.filter(i => i.resourceId === 'FILEMANAGE')?.length !== 0 ? {user?.username == 'SuperAdmin' || user?.userResources?.some(i => i.resourceId === 'FILEMANAGE') ?
<Menu.Item key="fileCont"> <Menu.Item key="fileCont">
<Link to="/fillion/file">档案管理</Link> <Link to="/fillion/file">档案管理</Link>
</Menu.Item> : ''} </Menu.Item> : ''}
@ -85,19 +86,19 @@ export function getNavItem(user, dispatch) {
{/* <Menu.Item key="jiekouguanli"> {/* <Menu.Item key="jiekouguanli">
<Link to="/fillion/jiekouguanli">接口管理</Link> <Link to="/fillion/jiekouguanli">接口管理</Link>
</Menu.Item> */} </Menu.Item> */}
{user?.username == 'SuperAdmin' || user?.userResources?.filter(i => i.resourceId === 'PUBLICITYVIDEO')?.length !== 0 ? {user?.username == 'SuperAdmin' || user?.userResources?.some(i => i.resourceId === 'PUBLICITYVIDEO') ?
<Menu.Item key="fillionpromotional"> <Menu.Item key="fillionpromotional">
<Link to="/fillion/promotional">宣传视频</Link> <Link to="/fillion/promotional">宣传视频</Link>
</Menu.Item> : ''} </Menu.Item> : ''}
{user?.username == 'SuperAdmin' || user?.userResources?.some(i => i.resourceId === 'ASSESSMANAGE') ?
<Menu.Item key="fillionassess"> <Menu.Item key="fillionassess">
<Link to="/fillion/assess">考核评分</Link> <Link to="/fillion/assess">考核评分</Link>
</Menu.Item> </Menu.Item> : ''}
{user?.username == 'SuperAdmin' || user?.userResources?.some(i => i.resourceId === 'VIDEOCENTER') ?
<Menu.Item key="fillionvideoCenter"> <Menu.Item key="fillionvideoCenter">
<Link to="/fillion/videoCenter">视频中心</Link> <Link to="/fillion/videoCenter">视频中心</Link>
</Menu.Item> </Menu.Item> : ''}
</SubMenu> : null </SubMenu> : null
); );
} }

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

@ -52,7 +52,7 @@ export default [{
menuSelectKeys: ['fillionprocesssing'], menuSelectKeys: ['fillionprocesssing'],
component: Building, component: Building,
breadcrumb: '在建项目', breadcrumb: '在建项目',
//authCode: 'ROADMANAGE' authCode: 'BUILDINGPROJECT'
} }
, { , {
@ -163,12 +163,15 @@ export default [{
menuSelectKeys: ['fillionassess'], menuSelectKeys: ['fillionassess'],
component: Assess, component: Assess,
breadcrumb: '考核评分', breadcrumb: '考核评分',
authCode: 'ASSESSMANAGE'
}, { }, {
path: '/videoCenter', path: '/videoCenter',
key: 'fillionvideoCenter', key: 'fillionvideoCenter',
menuSelectKeys: ['fillionvideoCenter'], menuSelectKeys: ['fillionvideoCenter'],
component: VideoCenter, component: VideoCenter,
breadcrumb: '视频中心', breadcrumb: '视频中心',
authCode: 'VIDEOCENTER'
} }
] ]
} }

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

@ -13,7 +13,8 @@ const Authority = (props) => {
const { dispatch, loading, depMessage, depUser, resource, userResource, clientHeight, user } = props const { dispatch, loading, depMessage, depUser, resource, userResource, clientHeight, user } = props
const r1 = ['USERMANAGE', 'AUTHORIMANAGE', 'OVERLOADMANAGE', 'ROADMANAGE', 'BRIDGEMANAGE', 'MAINTENANCEMANAGE', 'TRANSPORTATIONMANAGE', const r1 = ['USERMANAGE', 'AUTHORIMANAGE', 'OVERLOADMANAGE', 'ROADMANAGE', 'BRIDGEMANAGE', 'MAINTENANCEMANAGE', 'TRANSPORTATIONMANAGE',
'CONSERVATIONMANAGE', 'PATROLMANAGE', 'PUBLICTRANSPORTMANAGE', 'FILEMANAGE', 'PUBLICITYVIDEO', 'FEEDBACKMANAGE', 'REPORTMANAGE', 'CONSERVATIONMANAGE', 'PATROLMANAGE', 'PUBLICTRANSPORTMANAGE', 'FILEMANAGE', 'PUBLICITYVIDEO', 'FEEDBACKMANAGE', 'REPORTMANAGE',
'WXPATROLREPORT', 'WXMAINTENANCEREPORT', 'WXFEEDBACKMANAGE', 'WXBUILDINGROAD' 'ASSESSMANAGE', 'VIDEOCENTER', 'BUILDINGPROJECT', 'WXPATROLREPORT', 'WXMAINTENANCEREPORT', 'WXFEEDBACKMANAGE', 'WXBUILDINGROAD',
'WXTODOLIST', 'WXDONELIST'
] ]
const [depUserCopy, setDepUserCopy] = useState([])//用于存放除了自己的管理的数组,即自己不能调整自己是否为管理员 const [depUserCopy, setDepUserCopy] = useState([])//用于存放除了自己的管理的数组,即自己不能调整自己是否为管理员
const [depSelectedKeys, setDepSelectedKeys] = useState([]) const [depSelectedKeys, setDepSelectedKeys] = useState([])
@ -69,7 +70,7 @@ const Authority = (props) => {
const onshowchange = (e) => { const onshowchange = (e) => {
setisshow(e.target.checked) setisshow(e.target.checked)
} }
console.log('depMessagedata', depMessagedata) //console.log('depMessagedata', depMessagedata)
useEffect(() => { useEffect(() => {
dispatch(getResource()) dispatch(getResource())
@ -87,7 +88,7 @@ const Authority = (props) => {
}, [userResource]) }, [userResource])
useEffect(async () => { useEffect(async () => {
if (depMessage.length) { if (depMessage.length) {
console.log('depMessage', depMessage) //('depMessage', depMessage)
//超级管理员展示所有部门 //超级管理员展示所有部门
if (user?.username === 'SuperAdmin') { if (user?.username === 'SuperAdmin') {
setdepMessagedata(depMessage) setdepMessagedata(depMessage)
@ -98,7 +99,7 @@ const Authority = (props) => {
//不是超级管理员,展示相应部门的数据 //不是超级管理员,展示相应部门的数据
dispatch(getDepUser(user.departmentId)) dispatch(getDepUser(user.departmentId))
const res = await dispatch(getDepById({ deptId: parseInt(user.departmentId) })) const res = await dispatch(getDepById({ deptId: parseInt(user.departmentId) }))
console.log('resssss', res) //console.log('resssss', res)
setdepMessagedata(res.payload.data) setdepMessagedata(res.payload.data)
// if (authDep.length > 0) { // if (authDep.length > 0) {
// dispatch(getDepUser(authDep[0]?.id)) // dispatch(getDepUser(authDep[0]?.id))
@ -118,9 +119,7 @@ const Authority = (props) => {
// } // }
// }, [depMessage]) // }, [depMessage])
useEffect(() => { useEffect(() => {
const copy = depUser.filter((item) => { const copy = [...new Set(depUser)]
return item.id !== user.id//把自己筛选出去
})
setDepUserCopy(copy) setDepUserCopy(copy)
if (copy.length) { if (copy.length) {
setUserSelectedKeys([copy[0].id]) setUserSelectedKeys([copy[0].id])

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

@ -29,10 +29,10 @@ 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)
console.log('depMessagedata', depMessagedata) //('depMessagedata', depMessagedata)
useEffect(async () => { useEffect(async () => {
if (depMessage.length) { if (depMessage.length) {
console.log('depMessage', depMessage) //console.log('depMessage', depMessage)
//超级管理员展示所有部门 //超级管理员展示所有部门
if (user?.username === 'SuperAdmin') { if (user?.username === 'SuperAdmin') {
setdepMessagedata(depMessage) setdepMessagedata(depMessage)
@ -42,7 +42,7 @@ const UserManage = (props) => {
//不是超级管理员,展示相应部门的数据 //不是超级管理员,展示相应部门的数据
dispatch(getDepUser(user.departmentId)) dispatch(getDepUser(user.departmentId))
const res = await dispatch(getDepById({ deptId: parseInt(user.departmentId) })) const res = await dispatch(getDepById({ deptId: parseInt(user.departmentId) }))
console.log('resssss', res) //('resssss', res)
setdepMessagedata(res.payload.data) setdepMessagedata(res.payload.data)
// setDepSelectedKeys([res.payload.data[0].id]) // setDepSelectedKeys([res.payload.data[0].id])
// dispatch(getDepUser(res.payload.data[0].id)) // dispatch(getDepUser(res.payload.data[0].id))
@ -66,12 +66,13 @@ const UserManage = (props) => {
dispatch(getDepMessage()) dispatch(getDepMessage())
}, []) }, [])
useEffect(() => { useEffect(() => {
console.log('depuser', depUser, user) //console.log('depuser', depUser, user)
const copy = depUser.filter((item) => { // const copy = depUser.filter((item) => {
console.log('item1', item) // //console.log('item1', item)
return item.id !== user.id//把自己筛选出去 // return item.id !== user.id//把自己筛选出去
}) // })
console.log('copy', copy) // //console.log('copy', copy)
const copy = [...new Set(depUser)]
setDepUserCopy(copy) setDepUserCopy(copy)
}, [depUser]) }, [depUser])
useEffect(() => { useEffect(() => {
@ -161,7 +162,7 @@ const UserManage = (props) => {
//弹窗确认 //弹窗确认
const onConfirm = (values) => { const onConfirm = (values) => {
console.log('values.contract', values.contract) //('values.contract', values.contract)
if (modalType == 'edit') { if (modalType == 'edit') {
dispatch(updateUser(modalRecord.id, values.contract)).then(res => { dispatch(updateUser(modalRecord.id, values.contract)).then(res => {
if (res.success) { if (res.success) {
@ -226,8 +227,8 @@ const UserManage = (props) => {
} }
//部门新增及编辑 //部门新增及编辑
const onDepConfirm = (data) => { const onDepConfirm = (data) => {
console.log('depModalType:', depModalType); //console.log('depModalType:', depModalType);
console.log('data:', data); //console.log('data:', data);
if (depModalType == 'edit') { if (depModalType == 'edit') {
dispatch(updateDep(data)).then(res => { dispatch(updateDep(data)).then(res => {
@ -442,7 +443,9 @@ function mapStateToProps(state) {
loading: depMessage.isRequesting, loading: depMessage.isRequesting,
depMessage: depMessage.data || [], depMessage: depMessage.data || [],
depUser: depUser.data || [], depUser: depUser.data || [],
user: auth.user user: auth.user,
actions: global.actions
}; };
} }

6
web/client/src/sections/organization/nav-item.js

@ -17,17 +17,17 @@ export function getNavItem(user, dispatch) {
// dispatch(push('/fillion/infor')); // dispatch(push('/fillion/infor'));
// return null // return null
// } // }
const isshow = user?.userResources?.filter(i => i.resourceId === 'USERMANAGE' || i.resourceId === 'AUTHORIMANAGE')?.length !== 0 const isshow = user?.userResources?.some(i => i.resourceId === 'USERMANAGE' || i.resourceId === 'AUTHORIMANAGE')
return ( return (
user?.username == 'SuperAdmin' || isshow ? user?.username == 'SuperAdmin' || isshow ?
<SubMenu key="organization" icon={<SettingOutlined />} title={'授权管理'}> <SubMenu key="organization" icon={<SettingOutlined />} title={'授权管理'}>
{user?.username == 'SuperAdmin' || user?.userResources?.filter(i => i.resourceId === 'USERMANAGE')?.length !== 0 ? < Menu.Item key="userManage"> {user?.username == 'SuperAdmin' || user?.userResources?.some(i => i.resourceId === 'USERMANAGE') ? < Menu.Item key="userManage">
<Link to="/organization/user">用户管理</Link> <Link to="/organization/user">用户管理</Link>
</Menu.Item> : '' </Menu.Item> : ''
} }
{user?.username == 'SuperAdmin' || user?.userResources?.filter(i => i.resourceId === 'AUTHORIMANAGE')?.length !== 0 ? <Menu.Item key="userAuthority"> {user?.username == 'SuperAdmin' || user?.userResources?.some(i => i.resourceId === 'AUTHORIMANAGE') ? <Menu.Item key="userAuthority">
<Link to="/organization/authority"> 权限管理</Link> <Link to="/organization/authority"> 权限管理</Link>
</Menu.Item> : ''} </Menu.Item> : ''}

Loading…
Cancel
Save