Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
C
CivManage
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
ReactWeb5
CivManage
Commits
8ae4fd46
Commit
8ae4fd46
authored
Nov 06, 2020
by
陈前坚
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'master' of
https://g.civnet.cn:8443/test/maintenance
parents
657d6bc3
dd04561a
Show whitespace changes
Inline
Side-by-side
Showing
19 changed files
with
1231 additions
and
696 deletions
+1231
-696
SiteModa.jsx
src/components/Modal/SiteModa.jsx
+11
-18
InitDataBase.jsx
src/pages/database/InitDataBase.jsx
+71
-66
ManagementDataBase.jsx
src/pages/database/ManagementDataBase.jsx
+35
-33
DefaultComponent.jsx
src/pages/orgnazation/DefaultComponent.jsx
+160
-175
ListCard.jsx
src/pages/orgnazation/ListCard.jsx
+86
-54
ListCardItem.less
src/pages/orgnazation/ListCardItem.less
+8
-17
listCardItem.jsx
src/pages/orgnazation/listCardItem.jsx
+86
-58
AddModal.jsx
src/pages/userCenter/RoleManage/AddModal.jsx
+91
-0
DelModal.jsx
src/pages/userCenter/RoleManage/DelModal.jsx
+59
-0
EditModal.jsx
src/pages/userCenter/RoleManage/EditModal.jsx
+97
-0
RoleManage.jsx
src/pages/userCenter/RoleManage/RoleManage.jsx
+197
-0
RoleManage.less
src/pages/userCenter/RoleManage/RoleManage.less
+26
-0
AddModal.jsx
src/pages/userCenter/siteManage/AddModal.jsx
+53
-53
DelModal.jsx
src/pages/userCenter/siteManage/DelModal.jsx
+34
-32
EditModal.jsx
src/pages/userCenter/siteManage/EditModal.jsx
+58
-60
SiteManage.jsx
src/pages/userCenter/siteManage/SiteManage.jsx
+142
-125
SiteManage.less
src/pages/userCenter/siteManage/SiteManage.less
+1
-4
config.js
src/routes/config.js
+1
-1
api.js
src/services/userCenter/RoleManage/api.js
+15
-0
No files found.
src/components/Modal/SiteModa.jsx
View file @
8ae4fd46
import
React
from
'react'
import
React
from
'react'
;
import
{
import
{
Modal
}
from
'antd'
;
Modal
}
from
'antd'
const
SiteModal
=
(
props
)
=>
{
const
SiteModal
=
props
=>
{
console
.
log
(
props
)
const
defaultCofig
=
{
const
defaultCofig
=
{
title
:
'测试
'
,
title
:
'提示
'
,
visible
:
false
,
visible
:
false
,
}
}
;
const
config
=
{
...
defaultCofig
,
...
props
}
const
config
=
{
...
defaultCofig
,
...
props
};
return
(
return
(
<
Modal
<
Modal
style=
{
{
width
:
'1000px'
}
}
{
...
config
}
>
style=
{
{
width
:
"1000px"
}
}
{
...
config
}
>
{
props
.
children
}
{
props
.
children
}
</
Modal
>
</
Modal
>
)
)
;
}
}
;
export
default
SiteModal
export
default
SiteModal
;
\ No newline at end of file
src/pages/database/InitDataBase.jsx
View file @
8ae4fd46
...
@@ -15,7 +15,7 @@ import {
...
@@ -15,7 +15,7 @@ import {
import
{
PageContainer
}
from
'@ant-design/pro-layout'
;
import
{
PageContainer
}
from
'@ant-design/pro-layout'
;
import
{
connect
}
from
'react-redux'
;
import
{
connect
}
from
'react-redux'
;
import
{
get
,
post
}
from
'../../services'
;
import
{
get
,
post
}
from
'../../services'
;
import
{
setTableSQLDirName
,
deleteConn
}
from
'@/services/database/api'
import
{
setTableSQLDirName
,
deleteConn
}
from
'@/services/database/api'
;
import
styles
from
'./InitDataBase.less'
;
import
styles
from
'./InitDataBase.less'
;
const
{
Option
}
=
Select
;
const
{
Option
}
=
Select
;
...
@@ -39,8 +39,8 @@ const InitDataBase = props => {
...
@@ -39,8 +39,8 @@ const InitDataBase = props => {
const
[
upData
,
setUpData
]
=
useState
(
1
);
// 列表刷新标记
const
[
upData
,
setUpData
]
=
useState
(
1
);
// 列表刷新标记
const
[
option
,
setOption
]
=
useState
([]);
// 下拉列表数据
const
[
option
,
setOption
]
=
useState
([]);
// 下拉列表数据
const
[
desc
,
setDesc
]
=
useState
(
''
);
// 修改描述
const
[
desc
,
setDesc
]
=
useState
(
''
);
// 修改描述
const
[
allSqlDir
,
setAllSqulDir
]
=
useState
([])
//
修改产品方案
const
[
allSqlDir
,
setAllSqulDir
]
=
useState
([])
;
//
修改产品方案
const
[
defaultSqlDir
,
setDefaultSqlDir
]
=
useState
(
''
)
//
修改产品方案默认值
const
[
defaultSqlDir
,
setDefaultSqlDir
]
=
useState
(
''
)
;
//
修改产品方案默认值
const
[
modalVisible
,
setModalVisible
]
=
useState
(
false
);
const
[
modalVisible
,
setModalVisible
]
=
useState
(
false
);
console
.
log
(
window
.
location
.
host
);
console
.
log
(
window
.
location
.
host
);
// 获取数据库链接记录
// 获取数据库链接记录
...
@@ -80,8 +80,8 @@ const InitDataBase = props => {
...
@@ -80,8 +80,8 @@ const InitDataBase = props => {
});
});
form
.
setFieldsValue
(
obj
);
form
.
setFieldsValue
(
obj
);
setDbForm
(
val
=>
({
...
val
,
...
obj
}));
setDbForm
(
val
=>
({
...
val
,
...
obj
}));
setAllSqulDir
(
res
.
allSqlDir
)
setAllSqulDir
(
res
.
allSqlDir
)
;
setDefaultSqlDir
(
res
.
tableSQLDirName
)
setDefaultSqlDir
(
res
.
tableSQLDirName
)
;
}
}
})
})
.
catch
(
err
=>
{
.
catch
(
err
=>
{
...
@@ -201,7 +201,7 @@ const InitDataBase = props => {
...
@@ -201,7 +201,7 @@ const InitDataBase = props => {
};
};
// 点击表格回显到表单
// 点击表格回显到表单
const
tableClick
=
item
=>
{
const
tableClick
=
item
=>
{
console
.
log
(
item
)
console
.
log
(
item
)
;
let
obj
=
{
...
dbForm
};
let
obj
=
{
...
dbForm
};
Object
.
keys
(
obj
).
forEach
(
k
=>
{
Object
.
keys
(
obj
).
forEach
(
k
=>
{
obj
[
k
]
=
item
[
k
];
obj
[
k
]
=
item
[
k
];
...
@@ -209,29 +209,31 @@ const InitDataBase = props => {
...
@@ -209,29 +209,31 @@ const InitDataBase = props => {
form
.
setFieldsValue
(
obj
);
form
.
setFieldsValue
(
obj
);
};
};
// 产品方案选择框回调
// 产品方案选择框回调
const
handleSelect
=
(
value
)
=>
{
const
handleSelect
=
value
=>
{
setTableSQLDirName
({
setTableSQLDirName
({
dirName
:
value
,
dirName
:
value
,
_version
:
9999
,
_version
:
9999
,
_dc
:
new
Date
().
getTime
()
_dc
:
new
Date
().
getTime
(),
}).
then
(
res
=>
{
})
if
(
res
.
success
){
.
then
(
res
=>
{
if
(
res
.
success
)
{
notification
.
success
({
notification
.
success
({
message
:
'提示'
,
message
:
'提示'
,
duration
:
3
,
duration
:
3
,
description
:
`已切换初始化脚本为:
${
value
}
`
,
description
:
`已切换初始化脚本为:
${
value
}
`
,
});
});
}
else
{
}
else
{
notification
.
error
({
notification
.
error
({
message
:
'提示'
,
message
:
'提示'
,
duration
:
3
,
duration
:
3
,
description
:
res
.
message
,
description
:
res
.
message
,
});
});
}
}
}).
catch
(
err
=>
{
console
.
error
(
err
)
})
})
}
.
catch
(
err
=>
{
console
.
error
(
err
);
});
};
// 展示修改描述
// 展示修改描述
const
changeDesc
=
()
=>
{
const
changeDesc
=
()
=>
{
setModalVisible
(
true
);
setModalVisible
(
true
);
...
@@ -265,34 +267,37 @@ const InitDataBase = props => {
...
@@ -265,34 +267,37 @@ const InitDataBase = props => {
setModalVisible
(
false
);
setModalVisible
(
false
);
});
});
};
};
//删除数据库连接记录
//
删除数据库连接记录
const
delConn
=
(
value
)
=>
{
const
delConn
=
value
=>
{
setTableLoading
(
true
)
setTableLoading
(
true
)
;
const
{
key
=
''
}
=
value
const
{
key
=
''
}
=
value
;
deleteConn
({
deleteConn
({
rowIndex
:
key
,
rowIndex
:
key
,
_version
:
9999
,
_version
:
9999
,
_dc
:
new
Date
().
getTime
()
_dc
:
new
Date
().
getTime
(),
}).
then
(
res
=>
{
})
setTableLoading
(
false
)
.
then
(
res
=>
{
if
(
res
.
success
){
setTableLoading
(
false
);
if
(
res
.
success
)
{
setUpData
(
upData
+
1
);
setUpData
(
upData
+
1
);
notification
.
success
({
notification
.
success
({
message
:
'提示'
,
message
:
'提示'
,
duration
:
3
,
duration
:
3
,
description
:
'操作成功'
description
:
'操作成功'
,
})
});
}
else
{
}
else
{
notification
.
error
({
notification
.
error
({
message
:
'提示'
,
message
:
'提示'
,
duration
:
3
,
duration
:
3
,
description
:
res
.
message
description
:
res
.
message
,
})
});
}
}).
catch
(
err
=>
{
setTableLoading
(
false
)
console
.
error
(
err
)})
}
}
})
.
catch
(
err
=>
{
setTableLoading
(
false
);
console
.
error
(
err
);
});
};
const
columns
=
[
const
columns
=
[
{
{
title
:
'服务器名或IP地址'
,
title
:
'服务器名或IP地址'
,
...
@@ -320,10 +325,11 @@ const InitDataBase = props => {
...
@@ -320,10 +325,11 @@ const InitDataBase = props => {
key
:
'desc'
,
key
:
'desc'
,
},
},
{
{
title
:
'修改描述'
,
title
:
'操作'
,
dataIndex
:
'name'
,
dataIndex
:
'action'
,
key
:
'name'
,
key
:
'action'
,
render
:
()
=>
(
render
:
(
text
,
record
)
=>
(
<
Space
>
<
Button
<
Button
type=
"primary"
type=
"primary"
size=
"small"
size=
"small"
...
@@ -333,18 +339,10 @@ const InitDataBase = props => {
...
@@ -333,18 +339,10 @@ const InitDataBase = props => {
>
>
修改描述
修改描述
</
Button
>
</
Button
>
),
<
Button
size=
"small"
danger
onClick=
{
()
=>
delConn
(
record
)
}
>
},
{
title
:
'删除'
,
dataIndex
:
'del'
,
key
:
'del'
,
render
:
(
text
,
record
)
=>
(
<
Button
size=
"small"
danger
onClick=
{
()
=>
delConn
(
record
)
}
>
删除
删除
</
Button
>
</
Button
>
</
Space
>
),
),
},
},
];
];
...
@@ -418,19 +416,27 @@ const InitDataBase = props => {
...
@@ -418,19 +416,27 @@ const InitDataBase = props => {
>
>
数据库初始化
数据库初始化
</
Button
>
</
Button
>
{
defaultSqlDir
&&
<
Select
{
defaultSqlDir
&&
(
placeholder=
'请选择解决方案'
<
Select
style=
{
placeholder=
"请选择解决方案"
{
width
:
'200px'
}
style=
{
{
width
:
'200px'
}
}
}
defaultValue=
{
defaultSqlDir
}
defaultValue=
{
defaultSqlDir
}
onChange
=
{
(
e
)=
>
{
handleSelect
(
e
)
}
}
onChange=
{
e
=>
{
handleSelect
(
e
);
}
}
>
>
{
allSqlDir
&&
allSqlDir
.
map
(
(
item
,
index
)
=>
{
{
allSqlDir
&&
console
.
log
(
defaultSqlDir
)
allSqlDir
.
map
((
item
,
index
)
=>
{
return
<
Option
value=
{
item
}
key=
{
index
}
>
{
item
}
</
Option
>
console
.
log
(
defaultSqlDir
);
})
}
return
(
</
Select
>
}
<
Option
value=
{
item
}
key=
{
index
}
>
{
' '
}
{
item
}{
' '
}
</
Option
>
);
})
}
</
Select
>
)
}
{
/* <span>{dbForm.inUse}</span> */
}
{
/* <span>{dbForm.inUse}</span> */
}
</
Space
>
</
Space
>
</
div
>
</
div
>
...
@@ -464,10 +470,9 @@ const InitDataBase = props => {
...
@@ -464,10 +470,9 @@ const InitDataBase = props => {
bodyStyle=
{
{
bodyStyle=
{
{
minHeight
:
'100px'
,
minHeight
:
'100px'
,
}
}
}
}
cancelText=
"取消"
cancelText=
"取消"
okText=
"确认修改"
okText=
"确认修改"
destroyOnClose
=
{
true
}
destroyOnClose
>
>
<
Row
>
<
Row
>
<
Col
span=
{
2
}
className=
{
styles
.
decsBox
}
>
<
Col
span=
{
2
}
className=
{
styles
.
decsBox
}
>
...
...
src/pages/database/ManagementDataBase.jsx
View file @
8ae4fd46
...
@@ -2,13 +2,13 @@ import React, { useEffect, useState } from 'react';
...
@@ -2,13 +2,13 @@ import React, { useEffect, useState } from 'react';
import
{
Card
,
Button
,
Table
,
Space
,
Modal
}
from
'antd'
;
import
{
Card
,
Button
,
Table
,
Space
,
Modal
}
from
'antd'
;
import
{
PageContainer
}
from
'@ant-design/pro-layout'
;
import
{
PageContainer
}
from
'@ant-design/pro-layout'
;
import
{
get
}
from
'../../services'
;
import
{
get
}
from
'../../services'
;
import
styles
from
'./ManagementDataBase.less'
import
styles
from
'./ManagementDataBase.less'
;
const
ManagementDataBase
=
()
=>
{
const
ManagementDataBase
=
()
=>
{
const
[
autoCheckList
,
setAutoCheckList
]
=
useState
([]);
const
[
autoCheckList
,
setAutoCheckList
]
=
useState
([]);
const
[
checkList
,
setCheckList
]
=
useState
([]);
const
[
checkList
,
setCheckList
]
=
useState
([]);
const
[
logList
,
setLogList
]
=
useState
([]);
const
[
logList
,
setLogList
]
=
useState
([]);
const
[
checkFlag
,
setCheckFlag
]
=
useState
(
1
)
const
[
checkFlag
,
setCheckFlag
]
=
useState
(
1
)
;
const
[
checkLoading
,
setCheckLoading
]
=
useState
(
false
);
const
[
checkLoading
,
setCheckLoading
]
=
useState
(
false
);
const
[
logLoading
,
setLogLoading
]
=
useState
(
false
);
const
[
logLoading
,
setLogLoading
]
=
useState
(
false
);
const
[
modalVisible
,
setModalVisible
]
=
useState
(
false
);
// 弹窗
const
[
modalVisible
,
setModalVisible
]
=
useState
(
false
);
// 弹窗
...
@@ -45,7 +45,7 @@ const ManagementDataBase = () => {
...
@@ -45,7 +45,7 @@ const ManagementDataBase = () => {
console
.
error
(
err
);
console
.
error
(
err
);
});
});
},
[
checkFlag
]);
},
[
checkFlag
]);
//获取数据库升级记录
//
获取数据库升级记录
useEffect
(()
=>
{
useEffect
(()
=>
{
setLogLoading
(
true
);
setLogLoading
(
true
);
get
(
`/Cityinterface/rest/services/OMS.svc/DatabaseStandard_GetLog`
,
{
get
(
`/Cityinterface/rest/services/OMS.svc/DatabaseStandard_GetLog`
,
{
...
@@ -70,18 +70,15 @@ const ManagementDataBase = () => {
...
@@ -70,18 +70,15 @@ const ManagementDataBase = () => {
});
});
},
[]);
},
[]);
const
handleCheck
=
()
=>
{
const
handleCheck
=
()
=>
{
setCheckFlag
(
checkFlag
+
1
)
setCheckFlag
(
checkFlag
+
1
);
};
};
const
handleUpdate
=
()
=>
{
const
handleUpdate
=
()
=>
{
alert
(
'updatedb'
)
alert
(
'updatedb'
)
;
console
.
log
(
'updatedb'
);
console
.
log
(
'updatedb'
);
};
};
const
handleLog
=
text
=>
{
const
handleLog
=
text
=>
{
let
arr
=
[]
let
arr
=
[];
arr
.
push
(
arr
.
push
(
text
.
split
(
/
[
(
\r\n
)
\r\n]
+/
).
map
(
item
=>
<
p
>
$
{
item
}
</
p
>));
text
.
split
(
/
[
(
\r\n
)
\r\n]
+/
).
map
(
item
=>
{
return
(<
p
>
$
{
item
}
</
p
>)
}))
setModalVisible
(
true
);
setModalVisible
(
true
);
setContent
(
text
);
setContent
(
text
);
};
};
...
@@ -141,38 +138,33 @@ const ManagementDataBase = () => {
...
@@ -141,38 +138,33 @@ const ManagementDataBase = () => {
title
:
'版本日志'
,
title
:
'版本日志'
,
dataIndex
:
'despersion'
,
dataIndex
:
'despersion'
,
key
:
'despersion'
,
key
:
'despersion'
,
render
:
text
=>
{
render
:
text
=>
(
return
(
<
Button
<
Button
size=
'small'
size=
"small"
onClick=
{
()
=>
{
onClick=
{
()
=>
{
handleLog
(
text
);
handleLog
(
text
);
}
}
}
}
>
>
日志
日志
</
Button
>
</
Button
>
);
),
},
},
},
{
{
title
:
'升级内容'
,
title
:
'升级内容'
,
dataIndex
:
'content'
,
dataIndex
:
'content'
,
key
:
'content'
,
key
:
'content'
,
ellipsis
:
true
,
ellipsis
:
true
,
render
:
text
=>
{
render
:
text
=>
(
return
(
<
Button
<
Button
size=
'small'
size=
"small"
type=
'primary'
type=
"primary"
onClick=
{
()
=>
{
onClick=
{
()
=>
{
handleLog
(
text
);
handleLog
(
text
);
}
}
}
}
>
>
升级内容
升级内容
</
Button
>
</
Button
>
);
),
},
},
},
];
];
...
@@ -187,12 +179,20 @@ const ManagementDataBase = () => {
...
@@ -187,12 +179,20 @@ const ManagementDataBase = () => {
dataSource=
{
autoCheckList
}
dataSource=
{
autoCheckList
}
bordered
bordered
loading=
{
checkLoading
}
loading=
{
checkLoading
}
size=
'small'
size=
"small"
/>
/>
<
div
className=
{
styles
.
tCenter
}
>
<
div
className=
{
styles
.
tCenter
}
>
<
Space
>
<
Space
>
<
Button
type=
'primary'
onClick=
{
handleCheck
}
loading=
{
checkLoading
}
>
检查
</
Button
>
<
Button
<
Button
danger
type=
'primary'
onClick=
{
handleUpdate
}
>
升级
</
Button
>
type=
"primary"
onClick=
{
handleCheck
}
loading=
{
checkLoading
}
>
检查
</
Button
>
<
Button
danger
type=
"primary"
onClick=
{
handleUpdate
}
>
升级
</
Button
>
</
Space
>
</
Space
>
</
div
>
</
div
>
</
Card
>
</
Card
>
...
@@ -207,7 +207,7 @@ const ManagementDataBase = () => {
...
@@ -207,7 +207,7 @@ const ManagementDataBase = () => {
dataSource=
{
checkList
}
dataSource=
{
checkList
}
bordered
bordered
loading=
{
checkLoading
}
loading=
{
checkLoading
}
size=
'small'
size=
"small"
/>
/>
</
Card
>
</
Card
>
<
Card
className=
{
styles
.
mgTop20
}
>
<
Card
className=
{
styles
.
mgTop20
}
>
...
@@ -218,7 +218,7 @@ const ManagementDataBase = () => {
...
@@ -218,7 +218,7 @@ const ManagementDataBase = () => {
dataSource=
{
logList
}
dataSource=
{
logList
}
bordered
bordered
loading=
{
logLoading
}
loading=
{
logLoading
}
size=
'small'
size=
"small"
/>
/>
</
Card
>
</
Card
>
</
PageContainer
>
</
PageContainer
>
...
@@ -232,13 +232,15 @@ const ManagementDataBase = () => {
...
@@ -232,13 +232,15 @@ const ManagementDataBase = () => {
onCancel=
{
()
=>
setModalVisible
(
false
)
}
onCancel=
{
()
=>
setModalVisible
(
false
)
}
width=
"1000px"
width=
"1000px"
bodyStyle=
{
{
bodyStyle=
{
{
minHeight
:
'100px'
,
minHeight
:
'100px'
,
maxHeight
:
'600px'
,
maxHeight
:
'600px'
,
overflowY
:
'scroll'
overflowY
:
'scroll'
,
}
}
}
}
style=
{
{
top
:
"40px"
}
}
style=
{
{
top
:
'40px'
}
}
footer=
{
[
footer=
{
[
<
Button
type=
'primary'
onClick=
{
()
=>
setModalVisible
(
false
)
}
>
关闭窗口
</
Button
>,
<
Button
type=
"primary"
onClick=
{
()
=>
setModalVisible
(
false
)
}
>
关闭窗口
</
Button
>,
]
}
]
}
>
>
{
content
}
{
content
}
...
...
src/pages/orgnazation/DefaultComponent.jsx
View file @
8ae4fd46
import
React
,{
useState
,
useEffect
,
}
from
'react'
import
React
,
{
useState
,
useEffect
}
from
'react'
;
import
{
import
{
Card
,
TreeSelect
,
Space
,
Button
,
Table
,
Input
,
Row
,
Col
}
from
'antd'
;
Card
,
TreeSelect
,
Space
,
Button
,
Table
,
Input
,
Row
,
Col
}
from
'antd'
;
import
{
PageContainer
}
from
'@ant-design/pro-layout'
;
import
{
PageContainer
}
from
'@ant-design/pro-layout'
;
import
{
connect
}
from
'react-redux'
;
import
{
connect
}
from
'react-redux'
;
import
TestModal
from
'./ModalComponent'
;
import
TestModal
from
'./ModalComponent'
;
import
ListCard
from
'./ListCard'
;
import
ListCard
from
'./ListCard'
;
import
{
get
,
post
}
from
'../../services'
;
import
{
get
,
post
}
from
'../../services'
;
import
{
orgGet
,
orgTest
}
from
'../../services/orgnazation/api'
import
{
orgGet
,
orgTest
}
from
'../../services/orgnazation/api'
;
import
styles
from
'./DefaultComponent.less'
import
styles
from
'./DefaultComponent.less'
;
const
{
Search
}
=
Input
const
{
Search
}
=
Input
;
const
{
TreeNode
}
=
TreeSelect
;
const
{
TreeNode
}
=
TreeSelect
;
// const treeData = [
// const treeData = [
// {
// {
...
@@ -39,204 +30,199 @@ const { TreeNode } = TreeSelect;
...
@@ -39,204 +30,199 @@ const { TreeNode } = TreeSelect;
// },
// },
// ];
// ];
const
DefaultComponent
=
()
=>
{
const
DefaultComponent
=
()
=>
{
const
[
treeValue
,
setTreeValue
]
=
useState
(
null
);
// 树节点选中的值
const
[
treeValue
,
setTreeValue
]
=
useState
(
null
)
//树节点选中的值
const
[
tableData
,
setTableData
]
=
useState
([]);
// table的值
const
[
tableData
,
setTableData
]
=
useState
([])
//table的值
const
[
selectedRowKeys
,
setSelectedRowKeys
]
=
useState
([]);
// table表格checkbox配置
const
[
selectedRowKeys
,
setSelectedRowKeys
]
=
useState
([])
//table表格checkbox配置
const
[
modalVisible
,
setModalVisible
]
=
useState
(
false
);
// 展示Modal弹窗
const
[
modalVisible
,
setModalVisible
]
=
useState
(
false
)
//展示Modal弹窗
const
[
testPeoList
,
setTestPeoList
]
=
useState
([]);
// 测试card数组
const
[
testPeoList
,
setTestPeoList
]
=
useState
([])
//测试card数组
const
[
treeData
,
setTreeData
]
=
useState
([]);
const
[
treeData
,
setTreeData
]
=
useState
([])
// 树节点选中的值
//树节点选中的值
const
treeChange
=
e
=>
{
const
treeChange
=
(
e
)
=>
{
setTreeValue
(
e
);
setTreeValue
(
e
)
};
}
// 用户搜索
//用户搜索
const
handleSearch
=
()
=>
{
const
handleSearch
=
()
=>
{
console
.
log
(
'handleSearch'
);
console
.
log
(
'handleSearch'
)
setModalVisible
(
true
);
setModalVisible
(
true
)
};
}
// 导入
//导入
const
handleImport
=
()
=>
{
const
handleImport
=
()
=>
{
setModalVisible
(
true
);
setModalVisible
(
true
)
};
}
// 搜索框时间
//搜索框时间
const
inputSearch
=
e
=>
{
const
inputSearch
=
(
e
)
=>
{
console
.
log
(
e
,
'inputSearch'
);
console
.
log
(
e
,
'inputSearch'
)
};
}
const
columns
=
[
const
columns
=
[
{
{
title
:
'用户ID'
,
title
:
'用户ID'
,
dataIndex
:
"userID"
,
dataIndex
:
'userID'
,
key
:
'userID'
key
:
'userID'
,
},
},
{
{
title
:
'登录名'
,
title
:
'登录名'
,
dataIndex
:
'loginName'
,
dataIndex
:
'loginName'
,
key
:
'loginName'
key
:
'loginName'
,
},
},
{
{
title
:
'用户姓名'
,
title
:
'用户姓名'
,
dataIndex
:
'userName'
,
dataIndex
:
'userName'
,
key
:
'userName'
,
key
:
'userName'
,
},
},
{
{
title
:
'手机号码'
,
title
:
'手机号码'
,
dataIndex
:
'phone'
,
dataIndex
:
'phone'
,
key
:
'phone'
key
:
'phone'
,
},
},
{
{
title
:
'钉钉账户'
,
title
:
'钉钉账户'
,
dataIndex
:
'ddid'
,
dataIndex
:
'ddid'
,
key
:
'ddid'
,
key
:
'ddid'
,
},
},
{
{
title
:
'微信账户'
,
title
:
'微信账户'
,
dataIndex
:
'wxid'
,
dataIndex
:
'wxid'
,
key
:
'wxid'
,
key
:
'wxid'
,
ellipsis
:
true
,
ellipsis
:
true
,
}
},
]
];
useEffect
(
()
=>
{
useEffect
(()
=>
{
orgGet
().
then
(
res
=>
{
orgGet
().
then
(
res
=>
{
console
.
log
(
res
,
'orgGet'
)
console
.
log
(
res
,
'orgGet'
);
if
(
res
){
if
(
res
)
{
let
arr
=
transTree
(
res
)
let
arr
=
transTree
(
res
);
console
.
log
(
transTree
(
res
),
'arr'
)
console
.
log
(
transTree
(
res
),
'arr'
);
setTreeData
(
arr
)
setTreeData
(
arr
);
}
}
});
})
},
[]);
},[])
// 处理返回的树形结构
//处理返回的树形结构
const
transTree
=
(
value
,
isChild
=
false
)
=>
{
const
transTree
=
(
value
,
isChild
=
false
)
=>
{
let
arr
=
value
;
let
arr
=
value
if
(
arr
.
length
<
0
)
{
if
(
arr
.
length
<
0
){
return
;
return
}
}
let
obj
=
{};
let
obj
=
{}
return
arr
.
map
(
item
=>
{
return
arr
.
map
(
item
=>
{
if
(
isChild
)
{
// item.title = item.text
item
.
title
=
item
.
userName
;
// item.value = item.id
item
.
value
=
item
.
userID
;
// if( item.children && item.children.length > 0){
}
else
{
// transTree(item.children)
item
.
title
=
item
.
text
;
// return obj=item
item
.
value
=
item
.
id
;
// }else{
// return item
// }
if
(
isChild
){
item
.
title
=
item
.
userName
item
.
value
=
item
.
userID
}
else
{
item
.
title
=
item
.
text
item
.
value
=
item
.
id
}
}
if
(
item
.
children
&&
item
.
children
.
length
>
0
){
if
(
item
.
children
&&
item
.
children
.
length
>
0
)
{
transTree
(
item
.
children
,
false
)
transTree
(
item
.
children
,
false
);
return
obj
=
item
return
(
obj
=
item
);
}
else
{
}
return
item
return
item
;
}
});
})
};
}
useEffect
(()
=>
{
useEffect
(
()
=>
{
get
(
'/Cityinterface/rest/services/OMS.svc/U_GetOneOUUserListNew'
,
{
get
(
'/Cityinterface/rest/services/OMS.svc/U_GetOneOUUserListNew'
,{
OUID
:
24
,
OUID
:
24
,
_version
:
9999
,
_version
:
9999
,
_dc
:
new
Date
().
getTime
(),
_dc
:
new
Date
().
getTime
()
}).
then
(
res
=>
{
}).
then
(
res
=>
{
if
(
res
.
success
)
{
if
(
res
.
success
){
setTableData
(
res
.
root
);
setTableData
(
res
.
root
)
}
}
});
})
const
testData
=
[];
const
testData
=
[]
const
test2list
=
[];
const
test2list
=
[]
for
(
let
i
=
1
;
i
<
10
;
i
++
)
{
for
(
let
i
=
1
;
i
<
10
;
i
++
){
testData
.
push
({
testData
.
push
({
key
:
i
,
key
:
i
,
ID
:
i
ID
:
i
,
})
})
;
test2list
.
push
({
test2list
.
push
({
label
:
i
+
"测试"
,
label
:
`
${
i
}
测试`
,
value
:
i
+
"测试"
,
value
:
`
${
i
}
测试`
,
})
})
;
}
}
console
.
log
(
test2list
)
console
.
log
(
test2list
)
;
setTestPeoList
(
test2list
)
setTestPeoList
(
test2list
)
;
},
[])
},
[]);
//
table选中框的值
//
table选中框的值
const
selectChange
=
(
e
)
=>
{
const
selectChange
=
e
=>
{
console
.
log
(
e
,
'e'
)
console
.
log
(
e
,
'e'
);
setSelectedRowKeys
(
e
)
setSelectedRowKeys
(
e
)
;
}
}
;
const
confirmModal
=
()
=>
{
const
confirmModal
=
()
=>
{
setModalVisible
(
false
)
setModalVisible
(
false
)
;
}
}
;
//table复选的配置
//
table复选的配置
const
rowSelection
=
{
const
rowSelection
=
{
selectedRowKeys
,
selectedRowKeys
,
onChange
:
selectChange
,
onChange
:
selectChange
,
}
}
;
const
btnLable
=
[
const
btnLable
=
[
{
label
:
'查找用户'
,
handle
:
handleSearch
,
config
:{
type
:
'primary'
,
danger
:
true
}
},
{
{
label
:
'用户导入'
,
handle
:
handleImport
,
config
:{
type
:
'info'
,}},
label
:
'查找用户'
,
]
handle
:
handleSearch
,
config
:
{
type
:
'primary'
,
danger
:
true
},
},
{
label
:
'用户导入'
,
handle
:
handleImport
,
config
:
{
type
:
'info'
}
},
];
return
(
return
(
<>
<>
<
PageContainer
>
<
PageContainer
>
<
Card
>
<
Card
>
<
Row
>
<
Row
>
<
Col
span
={1}
>
<
Col
span=
{
1
}
>
<
div
style=
{
{
height
:
"30px"
,
lineHeight
:
"30px"
}
}
>
<
div
style=
{
{
height
:
'30px'
,
lineHeight
:
'30px'
}
}
>
机构选择
</
div
>
机构选择
</
div
>
</
Col
>
</
Col
>
<
Col
span=
{
12
}
>
<
Col
span=
{
12
}
>
<
TreeSelect
<
TreeSelect
style=
{
{
"width"
:
"50%"
}
}
style=
{
{
width
:
'50%'
}
}
treeData=
{
treeData
}
treeData=
{
treeData
}
value=
{
treeValue
}
value=
{
treeValue
}
onChange=
{
(
e
)
=>
{
treeChange
(
e
)}
}
onChange=
{
e
=>
{
treeChange
(
e
);
}
}
/>
/>
</
Col
>
</
Col
>
<
Col
span=
{
8
}
>
<
Col
span=
{
8
}
/>
{
/* <Search
placeholder="请输入"
onSearch={(e) =>{inputSearch(e)}}
style={{ width: "50%" }}
enterButton
/> */
}
</
Col
>
</
Row
>
</
Row
>
<
div
style=
{
{
marginTop
:
'20px'
,
textAlign
:
'center'
}
}
>
<
div
style=
{
{
marginTop
:
'20px'
,
textAlign
:
'center'
}
}
>
<
Space
>
<
Space
>
{
{
btnLable
&&
btnLable
&&
btnLable
.
map
(
(
item
,
index
)
=>
{
btnLable
.
map
((
item
,
index
)
=>
{
const
{
config
}
=
item
const
{
config
}
=
item
;
return
(
return
(
<
Button
key=
{
index
}
{
...
config
}
onClick
={
()=
>
{
item
.
handle
&&
typeof
item
.
handle
===
'function'
&&
item
.
handle
()
}
}
>
{
item
.
label
}
</
Button
>
<
Button
)
key=
{
index
}
})
{
...
config
}
}
onClick=
{
()
=>
{
item
.
handle
&&
typeof
item
.
handle
===
'function'
&&
item
.
handle
();
}
}
>
{
item
.
label
}
</
Button
>
);
})
}
</
Space
>
</
Space
>
</
div
>
</
div
>
<
TestModal
<
TestModal
title=
'用户选择'
title=
"用户选择"
visible
=
{
modalVisible
}
visible
=
{
modalVisible
}
maskClosable
maskClosable
onOk=
{
()
=>
confirmModal
()
}
onOk=
{
()
=>
confirmModal
()
}
onCancel=
{
()
=>
setModalVisible
(
false
)
}
onCancel=
{
()
=>
setModalVisible
(
false
)
}
bodyStyle
={{
width
:"100%",
height
:"100%",
}}
bodyStyle
=
{
{
width
:
'100%'
,
height
:
'100%'
}
}
style=
{
{
top
:
20
}
}
style=
{
{
top
:
20
}
}
width=
"1000px"
width=
"1000px"
destroyOnClose
=
{
true
}
destroyOnClose
cancelText=
'取消'
cancelText=
"取消"
okText=
'确认选择'
okText=
"确认选择"
>
>
<
ListCard
optionsList
={
testPeoList
}
></
ListCard
>
<
ListCard
optionsList
=
{
testPeoList
}
/
>
</
TestModal
>
</
TestModal
>
</
Card
>
</
Card
>
<
Card
className=
{
styles
.
mgTop20
}
>
<
Card
className=
{
styles
.
mgTop20
}
>
...
@@ -245,15 +231,15 @@ const DefaultComponent = ()=> {
...
@@ -245,15 +231,15 @@ const DefaultComponent = ()=> {
className=
{
styles
.
mgTop20
}
className=
{
styles
.
mgTop20
}
rowSelection=
{
rowSelection
}
rowSelection=
{
rowSelection
}
columns=
{
columns
}
columns=
{
columns
}
dataSource
={
tableData
}
dataSource=
{
tableData
}
bordered
bordered
rowKey=
'userID'
rowKey=
"userID"
scroll=
{
{
y
:
400
}
}
scroll=
{
{
y
:
400
}
}
></
Table
>
/
>
</
Card
>
</
Card
>
</
PageContainer
>
</
PageContainer
>
</>
</>
)
)
;
}
}
;
export
default
connect
()(
DefaultComponent
)
export
default
connect
()(
DefaultComponent
);
\ No newline at end of file
src/pages/orgnazation/ListCard.jsx
View file @
8ae4fd46
import
React
,
{
useState
,
useEffect
,
useCallback
}
from
'react'
;
import
React
,
{
useState
,
useEffect
,
useCallback
}
from
'react'
;
import
{
Spin
}
from
'antd'
;
import
{
Spin
,
Button
}
from
'antd'
;
import
ListCardItem
from
'./listCardItem'
;
import
ListCardItem
from
'./listCardItem'
;
import
{
get
,
post
}
from
'../../services'
;
import
{
get
,
post
}
from
'../../services'
;
import
{
orgTest
}
from
'../..
/services/orgnazation/api'
;
import
{
orgTest
}
from
'@
/services/orgnazation/api'
;
const
tip
=
'loading...'
const
tip
=
'loading...'
;
const
ListCard
=
(
props
)
=>
{
const
ListCard
=
props
=>
{
const
{
ouid
,
searchWord
}
=
props
const
{
ouid
,
searchWord
,
valueCallback
}
=
props
;
const
[
valueList
,
setValueList
]
=
useState
([])
const
[
valueList
,
setValueList
]
=
useState
([]);
const
[
testList
,
setTestList
]
=
useState
([])
const
[
dataList
,
setdataList
]
=
useState
([]);
const
[
loading
,
setLoading
]
=
useState
(
true
)
const
[
loading
,
setLoading
]
=
useState
(
true
);
const
{
optionsList
}
=
props
const
{
optionsList
}
=
props
;
const
getValueCallback
=
useCallback
(
const
getValueCallback
=
useCallback
((
value
,
index
)
=>
{
(
value
,
index
)
=>
{
console
.
log
(
value
,
index
);
console
.
log
(
value
,
index
)
setValueList
((
valueList
[
index
]
=
value
));
setValueList
(
valueList
[
index
]
=
value
)
console
.
log
(
valueList
,
'valueList'
);
console
.
log
(
valueList
,
'valueList'
)
},
[]);
},[])
useEffect
(()
=>
{
useEffect
(()
=>
{
setLoading
(
true
);
setLoading
(
true
)
const
defaultConfig
=
{
const
defaultConfig
=
{
optionsList
:
[],
optionsList
:[],
title
:
'默认组'
,
title
:
'默认组'
,
id
:
''
,
id
:
''
,
};
}
// /Cityinterface/rest/services/OMS.svc/U_GetUserListForBatchOper
get
(
"/Cityinterface/rest/services/OMS.svc/U_GetUserListForBatchOper"
,{
get
(
'/Cityinterface/rest/services/OMS.svc/P_GetUserByStation'
,
{
OUID
:
ouid
||
''
,
// OUID:ouid||'',
_version
:
9999
,
stationID
:
ouid
||
''
,
_dc
:
new
Date
().
getTime
()
_version
:
9999
,
}).
then
(
res
=>
{
_dc
:
new
Date
().
getTime
(),
setLoading
(
false
)
const
list
=
[]
res
&&
res
.
map
(
item
=>
{
list
.
push
({...
defaultConfig
,...
item
})
})
})
setTestList
(
list
)
.
then
(
res
=>
{
}).
catch
(
err
=>
{
setLoading
(
false
);
console
.
error
(
err
)
const
list
=
[];
setLoading
(
false
)
res
&&
res
.
map
(
item
=>
{
list
.
push
({
...
defaultConfig
,
...
item
});
});
setdataList
(
list
);
})
})
//多级嵌套测试
.
catch
(
err
=>
{
orgTest
().
then
(
res
=>
{
console
.
error
(
err
);
console
.
log
(
res
,
'res'
)
setLoading
(
false
);
})
});
},[
ouid
])
// 多级嵌套测试
// orgTest().then(res =>{
// console.log(res,'res')
// })
},
[
ouid
]);
return
(
return
(
<>
<
div
>
{
{
loading
?
(
loading
?
<
Spin
size=
"large"
spinning
=
{
loading
}
tip=
{
tip
}
style=
{
{
position
:
'absolute'
,
top
:
'30%'
,
left
:
'0'
,
right
:
'0'
,
bottom
:
'0'
}
}
/>
:
<
Spin
testList
&&
testList
.
map
((
item
,
index
)
=>
{
size=
"large"
return
(<
ListCardItem
{
...
item
}
itemid=
{
index
}
key=
{
index
}
spinning=
{
loading
}
getValueCallback=
{
getValueCallback
}
searchWord
={
searchWord
}
{
...
props
}
></
ListCardItem
>)
tip=
{
tip
}
})
style=
{
{
}
position
:
'absolute'
,
</>
top
:
'30%'
,
)
left
:
'0'
,
}
right
:
'0'
,
bottom
:
'0'
,
}
}
/>
)
:
(
dataList
&&
dataList
.
length
>
0
&&
dataList
.
map
((
item
,
index
)
=>
(
<
ListCardItem
{
...
item
}
itemid=
{
index
}
key=
{
`item${index}key`
}
getValueCallback=
{
getValueCallback
}
searchWord=
{
searchWord
}
{
...
props
}
/>
))
)
}
{
false
&&
!
loading
&&
dataList
&&
(
<
Button
type=
"primary"
onClick=
{
()
=>
valueCallback
(
valueList
)
}
style=
{
{
marginTop
:
'20px'
}
}
>
提交
</
Button
>
)
}
</
div
>
);
};
export
default
ListCard
export
default
ListCard
;
\ No newline at end of file
src/pages/orgnazation/ListCardItem.less
View file @
8ae4fd46
:global{
.spans span{
background-color: red !important;
}
}
.divBox {
.divBox {
display: flex;
display: flex;
flex-wrap: wrap;
flex-wrap: wrap;
border: 1px solid #b5b8c8;
border: 1px solid #b5b8c8;
margin-top: 20px;
margin-top: 20px;
min-height:
4
0px;
min-height:
5
0px;
.topCheckbox{
.topCheckbox{
height: 20px;
height: 20px;
background-color: #fff;
background-color: #fff;
...
@@ -20,17 +15,12 @@
...
@@ -20,17 +15,12 @@
margin-left: 20px;
margin-left: 20px;
justify-content: space-between;
justify-content: space-between;
.check {
.check {
margin: 10px 0 ;
// margin: 10px 0 ;
flex: 1;
// flex: 1;
.spans {
background-color: red !important;
span{
font-size: 200px;
display: none;
color: chartreuse !important;
}
}
}
}
}
}
}
}
.isSearch{
color: red;
background-color: yellow;
}
\ No newline at end of file
src/pages/orgnazation/listCardItem.jsx
View file @
8ae4fd46
import
React
,{
useState
,
useEffect
}
from
'react'
import
React
,
{
useState
,
useEffect
,
useRef
,
useLayoutEffect
}
from
'react'
;
import
{
import
{
Checkbox
,
Row
,
Col
}
from
'antd'
;
Checkbox
,
import
styles
from
'./ListCardItem.less'
;
Row
,
Col
}
from
'antd'
;
import
styles
from
'./ListCardItem.less'
const
CheckGroup
=
Checkbox
.
Group
;
const
CheckGroup
=
Checkbox
.
Group
;
const
ListCardItem
=
(
props
)
=>
{
const
ListCardItem
=
props
=>
{
console
.
log
(
props
.
searchWord
)
const
{
getValueCallback
,
itemid
,
userList
,
OUName
,
searchWord
}
=
props
;
const
[
indeterminate
,
setIndeterminate
]
=
useState
(
false
)
const
[
indeterminate
,
setIndeterminate
]
=
useState
(
false
);
const
[
allChecked
,
setAllChecked
]
=
useState
(
false
)
//全选状态
const
[
allChecked
,
setAllChecked
]
=
useState
(
false
);
// 全选状态
const
[
checkList
,
setCheckList
]
=
useState
([])
//复选框列表
const
[
checkList
,
setCheckList
]
=
useState
([]);
// 复选框列表选中的值
const
{
getValueCallback
,
itemid
,
userList
,
OUName
,
searchWord
}
=
props
const
[
defaultList
,
setDefaultList
]
=
useState
([]);
// 默认的选项
const
defaultList
=
userList
&&
userList
.
map
(
(
item
,
index
)
=>
{
useEffect
(()
=>
{
// if(!searchWord){
console
.
log
(
userList
,
'执行了`````'
);
// return
let
arr
=
[];
// }else{
userList
.
map
((
item
,
index
)
=>
{
// if(!item.userName.includes(searchWord))return
let
obj
=
{
...
item
};
// }
obj
.
label
=
(
item
.
label
=
item
.
userName
||
item
.
label
<
span
item
.
value
=
item
.
userID
||
item
.
label
className=
{
return
item
searchWord
&&
obj
.
userName
.
includes
(
searchWord
)
})
||
[]
?
styles
.
isSearch
:
''
const
handleAllChecked
=
(
e
)
=>
{
const
{
checked
}
=
e
.
target
setAllChecked
(
checked
)
let
arr
=
[]
if
(
checked
){
arr
=
defaultList
.
map
(
item
=>
{
item
.
isChecked
=
checked
return
item
})
}
else
{
arr
=
[]
}
}
setCheckList
(
arr
)
>
setIndeterminate
(
false
)
{
obj
.
userName
}
getValueCallback
(
arr
,
itemid
)
</
span
>
);
obj
.
value
=
obj
.
userID
;
arr
.
push
(
obj
);
});
setDefaultList
(
arr
);
},
[
searchWord
]);
useEffect
(()
=>
{
console
.
log
(
userList
,
'执行了`````'
);
let
arr2
=
[];
userList
.
map
((
item
,
index
)
=>
{
if
(
item
.
isChecked
)
{
arr2
.
push
(
item
.
userID
);
}
}
const
handleChecked
=
(
e
)
=>
{
});
setCheckList
(
e
)
;
setCheckList
(
arr2
);
setAllChecked
(
e
.
length
===
defaultList
.
length
)
},
[
userList
]);
setIndeterminate
(
!!
e
.
length
&&
e
.
length
<
defaultList
.
length
)
const
handleAllChecked
=
e
=>
{
getValueCallback
(
e
,
itemid
)
const
{
checked
}
=
e
.
target
;
setAllChecked
(
checked
);
let
arr
=
[];
if
(
checked
)
{
arr
=
defaultList
.
map
(
item
=>
item
.
value
);
}
else
{
arr
=
[];
}
}
setCheckList
(
arr
);
setIndeterminate
(
false
);
getValueCallback
(
arr
,
itemid
);
};
const
handleChecked
=
e
=>
{
console
.
log
(
e
,
'e45'
);
setCheckList
(
e
);
setAllChecked
(
e
.
length
===
defaultList
.
length
);
setIndeterminate
(
!!
e
.
length
&&
e
.
length
<
defaultList
.
length
);
getValueCallback
(
e
,
itemid
);
};
return
(
return
(
<>
<>
<
div
className
={`
$
{
styles
.
divBox
}`}
>
<
div
className=
{
`${styles.divBox}`
}
>
<
div
className=
{
styles
.
topCheckbox
}
>
<
div
className=
{
styles
.
topCheckbox
}
>
<
Checkbox
<
Checkbox
indeterminate
=
{
indeterminate
}
indeterminate=
{
indeterminate
}
checked=
{
allChecked
}
checked=
{
allChecked
}
onChange=
{
(
e
)
=>
{
handleAllChecked
(
e
)}
}
onChange=
{
e
=>
{
>
{
OUName
}
</
Checkbox
>
handleAllChecked
(
e
);
}
}
>
{
OUName
}
</
Checkbox
>
</
div
>
</
div
>
<
div
style=
{
{
width
:
"100%"
}
}
className
=
{
styles
.
checkdiv
}
>
<
div
style=
{
{
width
:
'100%'
}
}
className=
{
styles
.
checkdiv
}
>
{
/* {defaultList && defaultList.length>0 && <CheckGroup className = {`${styles.check} ${styles.span}`} onChange = {(e) => { handleChecked(e)}} value={checkList} options = {defaultList} /> } */
}
{
defaultList
&&
defaultList
.
length
>
0
&&
(
<
CheckGroup
onChange
=
{(
e
)
=
>
{
handleChecked
(
e
)
}
}
>
<
CheckGroup
className=
{
styles
.
check
}
onChange=
{
e
=>
{
handleChecked
(
e
);
}
}
value=
{
checkList
}
options=
{
defaultList
}
/>
)
}
{
/* { <CheckGroup onChange = {(e) => { handleChecked(e)}} >
{defaultList && defaultList.length>0 &&
{defaultList && defaultList.length>0 &&
defaultList.map( (item, index) =>{
defaultList.map( (item, index) =>{
return
item
.
label
.
includes
(
searchWord
)
&&
<
Checkbox
key=
{
index
}
checked=
{
item
.
isChecked
}
className=
{
item
.
label
.
includes
(
searchWord
)
&&
styles
.
spans
}
value=
{
item
.
value
}
>
{
item
.
label
}
</
Checkbox
>
return item.label.includes(searchWord) &&
<Checkbox key={index} value={item.value} >{item.label}{item.userID}{String(item.isChecked)}</Checkbox>
})
})
}
}
</
CheckGroup
>
</CheckGroup>} */
}
</
div
>
</
div
>
</
div
>
</
div
>
</>
</>
)
)
;
}
}
;
export
default
ListCardItem
export
default
ListCardItem
;
\ No newline at end of file
src/pages/userCenter/RoleManage/AddModal.jsx
0 → 100644
View file @
8ae4fd46
import
React
,
{
useState
}
from
'react'
;
import
{
Form
,
Input
,
notification
}
from
'antd'
;
import
SiteModal
from
'@/components/Modal/SiteModa'
;
import
{
addStation
}
from
'@/services/userCenter/siteManage/api'
;
const
{
Item
}
=
Form
;
const
AddModal
=
props
=>
{
const
[
form
]
=
Form
.
useForm
();
const
[
formLayout
,
setFormLayout
]
=
useState
(
'horizontal'
);
const
[
loading
,
setLoading
]
=
useState
(
false
);
const
{
confirmModal
}
=
props
;
const
onSubmit
=
()
=>
{
form
.
validateFields
()
.
then
(
res
=>
{
console
.
log
(
res
,
'res'
);
setLoading
(
true
);
addStation
({
stationName
:
res
.
stationName
,
description
:
res
.
description
,
_version
:
9999
,
_dc
:
new
Date
().
getTime
(),
})
.
then
(
res
=>
{
setLoading
(
false
);
if
(
res
.
success
)
{
form
.
resetFields
();
notification
.
success
({
message
:
'通知'
,
duration
:
3
,
description
:
'新增成功'
,
});
confirmModal
();
}
else
{
notification
.
error
({
message
:
'提示'
,
duration
:
3
,
description
:
res
.
message
,
});
}
})
.
catch
(
err
=>
{
setLoading
(
false
);
notification
.
error
({
message
:
'提示'
,
duration
:
3
,
description
:
err
,
});
});
})
.
catch
(
err
=>
{
console
.
error
(
err
);
});
};
const
onFinish
=
value
=>
{};
return
(
<
SiteModal
{
...
props
}
title=
"新增角色"
bodyStyle=
{
{
width
:
'100%'
,
minHeight
:
'100px'
}
}
style=
{
{
top
:
200
,
borderRadius
:
'20px'
}
}
width=
"600px"
destroyOnClose
cancelText=
"取消"
okText=
"确认选择"
onOk=
{
()
=>
onSubmit
()
}
confirmLoading=
{
loading
}
>
<
Form
form=
{
form
}
layout=
{
formLayout
}
onFinish=
{
onFinish
}
>
<
Item
label=
"角色名称"
name=
"stationName"
rules=
{
[
{
required
:
true
,
message
:
'请输入角色名称'
,
},
]
}
>
<
Input
placeholder=
"请输入角色名称"
/>
</
Item
>
<
Item
label=
"角色类别"
>
all
</
Item
>
<
Item
label=
"角色描述"
name=
"description"
>
<
Input
placeholder=
"请输入角色描述"
/>
</
Item
>
</
Form
>
</
SiteModal
>
);
};
export
default
AddModal
;
src/pages/userCenter/RoleManage/DelModal.jsx
0 → 100644
View file @
8ae4fd46
import
React
,
{
useState
}
from
'react'
;
import
{
notification
}
from
'antd'
;
import
SiteModal
from
'@/components/Modal/SiteModa'
;
import
{
deleteStation
}
from
'@/services/userCenter/siteManage/api'
;
const
DelModal
=
props
=>
{
const
{
confirmModal
,
stationId
}
=
props
;
const
[
loading
,
setLoading
]
=
useState
(
false
);
const
onSubmit
=
props
=>
{
setLoading
(
true
);
deleteStation
({
stationID
:
stationId
,
_version
:
9999
,
_dc
:
new
Date
().
getTime
(),
})
.
then
(
res
=>
{
setLoading
(
false
);
if
(
res
.
success
)
{
notification
.
success
({
message
:
'通知'
,
duration
:
3
,
description
:
'删除成功'
,
});
confirmModal
();
}
else
{
notification
.
error
({
message
:
'提示'
,
duration
:
3
,
description
:
res
.
message
,
});
}
})
.
catch
(
err
=>
{
setLoading
(
false
);
notification
.
error
({
message
:
'提示'
,
duration
:
3
,
description
:
err
,
});
});
};
return
(
<
SiteModal
{
...
props
}
title=
"删除角色"
bodyStyle=
{
{
width
:
'100%'
,
minHeight
:
'50px'
}
}
style=
{
{
top
:
200
}
}
width=
"400px"
destroyOnClose
cancelText=
"取消"
okText=
"确认删除"
onOk=
{
()
=>
onSubmit
()
}
confirmLoading=
{
loading
}
>
是否删除该角色?
</
SiteModal
>
);
};
export
default
DelModal
;
src/pages/userCenter/RoleManage/EditModal.jsx
0 → 100644
View file @
8ae4fd46
import
React
,
{
useState
,
useEffect
,
useRef
}
from
'react'
;
import
{
Form
,
Input
,
notification
}
from
'antd'
;
import
SiteModal
from
'@/components/Modal/SiteModa'
;
import
{
editStation
}
from
'@/services/userCenter/siteManage/api'
;
const
{
Item
}
=
Form
;
const
EditModal
=
props
=>
{
const
[
form
]
=
Form
.
useForm
();
const
[
formLayout
,
setFormLayout
]
=
useState
(
'horizontal'
);
const
[
loading
,
setLoading
]
=
useState
(
false
);
const
flag
=
useRef
();
const
{
confirmModal
,
stationObj
}
=
props
;
const
onSubmit
=
()
=>
{
form
.
validateFields
()
.
then
(
res
=>
{
setLoading
(
true
);
flag
.
current
=
res
;
editStation
({
stationName
:
res
.
stationName
,
description
:
res
.
description
,
stationID
:
stationObj
.
stationID
,
_version
:
9999
,
_dc
:
new
Date
().
getTime
(),
})
.
then
(
res
=>
{
setLoading
(
false
);
if
(
res
.
success
)
{
form
.
resetFields
();
notification
.
success
({
message
:
'通知'
,
duration
:
3
,
description
:
'编辑成功'
,
});
confirmModal
();
}
else
{
notification
.
error
({
message
:
'提示'
,
duration
:
3
,
description
:
res
.
message
,
});
}
})
.
catch
(
err
=>
{
setLoading
(
false
);
notification
.
error
({
message
:
'提示'
,
duration
:
3
,
description
:
err
,
});
});
})
.
catch
(
err
=>
{
console
.
error
(
err
);
});
};
useEffect
(()
=>
{
form
.
setFieldsValue
({
stationName
:
stationObj
.
text
,
description
:
stationObj
.
description
,
});
},
[
stationObj
]);
return
(
<
SiteModal
{
...
props
}
title=
"编辑角色"
bodyStyle=
{
{
width
:
'100%'
,
minHeight
:
'100px'
}
}
style=
{
{
top
:
200
,
borderRadius
:
'20px'
}
}
width=
"600px"
destroyOnClose
cancelText=
"取消"
okText=
"确认编辑"
onOk=
{
()
=>
onSubmit
()
}
confirmLoading=
{
loading
}
>
<
Form
form=
{
form
}
layout=
{
formLayout
}
>
<
Item
label=
"角色名称"
name=
"stationName"
rules=
{
[
{
required
:
true
,
message
:
'请输入角色名称'
,
},
]
}
>
<
Input
placeholder=
"请输入角色名称"
/>
</
Item
>
<
Item
label=
"角色类别"
>
all
</
Item
>
<
Item
label=
"角色描述"
name=
"description"
>
<
Input
placeholder=
"请输入角色描述"
/>
</
Item
>
</
Form
>
</
SiteModal
>
);
};
export
default
EditModal
;
src/pages/userCenter/RoleManage/RoleManage.jsx
0 → 100644
View file @
8ae4fd46
import
React
,
{
useState
,
useEffect
}
from
'react'
;
import
{
Row
,
Col
,
Tree
,
Card
,
Input
,
Tooltip
,
Button
}
from
'antd'
;
import
{
FileAddTwoTone
,
EditTwoTone
,
DeleteTwoTone
}
from
'@ant-design/icons'
;
import
{
PageContainer
,
GridContent
}
from
'@ant-design/pro-layout'
;
import
{
getWebModuleTree
}
from
'@/services/userCenter/RoleManage/api'
;
import
ListCard
from
'@/pages/orgnazation/ListCard'
;
import
styles
from
'@/pages/userCenter/RoleManage/RoleManage.less'
;
import
AddModal
from
'./AddModal'
;
import
DelModal
from
'./DelModal'
;
import
EditModal
from
'./EditModal'
;
const
{
Search
}
=
Input
;
const
placeholder
=
'请输入人员姓名'
;
const
SiteManage
=
()
=>
{
const
[
treeData
,
setTreeData
]
=
useState
([]);
const
[
searchWord
,
setSearchWord
]
=
useState
(
''
);
const
[
ouid
,
setOuid
]
=
useState
(
''
);
const
[
saveTreeId
,
setSaveTreeId
]
=
useState
(
''
);
// 保存点击回调的ird
const
[
modalVisible
,
setModalVisible
]
=
useState
(
false
);
// 新增弹窗
const
[
flag
,
setFlag
]
=
useState
(
1
);
const
[
stationId
,
setStationId
]
=
useState
(
''
);
// 选择的站点
const
[
stationObj
,
setStationObj
]
=
useState
({});
// 选择的站点
const
[
delVisible
,
setDelVisible
]
=
useState
(
false
);
// 删除弹窗
const
[
editVisible
,
setEditVisible
]
=
useState
(
false
);
// 修改弹窗
const
now
=
new
Date
().
getTime
();
// 点击树的回调
const
handleTreeSelect
=
e
=>
{
console
.
log
(
e
);
let
id
=
e
[
0
];
if
(
id
)
{
setSaveTreeId
(
id
);
setOuid
(
id
);
}
else
{
setOuid
(
saveTreeId
);
}
};
useEffect
(()
=>
{
getWebModuleTree
({
userMode
:
'super'
,
select
:
''
,
_version
:
9999
,
_dc
:
now
,
node
:
-
2
,
})
.
then
(
res
=>
{
let
arr
=
[];
if
(
res
)
{
arr
.
push
(
res
.
find
(
item
=>
item
.
id
===
'Web4StationRoot'
));
console
.
log
(
arr
,
'arr'
);
}
let
arr2
=
transTree
(
arr
);
setTreeData
(
arr2
);
})
.
catch
(
err
=>
{
console
.
error
(
err
);
});
},
[
flag
]);
const
Title
=
props
=>
{
const
{
text
}
=
props
;
console
.
log
(
props
);
return
(
<
div
className=
{
styles
.
treeTitle
}
>
{
text
}
<
div
className=
{
styles
.
titleBox
}
>
<
Tooltip
title=
"新增站点"
>
<
FileAddTwoTone
onClick=
{
()
=>
{
handleAdd
(
props
);
}
}
/>
</
Tooltip
>
<
Tooltip
title=
"编辑站点"
>
<
EditTwoTone
onClick=
{
()
=>
{
handleEdit
(
props
);
}
}
/>
</
Tooltip
>
<
Tooltip
title=
"删除站点"
>
<
DeleteTwoTone
onClick=
{
()
=>
{
handleDel
(
props
);
}
}
/>
</
Tooltip
>
</
div
>
</
div
>
);
};
const
handleAdd
=
e
=>
{
console
.
log
(
e
);
setModalVisible
(
true
);
};
// 站点删除
const
handleDel
=
e
=>
{
setStationId
(
e
.
stationID
);
setDelVisible
(
true
);
};
// 编辑站点
const
handleEdit
=
e
=>
{
setStationObj
(
e
);
setEditVisible
(
true
);
};
// 树形数据转换
const
transTree
=
val
=>
{
console
.
log
(
val
);
let
arr
=
val
;
return
arr
.
map
((
item
,
index
)
=>
{
item
.
title
=
Title
(
item
)
||
item
.
text
;
item
.
key
=
item
.
stationID
||
''
;
let
obj
=
{};
if
(
Array
.
isArray
(
item
.
children
)
&&
item
.
children
.
length
>
0
)
{
transTree
(
item
.
children
);
obj
=
item
;
return
obj
;
}
return
item
;
});
};
// 获取搜索框的值
const
handleSearch
=
value
=>
{
setSearchWord
(
value
);
};
const
confirmModal
=
e
=>
{
setModalVisible
(
false
);
setFlag
(
flag
+
1
);
};
const
delModal
=
()
=>
{
setDelVisible
(
false
);
setFlag
(
flag
+
1
);
};
const
editModal
=
()
=>
{
setEditVisible
(
false
);
setFlag
(
flag
+
1
);
};
const
valueCallback
=
props
=>
{
console
.
log
(
props
);
};
return
(
<
PageContainer
>
<
GridContent
>
<
Row
gutter=
{
12
}
>
<
Col
lg=
{
6
}
md=
{
24
}
>
<
Card
className=
{
styles
.
cardBox
}
>
<
Tree
showLine=
{
{
showLeafIcon
:
false
}
}
showIcon
onSelect=
{
e
=>
handleTreeSelect
(
e
)
}
treeData=
{
treeData
}
/>
<
AddModal
visible=
{
modalVisible
}
onCancel=
{
()
=>
setModalVisible
(
false
)
}
confirmModal=
{
confirmModal
}
/>
<
DelModal
visible=
{
delVisible
}
stationId=
{
stationId
}
onCancel=
{
()
=>
setDelVisible
(
false
)
}
confirmModal=
{
delModal
}
/>
<
EditModal
visible=
{
editVisible
}
stationObj=
{
stationObj
}
onCancel=
{
()
=>
setEditVisible
(
false
)
}
confirmModal=
{
editModal
}
/>
</
Card
>
</
Col
>
<
Col
lg=
{
18
}
md=
{
24
}
>
<
Card
className=
{
styles
.
cardBox
}
>
<
Row
align=
"middle"
>
<
Col
span=
{
1
}
>
搜索
</
Col
>
<
Col
span=
{
8
}
>
<
Search
allowClear
placeholder=
{
placeholder
}
onSearch=
{
handleSearch
}
enterButton
/>
</
Col
>
</
Row
>
{
ouid
&&
(
<
ListCard
ouid=
{
ouid
}
searchWord=
{
searchWord
}
valueCallback=
{
valueCallback
}
/>
)
}
</
Card
>
</
Col
>
</
Row
>
</
GridContent
>
</
PageContainer
>
);
};
export
default
SiteManage
;
src/pages/userCenter/RoleManage/RoleManage.less
0 → 100644
View file @
8ae4fd46
.cardBox{
min-height: calc(100vh - 200px);
}
.ant-tree-node-content-wrapper-open{
display: flex;
align-items: center;
}
.treeTitle {
display: flex;
span {
display: none;
}
}
.treeTitle:hover {
span {
margin-left: 20px;
display: block;
}
}
.titleBox{
display: flex;
// flex-wrap: wrap;
justify-content: space-around;
align-items: center;
}
\ No newline at end of file
src/pages/userCenter/siteManage/AddModal.jsx
View file @
8ae4fd46
import
React
,
{
useState
}
from
'react'
;
import
React
,
{
useState
}
from
'react'
;
import
{
import
{
Form
,
Input
,
notification
}
from
'antd'
;
Form
,
Input
,
notification
}
from
'antd'
import
SiteModal
from
'@/components/Modal/SiteModa'
;
import
SiteModal
from
'@/components/Modal/SiteModa'
;
import
{
addStation
}
from
'@/services/userCenter/siteManage/api'
;
import
{
addStation
}
from
'@/services/userCenter/siteManage/api'
;
const
{
Item
}
=
Form
const
{
Item
}
=
Form
;
const
AddModal
=
(
props
)
=>
{
const
AddModal
=
props
=>
{
const
[
form
]
=
Form
.
useForm
();
const
[
form
]
=
Form
.
useForm
();
const
[
formLayout
,
setFormLayout
]
=
useState
(
'horizontal'
);
const
[
formLayout
,
setFormLayout
]
=
useState
(
'horizontal'
);
const
[
loading
,
setLoading
]
=
useState
(
false
)
const
[
loading
,
setLoading
]
=
useState
(
false
);
const
{
confirmModal
}
=
props
const
{
confirmModal
}
=
props
;
const
onSubmit
=
()
=>
{
const
onSubmit
=
()
=>
{
form
.
validateFields
().
then
(
res
=>
{
form
console
.
log
(
res
,
'res'
)
.
validateFields
()
setLoading
(
true
)
.
then
(
res
=>
{
console
.
log
(
res
,
'res'
);
setLoading
(
true
);
addStation
({
addStation
({
stationName
:
res
.
stationName
,
stationName
:
res
.
stationName
,
description
:
res
.
description
,
description
:
res
.
description
,
_version
:
9999
,
_version
:
9999
,
_dc
:
new
Date
().
getTime
()
_dc
:
new
Date
().
getTime
(),
}).
then
(
res
=>
{
})
setLoading
(
false
)
.
then
(
res
=>
{
if
(
res
.
success
){
setLoading
(
false
);
form
.
resetFields
()
if
(
res
.
success
)
{
form
.
resetFields
();
notification
.
success
({
notification
.
success
({
message
:
'通知'
,
message
:
'通知'
,
duration
:
3
,
duration
:
3
,
description
:
'新增成功'
,
description
:
'新增成功'
,
});
});
confirmModal
()
confirmModal
();
}
else
{
}
else
{
notification
.
error
({
notification
.
error
({
message
:
'提示'
,
message
:
'提示'
,
duration
:
3
,
duration
:
3
,
description
:
res
.
message
,
description
:
res
.
message
,
});
});
}
}
}).
catch
(
err
=>
{
})
setLoading
(
false
)
.
catch
(
err
=>
{
setLoading
(
false
);
notification
.
error
({
notification
.
error
({
message
:
'提示'
,
message
:
'提示'
,
duration
:
3
,
duration
:
3
,
description
:
err
,
description
:
err
,
});
});
});
})
})
}).
catch
(
err
=>
{
.
catch
(
err
=>
{
console
.
error
(
err
)
console
.
error
(
err
);
})
});
}
}
;
const
onFinish
=
(
value
)
=>
{
const
onFinish
=
value
=>
{};
}
return
(
return
(
<
SiteModal
<
SiteModal
{
...
props
}
title=
'新增站点'
{
...
props
}
bodyStyle
={{
width
:"100%",
minHeight
:"100
px
"}}
title=
"新增站点"
style=
{
{
top
:
200
,
borderRadius
:
"20px"
,}
}
bodyStyle=
{
{
width
:
'100%'
,
minHeight
:
'100px'
}
}
style=
{
{
top
:
200
,
borderRadius
:
'20px'
}
}
width=
"600px"
width=
"600px"
destroyOnClose
=
{
true
}
destroyOnClose
cancelText=
'取消'
cancelText=
"取消"
okText=
'确认选择'
okText=
"确认选择"
onOk=
{
()
=>
onSubmit
()
}
onOk=
{
()
=>
onSubmit
()
}
confirmLoading=
{
loading
}
confirmLoading=
{
loading
}
>
>
<
Form
<
Form
form=
{
form
}
layout=
{
formLayout
}
onFinish=
{
onFinish
}
>
form=
{
form
}
<
Item
layout=
{
formLayout
}
label=
"站点名称"
onFinish=
{
onFinish
}
name=
"stationName"
>
<
Item
label=
'站点名称'
name=
'stationName'
rules=
{
[
rules=
{
[
{
{
required
:
true
,
required
:
true
,
...
@@ -77,15 +77,15 @@ const AddModal = (props) =>{
...
@@ -77,15 +77,15 @@ const AddModal = (props) =>{
},
},
]
}
]
}
>
>
<
Input
placeholder=
'请输入站点名称'
></
Input
>
<
Input
placeholder=
"请输入站点名称"
/
>
</
Item
>
</
Item
>
<
Item
label=
'站点类别'
>
all
</
Item
>
<
Item
label=
"站点类别"
>
all
</
Item
>
<
Item
label=
'站点描述'
name=
'description'
>
<
Item
label=
"站点描述"
name=
"description"
>
<
Input
placeholder=
'请输入站点描述'
></
Input
>
<
Input
placeholder=
"请输入站点描述"
/
>
</
Item
>
</
Item
>
</
Form
>
</
Form
>
</
SiteModal
>
</
SiteModal
>
)
)
;
}
}
;
export
default
AddModal
export
default
AddModal
;
src/pages/userCenter/siteManage/DelModal.jsx
View file @
8ae4fd46
import
React
,
{
useState
}
from
'react'
;
import
React
,
{
useState
}
from
'react'
;
import
{
import
{
notification
}
from
'antd'
;
notification
}
from
'antd'
import
SiteModal
from
'@/components/Modal/SiteModa'
;
import
SiteModal
from
'@/components/Modal/SiteModa'
;
import
{
deleteStation
}
from
'@/services/userCenter/siteManage/api'
import
{
deleteStation
}
from
'@/services/userCenter/siteManage/api'
;
const
DelModal
=
(
props
)
=>
{
const
DelModal
=
props
=>
{
const
{
confirmModal
,
stationId
}
=
props
const
{
confirmModal
,
stationId
}
=
props
;
const
[
loading
,
setLoading
]
=
useState
(
false
)
const
[
loading
,
setLoading
]
=
useState
(
false
);
const
onSubmit
=
(
props
)
=>
{
const
onSubmit
=
props
=>
{
setLoading
(
true
)
setLoading
(
true
)
;
deleteStation
({
deleteStation
({
stationID
:
stationId
,
stationID
:
stationId
,
_version
:
9999
,
_version
:
9999
,
_dc
:
new
Date
().
getTime
()
_dc
:
new
Date
().
getTime
(),
}).
then
(
res
=>
{
})
setLoading
(
false
)
.
then
(
res
=>
{
if
(
res
.
success
){
setLoading
(
false
);
if
(
res
.
success
)
{
notification
.
success
({
notification
.
success
({
message
:
'通知'
,
message
:
'通知'
,
duration
:
3
,
duration
:
3
,
description
:
'删除成功'
,
description
:
'删除成功'
,
});
});
confirmModal
()
confirmModal
();
}
else
{
}
else
{
notification
.
error
({
notification
.
error
({
message
:
'提示'
,
message
:
'提示'
,
duration
:
3
,
duration
:
3
,
description
:
res
.
message
,
description
:
res
.
message
,
});
});
}
}
}).
catch
(
err
=>
{
})
setLoading
(
false
)
.
catch
(
err
=>
{
setLoading
(
false
);
notification
.
error
({
notification
.
error
({
message
:
'提示'
,
message
:
'提示'
,
duration
:
3
,
duration
:
3
,
description
:
err
description
:
err
,
});
});
})
});
}
};
return
(
return
(
<
SiteModal
{
...
props
}
title=
'删除站点'
<
SiteModal
bodyStyle
={{
width
:"100%",
minHeight
:"50
px
",}}
{
...
props
}
style=
{
{
top
:
200
}
}
title=
"删除站点"
bodyStyle=
{
{
width
:
'100%'
,
minHeight
:
'50px'
}
}
style=
{
{
top
:
200
}
}
width=
"400px"
width=
"400px"
destroyOnClose
=
{
true
}
destroyOnClose
cancelText=
'取消'
cancelText=
"取消"
okText=
'确认删除'
okText=
"确认删除"
onOk=
{
()
=>
onSubmit
()
}
onOk=
{
()
=>
onSubmit
()
}
confirmLoading=
{
loading
}
confirmLoading=
{
loading
}
>
>
是否删除该站点?
是否删除该站点?
</
SiteModal
>
</
SiteModal
>
)
)
;
}
}
;
export
default
DelModal
export
default
DelModal
;
src/pages/userCenter/siteManage/EditModal.jsx
View file @
8ae4fd46
import
React
,
{
useState
,
useEffect
,
useRef
}
from
'react'
;
import
React
,
{
useState
,
useEffect
,
useRef
}
from
'react'
;
import
{
import
{
Form
,
Input
,
notification
}
from
'antd'
;
Form
,
Input
,
notification
}
from
'antd'
import
SiteModal
from
'@/components/Modal/SiteModa'
;
import
SiteModal
from
'@/components/Modal/SiteModa'
;
import
{
editStation
}
from
'@/services/userCenter/siteManage/api'
;
import
{
editStation
}
from
'@/services/userCenter/siteManage/api'
;
const
{
Item
}
=
Form
const
{
Item
}
=
Form
;
const
EditModal
=
(
props
)
=>
{
const
EditModal
=
props
=>
{
const
[
form
]
=
Form
.
useForm
();
const
[
form
]
=
Form
.
useForm
();
const
[
formLayout
,
setFormLayout
]
=
useState
(
'horizontal'
);
const
[
formLayout
,
setFormLayout
]
=
useState
(
'horizontal'
);
const
[
loading
,
setLoading
]
=
useState
(
false
)
const
[
loading
,
setLoading
]
=
useState
(
false
);
const
flag
=
useRef
()
const
flag
=
useRef
();
const
{
confirmModal
,
stationObj
}
=
props
const
{
confirmModal
,
stationObj
}
=
props
;
const
onSubmit
=
()
=>
{
const
onSubmit
=
()
=>
{
form
.
validateFields
().
then
(
res
=>
{
form
setLoading
(
true
)
.
validateFields
()
flag
.
current
=
res
.
then
(
res
=>
{
setLoading
(
true
);
flag
.
current
=
res
;
editStation
({
editStation
({
stationName
:
res
.
stationName
,
stationName
:
res
.
stationName
,
description
:
res
.
description
,
description
:
res
.
description
,
stationID
:
stationObj
.
stationID
,
stationID
:
stationObj
.
stationID
,
_version
:
9999
,
_version
:
9999
,
_dc
:
new
Date
().
getTime
()
_dc
:
new
Date
().
getTime
(),
}).
then
(
res
=>
{
})
setLoading
(
false
)
.
then
(
res
=>
{
if
(
res
.
success
){
setLoading
(
false
);
form
.
resetFields
()
if
(
res
.
success
)
{
form
.
resetFields
();
notification
.
success
({
notification
.
success
({
message
:
'通知'
,
message
:
'通知'
,
duration
:
3
,
duration
:
3
,
description
:
'编辑成功'
,
description
:
'编辑成功'
,
});
});
confirmModal
()
confirmModal
();
}
else
{
}
else
{
notification
.
error
({
notification
.
error
({
message
:
'提示'
,
message
:
'提示'
,
duration
:
3
,
duration
:
3
,
description
:
res
.
message
,
description
:
res
.
message
,
});
});
}
}
}).
catch
(
err
=>
{
})
setLoading
(
false
)
.
catch
(
err
=>
{
setLoading
(
false
);
notification
.
error
({
notification
.
error
({
message
:
'提示'
,
message
:
'提示'
,
duration
:
3
,
duration
:
3
,
description
:
err
,
description
:
err
,
});
});
});
})
})
}).
catch
(
err
=>
{
.
catch
(
err
=>
{
console
.
error
(
err
)
console
.
error
(
err
);
})
});
}
}
;
useEffect
(
()
=>
{
useEffect
(
()
=>
{
form
.
setFieldsValue
({
form
.
setFieldsValue
({
stationName
:
stationObj
.
text
,
stationName
:
stationObj
.
text
,
description
:
stationObj
.
description
description
:
stationObj
.
description
,
})
});
return
()
=>
{
},
[
stationObj
]);
console
.
log
(
flag
.
current
)
return
(
form
.
setFieldsValue
(
flag
.
current
)
<
SiteModal
}
{
...
props
}
},[
stationObj
])
title=
"编辑站点"
return
(
bodyStyle=
{
{
width
:
'100%'
,
minHeight
:
'100px'
}
}
<
SiteModal
{
...
props
}
title=
'编辑站点'
style=
{
{
top
:
200
,
borderRadius
:
'20px'
}
}
bodyStyle
={{
width
:"100%",
minHeight
:"100
px
"}}
style=
{
{
top
:
200
,
borderRadius
:
"20px"
,}
}
width=
"600px"
width=
"600px"
destroyOnClose
=
{
true
}
destroyOnClose
cancelText=
'取消'
cancelText=
"取消"
okText=
'确认编辑'
okText=
"确认编辑"
onOk=
{
()
=>
onSubmit
()
}
onOk=
{
()
=>
onSubmit
()
}
confirmLoading=
{
loading
}
confirmLoading=
{
loading
}
>
>
<
Form
<
Form
form=
{
form
}
layout=
{
formLayout
}
>
form=
{
form
}
<
Item
layout=
{
formLayout
}
label=
"站点名称"
>
name=
"stationName"
<
Item
label=
'站点名称'
name=
'stationName'
rules=
{
[
rules=
{
[
{
{
required
:
true
,
required
:
true
,
...
@@ -85,15 +83,15 @@ const EditModal = (props) =>{
...
@@ -85,15 +83,15 @@ const EditModal = (props) =>{
},
},
]
}
]
}
>
>
<
Input
placeholder=
'请输入站点名称'
></
Input
>
<
Input
placeholder=
"请输入站点名称"
/
>
</
Item
>
</
Item
>
<
Item
label=
'站点类别'
>
all
</
Item
>
<
Item
label=
"站点类别"
>
all
</
Item
>
<
Item
label=
'站点描述'
name=
'description'
>
<
Item
label=
"站点描述"
name=
"description"
>
<
Input
placeholder=
'请输入站点描述'
></
Input
>
<
Input
placeholder=
"请输入站点描述"
/
>
</
Item
>
</
Item
>
</
Form
>
</
Form
>
</
SiteModal
>
</
SiteModal
>
)
)
;
}
}
;
export
default
EditModal
export
default
EditModal
;
src/pages/userCenter/siteManage/SiteManage.jsx
View file @
8ae4fd46
import
React
,
{
useState
,
useEffect
}
from
'react'
;
import
React
,
{
useState
,
useEffect
}
from
'react'
;
import
{
Row
,
Col
,
Tree
,
Card
,
Input
,
Tooltip
}
from
'antd'
;
import
{
Row
,
Col
,
Tree
,
Card
,
Input
,
Tooltip
,
Button
}
from
'antd'
;
import
{
import
{
FileAddTwoTone
,
EditTwoTone
,
DeleteTwoTone
}
from
'@ant-design/icons'
;
FileAddTwoTone
,
EditTwoTone
,
DeleteTwoTone
,
}
from
'@ant-design/icons'
;
import
{
PageContainer
,
GridContent
}
from
'@ant-design/pro-layout'
;
import
{
PageContainer
,
GridContent
}
from
'@ant-design/pro-layout'
;
import
{
get
OUTree
,
getWebModuleTree
}
from
'@/services/userCenter/siteManage/api'
;
import
{
get
WebModuleTree
}
from
'@/services/userCenter/siteManage/api'
;
import
ListCard
from
'@/pages/orgnazation/ListCard'
;
import
ListCard
from
'@/pages/orgnazation/ListCard'
;
import
styles
from
'@/pages/userCenter/siteManage/SiteManage.less'
;
import
styles
from
'@/pages/userCenter/siteManage/SiteManage.less'
;
import
AddModal
from
'./AddModal'
import
AddModal
from
'./AddModal'
;
import
DelModal
from
'./DelModal'
import
DelModal
from
'./DelModal'
;
import
EditModal
from
'./EditModal'
import
EditModal
from
'./EditModal'
;
const
{
Search
}
=
Input
;
const
{
Search
}
=
Input
;
const
placeholder
=
'请输入人员姓名'
const
placeholder
=
'请输入人员姓名'
;
const
SiteManage
=
()
=>
{
const
SiteManage
=
()
=>
{
const
[
treeData
,
setTreeData
]
=
useState
([])
const
[
treeData
,
setTreeData
]
=
useState
([]);
const
[
searchWord
,
setSearchWord
]
=
useState
(
''
)
const
[
searchWord
,
setSearchWord
]
=
useState
(
''
);
const
[
ouid
,
setOuid
]
=
useState
(
''
)
const
[
ouid
,
setOuid
]
=
useState
(
''
);
const
[
saveTreeId
,
setSaveTreeId
]
=
useState
(
''
)
//
保存点击回调的id
const
[
saveTreeId
,
setSaveTreeId
]
=
useState
(
''
)
;
//
保存点击回调的id
const
[
modalVisible
,
setModalVisible
]
=
useState
(
false
)
//
新增弹窗
const
[
modalVisible
,
setModalVisible
]
=
useState
(
false
)
;
//
新增弹窗
const
[
flag
,
setFlag
]
=
useState
(
1
)
const
[
flag
,
setFlag
]
=
useState
(
1
)
;
const
[
stationId
,
setStationId
]
=
useState
(
''
)
//
选择的站点
const
[
stationId
,
setStationId
]
=
useState
(
''
);
//
选择的站点
const
[
stationObj
,
setStationObj
]
=
useState
({})
//
选择的站点
const
[
stationObj
,
setStationObj
]
=
useState
({});
//
选择的站点
const
[
delVisible
,
setDelVisible
]
=
useState
(
false
)
//
删除弹窗
const
[
delVisible
,
setDelVisible
]
=
useState
(
false
)
;
//
删除弹窗
const
[
editVisible
,
setEditVisible
]
=
useState
(
false
)
//
修改弹窗
const
[
editVisible
,
setEditVisible
]
=
useState
(
false
)
;
//
修改弹窗
const
now
=
new
Date
().
getTime
()
const
now
=
new
Date
().
getTime
()
;
//点击树的回调
//
点击树的回调
const
handleTreeSelect
=
(
e
)
=>
{
const
handleTreeSelect
=
e
=>
{
console
.
log
(
e
)
console
.
log
(
e
)
;
let
id
=
e
[
0
]
let
id
=
e
[
0
]
;
if
(
id
)
{
if
(
id
)
{
setSaveTreeId
(
id
)
setSaveTreeId
(
id
)
;
setOuid
(
id
)
setOuid
(
id
)
;
}
else
{
}
else
{
setOuid
(
saveTreeId
)
setOuid
(
saveTreeId
)
;
}
}
}
}
;
useEffect
(()
=>
{
useEffect
(()
=>
{
getWebModuleTree
({
getWebModuleTree
({
userMode
:
"super"
,
userMode
:
'super'
,
select
:
''
,
select
:
''
,
_version
:
9999
,
_version
:
9999
,
_dc
:
now
,
_dc
:
now
,
node
:
-
2
node
:
-
2
,
}).
then
(
res
=>
{
})
let
arr
=
[]
.
then
(
res
=>
{
if
(
res
){
let
arr
=
[];
arr
.
push
(
res
.
find
(
item
=>
{
if
(
res
)
{
return
item
.
id
===
'Web4StationRoot'
arr
.
push
(
res
.
find
(
item
=>
item
.
id
===
'Web4StationRoot'
));
}))
console
.
log
(
arr
,
'arr'
);
console
.
log
(
arr
,
'arr'
)
}
}
let
arr2
=
transTree
(
arr
)
let
arr2
=
transTree
(
arr
);
setTreeData
(
arr2
)
setTreeData
(
arr2
);
}).
catch
(
err
=>
{
console
.
error
(
err
)
})
})
// getOUTree().then(res =>{
.
catch
(
err
=>
{
// let arr = transTree(res)
console
.
error
(
err
);
// setTreeData(arr)
});
// }).catch(err =>{
},
[
flag
]);
// console.error(err)
const
Title
=
props
=>
{
// })
const
{
text
}
=
props
;
},[
flag
])
const
Title
=
(
props
)
=>
{
const
{
text
}
=
props
return
(
return
(
<
div
className=
{
styles
.
treeTitle
}
>
<
div
className=
{
styles
.
treeTitle
}
>
{
text
}
{
text
}
<
div
className=
{
styles
.
titleBox
}
>
<
div
className=
{
styles
.
titleBox
}
>
<
Tooltip
title=
'新增站点'
><
FileAddTwoTone
onClick=
{
()
=>
{
handleAdd
(
props
)}
}
/></
Tooltip
>
<
Tooltip
title=
"新增站点"
>
<
Tooltip
title=
'编辑站点'
><
EditTwoTone
onClick=
{
()
=>
{
handleEdit
(
props
)}
}
/></
Tooltip
>
<
FileAddTwoTone
<
Tooltip
title=
'删除站点'
><
DeleteTwoTone
onClick=
{
()
=>
{
handleDel
(
props
)}
}
/></
Tooltip
>
onClick=
{
()
=>
{
handleAdd
(
props
);
}
}
/>
</
Tooltip
>
<
Tooltip
title=
"编辑站点"
>
<
EditTwoTone
onClick=
{
()
=>
{
handleEdit
(
props
);
}
}
/>
</
Tooltip
>
<
Tooltip
title=
"删除站点"
>
<
DeleteTwoTone
onClick=
{
()
=>
{
handleDel
(
props
);
}
}
/>
</
Tooltip
>
</
div
>
</
div
>
</
div
>
</
div
>
)
);
}
};
const
handleAdd
=
(
e
)
=>
{
const
handleAdd
=
e
=>
{
console
.
log
(
e
)
console
.
log
(
e
);
setModalVisible
(
true
)
setModalVisible
(
true
);
}
};
//站点删除
// 站点删除
const
handleDel
=
(
e
)
=>
{
const
handleDel
=
e
=>
{
setStationId
(
e
.
stationID
)
setStationId
(
e
.
stationID
);
setDelVisible
(
true
)
setDelVisible
(
true
);
}
};
//编辑站点
// 编辑站点
const
handleEdit
=
(
e
)
=>
{
const
handleEdit
=
e
=>
{
setStationObj
(
e
)
setStationObj
(
e
);
setEditVisible
(
true
)
setEditVisible
(
true
);
}
};
//树形数据转换
// 树形数据转换
const
transTree
=
(
val
)
=>
{
const
transTree
=
val
=>
{
let
arr
=
val
let
arr
=
val
;
return
arr
.
map
(
item
=>
{
return
arr
.
map
((
item
,
index
)
=>
{
item
.
title
=
Title
(
item
)
||
item
.
text
item
.
title
=
Title
(
item
)
||
item
.
text
;
item
.
key
=
item
.
id
item
.
key
=
item
.
stationID
||
''
;
// item.icon = (<img src={user_green} style={{marginBottom:'2px'}}/>)
let
obj
=
{};
let
obj
=
{}
if
(
Array
.
isArray
(
item
.
children
)
&&
item
.
children
.
length
>
0
)
{
if
(
Array
.
isArray
(
item
.
children
)
&&
item
.
children
.
length
>
0
){
transTree
(
item
.
children
);
transTree
(
item
.
children
)
obj
=
item
;
return
obj
=
item
return
obj
;
}
else
{
return
item
}
})
}
//获取搜索框的值
const
handleSearch
=
(
value
)
=>
{
setSearchWord
(
value
)
}
const
confirmModal
=
(
e
)
=>
{
setModalVisible
(
false
)
setFlag
(
flag
+
1
)
}
const
delModal
=
()
=>
{
setDelVisible
(
false
)
setFlag
(
flag
+
1
)
}
const
editModal
=
()
=>
{
setEditVisible
(
false
)
setFlag
(
flag
+
1
)
}
}
return
item
;
});
};
// 获取搜索框的值
const
handleSearch
=
value
=>
{
setSearchWord
(
value
);
};
const
confirmModal
=
e
=>
{
setModalVisible
(
false
);
setFlag
(
flag
+
1
);
};
const
delModal
=
()
=>
{
setDelVisible
(
false
);
setFlag
(
flag
+
1
);
};
const
editModal
=
()
=>
{
setEditVisible
(
false
);
setFlag
(
flag
+
1
);
};
const
valueCallback
=
props
=>
{
console
.
log
(
props
);
};
return
(
return
(
<
PageContainer
>
<
PageContainer
>
<
GridContent
>
<
GridContent
>
<
Row
gutter=
{
12
}
>
<
Row
gutter=
{
12
}
>
<
Col
lg=
{
6
}
md=
{
24
}
>
<
Col
lg=
{
6
}
md=
{
24
}
>
<
Card
className=
{
styles
.
cardBox
}
>
<
Card
className=
{
styles
.
cardBox
}
>
<
Tree
<
Tree
showLine=
{
{
showLeafIcon
:
false
}
}
showLine=
{
{
showLeafIcon
:
false
}
}
showIcon
showIcon
onSelect=
{
(
e
)
=>
handleTreeSelect
(
e
)
}
onSelect=
{
e
=>
handleTreeSelect
(
e
)
}
treeData=
{
treeData
}
treeData=
{
treeData
}
/>
/>
<
AddModal
<
AddModal
visible
=
{
modalVisible
}
visible
=
{
modalVisible
}
onCancel=
{
()
=>
setModalVisible
(
false
)
}
onCancel=
{
()
=>
setModalVisible
(
false
)
}
confirmModal=
{
confirmModal
}
confirmModal=
{
confirmModal
}
/>
/>
...
@@ -144,35 +154,42 @@ const SiteManage = ()=>{
...
@@ -144,35 +154,42 @@ const SiteManage = ()=>{
visible=
{
delVisible
}
visible=
{
delVisible
}
stationId=
{
stationId
}
stationId=
{
stationId
}
onCancel=
{
()
=>
setDelVisible
(
false
)
}
onCancel=
{
()
=>
setDelVisible
(
false
)
}
confirmModal
=
{
delModal
}
/>
confirmModal=
{
delModal
}
/>
<
EditModal
<
EditModal
visible=
{
editVisible
}
visible=
{
editVisible
}
stationObj=
{
stationObj
}
stationObj=
{
stationObj
}
onCancel=
{
()
=>
setEditVisible
(
false
)
}
onCancel=
{
()
=>
setEditVisible
(
false
)
}
confirmModal
=
{
editModal
}
confirmModal
=
{
editModal
}
/>
/>
</
Card
>
</
Card
>
</
Col
>
</
Col
>
<
Col
lg=
{
18
}
md=
{
24
}
>
<
Col
lg=
{
18
}
md=
{
24
}
>
<
Card
className=
{
styles
.
cardBox
}
>
<
Card
className=
{
styles
.
cardBox
}
>
<
Row
align=
'middle'
>
<
Row
align=
"middle"
>
<
Col
span=
{
1
}
>
搜索
</
Col
>
<
Col
span=
{
1
}
>
搜索
</
Col
>
<
Col
span=
{
8
}
>
<
Col
span=
{
8
}
>
<
Search
<
Search
allowClear
allowClear
placeholder
=
{
placeholder
}
placeholder
=
{
placeholder
}
onSearch
=
{
handleSearch
}
onSearch
=
{
handleSearch
}
enterButton
enterButton
/>
/>
</
Col
>
</
Col
>
</
Row
>
</
Row
>
{
ouid
&&
<
ListCard
ouid=
{
ouid
}
searchWord
=
{
searchWord
}
></
ListCard
>
}
{
ouid
&&
(
<
ListCard
ouid=
{
ouid
}
searchWord=
{
searchWord
}
valueCallback=
{
valueCallback
}
/>
)
}
</
Card
>
</
Card
>
</
Col
>
</
Col
>
</
Row
>
</
Row
>
</
GridContent
>
</
GridContent
>
</
PageContainer
>
</
PageContainer
>
)
)
;
}
}
;
export
default
SiteManage
export
default
SiteManage
;
src/pages/userCenter/siteManage/SiteManage.less
View file @
8ae4fd46
...
@@ -19,9 +19,7 @@
...
@@ -19,9 +19,7 @@
}
}
.titleBox{
.titleBox{
display: flex;
display: flex;
// flex-wrap: wrap;
justify-content: space-around;
justify-content: space-around;
align-items: center;
align-items: center;
}
}
.test{
border-radius: 200px;
}
\ No newline at end of file
src/routes/config.js
View file @
8ae4fd46
...
@@ -17,7 +17,7 @@ import RequestTest from '../pages/testPages/request';
...
@@ -17,7 +17,7 @@ import RequestTest from '../pages/testPages/request';
import
InitDataBase
from
'../pages/database/InitDataBase'
;
import
InitDataBase
from
'../pages/database/InitDataBase'
;
import
ManagementDataBase
from
'../pages/database/ManagementDataBase'
;
import
ManagementDataBase
from
'../pages/database/ManagementDataBase'
;
import
UserManage
from
'../pages/userCenter/UserManage'
;
import
UserManage
from
'../pages/userCenter/UserManage'
;
import
RoleManage
from
'../pages/userCenter/RoleManage'
;
import
RoleManage
from
'../pages/userCenter/RoleManage
/RoleManage
'
;
import
SiteManage
from
'../pages/userCenter/siteManage/SiteManage'
;
import
SiteManage
from
'../pages/userCenter/siteManage/SiteManage'
;
// import DefaultComponent from '../pages/orgnazation/DefaultComponent';
// import DefaultComponent from '../pages/orgnazation/DefaultComponent';
import
TestTable
from
'../pages/orgnazation/TestTable'
;
import
TestTable
from
'../pages/orgnazation/TestTable'
;
...
...
src/services/userCenter/RoleManage/api.js
0 → 100644
View file @
8ae4fd46
import
{
get
,
post
}
from
'@/services/index'
;
// 获取站点信息
export
const
getWebModuleTree
=
params
=>
get
(
'/Cityinterface/rest/services/OMS.svc/W4_GetWeb4ModuleTree'
,
params
);
// 新增站点
export
const
addStation
=
params
=>
get
(
'/Cityinterface/rest/services/OMS.svc/W4_AddStation'
,
params
);
// 删除站点
export
const
deleteStation
=
params
=>
get
(
'/Cityinterface/rest/services/OMS.svc/P_DeleteStation'
,
params
);
// 编辑站点
export
const
editStation
=
params
=>
get
(
'/Cityinterface/rest/services/OMS.svc/P_EditStation'
,
params
);
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment