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
79311bc5
Commit
79311bc5
authored
Oct 13, 2021
by
邓超
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
fix: 对运维平台进行优化,修改测试到的问题
parent
6f3ea24c
Pipeline
#35929
skipped with stages
Changes
14
Pipelines
1
Show whitespace changes
Inline
Side-by-side
Showing
14 changed files
with
894 additions
and
541 deletions
+894
-541
ManagementDataBase.jsx
src/pages/database/ManagementDataBase.jsx
+27
-0
miniMenu.jsx
src/pages/mobileConfig/menuconfig/miniMenu.jsx
+1
-1
index.less
...Center/bsmanager/tablemanager/components/Field/index.less
+1
-1
flow.jsx
src/pages/platformCenter/bsmanager/workFlow/flow.jsx
+16
-12
Timelimit.jsx
...ormCenter/bsmanager/workFlow/flowComponents/Timelimit.jsx
+7
-21
AddModal.jsx
.../workFlow/flowComponents/timelimitComponents/AddModal.jsx
+2
-4
flowNode.jsx
...s/platformCenter/bsmanager/workFlow/flowNode/flowNode.jsx
+55
-36
flowNode.less
.../platformCenter/bsmanager/workFlow/flowNode/flowNode.less
+4
-1
AuxiliaryView.jsx
...er/workFlow/flowNode/flowNodeComponents/AuxiliaryView.jsx
+36
-24
NodeEdit.jsx
...manager/workFlow/flowNode/flowNodeComponents/NodeEdit.jsx
+35
-40
Fieldselection.jsx
.../flowNodeComponents/nodeEditComponents/Fieldselection.jsx
+17
-15
fieldEditor.jsx
src/pages/platformCenter/filedConfig/fieldEditor.jsx
+484
-251
filedConfig.jsx
src/pages/platformCenter/filedConfig/filedConfig.jsx
+159
-77
UserManage.js
src/pages/userCenter/userManage/UserManage.js
+50
-58
No files found.
src/pages/database/ManagementDataBase.jsx
View file @
79311bc5
...
@@ -9,6 +9,7 @@ import {
...
@@ -9,6 +9,7 @@ import {
notification
,
notification
,
Spin
,
Spin
,
}
from
'antd'
;
}
from
'antd'
;
import
copy
from
'copy-to-clipboard'
;
import
PageContainer
from
'@/components/BasePageContainer'
;
import
PageContainer
from
'@/components/BasePageContainer'
;
import
styles
from
'./ManagementDataBase.less'
;
import
styles
from
'./ManagementDataBase.less'
;
import
{
import
{
...
@@ -177,6 +178,22 @@ const ManagementDataBase = () => {
...
@@ -177,6 +178,22 @@ const ManagementDataBase = () => {
// setContent(text);
// setContent(text);
setContent
(
arr
);
setContent
(
arr
);
};
};
// 复制SQL
const
copySql
=
text
=>
{
if
(
copy
(
text
))
{
notification
.
success
({
message
:
'提示'
,
duration
:
3
,
description
:
'复制成功'
,
});
}
else
{
notification
.
error
({
message
:
'提示'
,
duration
:
3
,
description
:
'复制失败'
,
});
}
};
const
autoCheckColumns
=
[
const
autoCheckColumns
=
[
{
{
title
:
'表名称'
,
title
:
'表名称'
,
...
@@ -212,6 +229,16 @@ const ManagementDataBase = () => {
...
@@ -212,6 +229,16 @@ const ManagementDataBase = () => {
key
:
'Message'
,
key
:
'Message'
,
ellipsis
:
true
,
ellipsis
:
true
,
},
},
{
title
:
'SQL语句'
,
dataIndex
:
'DiffSql'
,
key
:
'DiffSql'
,
render
:
text
=>
(
<
Button
size=
"small"
type=
"primary"
onClick=
{
()
=>
copySql
(
text
)
}
>
复制SQL
</
Button
>
),
},
];
];
const
logColumns
=
[
const
logColumns
=
[
{
{
...
...
src/pages/mobileConfig/menuconfig/miniMenu.jsx
View file @
79311bc5
...
@@ -431,7 +431,7 @@ const MiniMenu = props => {
...
@@ -431,7 +431,7 @@ const MiniMenu = props => {
dragMenu
({
dragMenu
({
menuID
:
obj
.
id
,
menuID
:
obj
.
id
,
newParentID
:
obj
.
parentId
||
-
1
,
newParentID
:
obj
.
parentId
.
toString
()
||
'-1'
,
menuList
:
String
(
arrList
)
||
''
,
menuList
:
String
(
arrList
)
||
''
,
_version
:
9999
,
_version
:
9999
,
_dc
:
Date
.
now
(),
_dc
:
Date
.
now
(),
...
...
src/pages/platformCenter/bsmanager/tablemanager/components/Field/index.less
View file @
79311bc5
...
@@ -6,7 +6,7 @@
...
@@ -6,7 +6,7 @@
max-height: 20rem;
max-height: 20rem;
overflow-y: scroll;
overflow-y: scroll;
.ant-card{
.ant-card{
width: 8
0
%;
width: 8
3
%;
margin-left: 4rem;
margin-left: 4rem;
}
}
.ant-card-head-title{
.ant-card-head-title{
...
...
src/pages/platformCenter/bsmanager/workFlow/flow.jsx
View file @
79311bc5
...
@@ -136,8 +136,9 @@ const Flow = () => {
...
@@ -136,8 +136,9 @@ const Flow = () => {
dataIndex
:
'extendWebPage'
,
dataIndex
:
'extendWebPage'
,
align
:
'center'
,
align
:
'center'
,
render
:
text
=>
(
render
:
text
=>
(
// eslint-disable-next-line react/no-danger
<
span
style=
{
{
color
:
text
===
'(默认)'
?
'grey'
:
'000000D9'
}
}
>
<
span
dangerouslySetInnerHTML=
{
{
__html
:
text
}
}
/>
{
text
}
</
span
>
),
),
},
},
{
{
...
@@ -145,8 +146,9 @@ const Flow = () => {
...
@@ -145,8 +146,9 @@ const Flow = () => {
dataIndex
:
'extendMobilePage'
,
dataIndex
:
'extendMobilePage'
,
align
:
'center'
,
align
:
'center'
,
render
:
text
=>
(
render
:
text
=>
(
// eslint-disable-next-line react/no-danger
<
span
style=
{
{
color
:
text
===
'(默认)'
?
'grey'
:
'000000D9'
}
}
>
<
span
dangerouslySetInnerHTML=
{
{
__html
:
text
}
}
/>
{
text
}
</
span
>
),
),
},
},
{
{
...
@@ -155,8 +157,9 @@ const Flow = () => {
...
@@ -155,8 +157,9 @@ const Flow = () => {
align
:
'center'
,
align
:
'center'
,
width
:
80
,
width
:
80
,
render
:
text
=>
(
render
:
text
=>
(
// eslint-disable-next-line react/no-danger
<
span
style=
{
{
color
:
text
===
'(无)'
?
'grey'
:
'000000D9'
}
}
>
<
span
dangerouslySetInnerHTML=
{
{
__html
:
text
}
}
/>
{
text
}
</
span
>
),
),
},
},
{
{
...
@@ -164,8 +167,9 @@ const Flow = () => {
...
@@ -164,8 +167,9 @@ const Flow = () => {
dataIndex
:
'flowEndBehavior'
,
dataIndex
:
'flowEndBehavior'
,
align
:
'center'
,
align
:
'center'
,
render
:
text
=>
(
render
:
text
=>
(
// eslint-disable-next-line react/no-danger
<
span
style=
{
{
color
:
text
===
'(不做处理)'
?
'grey'
:
'000000D9'
}
}
>
<
span
dangerouslySetInnerHTML=
{
{
__html
:
text
}
}
/>
{
text
}
</
span
>
),
),
},
},
{
{
...
@@ -179,8 +183,7 @@ const Flow = () => {
...
@@ -179,8 +183,7 @@ const Flow = () => {
dataIndex
:
'errorNodes'
,
dataIndex
:
'errorNodes'
,
align
:
'center'
,
align
:
'center'
,
render
:
text
=>
(
render
:
text
=>
(
// eslint-disable-next-line react/no-danger
<
span
style=
{
{
color
:
text
===
'(无)'
?
'grey'
:
'red'
}
}
>
{
text
}
</
span
>
<
span
dangerouslySetInnerHTML=
{
{
__html
:
text
}
}
/>
),
),
},
},
{
{
...
@@ -188,8 +191,9 @@ const Flow = () => {
...
@@ -188,8 +191,9 @@ const Flow = () => {
dataIndex
:
'interfaceConfig'
,
dataIndex
:
'interfaceConfig'
,
align
:
'center'
,
align
:
'center'
,
render
:
text
=>
(
render
:
text
=>
(
// eslint-disable-next-line react/no-danger
<
span
style=
{
{
color
:
text
===
'(无)'
?
'grey'
:
'000000D9'
}
}
>
<
span
dangerouslySetInnerHTML=
{
{
__html
:
text
}
}
/>
{
text
}
</
span
>
),
),
},
},
{
{
...
...
src/pages/platformCenter/bsmanager/workFlow/flowComponents/Timelimit.jsx
View file @
79311bc5
...
@@ -82,45 +82,30 @@ const Timelimit = props => {
...
@@ -82,45 +82,30 @@ const Timelimit = props => {
title
:
'规则名称'
,
title
:
'规则名称'
,
dataIndex
:
'Name'
,
dataIndex
:
'Name'
,
align
:
'center'
,
align
:
'center'
,
render
:
text
=>
(
// eslint-disable-next-line react/no-danger
<
span
dangerouslySetInnerHTML=
{
{
__html
:
text
}
}
/>
),
},
},
{
{
title
:
'开始节点'
,
title
:
'开始节点'
,
dataIndex
:
'StartNode'
,
dataIndex
:
'StartNode'
,
align
:
'center'
,
align
:
'center'
,
render
:
text
=>
(
// eslint-disable-next-line react/no-danger
<
span
dangerouslySetInnerHTML=
{
{
__html
:
text
}
}
/>
),
},
},
{
{
title
:
'结束节点'
,
title
:
'结束节点'
,
dataIndex
:
'EndNode'
,
dataIndex
:
'EndNode'
,
align
:
'center'
,
align
:
'center'
,
render
:
text
=>
(
// eslint-disable-next-line react/no-danger
<
span
dangerouslySetInnerHTML=
{
{
__html
:
text
}
}
/>
),
},
},
{
{
title
:
'默认时限'
,
title
:
'默认时限'
,
dataIndex
:
'TimeLimit'
,
dataIndex
:
'TimeLimit'
,
align
:
'center'
,
align
:
'center'
,
render
:
text
=>
(
// eslint-disable-next-line react/no-danger
<
span
dangerouslySetInnerHTML=
{
{
__html
:
text
}
}
/>
),
},
},
{
{
title
:
'时限指派字段'
,
title
:
'时限指派字段'
,
dataIndex
:
'TimeLimitField
Html
'
,
dataIndex
:
'TimeLimitField'
,
align
:
'center'
,
align
:
'center'
,
render
:
text
=>
(
render
:
text
=>
(
// eslint-disable-next-line react/no-danger
<
span
style=
{
{
color
:
text
===
'(未配置)'
?
'grey'
:
'#0000009D'
}
}
>
<
span
dangerouslySetInnerHTML=
{
{
__html
:
text
}
}
/>
{
text
}
</
span
>
),
),
},
},
{
{
...
@@ -128,8 +113,9 @@ const Timelimit = props => {
...
@@ -128,8 +113,9 @@ const Timelimit = props => {
dataIndex
:
'TimeoutField'
,
dataIndex
:
'TimeoutField'
,
align
:
'center'
,
align
:
'center'
,
render
:
text
=>
(
render
:
text
=>
(
// eslint-disable-next-line react/no-danger
<
span
style=
{
{
color
:
text
===
'(未配置)'
?
'grey'
:
'#0000009D'
}
}
>
<
span
dangerouslySetInnerHTML=
{
{
__html
:
text
}
}
/>
{
text
}
</
span
>
),
),
},
},
{
{
...
...
src/pages/platformCenter/bsmanager/workFlow/flowComponents/timelimitComponents/AddModal.jsx
View file @
79311bc5
...
@@ -230,8 +230,7 @@ const AddModal = props => {
...
@@ -230,8 +230,7 @@ const AddModal = props => {
<
Select
>
<
Select
>
{
timeLimitFlowNodes
.
map
(
item
=>
(
{
timeLimitFlowNodes
.
map
(
item
=>
(
<
Option
value=
{
item
.
Name
}
key=
{
item
.
ID
}
>
<
Option
value=
{
item
.
Name
}
key=
{
item
.
ID
}
>
{
/* eslint-disable-next-line react/no-danger */
}
<
span
>
{
item
.
Name
}
</
span
>
<
span
dangerouslySetInnerHTML=
{
{
__html
:
item
.
Name
}
}
/>
</
Option
>
</
Option
>
))
}
))
}
</
Select
>
</
Select
>
...
@@ -244,8 +243,7 @@ const AddModal = props => {
...
@@ -244,8 +243,7 @@ const AddModal = props => {
<
Select
>
<
Select
>
{
timeLimitFlowNodes
.
map
(
item
=>
(
{
timeLimitFlowNodes
.
map
(
item
=>
(
<
Option
value=
{
item
.
Name
}
key=
{
item
.
ID
}
>
<
Option
value=
{
item
.
Name
}
key=
{
item
.
ID
}
>
{
/* eslint-disable-next-line react/no-danger */
}
<
span
>
{
item
.
Name
}
</
span
>
<
span
dangerouslySetInnerHTML=
{
{
__html
:
item
.
Name
}
}
/>
</
Option
>
</
Option
>
))
}
))
}
</
Select
>
</
Select
>
...
...
src/pages/platformCenter/bsmanager/workFlow/flowNode/flowNode.jsx
View file @
79311bc5
...
@@ -93,6 +93,17 @@ const FlowNode = () => {
...
@@ -93,6 +93,17 @@ const FlowNode = () => {
}
}
setExpandedRowKeys
(
data
);
setExpandedRowKeys
(
data
);
};
};
// 表格内文案样式
const
textStyleOne
=
(
text
,
record
)
=>
{
if
(
record
.
colorType
===
2
)
{
return
'red'
;
}
if
(
text
===
'(未配置)'
)
{
return
'grey'
;
}
return
'000000D9'
;
};
// 定义展开的表格
// 定义展开的表格
const
createUnfoldTable
=
itemTable
=>
{
const
createUnfoldTable
=
itemTable
=>
{
const
columns
=
[
const
columns
=
[
...
@@ -101,12 +112,15 @@ const FlowNode = () => {
...
@@ -101,12 +112,15 @@ const FlowNode = () => {
dataIndex
:
'name'
,
dataIndex
:
'name'
,
width
:
149
,
width
:
149
,
align
:
'left'
,
align
:
'left'
,
render
:
text
=>
(
render
:
(
text
,
record
)
=>
(
<
div
<
div
style=
{
{
paddingLeft
:
60
}
}
style=
{
{
// eslint-disable-next-line react/no-danger
paddingLeft
:
60
,
dangerouslySetInnerHTML=
{
{
__html
:
text
}
}
color
:
record
.
colorType
===
2
?
'red'
:
'#000000D9'
,
/>
}
}
>
{
text
}
</
div
>
),
),
},
},
{
{
...
@@ -114,19 +128,15 @@ const FlowNode = () => {
...
@@ -114,19 +128,15 @@ const FlowNode = () => {
dataIndex
:
'aliasName'
,
dataIndex
:
'aliasName'
,
align
:
'center'
,
align
:
'center'
,
width
:
80
,
width
:
80
,
render
:
text
=>
(
render
:
text
=>
<
span
>
{
text
}
</
span
>,
// eslint-disable-next-line react/no-danger
<
span
dangerouslySetInnerHTML=
{
{
__html
:
text
}
}
/>
),
},
},
{
{
title
:
'移交方式'
,
title
:
'移交方式'
,
dataIndex
:
'extendHandover'
,
dataIndex
:
'extendHandover'
,
align
:
'center'
,
align
:
'center'
,
width
:
80
,
width
:
80
,
render
:
text
=>
(
render
:
(
text
,
record
)
=>
(
// eslint-disable-next-line react/no-danger
<
span
style=
{
{
color
:
textStyleOne
(
text
,
record
)
}
}
>
{
text
}
</
span
>
<
span
dangerouslySetInnerHTML=
{
{
__html
:
text
}
}
/>
),
),
},
},
{
{
...
@@ -134,9 +144,8 @@ const FlowNode = () => {
...
@@ -134,9 +144,8 @@ const FlowNode = () => {
dataIndex
:
'extendNodeType'
,
dataIndex
:
'extendNodeType'
,
align
:
'center'
,
align
:
'center'
,
width
:
80
,
width
:
80
,
render
:
text
=>
(
render
:
(
text
,
record
)
=>
(
// eslint-disable-next-line react/no-danger
<
span
style=
{
{
color
:
textStyleOne
(
text
,
record
)
}
}
>
{
text
}
</
span
>
<
span
dangerouslySetInnerHTML=
{
{
__html
:
text
}
}
/>
),
),
},
},
{
{
...
@@ -147,10 +156,9 @@ const FlowNode = () => {
...
@@ -147,10 +156,9 @@ const FlowNode = () => {
ellipsis
:
{
ellipsis
:
{
showTitle
:
true
,
showTitle
:
true
,
},
},
render
:
text
=>
(
render
:
(
text
,
record
)
=>
(
<
Tooltip
placement=
"topLeft"
title=
{
text
}
>
<
Tooltip
placement=
"topLeft"
title=
{
text
}
>
{
/* eslint-disable-next-line react/no-danger */
}
<
span
style=
{
{
color
:
textStyleOne
(
text
,
record
)
}
}
>
{
text
}
</
span
>
<
span
dangerouslySetInnerHTML=
{
{
__html
:
text
}
}
/>
</
Tooltip
>
</
Tooltip
>
),
),
},
},
...
@@ -159,15 +167,21 @@ const FlowNode = () => {
...
@@ -159,15 +167,21 @@ const FlowNode = () => {
dataIndex
:
'extendSeeFields'
,
dataIndex
:
'extendSeeFields'
,
align
:
'center'
,
align
:
'center'
,
width
:
80
,
width
:
80
,
render
:
(
text
,
record
)
=>
(
<
span
style=
{
{
color
:
record
.
colorType
===
2
?
'red'
:
'#000000D9'
}
}
>
{
text
}
</
span
>
),
},
},
{
{
title
:
'字段'
,
title
:
'字段'
,
dataIndex
:
'extendFields'
,
dataIndex
:
'extendFields'
,
align
:
'center'
,
align
:
'center'
,
width
:
80
,
width
:
80
,
render
:
text
=>
(
render
:
(
text
,
record
)
=>
(
// eslint-disable-next-line react/no-danger
<
span
style=
{
{
color
:
record
.
colorType
===
2
?
'red'
:
'#000000D9'
}
}
>
<
span
dangerouslySetInnerHTML=
{
{
__html
:
text
}
}
/>
{
text
}
</
span
>
),
),
},
},
...
@@ -176,9 +190,10 @@ const FlowNode = () => {
...
@@ -176,9 +190,10 @@ const FlowNode = () => {
dataIndex
:
'extendEditableLater'
,
dataIndex
:
'extendEditableLater'
,
align
:
'center'
,
align
:
'center'
,
width
:
80
,
width
:
80
,
render
:
text
=>
(
render
:
(
text
,
record
)
=>
(
// eslint-disable-next-line react/no-danger
<
span
style=
{
{
color
:
record
.
colorType
===
2
?
'red'
:
'#000000D9'
}
}
>
<
span
dangerouslySetInnerHTML=
{
{
__html
:
text
}
}
/>
{
text
}
</
span
>
),
),
},
},
{
{
...
@@ -186,9 +201,10 @@ const FlowNode = () => {
...
@@ -186,9 +201,10 @@ const FlowNode = () => {
dataIndex
:
'extendRollbackable'
,
dataIndex
:
'extendRollbackable'
,
align
:
'center'
,
align
:
'center'
,
width
:
80
,
width
:
80
,
render
:
text
=>
(
render
:
(
text
,
record
)
=>
(
// eslint-disable-next-line react/no-danger
<
span
style=
{
{
color
:
record
.
colorType
===
2
?
'red'
:
'#000000D9'
}
}
>
<
span
dangerouslySetInnerHTML=
{
{
__html
:
text
}
}
/>
{
text
}
</
span
>
),
),
},
},
{
{
...
@@ -196,9 +212,10 @@ const FlowNode = () => {
...
@@ -196,9 +212,10 @@ const FlowNode = () => {
dataIndex
:
'extendRollbackNode'
,
dataIndex
:
'extendRollbackNode'
,
align
:
'center'
,
align
:
'center'
,
width
:
80
,
width
:
80
,
render
:
text
=>
(
render
:
(
text
,
record
)
=>
(
// eslint-disable-next-line react/no-danger
<
span
style=
{
{
color
:
record
.
colorType
===
2
?
'red'
:
'#000000D9'
}
}
>
<
span
dangerouslySetInnerHTML=
{
{
__html
:
text
}
}
/>
{
text
}
</
span
>
),
),
},
},
{
{
...
@@ -206,9 +223,10 @@ const FlowNode = () => {
...
@@ -206,9 +223,10 @@ const FlowNode = () => {
dataIndex
:
'tranferable'
,
dataIndex
:
'tranferable'
,
align
:
'center'
,
align
:
'center'
,
width
:
80
,
width
:
80
,
render
:
text
=>
(
render
:
(
text
,
record
)
=>
(
// eslint-disable-next-line react/no-danger
<
span
style=
{
{
color
:
record
.
colorType
===
2
?
'red'
:
'#000000D9'
}
}
>
<
span
dangerouslySetInnerHTML=
{
{
__html
:
text
}
}
/>
{
text
}
</
span
>
),
),
},
},
{
{
...
@@ -216,9 +234,10 @@ const FlowNode = () => {
...
@@ -216,9 +234,10 @@ const FlowNode = () => {
dataIndex
:
'eventInformation'
,
dataIndex
:
'eventInformation'
,
align
:
'center'
,
align
:
'center'
,
width
:
80
,
width
:
80
,
render
:
text
=>
(
render
:
(
text
,
record
)
=>
(
// eslint-disable-next-line react/no-danger
<
span
style=
{
{
color
:
record
.
colorType
===
2
?
'red'
:
'#000000D9'
}
}
>
<
span
dangerouslySetInnerHTML=
{
{
__html
:
text
}
}
/>
{
text
}
</
span
>
),
),
},
},
{
{
...
...
src/pages/platformCenter/bsmanager/workFlow/flowNode/flowNode.less
View file @
79311bc5
...
@@ -28,8 +28,11 @@
...
@@ -28,8 +28,11 @@
// 编辑节点表单
// 编辑节点表单
.formData {
.formData {
height:
32rem
;
height:
calc(100vh - 162px)
;
overflow-y: scroll;
overflow-y: scroll;
.ant-radio-wrapper {
min-width: 130px;
}
.filedListItem {
.filedListItem {
display: flex;
display: flex;
flex-wrap: nowrap;
flex-wrap: nowrap;
...
...
src/pages/platformCenter/bsmanager/workFlow/flowNode/flowNodeComponents/AuxiliaryView.jsx
View file @
79311bc5
...
@@ -85,55 +85,67 @@ const AuxiliaryView = props => {
...
@@ -85,55 +85,67 @@ const AuxiliaryView = props => {
title
:
'前端便签'
,
title
:
'前端便签'
,
dataIndex
:
'WebLabel'
,
dataIndex
:
'WebLabel'
,
align
:
'center'
,
align
:
'center'
,
render
:
text
=>
(
render
:
text
=>
{
// eslint-disable-next-line react/no-danger
if
(
text
===
'(未配置)'
||
text
===
'(无)'
)
{
<
span
dangerouslySetInnerHTML=
{
{
__html
:
text
}
}
/>
return
<
span
style=
{
{
color
:
'grey'
}
}
>
{
text
}
</
span
>;
),
}
return
<
span
>
{
text
}
</
span
>;
},
},
},
{
{
title
:
'前端视图'
,
title
:
'前端视图'
,
dataIndex
:
'WebPage'
,
dataIndex
:
'WebPage'
,
align
:
'center'
,
align
:
'center'
,
render
:
text
=>
(
render
:
text
=>
{
// eslint-disable-next-line react/no-danger
if
(
text
===
'(未配置)'
||
text
===
'(无)'
)
{
<
span
dangerouslySetInnerHTML=
{
{
__html
:
text
}
}
/>
return
<
span
style=
{
{
color
:
'grey'
}
}
>
{
text
}
</
span
>;
),
}
return
<
span
>
{
text
}
</
span
>;
},
},
},
{
{
title
:
'前端参数'
,
title
:
'前端参数'
,
dataIndex
:
'WebParam'
,
dataIndex
:
'WebParam'
,
align
:
'center'
,
align
:
'center'
,
render
:
text
=>
(
render
:
text
=>
{
// eslint-disable-next-line react/no-danger
if
(
text
===
'(未配置)'
||
text
===
'(无)'
)
{
<
span
dangerouslySetInnerHTML=
{
{
__html
:
text
}
}
/>
return
<
span
style=
{
{
color
:
'grey'
}
}
>
{
text
}
</
span
>;
),
}
return
<
span
>
{
text
}
</
span
>;
},
},
},
{
{
title
:
'手持标签'
,
title
:
'手持标签'
,
dataIndex
:
'MobileLabel'
,
dataIndex
:
'MobileLabel'
,
align
:
'center'
,
align
:
'center'
,
render
:
text
=>
(
render
:
text
=>
{
// eslint-disable-next-line react/no-danger
if
(
text
===
'(未配置)'
||
text
===
'(无)'
)
{
<
span
dangerouslySetInnerHTML=
{
{
__html
:
text
}
}
/>
return
<
span
style=
{
{
color
:
'grey'
}
}
>
{
text
}
</
span
>;
),
}
return
<
span
>
{
text
}
</
span
>;
},
},
},
{
{
title
:
'手持视图'
,
title
:
'手持视图'
,
dataIndex
:
'MobilePage'
,
dataIndex
:
'MobilePage'
,
align
:
'center'
,
align
:
'center'
,
render
:
text
=>
(
render
:
text
=>
{
// eslint-disable-next-line react/no-danger
if
(
text
===
'(未配置)'
||
text
===
'(无)'
)
{
<
span
dangerouslySetInnerHTML=
{
{
__html
:
text
}
}
/>
return
<
span
style=
{
{
color
:
'grey'
}
}
>
{
text
}
</
span
>;
),
}
return
<
span
>
{
text
}
</
span
>;
},
},
},
{
{
title
:
'手持参数'
,
title
:
'手持参数'
,
dataIndex
:
'MobileParam'
,
dataIndex
:
'MobileParam'
,
align
:
'center'
,
align
:
'center'
,
render
:
text
=>
(
render
:
text
=>
{
// eslint-disable-next-line react/no-danger
if
(
text
===
'(未配置)'
||
text
===
'(无)'
)
{
<
span
dangerouslySetInnerHTML=
{
{
__html
:
text
}
}
/>
return
<
span
style=
{
{
color
:
'grey'
}
}
>
{
text
}
</
span
>;
),
}
return
<
span
>
{
text
}
</
span
>;
},
},
},
{
{
title
:
'操作'
,
title
:
'操作'
,
...
...
src/pages/platformCenter/bsmanager/workFlow/flowNode/flowNodeComponents/NodeEdit.jsx
View file @
79311bc5
...
@@ -10,7 +10,6 @@ import {
...
@@ -10,7 +10,6 @@ import {
import
{
import
{
Form
,
Form
,
Modal
,
Input
,
Input
,
Radio
,
Radio
,
Select
,
Select
,
...
@@ -18,6 +17,8 @@ import {
...
@@ -18,6 +17,8 @@ import {
Checkbox
,
Checkbox
,
Button
,
Button
,
message
,
message
,
Drawer
,
Space
,
}
from
'antd'
;
}
from
'antd'
;
import
{
PlusOutlined
}
from
'@ant-design/icons'
;
import
{
PlusOutlined
}
from
'@ant-design/icons'
;
import
Fieldselection
from
'./nodeEditComponents/Fieldselection'
;
import
Fieldselection
from
'./nodeEditComponents/Fieldselection'
;
...
@@ -99,58 +100,47 @@ const NodeEdit = props => {
...
@@ -99,58 +100,47 @@ const NodeEdit = props => {
loadEventFields
({
eventTableName
:
value
.
TableName
}).
then
(
res
=>
{
loadEventFields
({
eventTableName
:
value
.
TableName
}).
then
(
res
=>
{
if
(
res
.
code
===
0
)
{
if
(
res
.
code
===
0
)
{
let
defaultCheckedList
=
value
[
val
]
?
value
[
val
].
split
(
','
)
:
[];
let
defaultCheckedList
=
value
[
val
]
?
value
[
val
].
split
(
','
)
:
[];
// 处理数据为树形结构
// 处理树形结构
let
keylist
=
new
Set
();
let
checkList
=
res
.
data
.
map
(
item
=>
{
let
list
=
new
Map
();
let
plainOptions
=
[];
res
.
data
.
forEach
(
item
=>
{
item
.
root
.
forEach
(
ele
=>
{
keylist
.
add
(
item
.
group
);
plainOptions
=
[...
plainOptions
,
ele
.
fieldName
];
if
(
keylist
.
has
(
item
.
group
))
{
let
listItem
=
list
.
get
(
item
.
group
);
// 存入check得选项,是否全选,选中的选项'
if
(
listItem
)
{
list
.
set
(
item
.
group
,
{
plainOptions
:
[...
listItem
.
plainOptions
,
item
.
fieldName
],
defaultCheckedList
:
[],
});
});
}
else
{
return
{
list
.
set
(
item
.
group
,
{
groupName
:
item
.
groupName
,
plainOptions
:
[
item
.
fieldName
]
,
plainOptions
,
defaultCheckedList
:
[],
defaultCheckedList
:
[],
};
});
});
}
}
});
let
checkList
=
[...
list
];
defaultCheckedList
.
forEach
(
item
=>
{
defaultCheckedList
.
forEach
(
item
=>
{
checkList
.
forEach
(
element
=>
{
checkList
.
forEach
(
element
=>
{
// 当前得模块是否有当前字段
// 当前得模块是否有当前字段
let
indeterminate
=
element
[
1
]
.
plainOptions
.
some
(
let
indeterminate
=
element
.
plainOptions
.
some
(
checkName
=>
checkName
===
item
,
checkName
=>
checkName
===
item
,
);
);
// 处理已选中的字段
// 处理已选中的字段
if
(
indeterminate
)
{
if
(
indeterminate
)
{
element
[
1
]
.
defaultCheckedList
.
push
(
item
);
element
.
defaultCheckedList
.
push
(
item
);
}
}
if
(
if
(
element
[
1
].
defaultCheckedList
.
length
>
0
&&
element
.
defaultCheckedList
.
length
>
0
&&
element
[
1
].
defaultCheckedList
.
length
<
element
.
defaultCheckedList
.
length
<
element
.
plainOptions
.
length
element
[
1
].
plainOptions
.
length
)
{
)
{
element
[
1
]
.
indeterminate
=
true
;
element
.
indeterminate
=
true
;
}
else
{
}
else
{
element
[
1
]
.
indeterminate
=
false
;
element
.
indeterminate
=
false
;
}
}
// 处理是否全选字段
// 处理是否全选字段
if
(
if
(
element
[
1
].
defaultCheckedList
.
length
===
element
.
defaultCheckedList
.
length
===
element
.
plainOptions
.
length
element
[
1
].
plainOptions
.
length
)
{
)
{
element
[
1
]
.
checkAll
=
true
;
element
.
checkAll
=
true
;
}
else
{
}
else
{
element
[
1
]
.
checkAll
=
false
;
element
.
checkAll
=
false
;
}
}
});
});
});
});
console
.
log
(
checkList
,
'checkList'
);
setFieldList
(
checkList
);
setFieldList
(
checkList
);
setTimeout
(()
=>
{
setTimeout
(()
=>
{
setShowField
(
true
);
setShowField
(
true
);
...
@@ -215,14 +205,19 @@ const NodeEdit = props => {
...
@@ -215,14 +205,19 @@ const NodeEdit = props => {
}
}
};
};
return
(
return
(
<
Modal
<
Drawer
title=
"流程节点配置"
title=
"流程节点配置"
width=
"500px"
onClose=
{
handleCancel
}
visible=
{
visible
}
visible=
{
visible
}
onOk=
{
onFinish
}
footer=
{
width=
"800px"
<
Space
>
onCancel=
{
handleCancel
}
<
Button
onClick=
{
handleCancel
}
>
取消
</
Button
>
maskClosable=
{
false
}
<
Button
onClick=
{
onFinish
}
type=
"primary"
>
centered
确定
</
Button
>
</
Space
>
}
>
>
<
Form
<
Form
form=
{
form
}
form=
{
form
}
...
@@ -329,13 +324,13 @@ const NodeEdit = props => {
...
@@ -329,13 +324,13 @@ const NodeEdit = props => {
/>
/>
</
div
>
</
div
>
</
Form
.
Item
>
</
Form
.
Item
>
<
Form
.
Item
label=
"查看字段
(工程模型)
"
>
<
Form
.
Item
label=
"查看字段"
>
<
div
className=
{
styles
.
filedListItem
}
>
<
div
className=
{
styles
.
filedListItem
}
>
<
Form
.
Item
<
Form
.
Item
name=
"SeeFields"
name=
"SeeFields"
style=
{
{
marginBottom
:
0
,
width
:
'100%'
}
}
style=
{
{
marginBottom
:
0
,
width
:
'100%'
}
}
>
>
<
Input
placeholder=
"请选择查看字段"
allowClear
/>
<
Input
placeholder=
"请选择查看字段
(工程模型)
"
allowClear
/>
</
Form
.
Item
>
</
Form
.
Item
>
<
Button
<
Button
type=
"dashed"
type=
"dashed"
...
@@ -379,7 +374,7 @@ const NodeEdit = props => {
...
@@ -379,7 +374,7 @@ const NodeEdit = props => {
fieldList=
{
fieldList
}
fieldList=
{
fieldList
}
onSubumit=
{
val
=>
setFiled
(
val
)
}
onSubumit=
{
val
=>
setFiled
(
val
)
}
/>
/>
</
Modal
>
</
Drawer
>
);
);
};
};
export
default
NodeEdit
;
export
default
NodeEdit
;
src/pages/platformCenter/bsmanager/workFlow/flowNode/flowNodeComponents/nodeEditComponents/Fieldselection.jsx
View file @
79311bc5
...
@@ -19,7 +19,7 @@ const Fieldselection = props => {
...
@@ -19,7 +19,7 @@ const Fieldselection = props => {
return
;
return
;
}
}
checkList
.
forEach
(
element
=>
{
checkList
.
forEach
(
element
=>
{
arr
=
[...
arr
,
...
element
[
1
]
.
defaultCheckedList
];
arr
=
[...
arr
,
...
element
.
defaultCheckedList
];
});
});
setSelectList
(
arr
);
setSelectList
(
arr
);
// 初始化拖拽
// 初始化拖拽
...
@@ -35,11 +35,11 @@ const Fieldselection = props => {
...
@@ -35,11 +35,11 @@ const Fieldselection = props => {
const
onChange
=
(
list
,
index
)
=>
{
const
onChange
=
(
list
,
index
)
=>
{
setCheckList
(
value
=>
{
setCheckList
(
value
=>
{
const
chooseList
=
JSON
.
parse
(
JSON
.
stringify
(
value
));
const
chooseList
=
JSON
.
parse
(
JSON
.
stringify
(
value
));
chooseList
[
index
]
[
1
]
.
defaultCheckedList
=
list
;
chooseList
[
index
].
defaultCheckedList
=
list
;
chooseList
[
index
]
[
1
]
.
indeterminate
=
chooseList
[
index
].
indeterminate
=
!!
list
.
length
&&
list
.
length
<
chooseList
[
index
]
[
1
]
.
plainOptions
.
length
;
!!
list
.
length
&&
list
.
length
<
chooseList
[
index
].
plainOptions
.
length
;
chooseList
[
index
]
[
1
]
.
checkAll
=
chooseList
[
index
].
checkAll
=
list
.
length
===
chooseList
[
index
]
[
1
]
.
plainOptions
.
length
;
list
.
length
===
chooseList
[
index
].
plainOptions
.
length
;
return
chooseList
;
return
chooseList
;
});
});
};
};
...
@@ -47,11 +47,11 @@ const Fieldselection = props => {
...
@@ -47,11 +47,11 @@ const Fieldselection = props => {
const
onCheckAllChange
=
(
e
,
index
)
=>
{
const
onCheckAllChange
=
(
e
,
index
)
=>
{
setCheckList
(
value
=>
{
setCheckList
(
value
=>
{
const
chooseList
=
JSON
.
parse
(
JSON
.
stringify
(
value
));
const
chooseList
=
JSON
.
parse
(
JSON
.
stringify
(
value
));
chooseList
[
index
]
[
1
]
.
defaultCheckedList
=
e
.
target
.
checked
chooseList
[
index
].
defaultCheckedList
=
e
.
target
.
checked
?
chooseList
[
index
]
[
1
]
.
plainOptions
?
chooseList
[
index
].
plainOptions
:
[];
:
[];
chooseList
[
index
]
[
1
]
.
indeterminate
=
false
;
chooseList
[
index
].
indeterminate
=
false
;
chooseList
[
index
]
[
1
]
.
checkAll
=
e
.
target
.
checked
;
chooseList
[
index
].
checkAll
=
e
.
target
.
checked
;
return
chooseList
;
return
chooseList
;
});
});
};
};
...
@@ -98,19 +98,21 @@ const Fieldselection = props => {
...
@@ -98,19 +98,21 @@ const Fieldselection = props => {
<
div
className=
{
styles
.
cardBox
}
key=
{
index
}
>
<
div
className=
{
styles
.
cardBox
}
key=
{
index
}
>
<
div
className=
{
styles
.
title
}
>
<
div
className=
{
styles
.
title
}
>
<
Divider
orientation=
"left"
className=
{
styles
.
cardDivider
}
>
<
Divider
orientation=
"left"
className=
{
styles
.
cardDivider
}
>
<
span
style=
{
{
marginRight
:
'10px'
}
}
>
{
item
[
0
]
}
</
span
>
<
span
style=
{
{
marginRight
:
'10px'
}
}
>
{
item
.
groupName
}
</
span
>
<
Checkbox
<
Checkbox
indeterminate=
{
item
[
1
]
.
indeterminate
}
indeterminate=
{
item
.
indeterminate
}
onChange=
{
e
=>
onCheckAllChange
(
e
,
index
)
}
onChange=
{
e
=>
onCheckAllChange
(
e
,
index
)
}
checked=
{
item
[
1
]
.
checkAll
}
checked=
{
item
.
checkAll
}
/>
/>
</
Divider
>
</
Divider
>
</
div
>
</
div
>
<
div
className=
{
styles
.
filedList
}
>
<
div
className=
{
styles
.
filedList
}
>
<
CheckboxGroup
<
CheckboxGroup
key=
{
index
}
key=
{
index
}
options=
{
item
[
1
]
.
plainOptions
}
options=
{
item
.
plainOptions
}
value=
{
item
[
1
]
.
defaultCheckedList
}
value=
{
item
.
defaultCheckedList
}
onChange=
{
list
=>
onChange
(
list
,
index
)
}
onChange=
{
list
=>
onChange
(
list
,
index
)
}
/>
/>
</
div
>
</
div
>
...
...
src/pages/platformCenter/filedConfig/fieldEditor.jsx
View file @
79311bc5
import
React
,
{
useState
,
useEffect
}
from
'react'
;
import
React
,
{
useState
,
useEffect
}
from
'react'
;
import
{
Form
,
Modal
,
Input
,
Select
,
Radio
,
Checkbox
,
notification
,
Tooltip
}
from
'antd'
;
import
{
Form
,
Modal
,
Input
,
Select
,
Radio
,
Checkbox
,
notification
,
Tooltip
,
Drawer
,
Space
,
Button
,
}
from
'antd'
;
import
{
import
{
getField
,
loadTableFields
,
LoadEventFields
,
LoadEventType
,
UpdateFields
getField
,
}
from
'@/services/platform/bs'
loadTableFields
,
import
styles
from
'./index.less'
LoadEventFields
,
import
ChangeAdd
from
'./changeAdd'
LoadEventType
,
UpdateFields
,
}
from
'@/services/platform/bs'
;
import
styles
from
'./index.less'
;
import
ChangeAdd
from
'./changeAdd'
;
import
{
PlusSquareOutlined
}
from
'@ant-design/icons'
;
import
{
PlusSquareOutlined
}
from
'@ant-design/icons'
;
import
{
shape
}
from
'prop-types'
;
import
{
shape
}
from
'prop-types'
;
const
AddModal
=
props
=>
{
const
AddModal
=
props
=>
{
const
{
callBackSubmit
=
()
=>
{
},
isType
,
itemData
,
isVisible
,
formObj1
}
=
props
;
const
{
callBackSubmit
=
()
=>
{},
isType
,
itemData
,
isVisible
,
formObj1
,
onCancel
,
}
=
props
;
const
[
loading
,
setLoading
]
=
useState
(
false
);
const
[
loading
,
setLoading
]
=
useState
(
false
);
const
[
fieldName
,
setFieldName
]
=
useState
([]);
// 弹窗
const
[
fieldName
,
setFieldName
]
=
useState
([]);
// 弹窗
const
[
eventList
,
setEventList
]
=
useState
([]);
// 事件
const
[
eventList
,
setEventList
]
=
useState
([]);
// 事件
const
[
filed
,
setFiled
]
=
useState
({});
// 事件
const
[
filed
,
setFiled
]
=
useState
({});
// 事件
const
[
verification
,
setVerification
]
=
useState
([]);
const
[
verification
,
setVerification
]
=
useState
([]);
const
[
Shape
,
setShape
]
=
useState
(
'文本'
)
const
[
Shape
,
setShape
]
=
useState
(
'文本'
);
const
[
characteristics
,
setCharacteristics
]
=
useState
([
'文本'
,
'数值'
,
'唯一值文本'
,
'多行文本'
,
'编码'
,
'地址'
,
'本人部门'
,
'本人姓名'
,
'本人ID'
,
'选择器'
,
'搜索选择器'
,
'值选择器'
,
'值复选器'
,
'业务选择器'
,
'可编辑值选择器'
,
'平铺值选择器'
,
'站点选择器'
,
'人员选择器'
,
'人员选择器新'
,
'城市选择器'
,
'台账选择器'
,
'附件'
,
'可预览附件'
,
'图片'
,
'可预览图片'
,
'录音'
,
'视频'
,
'日期时间'
,
'日期'
,
'日期月份'
,
'日期年份'
,
'日期周'
,
'时分秒'
,
'设备选择'
,
'坐标控件'
,
'区域控件'
,
'路径控件'
,
'智能抄表'
,
'二维码识别'
,
'设备二维码'
,
'位置坐标'
])
const
[
characteristics
,
setCharacteristics
]
=
useState
([
'文本'
,
'数值'
,
'唯一值文本'
,
'多行文本'
,
'编码'
,
'地址'
,
'本人部门'
,
'本人姓名'
,
'本人ID'
,
'选择器'
,
'搜索选择器'
,
'值选择器'
,
'值复选器'
,
'业务选择器'
,
'可编辑值选择器'
,
'平铺值选择器'
,
'站点选择器'
,
'人员选择器'
,
'人员选择器新'
,
'城市选择器'
,
'台账选择器'
,
'附件'
,
'可预览附件'
,
'图片'
,
'可预览图片'
,
'录音'
,
'视频'
,
'日期时间'
,
'日期'
,
'日期月份'
,
'日期年份'
,
'日期周'
,
'时分秒'
,
'设备选择'
,
'坐标控件'
,
'区域控件'
,
'路径控件'
,
'智能抄表'
,
'二维码识别'
,
'设备二维码'
,
'位置坐标'
,
]);
const
[
visible
,
setVisible
]
=
useState
(
false
);
// 弹窗
const
[
visible
,
setVisible
]
=
useState
(
false
);
// 弹窗
const
[
isShow
,
setIsShow
]
=
useState
(
false
);
// 弹窗
const
[
isShow
,
setIsShow
]
=
useState
(
false
);
// 弹窗
const
[
type
,
setType
]
=
useState
(
''
);
// 弹窗类型
const
[
type
,
setType
]
=
useState
(
''
);
// 弹窗类型
const
[
formObj
,
setFormObj
]
=
useState
({
rule
:
[],
numerical
:
''
});
const
[
formObj
,
setFormObj
]
=
useState
({
rule
:
[],
numerical
:
''
});
const
[
characterValue
,
setCharacterValue
]
=
useState
(
''
)
const
[
characterValue
,
setCharacterValue
]
=
useState
(
''
);
const
[
pramData
,
setPramData
]
=
useState
({
Unit
:
''
,
ExceptionEvent
:
''
,
Group
:
''
,
RowSpan
:
0
,
ColSpan
:
0
,
ReadOnly
:
false
,
EditableLater
:
false
,
ExceptionValue
:
''
,
Preset
:
''
,
picture
:
false
,
must
:
false
,
coordinates
:
false
})
const
[
pramData
,
setPramData
]
=
useState
({
const
[
checkedList
,
setCheckedList
]
=
useState
([]);
//选中的复选框内容
Unit
:
''
,
ExceptionEvent
:
''
,
Group
:
''
,
RowSpan
:
0
,
ColSpan
:
0
,
ReadOnly
:
false
,
EditableLater
:
false
,
ExceptionValue
:
''
,
Preset
:
''
,
picture
:
false
,
must
:
false
,
coordinates
:
false
,
});
const
[
checkedList
,
setCheckedList
]
=
useState
([]);
//选中的复选框内容
const
{
TextArea
}
=
Input
;
const
{
TextArea
}
=
Input
;
const
[
form
]
=
Form
.
useForm
();
const
[
form
]
=
Form
.
useForm
();
const
{
Item
}
=
Form
;
const
{
Item
}
=
Form
;
...
@@ -33,25 +111,48 @@ const AddModal = props => {
...
@@ -33,25 +111,48 @@ const AddModal = props => {
if
(
validate
)
{
if
(
validate
)
{
setLoading
(
true
);
setLoading
(
true
);
let
obj
=
form
.
getFieldsValue
();
let
obj
=
form
.
getFieldsValue
();
let
data
=
[{
Unit
:
pramData
.
Unit
||
''
,
StoreType
:
"nvarchar(255)"
,
Group
:
pramData
.
Group
||
''
,
Shape
,
ExceptionEvent
:
pramData
.
ExceptionEvent
||
''
,
RowSpan
:
pramData
.
RowSpan
||
0
,
ColSpan
:
pramData
.
ColSpan
||
0
,
ReadOnly
:
pramData
.
ReadOnly
||
false
,
EditableLater
:
pramData
.
EditableLater
||
false
,
ExceptionValue
:
pramData
.
ExceptionValue
||
''
,
Preset
:
pramData
.
Preset
||
''
,
ID
:
Number
(
itemData
.
ID
),
Name
:
obj
.
Name
,
Alias
:
obj
.
Alias
,
SyncEvent
:
obj
.
SyncEvent
,
ValidationRule
:
obj
.
ValidationRule
,
ExceptionEventFields
:
characterValue
}]
let
data
=
[
{
Unit
:
pramData
.
Unit
||
''
,
StoreType
:
'nvarchar(255)'
,
Group
:
pramData
.
Group
||
''
,
Shape
,
ExceptionEvent
:
pramData
.
ExceptionEvent
||
''
,
RowSpan
:
pramData
.
RowSpan
||
0
,
ColSpan
:
pramData
.
ColSpan
||
0
,
ReadOnly
:
pramData
.
ReadOnly
||
false
,
EditableLater
:
pramData
.
EditableLater
||
false
,
ExceptionValue
:
pramData
.
ExceptionValue
||
''
,
Preset
:
pramData
.
Preset
||
''
,
ID
:
Number
(
itemData
.
ID
),
Name
:
obj
.
Name
,
Alias
:
obj
.
Alias
,
SyncEvent
:
obj
.
SyncEvent
,
ValidationRule
:
obj
.
ValidationRule
,
ExceptionEventFields
:
characterValue
,
},
];
switch
(
Shape
)
{
switch
(
Shape
)
{
case
'编码'
:
case
'编码'
:
data
[
0
].
Config
=
`
${
obj
.
code
}
.
${
obj
.
prefix
?
obj
.
prefix
:
''
}
`
;
data
[
0
].
Config
=
`
${
obj
.
code
}
.
${
obj
.
prefix
?
obj
.
prefix
:
''
}
`
;
break
break
;
case
'坐标控件'
:
case
'坐标控件'
:
pramData
.
coordinates
?
data
[
0
].
Config
=
'当前坐标'
:
data
[
0
].
Config
=
''
;
pramData
.
coordinates
break
?
(
data
[
0
].
Config
=
'当前坐标'
)
case
'图片'
:
case
'可预览图片'
:
:
(
data
[
0
].
Config
=
''
);
break
;
case
'图片'
:
case
'可预览图片'
:
data
[
0
].
Preset
=
pramData
.
picture
?
'拍照相册'
:
''
;
data
[
0
].
Preset
=
pramData
.
picture
?
'拍照相册'
:
''
;
data
[
0
].
ValidationRule
=
pramData
.
must
?
'required'
:
''
data
[
0
].
ValidationRule
=
pramData
.
must
?
'required'
:
''
;
break
break
;
default
:
default
:
data
[
0
].
Config
=
obj
.
Config
;
data
[
0
].
Config
=
obj
.
Config
;
}
}
UpdateFields
(
data
).
then
(
res
=>
{
UpdateFields
(
data
).
then
(
res
=>
{
setLoading
(
false
);
setLoading
(
false
);
if
(
res
.
msg
===
"Ok"
||
res
.
msg
===
""
)
{
if
(
res
.
msg
===
'Ok'
||
res
.
msg
===
''
)
{
form
.
resetFields
();
form
.
resetFields
();
callBackSubmit
();
callBackSubmit
();
notification
.
success
({
notification
.
success
({
...
@@ -59,7 +160,6 @@ const AddModal = props => {
...
@@ -59,7 +160,6 @@ const AddModal = props => {
duration
:
3
,
duration
:
3
,
description
:
'修改成功'
,
description
:
'修改成功'
,
});
});
}
else
{
}
else
{
notification
.
error
({
notification
.
error
({
message
:
'提示'
,
message
:
'提示'
,
...
@@ -67,88 +167,96 @@ const AddModal = props => {
...
@@ -67,88 +167,96 @@ const AddModal = props => {
description
:
res
.
msg
,
description
:
res
.
msg
,
});
});
}
}
})
});
}
}
});
});
};
};
useEffect
(()
=>
{
useEffect
(()
=>
{
if
(
isType
!=
''
)
{
if
(
isType
!=
''
)
{
let
req1
=
getField
({
fieldID
:
itemData
.
ID
})
let
req1
=
getField
({
fieldID
:
itemData
.
ID
});
let
req2
=
loadTableFields
({
tableName
:
formObj1
})
let
req2
=
loadTableFields
({
tableName
:
formObj1
});
let
req3
=
LoadEventType
({})
let
req3
=
LoadEventType
({});
Promise
.
all
([
req1
,
req2
,
req3
]).
then
(
res
=>
{
Promise
.
all
([
req1
,
req2
,
req3
]).
then
(
res
=>
{
res
[
1
].
msg
===
'Ok'
&&
setFieldName
(
res
[
1
].
data
.
root
)
res
[
1
].
msg
===
'Ok'
&&
setFieldName
(
res
[
1
].
data
.
root
);
res
[
2
].
msg
===
'Ok'
&&
setEventList
(
res
[
2
].
data
.
root
)
res
[
2
].
msg
===
'Ok'
&&
setEventList
(
res
[
2
].
data
.
root
);
if
(
res
[
0
].
msg
===
'Ok'
)
{
if
(
res
[
0
].
msg
===
'Ok'
)
{
form
.
setFieldsValue
({
...
res
[
0
].
data
.
root
})
form
.
setFieldsValue
({
...
res
[
0
].
data
.
root
});
if
(
res
[
0
].
data
.
root
.
ExceptionEventFields
===
''
)
{
if
(
res
[
0
].
data
.
root
.
ExceptionEventFields
===
''
)
{
setCharacterValue
(
''
)
setCharacterValue
(
''
);
setCheckedList
([])
setCheckedList
([]);
setIsShow
(
false
)
setIsShow
(
false
);
}
else
{
}
else
{
setIsShow
(
true
)
setIsShow
(
true
);
setCharacterValue
(
res
[
0
].
data
.
root
.
ExceptionEventFields
)
setCharacterValue
(
res
[
0
].
data
.
root
.
ExceptionEventFields
);
setCheckedList
(
res
[
0
].
data
.
root
.
ExceptionEventFields
.
split
(
','
))
setCheckedList
(
res
[
0
].
data
.
root
.
ExceptionEventFields
.
split
(
','
));
}
}
setShape
(
res
[
0
].
data
.
root
.
Shape
)
setShape
(
res
[
0
].
data
.
root
.
Shape
);
let
coordinates
=
false
,
picture
=
false
,
must
=
false
let
coordinates
=
false
,
picture
=
false
,
must
=
false
;
switch
(
res
[
0
].
data
.
root
.
Shape
)
{
switch
(
res
[
0
].
data
.
root
.
Shape
)
{
case
'坐标控件'
:
case
'坐标控件'
:
res
[
0
].
data
.
root
.
Config
===
"当前坐标"
?
coordinates
=
true
:
coordinates
=
false
res
[
0
].
data
.
root
.
Config
===
'当前坐标'
break
?
(
coordinates
=
true
)
case
'图片'
:
case
'可预览图片'
:
:
(
coordinates
=
false
);
res
[
0
].
data
.
root
.
Preset
===
"拍照相册"
?
picture
=
true
:
picture
=
false
;
break
;
res
[
0
].
data
.
root
.
ValidationRule
===
"required"
?
must
=
true
:
must
=
false
case
'图片'
:
break
case
'可预览图片'
:
res
[
0
].
data
.
root
.
Preset
===
'拍照相册'
?
(
picture
=
true
)
:
(
picture
=
false
);
res
[
0
].
data
.
root
.
ValidationRule
===
'required'
?
(
must
=
true
)
:
(
must
=
false
);
break
;
case
'编码'
:
case
'编码'
:
let
code
=
res
[
0
].
data
.
root
.
Config
.
split
(
"."
)
let
code
=
res
[
0
].
data
.
root
.
Config
.
split
(
'.'
);
form
.
setFieldsValue
({
code
:
code
[
0
]
||
''
,
prefix
:
code
[
1
]
===
"undefined"
?
''
:
code
[
1
]
});
form
.
setFieldsValue
({
break
code
:
code
[
0
]
||
''
,
prefix
:
code
[
1
]
===
'undefined'
?
''
:
code
[
1
],
});
break
;
}
}
setPramData
({
...
res
[
0
].
data
.
root
,
coordinates
,
must
,
picture
})
setPramData
({
...
res
[
0
].
data
.
root
,
coordinates
,
must
,
picture
});
let
index
=
res
[
2
].
data
.
root
.
find
(
item
=>
{
return
item
.
Name
==
res
[
0
].
data
.
root
.
ExceptionEvent
})
let
index
=
res
[
2
].
data
.
root
.
find
(
item
=>
{
console
.
log
(
'index'
,
index
);
return
item
.
Name
==
res
[
0
].
data
.
root
.
ExceptionEvent
;
getFieldData
(
index
.
TableName
)
});
console
.
log
(
'index'
,
index
);
getFieldData
(
index
.
TableName
);
}
}
})
});
}
}
},
[
isVisible
]);
},
[
isVisible
]);
const
layout
=
{
const
layout
=
{
layout
:
'horizontal'
,
layout
:
'horizontal'
,
labelCol
:
{
labelCol
:
{
span
:
4
,
span
:
3
,
},
},
wrapperCol
:
{
wrapperCol
:
{
span
:
17
,
span
:
30
,
},
},
};
};
const
handleChange
=
(
value
)
=>
{
const
handleChange
=
value
=>
{
form
.
setFieldsValue
({
schemename
:
value
});
form
.
setFieldsValue
({
schemename
:
value
});
}
};
const
onOK
=
prop
=>
{
const
onOK
=
prop
=>
{
setVisible
(
false
);
setVisible
(
false
);
if
(
type
===
'rule'
)
{
if
(
type
===
'rule'
)
{
form
.
setFieldsValue
({
ValidationRule
:
prop
});
form
.
setFieldsValue
({
ValidationRule
:
prop
});
}
else
{
}
else
{
setCheckedList
(
prop
.
checkedList
)
setCheckedList
(
prop
.
checkedList
);
setCharacterValue
(
prop
.
str
)
setCharacterValue
(
prop
.
str
);
}
}
};
};
const
add
=
(
type
)
=>
{
const
add
=
type
=>
{
let
obj
=
form
.
getFieldsValue
();
let
obj
=
form
.
getFieldsValue
();
let
data
=
{
...
formObj
}
let
data
=
{
...
formObj
};
if
(
obj
.
ValidationRule
)
{
if
(
obj
.
ValidationRule
)
{
let
arr
=
obj
.
ValidationRule
.
split
(
","
)
let
arr
=
obj
.
ValidationRule
.
split
(
','
);
arr
.
map
(
item
=>
{
arr
.
map
(
item
=>
{
switch
(
item
)
{
switch
(
item
)
{
case
'required'
:
case
'required'
:
...
@@ -161,117 +269,114 @@ const AddModal = props => {
...
@@ -161,117 +269,114 @@ const AddModal = props => {
data
.
rule
.
push
(
item
);
data
.
rule
.
push
(
item
);
break
;
break
;
default
:
default
:
data
.
numerical
=
item
data
.
numerical
=
item
;
}
}
})
});
}
else
{
}
else
{
data
=
{
rule
:
[],
numerical
:
''
}
data
=
{
rule
:
[],
numerical
:
''
};
}
}
setType
(
type
);
setType
(
type
);
setFormObj
(
data
)
setFormObj
(
data
);
setVisible
(
true
);
setVisible
(
true
);
}
};
const
handleEvent
=
(
value
,
e
)
=>
{
const
handleEvent
=
(
value
,
e
)
=>
{
let
data
=
{
...
pramData
}
let
data
=
{
...
pramData
};
data
.
ExceptionEvent
=
e
.
name
data
.
ExceptionEvent
=
e
.
name
;
if
(
e
.
tablename
)
{
if
(
e
.
tablename
)
{
getFieldData
(
e
.
tablename
)
getFieldData
(
e
.
tablename
);
setPramData
(
data
)
setPramData
(
data
);
}
else
{
}
else
{
setIsShow
(
false
)
setIsShow
(
false
);
setFiled
({})
setFiled
({});
setCharacterValue
(
''
)
setCharacterValue
(
''
);
setCheckedList
([])
setCheckedList
([]);
}
}
}
const
getFieldData
=
(
value
)
=>
{
};
const
getFieldData
=
value
=>
{
LoadEventFields
({
eventTableName
:
value
,
distinctFields
:
''
}).
then
(
res
=>
{
LoadEventFields
({
eventTableName
:
value
,
distinctFields
:
''
}).
then
(
res
=>
{
if
(
res
.
msg
===
'Ok'
)
{
if
(
res
.
msg
===
'Ok'
)
{
setFiled
(
formateArrDataA
(
res
.
data
.
root
,
'group'
))
setFiled
(
formateArrDataA
(
res
.
data
.
root
,
'group'
));
setIsShow
(
true
)
setIsShow
(
true
);
}
}
});
})
};
}
const
formateArrDataA
=
(
initialArr
,
name
)
=>
{
const
formateArrDataA
=
(
initialArr
,
name
)
=>
{
// 判定传参是否符合规则
// 判定传参是否符合规则
if
(
!
(
initialArr
instanceof
Array
))
{
if
(
!
(
initialArr
instanceof
Array
))
{
return
'请传入正确格式的数组'
return
'请传入正确格式的数组'
;
}
}
if
(
!
name
)
{
if
(
!
name
)
{
return
'请传入对象属性'
return
'请传入对象属性'
;
}
}
//先获取一下这个数组中有多少个"name"
//先获取一下这个数组中有多少个"name"
let
nameArr
=
[]
let
nameArr
=
[];
for
(
let
i
in
initialArr
)
{
for
(
let
i
in
initialArr
)
{
if
(
nameArr
.
indexOf
(
initialArr
[
i
][
`
${
name
}
`
])
===
-
1
)
{
if
(
nameArr
.
indexOf
(
initialArr
[
i
][
`
${
name
}
`
])
===
-
1
)
{
nameArr
.
push
(
initialArr
[
i
][
`
${
name
}
`
])
nameArr
.
push
(
initialArr
[
i
][
`
${
name
}
`
]);
}
}
}
}
//新建一个包含多个list的结果对象
//新建一个包含多个list的结果对象
let
tempObj
=
{}
let
tempObj
=
{};
// 根据不同的"name"生成多个数组
// 根据不同的"name"生成多个数组
for
(
let
k
in
nameArr
)
{
for
(
let
k
in
nameArr
)
{
for
(
let
j
in
initialArr
)
{
for
(
let
j
in
initialArr
)
{
if
(
initialArr
[
j
][
`
${
name
}
`
]
==
nameArr
[
k
])
{
if
(
initialArr
[
j
][
`
${
name
}
`
]
==
nameArr
[
k
])
{
// 每次外循环时新建一个对应"name"的数组, 内循环时当前数组不变
// 每次外循环时新建一个对应"name"的数组, 内循环时当前数组不变
tempObj
[
nameArr
[
k
]]
=
tempObj
[
nameArr
[
k
]]
||
[]
tempObj
[
nameArr
[
k
]]
=
tempObj
[
nameArr
[
k
]]
||
[];
tempObj
[
nameArr
[
k
]].
push
(
initialArr
[
j
])
tempObj
[
nameArr
[
k
]].
push
(
initialArr
[
j
]);
}
}
}
}
}
}
for
(
let
key
in
tempObj
)
{
for
(
let
key
in
tempObj
)
{
let
arr
=
[]
let
arr
=
[];
tempObj
[
key
].
map
(
item
=>
{
tempObj
[
key
].
map
(
item
=>
{
tempObj
[
key
]
=
arr
;
tempObj
[
key
]
=
arr
;
arr
.
push
(
item
.
fieldName
)
arr
.
push
(
item
.
fieldName
);
})
});
}
return
tempObj
}
}
const
handleCharacteristics
=
(
value
)
=>
{
return
tempObj
;
let
data
=
{
...
pramData
}
};
setShape
(
value
)
const
handleCharacteristics
=
value
=>
{
data
.
must
=
false
let
data
=
{
...
pramData
};
data
.
coordinates
=
false
setShape
(
value
);
data
.
picture
=
false
data
.
must
=
false
;
data
.
Preset
=
''
data
.
coordinates
=
false
;
setPramData
(
data
)
data
.
picture
=
false
;
data
.
Preset
=
''
;
setPramData
(
data
);
form
.
setFieldsValue
({
ValidationRule
:
''
});
form
.
setFieldsValue
({
ValidationRule
:
''
});
if
(
value
.
indexOf
(
"日期"
)
!=
-
1
||
value
===
"时分秒"
)
{
if
(
value
.
indexOf
(
'日期'
)
!=
-
1
||
value
===
'时分秒'
)
{
form
.
setFieldsValue
({
Config
:
undefined
});
form
.
setFieldsValue
({
Config
:
undefined
});
}
}
};
}
const
onCharacterValue
=
e
=>
{
const
onCharacterValue
=
(
e
)
=>
{
setCharacterValue
(
e
.
target
.
value
);
setCharacterValue
(
e
.
target
.
value
)
};
}
const
onChangeReady
=
(
e
,
str
)
=>
{
const
onChangeReady
=
(
e
,
str
)
=>
{
let
data
=
{
...
pramData
}
let
data
=
{
...
pramData
};
switch
(
str
)
{
switch
(
str
)
{
case
'ReadOnly'
:
case
'ReadOnly'
:
data
.
ReadOnly
=
e
.
target
.
checked
;
data
.
ReadOnly
=
e
.
target
.
checked
;
break
;
break
;
case
'EditableLater'
:
case
'EditableLater'
:
data
.
EditableLater
=
e
.
target
.
checked
data
.
EditableLater
=
e
.
target
.
checked
;
break
;
break
;
case
'must'
:
case
'must'
:
data
.
must
=
e
.
target
.
checked
data
.
must
=
e
.
target
.
checked
;
break
;
break
;
case
'picture'
:
case
'picture'
:
data
.
picture
=
e
.
target
.
checked
data
.
picture
=
e
.
target
.
checked
;
break
;
break
;
case
'coordinates'
:
case
'coordinates'
:
data
.
coordinates
=
e
.
target
.
checked
data
.
coordinates
=
e
.
target
.
checked
;
break
;
break
;
}
}
setPramData
(
data
)
setPramData
(
data
);
}
};
const
handleInput
=
(
e
,
str
)
=>
{
const
handleInput
=
(
e
,
str
)
=>
{
let
data
=
{
...
pramData
}
let
data
=
{
...
pramData
};
switch
(
str
)
{
switch
(
str
)
{
case
'Unit'
:
case
'Unit'
:
data
.
Unit
=
e
.
target
.
value
;
data
.
Unit
=
e
.
target
.
value
;
...
@@ -286,49 +391,47 @@ const AddModal = props => {
...
@@ -286,49 +391,47 @@ const AddModal = props => {
data
.
ExceptionValue
=
e
.
target
.
value
;
data
.
ExceptionValue
=
e
.
target
.
value
;
break
;
break
;
default
:
default
:
break
break
;
}
setPramData
(
data
)
}
}
const
handleSeparator
=
(
value
)
=>
{
setPramData
(
data
);
let
data
=
{
...
pramData
}
};
const
handleSeparator
=
value
=>
{
let
data
=
{
...
pramData
};
switch
(
value
)
{
switch
(
value
)
{
case
'6'
:
case
'6'
:
data
.
Preset
=
'是'
data
.
Preset
=
'是'
;
form
.
setFieldsValue
({
Config
:
'是,否'
});
form
.
setFieldsValue
({
Config
:
'是,否'
});
break
;
break
;
case
'7'
:
case
'7'
:
data
.
Preset
=
'否'
data
.
Preset
=
'否'
;
form
.
setFieldsValue
({
Config
:
'是,否'
});
form
.
setFieldsValue
({
Config
:
'是,否'
});
break
;
break
;
case
'8'
:
case
'8'
:
data
.
Preset
=
'否'
data
.
Preset
=
'否'
;
form
.
setFieldsValue
({
Config
:
'否,是'
});
form
.
setFieldsValue
({
Config
:
'否,是'
});
break
;
break
;
}
}
setPramData
(
data
)
setPramData
(
data
);
}
};
return
(
return
(
<>
<>
<
Modal
<
Drawer
title=
'修改'
title=
"修改"
bodyStyle=
{
{
width
:
'100%'
,
minHeight
:
'100px'
}
}
width=
"600px"
width=
"700px"
// {...props}
destroyOnClose
maskClosable=
{
false
}
centered=
{
true
}
cancelText=
"取消"
okText=
"确认"
{
...
props
}
visible=
{
isVisible
}
visible=
{
isVisible
}
onOk=
{
()
=>
onSubmit
()
}
onClose=
{
onCancel
}
confirmLoading=
{
loading
}
footer=
{
forceRender=
{
true
}
<
Space
>
getContainer=
{
false
}
<
Button
onClick=
{
onCancel
}
>
取消
</
Button
>
<
Button
onClick=
{
onSubmit
}
type=
"primary"
>
确定
</
Button
>
</
Space
>
}
>
>
{
isVisible
&&
(
{
isVisible
&&
(
<
Form
form=
{
form
}
{
...
layout
}
>
<
Form
form=
{
form
}
{
...
layout
}
>
<
Item
<
Item
label=
"字段名"
label=
"字段名"
name=
"Name"
name=
"Name"
...
@@ -336,138 +439,233 @@ const AddModal = props => {
...
@@ -336,138 +439,233 @@ const AddModal = props => {
>
>
<
Input
placeholder=
"请输入别名"
disabled
/>
<
Input
placeholder=
"请输入别名"
disabled
/>
</
Item
>
</
Item
>
<
Item
<
Item
label=
"别名"
name=
"Alias"
>
label=
"别名"
name=
"Alias"
>
<
Input
placeholder=
"请输入别名"
allowClear
/>
<
Input
placeholder=
"请输入别名"
allowClear
/>
</
Item
>
</
Item
>
<
Item
<
Item
name=
"ReadOnly"
label=
"属性"
>
name=
"ReadOnly"
label=
"属性"
>
<
div
>
<
div
>
<
Checkbox
checked=
{
pramData
.
ReadOnly
}
onChange=
{
(
e
)
=>
onChangeReady
(
e
,
'ReadOnly'
)
}
>
只读
</
Checkbox
>
<
Checkbox
<
Checkbox
checked=
{
pramData
.
EditableLater
}
onChange=
{
(
e
)
=>
onChangeReady
(
e
,
'EditableLater'
)
}
>
允许补正(事后修改)
</
Checkbox
>
checked=
{
pramData
.
ReadOnly
}
onChange=
{
e
=>
onChangeReady
(
e
,
'ReadOnly'
)
}
>
只读
</
Checkbox
>
<
Checkbox
checked=
{
pramData
.
EditableLater
}
onChange=
{
e
=>
onChangeReady
(
e
,
'EditableLater'
)
}
>
允许补正(事后修改)
</
Checkbox
>
</
div
>
</
div
>
</
Item
>
</
Item
>
<
Item
<
Item
label=
"同步"
name=
"SyncEvent"
>
label=
"同步"
name=
"SyncEvent"
>
<
Radio
.
Group
>
<
Radio
.
Group
>
<
Radio
value=
{
0
}
style=
{
{
marginRight
:
'0.5rem'
}
}
>
不同步
</
Radio
>
<
Radio
value=
{
0
}
style=
{
{
marginRight
:
'0.5rem'
}
}
>
<
Radio
value=
{
1
}
style=
{
{
marginRight
:
'0.5rem'
}
}
>
工单 → 事件
</
Radio
>
不同步
<
Radio
value=
{
2
}
>
事件(上报时) → 工单
</
Radio
>
</
Radio
>
<
Radio
value=
{
1
}
style=
{
{
marginRight
:
'0.5rem'
}
}
>
工单 → 事件
</
Radio
>
<
Radio
value=
{
2
}
>
事件(上报时) → 工单
</
Radio
>
</
Radio
.
Group
>
</
Radio
.
Group
>
</
Item
>
</
Item
>
<
Item
<
Item
label=
"形态"
>
label=
"形态"
>
<
div
className=
{
styles
.
listEvent
}
>
<
div
className=
{
styles
.
listEvent
}
>
<
Select
style=
{
{
width
:
'42%'
}
}
value=
{
Shape
}
onChange=
{
handleCharacteristics
}
>
<
Select
{
characteristics
.
length
?
characteristics
.
map
((
item
,
index
)
=>
{
return
<
Select
.
Option
key=
{
index
}
value=
{
item
}
>
{
item
}
</
Select
.
Option
>;
})
:
''
}
style=
{
{
width
:
'42%'
}
}
value=
{
Shape
}
onChange=
{
handleCharacteristics
}
>
{
characteristics
.
length
?
characteristics
.
map
((
item
,
index
)
=>
{
return
(
<
Select
.
Option
key=
{
index
}
value=
{
item
}
>
{
item
}
</
Select
.
Option
>
);
})
:
''
}
</
Select
>
</
Select
>
<
div
className=
{
styles
.
unit
}
>
单位:
<
Input
style=
{
{
width
:
'5rem'
}
}
placeholder=
""
allowClear
value=
{
pramData
.
Unit
}
onChange=
{
(
e
)
=>
handleInput
(
e
,
'Unit'
)
}
/></
div
>
<
div
className=
{
styles
.
unit
}
>
<
div
className=
{
styles
.
unit
}
>
宽:
<
Input
style=
{
{
width
:
'4rem'
}
}
placeholder=
""
allowClear
value=
{
pramData
.
RowSpan
}
onChange=
{
(
e
)
=>
handleInput
(
e
,
'RowSpan'
)
}
/></
div
>
单位:
<
Input
style=
{
{
width
:
'5rem'
}
}
placeholder=
""
allowClear
value=
{
pramData
.
Unit
}
onChange=
{
e
=>
handleInput
(
e
,
'Unit'
)
}
/>
</
div
>
<
div
className=
{
styles
.
unit
}
>
宽:
<
Input
style=
{
{
width
:
'4rem'
}
}
placeholder=
""
allowClear
value=
{
pramData
.
RowSpan
}
onChange=
{
e
=>
handleInput
(
e
,
'RowSpan'
)
}
/>
</
div
>
</
div
>
</
div
>
</
Item
>
</
Item
>
{
(()
=>
{
{
(()
=>
{
switch
(
Shape
)
{
switch
(
Shape
)
{
case
'编码'
:
case
'编码'
:
return
<>
return
(
<
Item
<>
label=
"前缀"
<
Item
label=
"前缀"
name=
"prefix"
>
name=
"prefix"
<
Input
>
style=
{
{
width
:
'95%'
}
}
<
Input
style=
{
{
width
:
'95%'
}
}
placeholder=
""
allowClear
/>
placeholder=
""
allowClear
/>
</
Item
>
</
Item
>
<
Item
<
Item
label=
"编码方式"
name=
"code"
>
label=
"编码方式"
name=
"code"
>
<
Radio
.
Group
>
<
Radio
.
Group
>
<
Radio
value=
'年份编码'
style=
{
{
marginRight
:
'0.5rem'
}
}
>
XJ-2019-000001(前缀-年份-六位编码)
</
Radio
>
<
Radio
<
Radio
value=
'年月编码'
style=
{
{
marginRight
:
'0.5rem'
}
}
>
XJ-201909-000001(前缀-年份月份-六位编码)
</
Radio
>
value=
"年份编码"
<
Radio
value=
'一般编码'
defaultChecked
>
XJ00000001(前缀 八位编码)
</
Radio
>
style=
{
{
marginRight
:
'0.5rem'
}
}
>
XJ-2019-000001(前缀-年份-六位编码)
</
Radio
>
<
Radio
value=
"年月编码"
style=
{
{
marginRight
:
'0.5rem'
}
}
>
XJ-201909-000001(前缀-年份月份-六位编码)
</
Radio
>
<
Radio
value=
"一般编码"
defaultChecked
>
XJ00000001(前缀 八位编码)
</
Radio
>
</
Radio
.
Group
>
</
Radio
.
Group
>
</
Item
>
</
Item
>
</>
</>
case
'值选择器'
:
case
'值复选器'
:
case
'可编辑值选择器'
:
case
'平铺值选择器'
:
);
return
<>
<
Item
case
'值选择器'
:
label=
"可选值"
case
'值复选器'
:
name=
"Config"
case
'可编辑值选择器'
:
>
case
'平铺值选择器'
:
return
(
<>
{
' '
}
<
Item
label=
"可选值"
name=
"Config"
>
<
TextArea
allowClear
/>
<
TextArea
allowClear
/>
</
Item
>
</
Item
>
<
Item
<
Item
colon=
{
false
}
label=
" "
>
colon=
{
false
}
{
' '
}
label=
" "
<
div
style=
{
{
display
:
'flex'
,
alignItems
:
'center'
}
}
>
>
<
div
style=
{
{
display
:
'flex'
,
alignItems
:
'center'
}
}
>
<
span
style=
{
{
marginRight
:
'0.4rem'
}
}
>
<
span
style=
{
{
marginRight
:
'0.4rem'
}
}
>
以英文逗号为分隔符填写,或其他分隔符粘贴:
</
span
>
以英文逗号为分隔符填写,或其他分隔符粘贴:
<
Select
onChange=
{
handleSeparator
}
style=
{
{
width
:
'30%'
}
}
>
</
span
>
<
Select
.
Option
value=
'0'
>
以,分隔(英文逗号)
</
Select
.
Option
>
<
Select
<
Select
.
Option
value=
'1'
>
以/分隔(正斜杠)
</
Select
.
Option
>
onChange=
{
handleSeparator
}
<
Select
.
Option
value=
'2'
>
以\\分隔(反斜杠)
</
Select
.
Option
>
style=
{
{
width
:
'30%'
}
}
<
Select
.
Option
value=
'3'
>
以、分隔(中文顿号)
</
Select
.
Option
>
>
<
Select
.
Option
value=
'4'
>
以;分隔(英文分号)
</
Select
.
Option
>
<
Select
.
Option
value=
"0"
>
<
Select
.
Option
value=
'5'
>
以;分隔(中文分号)
</
Select
.
Option
>
以,分隔(英文逗号)
<
Select
.
Option
value=
'6'
>
(是)/否
</
Select
.
Option
>
</
Select
.
Option
>
<
Select
.
Option
value=
'7'
>
是/(否)
</
Select
.
Option
>
<
Select
.
Option
value=
"1"
>
<
Select
.
Option
value=
'8'
>
(否)/是
</
Select
.
Option
>
以/分隔(正斜杠)
</
Select
.
Option
>
<
Select
.
Option
value=
"2"
>
以\\分隔(反斜杠)
</
Select
.
Option
>
<
Select
.
Option
value=
"3"
>
以、分隔(中文顿号)
</
Select
.
Option
>
<
Select
.
Option
value=
"4"
>
以;分隔(英文分号)
</
Select
.
Option
>
<
Select
.
Option
value=
"5"
>
以;分隔(中文分号)
</
Select
.
Option
>
<
Select
.
Option
value=
"6"
>
(是)/否
</
Select
.
Option
>
<
Select
.
Option
value=
"7"
>
是/(否)
</
Select
.
Option
>
<
Select
.
Option
value=
"8"
>
(否)/是
</
Select
.
Option
>
</
Select
>
</
Select
>
</
div
>
</
div
>
</
Item
>
</
Item
>
</>
</>
case
'图片'
:
case
'可预览图片'
:
);
return
<
Item
case
'图片'
:
name=
"ReadOnly"
case
'可预览图片'
:
label=
"选项"
return
(
>
<
Item
name=
"ReadOnly"
label=
"选项"
>
<
div
>
<
div
>
<
Checkbox
checked=
{
pramData
.
picture
}
onChange=
{
(
e
)
=>
onChangeReady
(
e
,
'picture'
)
}
>
允许从相册选取
</
Checkbox
>
<
Checkbox
<
Checkbox
checked=
{
pramData
.
must
}
onChange=
{
(
e
)
=>
onChangeReady
(
e
,
'must'
)
}
>
必填字段
</
Checkbox
>
checked=
{
pramData
.
picture
}
onChange=
{
e
=>
onChangeReady
(
e
,
'picture'
)
}
>
允许从相册选取
</
Checkbox
>
<
Checkbox
checked=
{
pramData
.
must
}
onChange=
{
e
=>
onChangeReady
(
e
,
'must'
)
}
>
必填字段
</
Checkbox
>
</
div
>
</
div
>
</
Item
>
</
Item
>
case
'日期时间'
:
case
'日期'
:
case
'日期月份'
:
case
'日期年份'
:
case
'日期周'
:
case
'时分秒'
:
);
return
<
Item
case
'日期时间'
:
label=
"选项"
case
'日期'
:
name=
"Config"
case
'日期月份'
:
>
case
'日期年份'
:
case
'日期周'
:
case
'时分秒'
:
return
(
<
Item
label=
"选项"
name=
"Config"
>
<
Radio
.
Group
style=
{
{
marginTop
:
'0.3rem'
}
}
>
<
Radio
.
Group
style=
{
{
marginTop
:
'0.3rem'
}
}
>
<
Radio
value=
'默认为空'
defaultChecked
style=
{
{
width
:
'18rem'
,
marginBottom
:
'0.5rem'
}
}
>
默认为空
</
Radio
>
<
Radio
<
Radio
value=
''
>
默认为当前时间
</
Radio
>
value=
"默认为空"
<
Radio
value=
'不可选择'
style=
{
{
width
:
'18rem'
}
}
>
锁定为当前时间(通过用户点击刷新)
</
Radio
>
defaultChecked
<
Radio
value=
'不超过当前时间'
>
不超过当前时间
</
Radio
>
style=
{
{
width
:
'18rem'
,
marginBottom
:
'0.5rem'
}
}
>
默认为空
</
Radio
>
<
Radio
value=
""
>
默认为当前时间
</
Radio
>
<
Radio
value=
"不可选择"
style=
{
{
width
:
'18rem'
}
}
>
锁定为当前时间(通过用户点击刷新)
</
Radio
>
<
Radio
value=
"不超过当前时间"
>
不超过当前时间
</
Radio
>
</
Radio
.
Group
>
</
Radio
.
Group
>
</
Item
>
</
Item
>
);
case
'坐标控件'
:
case
'坐标控件'
:
return
<
Item
return
(
label=
"选项"
<
Item
label=
"选项"
name=
"Config"
>
name=
"Config"
>
<
div
>
<
div
>
<
Checkbox
value=
'当前坐标'
style=
{
{
marginRight
:
'0.2rem'
}
}
checked=
{
pramData
.
coordinates
}
onChange=
{
(
e
)
=>
onChangeReady
(
e
,
'coordinates'
)
}
></
Checkbox
>
锁定为当前位置坐标
<
Checkbox
value=
"当前坐标"
style=
{
{
marginRight
:
'0.2rem'
}
}
checked=
{
pramData
.
coordinates
}
onChange=
{
e
=>
onChangeReady
(
e
,
'coordinates'
)
}
/>
锁定为当前位置坐标
</
div
>
</
div
>
</
Item
>
</
Item
>
);
default
:
default
:
return
<
Item
return
(
label=
"配置"
<
Item
label=
"配置"
name=
"Config"
>
name=
"Config"
>
<
TextArea
allowClear
/>
<
TextArea
allowClear
/>
</
Item
>
</
Item
>
);
}
}
}
})()
}
)()
}
{
Shape
===
'图片'
||
Shape
===
'可预览图片'
?
(
{
Shape
===
'图片'
||
Shape
===
'可预览图片'
?
''
:
''
<
Item
)
:
(
label=
"预设值"
<
Item
label=
"预设值"
>
>
<
div
className=
{
styles
.
listEvent
}
>
<
div
className=
{
styles
.
listEvent
}
>
<
Input
style=
{
{
width
:
'40%'
,
height
:
'1.8rem'
}
}
value=
{
pramData
.
Preset
}
onChange=
{
(
e
)
=>
handleInput
(
e
,
'Preset'
)
}
placeholder=
""
allowClear
/>
<
Input
style=
{
{
width
:
'40%'
,
height
:
'1.8rem'
}
}
value=
{
pramData
.
Preset
}
onChange=
{
e
=>
handleInput
(
e
,
'Preset'
)
}
placeholder=
""
allowClear
/>
<
Item
<
Item
style=
{
{
marginLeft
:
'1rem'
}
}
style=
{
{
marginLeft
:
'1rem'
}
}
label=
"验证"
label=
"验证"
...
@@ -479,17 +677,26 @@ const AddModal = props => {
...
@@ -479,17 +677,26 @@ const AddModal = props => {
<
Tooltip
title=
"选择验证规则"
>
<
Tooltip
title=
"选择验证规则"
>
<
PlusSquareOutlined
<
PlusSquareOutlined
onClick=
{
()
=>
add
(
'rule'
)
}
onClick=
{
()
=>
add
(
'rule'
)
}
style=
{
{
fontSize
:
'24px'
,
color
:
'#1890FF'
,
display
:
'flex'
,
alignItems
:
'center'
}
}
style=
{
{
fontSize
:
'24px'
,
color
:
'#1890FF'
,
display
:
'flex'
,
alignItems
:
'center'
,
}
}
/>
/>
</
Tooltip
>
</
Tooltip
>
</
div
>
</
div
>
</
Item
>
</
Item
>
}
)
}
<
Item
<
Item
label=
"异常值"
>
label=
"异常值"
>
<
div
className=
{
styles
.
listEvent
}
>
<
div
className=
{
styles
.
listEvent
}
>
<
Input
style=
{
{
width
:
'40%'
,
height
:
'1.8rem'
}
}
value=
{
pramData
.
ExceptionValue
}
onChange=
{
(
e
)
=>
handleInput
(
e
,
'ExceptionValue'
)
}
placeholder=
""
allowClear
/>
<
Input
style=
{
{
width
:
'40%'
,
height
:
'1.8rem'
}
}
value=
{
pramData
.
ExceptionValue
}
onChange=
{
e
=>
handleInput
(
e
,
'ExceptionValue'
)
}
placeholder=
""
allowClear
/>
<
Item
<
Item
style=
{
{
marginLeft
:
'1rem'
}
}
style=
{
{
marginLeft
:
'1rem'
}
}
label=
"触发事件"
label=
"触发事件"
...
@@ -497,27 +704,51 @@ const AddModal = props => {
...
@@ -497,27 +704,51 @@ const AddModal = props => {
style=
{
{
margin
:
'0 0 0 1rem'
}
}
style=
{
{
margin
:
'0 0 0 1rem'
}
}
>
>
<
Select
style=
{
{
width
:
'12rem'
}
}
onChange=
{
handleEvent
}
>
<
Select
style=
{
{
width
:
'12rem'
}
}
onChange=
{
handleEvent
}
>
{
eventList
.
length
?
eventList
.
map
((
item
,
index
)
=>
{
return
<
Select
.
Option
key=
{
index
}
tablename=
{
item
.
TableName
}
name=
{
item
.
Name
}
value=
{
item
.
ID
}
>
{
item
.
Name
}
</
Select
.
Option
>;
})
:
''
}
{
eventList
.
length
?
eventList
.
map
((
item
,
index
)
=>
{
return
(
<
Select
.
Option
key=
{
index
}
tablename=
{
item
.
TableName
}
name=
{
item
.
Name
}
value=
{
item
.
ID
}
>
{
item
.
Name
}
</
Select
.
Option
>
);
})
:
''
}
</
Select
>
</
Select
>
</
Item
>
</
Item
>
</
div
>
</
div
>
</
Item
>
</
Item
>
<
Item
<
Item
label=
"字段集"
>
label=
"字段集"
>
<
div
className=
{
styles
.
listEvent
}
>
<
div
className=
{
styles
.
listEvent
}
>
<
Input
style=
{
{
width
:
'93%'
}
}
placeholder=
""
disabled=
{
!
isShow
}
onChange=
{
onCharacterValue
}
allowClear
value=
{
characterValue
}
/>
<
Input
style=
{
{
width
:
'93%'
}
}
placeholder=
""
disabled=
{
!
isShow
}
onChange=
{
onCharacterValue
}
allowClear
value=
{
characterValue
}
/>
<
Tooltip
title=
{
!
isShow
?
''
:
'字符集选择'
}
>
<
Tooltip
title=
{
!
isShow
?
''
:
'字符集选择'
}
>
<
PlusSquareOutlined
<
PlusSquareOutlined
onClick=
{
()
=>
!
isShow
?
''
:
add
(
'characteristics'
)
}
onClick=
{
()
=>
(
!
isShow
?
''
:
add
(
'characteristics'
))
}
style=
{
{
fontSize
:
'24px'
,
color
:
!
isShow
?
'gray'
:
'#1890FF'
,
cursor
:
!
isShow
?
'no-drop'
:
'pointer'
,
display
:
'flex'
,
alignItems
:
'center'
,
marginLeft
:
'0.5rem'
}
}
style=
{
{
fontSize
:
'24px'
,
color
:
!
isShow
?
'gray'
:
'#1890FF'
,
cursor
:
!
isShow
?
'no-drop'
:
'pointer'
,
display
:
'flex'
,
alignItems
:
'center'
,
marginLeft
:
'0.5rem'
,
}
}
/>
/>
</
Tooltip
>
</
Tooltip
>
</
div
>
</
div
>
</
Item
>
</
Item
>
</
Form
>
</
Form
>
)
}
)
}
</
Modal
>
<
ChangeAdd
<
ChangeAdd
visible=
{
visible
}
visible=
{
visible
}
onCancel=
{
()
=>
setVisible
(
false
)
}
onCancel=
{
()
=>
setVisible
(
false
)
}
...
@@ -526,7 +757,9 @@ const AddModal = props => {
...
@@ -526,7 +757,9 @@ const AddModal = props => {
isType=
{
type
}
isType=
{
type
}
filed=
{
filed
}
filed=
{
filed
}
characterValue=
{
characterValue
}
characterValue=
{
characterValue
}
formObj=
{
formObj
}
/>
formObj=
{
formObj
}
/>
</
Drawer
>
</>
</>
);
);
};
};
...
...
src/pages/platformCenter/filedConfig/filedConfig.jsx
View file @
79311bc5
...
@@ -8,19 +8,29 @@ import {
...
@@ -8,19 +8,29 @@ import {
Popconfirm
,
Popconfirm
,
Spin
,
Spin
,
notification
,
notification
,
Tooltip
Tooltip
,
}
from
'antd'
;
}
from
'antd'
;
import
{
EditOutlined
,
DeleteOutlined
,
SortDescendingOutlined
,
PlusSquareOutlined
,
RollbackOutlined
}
from
'@ant-design/icons'
;
import
{
import
{
reloadTableFields
,
removeFields
,
loadUnattachedTables
}
from
'@/services/platform/bs'
;
EditOutlined
,
DeleteOutlined
,
SortDescendingOutlined
,
PlusSquareOutlined
,
RollbackOutlined
,
}
from
'@ant-design/icons'
;
import
{
reloadTableFields
,
removeFields
,
loadUnattachedTables
,
}
from
'@/services/platform/bs'
;
import
FieldEditor
from
'./fieldEditor'
;
import
FieldEditor
from
'./fieldEditor'
;
import
{
useHistory
}
from
'react-router-dom'
;
import
{
useHistory
}
from
'react-router-dom'
;
import
styles
from
'./index.less'
import
styles
from
'./index.less'
;
import
AffiliateAdd
from
'../bsmanager/tablemanager/components/Field/affiliateAdd'
import
AffiliateAdd
from
'../bsmanager/tablemanager/components/Field/affiliateAdd'
;
import
LoadGroup
from
'../bsmanager/tablemanager/components/Field/loadGroup'
import
LoadGroup
from
'../bsmanager/tablemanager/components/Field/loadGroup'
;
const
AddModal
=
props
=>
{
const
AddModal
=
props
=>
{
const
history
=
useHistory
();
const
history
=
useHistory
();
const
[
allData
,
setAllData
]
=
useState
([]);
const
[
allData
,
setAllData
]
=
useState
([]);
const
[
tableList
,
setTableList
]
=
useState
([])
const
[
tableList
,
setTableList
]
=
useState
([]);
const
[
tableData
,
setTableData
]
=
useState
([]);
const
[
tableData
,
setTableData
]
=
useState
([]);
const
[
treeLoading
,
setTreeLoading
]
=
useState
(
false
);
const
[
treeLoading
,
setTreeLoading
]
=
useState
(
false
);
const
[
formObj
,
setFormObj
]
=
useState
(
''
);
const
[
formObj
,
setFormObj
]
=
useState
(
''
);
...
@@ -28,8 +38,8 @@ const AddModal = props => {
...
@@ -28,8 +38,8 @@ const AddModal = props => {
const
[
isVisible
,
setIsVisible
]
=
useState
(
false
);
// 弹窗
const
[
isVisible
,
setIsVisible
]
=
useState
(
false
);
// 弹窗
const
[
isType
,
setIsType
]
=
useState
(
''
);
// 弹窗类型
const
[
isType
,
setIsType
]
=
useState
(
''
);
// 弹窗类型
const
[
itemData
,
setItemData
]
=
useState
({});
const
[
itemData
,
setItemData
]
=
useState
({});
const
[
select
,
setSelect
]
=
useState
([])
const
[
select
,
setSelect
]
=
useState
([]);
const
[
selectTableName
,
setSelectTableName
]
=
useState
({})
const
[
selectTableName
,
setSelectTableName
]
=
useState
({});
const
[
pramFormObj
,
setPramFormObj
]
=
useState
({});
const
[
pramFormObj
,
setPramFormObj
]
=
useState
({});
const
[
visible
,
setVisible
]
=
useState
(
false
);
// 弹窗
const
[
visible
,
setVisible
]
=
useState
(
false
);
// 弹窗
const
[
type
,
setType
]
=
useState
(
''
);
// 弹窗类型
const
[
type
,
setType
]
=
useState
(
''
);
// 弹窗类型
...
@@ -45,12 +55,21 @@ const AddModal = props => {
...
@@ -45,12 +55,21 @@ const AddModal = props => {
const
getField
=
()
=>
{
const
getField
=
()
=>
{
loadUnattachedTables
().
then
(
res
=>
{
loadUnattachedTables
().
then
(
res
=>
{
if
(
res
.
data
.
root
&&
res
.
data
.
root
.
length
)
{
if
(
res
.
data
.
root
&&
res
.
data
.
root
.
length
)
{
setTableList
(
res
.
data
.
root
)
setTableList
(
res
.
data
.
root
);
}
}
});
})
};
// 处理表格特殊样式
const
styleConfig
=
record
=>
{
if
(
record
.
Type
===
1
)
{
return
'red'
;
}
if
(
record
.
Type
===
2
)
{
return
'grey'
;
}
}
const
expandedRowRender
=
(
item
)
=>
{
return
'000000D9'
;
};
const
expandedRowRender
=
item
=>
{
const
columns
=
[
const
columns
=
[
{
{
title
:
'字段名'
,
title
:
'字段名'
,
...
@@ -58,7 +77,11 @@ const AddModal = props => {
...
@@ -58,7 +77,11 @@ const AddModal = props => {
key
:
'name'
,
key
:
'name'
,
width
:
190
,
width
:
190
,
align
:
'left'
,
align
:
'left'
,
render
:
text
=>
<
div
style=
{
{
paddingLeft
:
'2rem'
}
}
>
{
text
}
</
div
>,
render
:
(
text
,
record
)
=>
(
<
div
style=
{
{
paddingLeft
:
'2rem'
,
color
:
styleConfig
(
record
)
}
}
>
{
text
}
</
div
>
),
},
},
{
{
title
:
'别名'
,
title
:
'别名'
,
...
@@ -66,6 +89,9 @@ const AddModal = props => {
...
@@ -66,6 +89,9 @@ const AddModal = props => {
key
:
'alias'
,
key
:
'alias'
,
align
:
'center'
,
align
:
'center'
,
width
:
200
,
width
:
200
,
render
:
(
text
,
record
)
=>
(
<
span
style=
{
{
color
:
styleConfig
(
record
)
}
}
>
{
text
}
</
span
>
),
},
},
{
{
title
:
'字段类型'
,
title
:
'字段类型'
,
...
@@ -73,6 +99,9 @@ const AddModal = props => {
...
@@ -73,6 +99,9 @@ const AddModal = props => {
key
:
'storeType'
,
key
:
'storeType'
,
align
:
'center'
,
align
:
'center'
,
width
:
200
,
width
:
200
,
render
:
(
text
,
record
)
=>
(
<
span
style=
{
{
color
:
styleConfig
(
record
)
}
}
>
{
text
}
</
span
>
),
},
},
{
{
title
:
'形态'
,
title
:
'形态'
,
...
@@ -80,6 +109,9 @@ const AddModal = props => {
...
@@ -80,6 +109,9 @@ const AddModal = props => {
key
:
'shape'
,
key
:
'shape'
,
align
:
'center'
,
align
:
'center'
,
width
:
200
,
width
:
200
,
render
:
(
text
,
record
)
=>
(
<
span
style=
{
{
color
:
styleConfig
(
record
)
}
}
>
{
text
}
</
span
>
),
},
},
{
{
title
:
'配置'
,
title
:
'配置'
,
...
@@ -87,6 +119,9 @@ const AddModal = props => {
...
@@ -87,6 +119,9 @@ const AddModal = props => {
key
:
'config'
,
key
:
'config'
,
align
:
'center'
,
align
:
'center'
,
width
:
200
,
width
:
200
,
render
:
(
text
,
record
)
=>
(
<
span
style=
{
{
color
:
styleConfig
(
record
)
}
}
>
{
text
}
</
span
>
),
},
},
{
{
...
@@ -95,6 +130,9 @@ const AddModal = props => {
...
@@ -95,6 +130,9 @@ const AddModal = props => {
key
:
'readOnly'
,
key
:
'readOnly'
,
align
:
'center'
,
align
:
'center'
,
width
:
200
,
width
:
200
,
render
:
(
text
,
record
)
=>
(
<
span
style=
{
{
color
:
styleConfig
(
record
)
}
}
>
{
text
}
</
span
>
),
},
},
{
{
title
:
'同步'
,
title
:
'同步'
,
...
@@ -102,6 +140,9 @@ const AddModal = props => {
...
@@ -102,6 +140,9 @@ const AddModal = props => {
key
:
'syncEvent'
,
key
:
'syncEvent'
,
align
:
'center'
,
align
:
'center'
,
width
:
200
,
width
:
200
,
render
:
(
text
,
record
)
=>
(
<
span
style=
{
{
color
:
styleConfig
(
record
)
}
}
>
{
text
}
</
span
>
),
},
},
{
{
title
:
'操作'
,
title
:
'操作'
,
...
@@ -111,10 +152,12 @@ const AddModal = props => {
...
@@ -111,10 +152,12 @@ const AddModal = props => {
render
:
(
text
,
record
)
=>
(
render
:
(
text
,
record
)
=>
(
<
Space
>
<
Space
>
<
Tooltip
title=
"修改"
>
<
Tooltip
title=
"修改"
>
<
EditOutlined
style=
{
{
fontSize
:
'16px'
,
color
:
'#1890FF'
}
}
<
EditOutlined
style=
{
{
fontSize
:
'16px'
,
color
:
'#1890FF'
}
}
onClick=
{
()
=>
{
onClick=
{
()
=>
{
editor
(
record
);
editor
(
record
);
}
}
>
}
}
>
编辑
编辑
</
EditOutlined
>
</
EditOutlined
>
</
Tooltip
>
</
Tooltip
>
...
@@ -128,7 +171,11 @@ const AddModal = props => {
...
@@ -128,7 +171,11 @@ const AddModal = props => {
}
}
}
}
>
>
<
Tooltip
title=
"删除"
>
<
Tooltip
title=
"删除"
>
<
DeleteOutlined
style=
{
{
fontSize
:
'16px'
,
color
:
'#e86060'
}
}
>
删除
</
DeleteOutlined
>
<
DeleteOutlined
style=
{
{
fontSize
:
'16px'
,
color
:
'#e86060'
}
}
>
删除
</
DeleteOutlined
>
</
Tooltip
>
</
Tooltip
>
</
Popconfirm
>
</
Popconfirm
>
</
div
>
</
div
>
...
@@ -137,23 +184,35 @@ const AddModal = props => {
...
@@ -137,23 +184,35 @@ const AddModal = props => {
},
},
];
];
return
<
Table
columns=
{
columns
}
onRow=
{
record
=>
{
return
(
<
Table
columns=
{
columns
}
onRow=
{
record
=>
{
return
{
return
{
onDoubleClick
:
event
=>
{
onDoubleClick
:
event
=>
{
event
.
stopPropagation
()
event
.
stopPropagation
();
editor
(
record
);
editor
(
record
);
},
},
onClick
:
event
=>
{
onClick
:
event
=>
{
event
.
stopPropagation
()
event
.
stopPropagation
();
setSelectTableName
(
record
)
setSelectTableName
(
record
);
},
// 点击行
},
// 点击行
}
}
}
bordered
rowClassName=
{
setRowClassName
}
showHeader=
{
false
}
dataSource=
{
allData
[
item
.
type
]
}
pagination=
{
false
}
/>;
};
};
const
setRowClassName
=
(
record
)
=>
}
}
Object
.
entries
(
record
).
toString
()
===
Object
.
entries
(
selectTableName
).
toString
()
?
styles
.
clickRowStyle
:
''
;
bordered
rowClassName=
{
setRowClassName
}
showHeader=
{
false
}
dataSource=
{
allData
[
item
.
type
]
}
pagination=
{
false
}
/>
);
};
const
setRowClassName
=
record
=>
Object
.
entries
(
record
).
toString
()
===
Object
.
entries
(
selectTableName
).
toString
()
?
styles
.
clickRowStyle
:
''
;
const
columns
=
[
const
columns
=
[
{
{
title
:
'字段名'
,
title
:
'字段名'
,
dataIndex
:
'type'
,
dataIndex
:
'type'
,
...
@@ -161,9 +220,12 @@ const AddModal = props => {
...
@@ -161,9 +220,12 @@ const AddModal = props => {
align
:
'left'
,
align
:
'left'
,
width
:
150
,
width
:
150
,
render
:
text
=>
{
render
:
text
=>
{
return
(<
a
>
{
text
}
(共
{
allData
[
text
]
?
allData
[
text
].
length
:
''
}
条)
</
a
>)
return
(
}
<
a
>
{
text
}
(共
{
allData
[
text
]
?
allData
[
text
].
length
:
''
}
条)
</
a
>
);
},
},
},
{
{
title
:
'别名'
,
title
:
'别名'
,
...
@@ -214,69 +276,67 @@ const AddModal = props => {
...
@@ -214,69 +276,67 @@ const AddModal = props => {
ellipsis
:
true
,
ellipsis
:
true
,
key
:
'title'
,
key
:
'title'
,
align
:
'center'
,
align
:
'center'
,
},
},
];
];
useEffect
(()
=>
{
useEffect
(()
=>
{
if
(
props
.
match
.
params
.
id
)
{
if
(
props
.
match
.
params
.
id
)
{
setFormObj
(
props
.
match
.
params
.
id
)
setFormObj
(
props
.
match
.
params
.
id
);
setTreeLoading
(
true
);
setTreeLoading
(
true
);
reloadTableFields
({
reloadTableFields
({
tableName
:
props
.
match
.
params
.
id
,
tableName
:
props
.
match
.
params
.
id
,
}).
then
(
res
=>
{
}).
then
(
res
=>
{
setTreeLoading
(
false
);
setTreeLoading
(
false
);
if
(
res
.
msg
===
'Ok'
)
{
if
(
res
.
msg
===
'Ok'
)
{
let
arr
=
formateArrDataA
(
res
.
data
.
root
,
'group'
)
let
arr
=
formateArrDataA
(
res
.
data
.
root
,
'group'
);
let
newArr
=
[]
let
newArr
=
[];
Object
.
keys
(
arr
).
map
((
item
,
index
)
=>
{
Object
.
keys
(
arr
).
map
((
item
,
index
)
=>
{
newArr
.
push
({
type
:
item
,
key
:
index
,
id
:
index
})
newArr
.
push
({
type
:
item
,
key
:
index
,
id
:
index
});
})
});
setAllData
(
arr
);
setAllData
(
arr
);
setTableData
(
newArr
);
setTableData
(
newArr
);
setSelect
(
newArr
)
setSelect
(
newArr
);
}
}
});
});
getField
()
getField
();
}
}
},
[
flag
]);
},
[
flag
]);
const
formateArrDataA
=
(
initialArr
,
name
)
=>
{
const
formateArrDataA
=
(
initialArr
,
name
)
=>
{
// 判定传参是否符合规则
// 判定传参是否符合规则
if
(
!
(
initialArr
instanceof
Array
))
{
if
(
!
(
initialArr
instanceof
Array
))
{
return
'请传入正确格式的数组'
return
'请传入正确格式的数组'
;
}
}
if
(
!
name
)
{
if
(
!
name
)
{
return
'请传入对象属性'
return
'请传入对象属性'
;
}
}
//先获取一下这个数组中有多少个"name"
//先获取一下这个数组中有多少个"name"
let
nameArr
=
[]
let
nameArr
=
[];
for
(
let
i
in
initialArr
)
{
for
(
let
i
in
initialArr
)
{
if
(
nameArr
.
indexOf
(
initialArr
[
i
][
`
${
name
}
`
])
===
-
1
)
{
if
(
nameArr
.
indexOf
(
initialArr
[
i
][
`
${
name
}
`
])
===
-
1
)
{
nameArr
.
push
(
initialArr
[
i
][
`
${
name
}
`
])
nameArr
.
push
(
initialArr
[
i
][
`
${
name
}
`
]);
}
}
}
}
//新建一个包含多个list的结果对象
//新建一个包含多个list的结果对象
let
tempObj
=
{}
let
tempObj
=
{};
// 根据不同的"name"生成多个数组
// 根据不同的"name"生成多个数组
for
(
let
k
in
nameArr
)
{
for
(
let
k
in
nameArr
)
{
for
(
let
j
in
initialArr
)
{
for
(
let
j
in
initialArr
)
{
if
(
initialArr
[
j
][
`
${
name
}
`
]
==
nameArr
[
k
])
{
if
(
initialArr
[
j
][
`
${
name
}
`
]
==
nameArr
[
k
])
{
// 每次外循环时新建一个对应"name"的数组, 内循环时当前数组不变
// 每次外循环时新建一个对应"name"的数组, 内循环时当前数组不变
tempObj
[
nameArr
[
k
]]
=
tempObj
[
nameArr
[
k
]]
||
[]
tempObj
[
nameArr
[
k
]]
=
tempObj
[
nameArr
[
k
]]
||
[];
tempObj
[
nameArr
[
k
]].
push
(
initialArr
[
j
])
tempObj
[
nameArr
[
k
]].
push
(
initialArr
[
j
]);
}
}
}
}
}
}
for
(
let
keys
in
tempObj
)
{
for
(
let
keys
in
tempObj
)
{
let
arr
=
[]
let
arr
=
[];
tempObj
[
keys
].
map
((
item
,
index
)
=>
{
tempObj
[
keys
].
map
((
item
,
index
)
=>
{
tempObj
[
keys
]
=
arr
;
tempObj
[
keys
]
=
arr
;
item
.
key
=
index
item
.
key
=
index
;
arr
.
push
(
item
)
arr
.
push
(
item
);
})
});
}
return
tempObj
}
}
return
tempObj
;
};
// 删除表字段
// 删除表字段
const
deleteChart
=
record
=>
{
const
deleteChart
=
record
=>
{
removeFields
({
fieldIDs
:
record
.
ID
}).
then
(
res
=>
{
removeFields
({
fieldIDs
:
record
.
ID
}).
then
(
res
=>
{
...
@@ -298,44 +358,63 @@ const AddModal = props => {
...
@@ -298,44 +358,63 @@ const AddModal = props => {
};
};
// 返回上一级
// 返回上一级
const
back
=
()
=>
{
const
back
=
()
=>
{
let
template
=
props
.
history
.
location
.
state
.
template
let
template
=
props
.
history
.
location
.
state
.
template
;
history
.
push
({
pathname
:
'/platformCenter/bsmanger/tablemanger'
,
state
:
{
template
}
})
history
.
push
({
}
pathname
:
'/platformCenter/bsmanger/tablemanger'
,
state
:
{
template
},
});
};
const
onUnfold
=
(
expanded
,
record
)
=>
{
const
onUnfold
=
(
expanded
,
record
)
=>
{
const
data
=
[...
select
]
const
data
=
[...
select
];
let
index
=
data
.
indexOf
(
record
)
let
index
=
data
.
indexOf
(
record
);
if
(
expanded
)
{
if
(
expanded
)
{
data
.
push
(
record
)
data
.
push
(
record
);
}
else
{
}
else
{
data
.
splice
(
index
,
1
)
data
.
splice
(
index
,
1
);
}
setSelect
(
data
)
}
}
setSelect
(
data
);
};
//附加
//附加
const
add
=
(
record
)
=>
{
const
add
=
record
=>
{
setPramFormObj
(
props
.
history
.
location
.
state
.
template
);
setPramFormObj
(
props
.
history
.
location
.
state
.
template
);
setType
(
'affiliateAdd'
);
setType
(
'affiliateAdd'
);
setVisible
(
true
);
setVisible
(
true
);
}
};
//分组与排序
//分组与排序
const
sort
=
(
record
)
=>
{
const
sort
=
record
=>
{
setPramFormObj
(
props
.
history
.
location
.
state
.
template
);
setPramFormObj
(
props
.
history
.
location
.
state
.
template
);
setType
(
'sort'
);
setType
(
'sort'
);
setVisible
(
true
);
setVisible
(
true
);
}
};
const
onSubmit
=
prop
=>
{
const
onSubmit
=
prop
=>
{
setVisible
(
false
);
setVisible
(
false
);
setFlag
(
flag
+
1
)
setFlag
(
flag
+
1
);
};
};
return
(
return
(
<>
<>
<
Spin
tip=
"loading..."
spinning=
{
treeLoading
}
>
<
Spin
tip=
"loading..."
spinning=
{
treeLoading
}
>
<
div
className=
{
styles
.
containerBox
}
>
<
div
className=
{
styles
.
containerBox
}
>
<
div
className=
{
styles
.
config
}
><
div
className=
{
styles
.
title
}
>
{
formObj
}
(字段配置)
</
div
>
<
div
className=
{
styles
.
config
}
>
<
div
className=
{
styles
.
title
}
>
{
formObj
}
(字段配置)
</
div
>
<
div
className=
{
styles
.
btn
}
>
<
div
className=
{
styles
.
btn
}
>
<
Button
type=
"primary"
icon=
{
<
PlusSquareOutlined
/>
}
onClick=
{
add
}
>
附加
</
Button
>
<
Button
<
Button
type=
"primary"
icon=
{
<
SortDescendingOutlined
/>
}
onClick=
{
sort
}
>
分组排序
</
Button
>
type=
"primary"
<
Button
type=
"primary"
icon=
{
<
RollbackOutlined
/>
}
onClick=
{
back
}
>
返回
</
Button
></
div
>
icon=
{
<
PlusSquareOutlined
/>
}
onClick=
{
add
}
>
附加
</
Button
>
<
Button
type=
"primary"
icon=
{
<
SortDescendingOutlined
/>
}
onClick=
{
sort
}
>
分组排序
</
Button
>
<
Button
type=
"primary"
icon=
{
<
RollbackOutlined
/>
}
onClick=
{
back
}
>
返回
</
Button
>
</
div
>
</
div
>
</
div
>
<
Table
<
Table
...
@@ -343,22 +422,25 @@ const AddModal = props => {
...
@@ -343,22 +422,25 @@ const AddModal = props => {
dataSource=
{
tableData
}
dataSource=
{
tableData
}
expandable=
{
{
expandedRowRender
}
}
expandable=
{
{
expandedRowRender
}
}
size=
"small"
size=
"small"
rowKey=
'id'
rowKey=
"id"
expandedRowKeys=
{
select
.
map
(
item
=>
item
.
key
)
}
//展开的行
expandedRowKeys=
{
select
.
map
(
item
=>
item
.
key
)
}
//展开的行
expandRowByClick=
{
true
}
expandRowByClick=
{
true
}
defaultExpandAllRows=
{
true
}
defaultExpandAllRows=
{
true
}
pagination=
{
false
}
pagination=
{
false
}
scroll=
{
{
y
:
'calc(100vh - 186px)'
}
}
scroll=
{
{
y
:
'calc(100vh - 186px)'
}
}
size=
"small"
size=
"small"
onExpand=
{
onUnfold
}
/>
onExpand=
{
onUnfold
}
/>
</
div
>
</
div
>
</
Spin
><
FieldEditor
</
Spin
>
<
FieldEditor
isVisible=
{
isVisible
}
isVisible=
{
isVisible
}
isType=
{
isType
}
isType=
{
isType
}
itemData=
{
itemData
}
itemData=
{
itemData
}
formObj1=
{
formObj
}
formObj1=
{
formObj
}
onCancel=
{
()
=>
setIsVisible
(
false
)
}
onCancel=
{
()
=>
setIsVisible
(
false
)
}
callBackSubmit=
{
Submit
}
/>
callBackSubmit=
{
Submit
}
/>
{
visible
&&
type
===
'affiliateAdd'
&&
(
{
visible
&&
type
===
'affiliateAdd'
&&
(
<
AffiliateAdd
<
AffiliateAdd
visible=
{
visible
}
visible=
{
visible
}
...
@@ -378,8 +460,8 @@ const AddModal = props => {
...
@@ -378,8 +460,8 @@ const AddModal = props => {
onCancel=
{
()
=>
setVisible
(
false
)
}
onCancel=
{
()
=>
setVisible
(
false
)
}
callBackSubmit=
{
onSubmit
}
callBackSubmit=
{
onSubmit
}
/>
/>
)
}
</>
)
}
</>
);
);
};
};
export
default
AddModal
;
export
default
AddModal
;
src/pages/userCenter/userManage/UserManage.js
View file @
79311bc5
...
@@ -107,6 +107,7 @@ const UserManage = () => {
...
@@ -107,6 +107,7 @@ const UserManage = () => {
const
[
searchWord
,
setSearchWord
]
=
useState
(
''
);
// 关键字
const
[
searchWord
,
setSearchWord
]
=
useState
(
''
);
// 关键字
const
[
currentSelectOrg
,
setCurrentSelectOrg
]
=
useState
(
'-1'
);
// 左侧机构树-选中组织,字符串类型默认全部机构'-1',注意用户表中的OUID是数字
const
[
currentSelectOrg
,
setCurrentSelectOrg
]
=
useState
(
'-1'
);
// 左侧机构树-选中组织,字符串类型默认全部机构'-1',注意用户表中的OUID是数字
const
[
currentSelectOldOrg
,
setCurrentSelectOldOrg
]
=
useState
([]);
// 更改机构时的树-原先选中组织
const
[
currentSelectOldOrg
,
setCurrentSelectOldOrg
]
=
useState
([]);
// 更改机构时的树-原先选中组织
const
[
showSearchStyle
,
setShowSearchStyle
]
=
useState
(
false
);
// 是否显示模糊查询样式
/** ***Modal弹框,是否可视**** */
/** ***Modal弹框,是否可视**** */
const
[
userVisible
,
setUserVisible
]
=
useState
(
false
);
// 添加用户
const
[
userVisible
,
setUserVisible
]
=
useState
(
false
);
// 添加用户
...
@@ -143,7 +144,7 @@ const UserManage = () => {
...
@@ -143,7 +144,7 @@ const UserManage = () => {
const
[
currentOrgArea
,
setCurrentOrgArea
]
=
useState
(
''
);
const
[
currentOrgArea
,
setCurrentOrgArea
]
=
useState
(
''
);
const
[
currentOrgDistinct
,
setCurrentOrgDistinct
]
=
useState
(
''
);
const
[
currentOrgDistinct
,
setCurrentOrgDistinct
]
=
useState
(
''
);
const
[
saveExtentFlag
,
setSaveExtentFlag
]
=
useState
(
0
);
const
[
saveExtentFlag
,
setSaveExtentFlag
]
=
useState
(
0
);
const
[
filteredValue
,
setFilteredValue
]
=
useState
([]);
const
[
filteredValue
,
setFilteredValue
]
=
useState
([]);
const
{
Search
}
=
Input
;
const
{
Search
}
=
Input
;
const
setRowClassName
=
record
=>
const
setRowClassName
=
record
=>
record
.
userID
===
selectColor
.
userID
?
styles
.
clickRowStyle
:
''
;
record
.
userID
===
selectColor
.
userID
?
styles
.
clickRowStyle
:
''
;
...
@@ -155,30 +156,14 @@ const UserManage = () => {
...
@@ -155,30 +156,14 @@ const UserManage = () => {
key
:
'loginName'
,
key
:
'loginName'
,
width
:
150
,
width
:
150
,
// fixed: 'left',
// fixed: 'left',
render
:
item
=>
(
render
:
item
=>
searchStyle
(
item
),
<
div
ref
=
{
r
=>
{
if
(
r
)
{
r
.
innerHTML
=
item
;
}
}}
/
>
),
},
},
{
{
title
:
'用户姓名'
,
title
:
'用户姓名'
,
dataIndex
:
'userName'
,
dataIndex
:
'userName'
,
key
:
'userName'
,
key
:
'userName'
,
width
:
150
,
width
:
150
,
render
:
item
=>
(
render
:
item
=>
searchStyle
(
item
),
<
div
ref
=
{
r
=>
{
if
(
r
)
{
r
.
innerHTML
=
item
;
}
}}
/
>
),
},
},
{
{
title
:
'所在机构'
,
title
:
'所在机构'
,
...
@@ -196,17 +181,9 @@ const UserManage = () => {
...
@@ -196,17 +181,9 @@ const UserManage = () => {
key
:
'phone'
,
key
:
'phone'
,
width
:
150
,
width
:
150
,
ellipsis
:
true
,
ellipsis
:
true
,
render
:
record
=>
{
render
:
text
=>
{
if
(
record
)
{
if
(
text
)
{
return
(
return
searchStyle
(
text
);
<
div
ref
=
{
r
=>
{
if
(
r
)
{
r
.
innerHTML
=
record
;
}
}}
/
>
);
}
}
return
<
span
>
未绑定
<
/span>
;
return
<
span
>
未绑定
<
/span>
;
},
},
...
@@ -338,10 +315,7 @@ const UserManage = () => {
...
@@ -338,10 +315,7 @@ const UserManage = () => {
<
div
style
=
{{
width
:
'130px'
}}
>
<
div
style
=
{{
width
:
'130px'
}}
>
<
Form
form
=
{
form
}
>
<
Form
form
=
{
form
}
>
<
Item
>
<
Item
>
<
Radio
.
Group
<
Radio
.
Group
value
=
{
selectValue
}
onChange
=
{
onTypeChange
}
>
value
=
{
selectValue
}
onChange
=
{
onTypeChange
}
>
<
Space
direction
=
"vertical"
>
<
Space
direction
=
"vertical"
>
<
Radio
value
=
{
0
}
>
访客
<
/Radio
>
<
Radio
value
=
{
0
}
>
访客
<
/Radio
>
<
Radio
value
=
{
1
}
>
普通用户
<
/Radio
>
<
Radio
value
=
{
1
}
>
普通用户
<
/Radio
>
...
@@ -387,7 +361,19 @@ const UserManage = () => {
...
@@ -387,7 +361,19 @@ const UserManage = () => {
),
),
},
},
];
];
// 模糊查询匹配的样式
const
searchStyle
=
val
=>
{
let
n
;
if
(
showSearchStyle
)
{
n
=
val
.
replace
(
new
RegExp
(
searchWord
,
'g'
),
`<span style='color:red'>
${
searchWord
}
</span>`
,
);
}
else
{
n
=
val
;
}
return
<
div
dangerouslySetInnerHTML
=
{{
__html
:
n
}}
/>
;
};
// 获取搜索框的值
// 获取搜索框的值
const
handleSearch
=
e
=>
{
const
handleSearch
=
e
=>
{
setSearchWord
(
e
.
target
.
value
);
setSearchWord
(
e
.
target
.
value
);
...
@@ -419,7 +405,7 @@ const UserManage = () => {
...
@@ -419,7 +405,7 @@ const UserManage = () => {
<
span
className
=
{
styles
.
titleText
}
>
{
org
.
text
}
<
/span
>
<
span
className
=
{
styles
.
titleText
}
>
{
org
.
text
}
<
/span
>
<
span
className
=
{
styles
.
tip
}
>
<
span
className
=
{
styles
.
tip
}
>
<
Tooltip
title
=
""
className
=
{
styles
.
fs
}
>
<
Tooltip
title
=
""
className
=
{
styles
.
fs
}
>
<
Dropdown
overlay
=
{
orgButtonMenu
}
disabled
=
{
currentOrgOperate
}
>
<
Dropdown
overlay
=
{
orgButtonMenu
}
disabled
=
{
currentOrgOperate
}
>
<
PlusOutlined
<
PlusOutlined
style
=
{{
marginLeft
:
20
}}
style
=
{{
marginLeft
:
20
}}
onClick
=
{
e
=>
e
.
stopPropagation
()}
onClick
=
{
e
=>
e
.
stopPropagation
()}
...
@@ -472,7 +458,7 @@ const UserManage = () => {
...
@@ -472,7 +458,7 @@ const UserManage = () => {
.
then
(
newres
=>
{
.
then
(
newres
=>
{
if
(
newres
.
code
===
0
)
{
if
(
newres
.
code
===
0
)
{
let
res
=
newres
.
data
;
let
res
=
newres
.
data
;
console
.
log
(
res
)
console
.
log
(
res
)
;
setTreeLoading
(
false
);
setTreeLoading
(
false
);
setTreeData
(
res
);
setTreeData
(
res
);
setTreeDataCopy
(
res
);
setTreeDataCopy
(
res
);
...
@@ -511,8 +497,8 @@ const UserManage = () => {
...
@@ -511,8 +497,8 @@ const UserManage = () => {
// 点击树节点,获取当前机构下所有用户
// 点击树节点,获取当前机构下所有用户
const
onSelect
=
(
props
,
e
)
=>
{
const
onSelect
=
(
props
,
e
)
=>
{
console
.
log
(
e
)
console
.
log
(
e
)
;
console
.
log
(
props
)
console
.
log
(
props
)
;
setTableLoading
(
true
);
setTableLoading
(
true
);
if
(
e
)
{
if
(
e
)
{
setOrgTitle
(
e
.
node
.
title
.
props
.
children
[
0
].
props
.
children
);
setOrgTitle
(
e
.
node
.
title
.
props
.
children
[
0
].
props
.
children
);
...
@@ -533,6 +519,7 @@ const UserManage = () => {
...
@@ -533,6 +519,7 @@ const UserManage = () => {
groupID
:
props
[
0
],
groupID
:
props
[
0
],
}).
then
(
res
=>
{
}).
then
(
res
=>
{
if
(
res
.
code
===
0
)
{
if
(
res
.
code
===
0
)
{
console
.
log
(
res
);
setCurrentOrgArea
(
res
.
data
.
MapRange
);
setCurrentOrgArea
(
res
.
data
.
MapRange
);
setCurrentOrgDistinct
(
res
.
data
.
AreeName
);
setCurrentOrgDistinct
(
res
.
data
.
AreeName
);
}
}
...
@@ -562,6 +549,7 @@ const UserManage = () => {
...
@@ -562,6 +549,7 @@ const UserManage = () => {
item
.
key
=
index
;
item
.
key
=
index
;
return
item
;
return
item
;
});
});
setShowSearchStyle
(
false
);
setTableData
(
table
);
setTableData
(
table
);
}
else
{
}
else
{
setTableLoading
(
false
);
setTableLoading
(
false
);
...
@@ -773,12 +761,12 @@ const UserManage = () => {
...
@@ -773,12 +761,12 @@ const UserManage = () => {
const
onTypeChange
=
value
=>
{
const
onTypeChange
=
value
=>
{
setSelctValue
(
value
.
target
.
value
);
setSelctValue
(
value
.
target
.
value
);
};
};
const
authUser
=
(
record
)
=>
{
const
authUser
=
record
=>
{
setCurrentUser
(
record
);
setCurrentUser
(
record
);
console
.
log
(
selectValue
)
console
.
log
(
selectValue
)
;
AddUserAuthSetting
({
AddUserAuthSetting
({
userId
:
record
.
userID
,
userId
:
record
.
userID
,
userLevel
:
selectValue
userLevel
:
selectValue
,
}).
then
(
res
=>
{
}).
then
(
res
=>
{
if
(
res
.
code
===
0
)
{
if
(
res
.
code
===
0
)
{
message
.
info
(
'提交成功'
);
message
.
info
(
'提交成功'
);
...
@@ -817,12 +805,14 @@ const UserManage = () => {
...
@@ -817,12 +805,14 @@ const UserManage = () => {
setOrgTitle
(
'全部机构搜索结果'
);
// 设置表头
setOrgTitle
(
'全部机构搜索结果'
);
// 设置表头
setCurrentSelectOrg
(
'-1'
);
// 清空选中机构
setCurrentSelectOrg
(
'-1'
);
// 清空选中机构
console
.
log
(
res
.
data
);
console
.
log
(
res
.
data
);
setShowSearchStyle
(
true
);
setTableData
(
res
.
data
);
setTableData
(
res
.
data
);
setTableLength
(
res
.
data
.
length
);
setTableLength
(
res
.
data
.
length
);
}
else
{
}
else
{
notification
.
error
({
notification
.
error
({
message
:
'提交失败'
,
message
:
'提示'
,
description
:
res
.
message
,
duration
:
3
,
description
:
res
.
msg
,
});
});
}
}
})
})
...
@@ -1137,7 +1127,7 @@ const UserManage = () => {
...
@@ -1137,7 +1127,7 @@ const UserManage = () => {
let
res
=
newres
.
data
;
let
res
=
newres
.
data
;
setTreeLoading
(
false
);
setTreeLoading
(
false
);
setSearchWord
(
''
);
setSearchWord
(
''
);
setFilteredValue
([])
setFilteredValue
([])
;
// 第一次加载,默认选择第一个组织
// 第一次加载,默认选择第一个组织
onSelect
([
res
[
0
].
id
],
false
);
onSelect
([
res
[
0
].
id
],
false
);
}
else
{
}
else
{
...
@@ -1154,9 +1144,9 @@ const UserManage = () => {
...
@@ -1154,9 +1144,9 @@ const UserManage = () => {
message
.
error
(
err
);
message
.
error
(
err
);
});
});
};
};
const
onChangeInput
=
(
filters
)
=>
{
const
onChangeInput
=
filters
=>
{
setFilteredValue
(
filters
.
OUName
);
setFilteredValue
(
filters
.
OUName
);
}
}
;
// 更改机构范围
// 更改机构范围
const
submitExtent
=
(
extent
,
areaName
)
=>
{
const
submitExtent
=
(
extent
,
areaName
)
=>
{
...
@@ -1177,14 +1167,14 @@ const UserManage = () => {
...
@@ -1177,14 +1167,14 @@ const UserManage = () => {
setEditOrgExtentVisible
(
false
);
setEditOrgExtentVisible
(
false
);
};
};
const
addChange
=
e
=>
{
const
addChange
=
e
=>
{
console
.
log
(
e
)
console
.
log
(
e
)
;
e
.
domEvent
.
stopPropagation
()
e
.
domEvent
.
stopPropagation
()
;
}
}
;
/** ***操作按钮**** */
/** ***操作按钮**** */
// 机构操作
// 机构操作
const
orgButtonMenu
=
(
const
orgButtonMenu
=
(
<
Menu
onClick
=
{
e
=>
addChange
(
e
)}
>
<
Menu
onClick
=
{
e
=>
addChange
(
e
)}
>
<
Menu
.
Item
key
=
"1"
onClick
=
{
addUser
}
icon
=
{
<
UserAddOutlined
/>
}
>
<
Menu
.
Item
key
=
"1"
onClick
=
{
addUser
}
icon
=
{
<
UserAddOutlined
/>
}
>
添加用户
添加用户
<
/Menu.Item
>
<
/Menu.Item
>
...
@@ -1194,7 +1184,7 @@ const UserManage = () => {
...
@@ -1194,7 +1184,7 @@ const UserManage = () => {
<
/Menu
>
<
/Menu
>
);
);
const
orgButtonMenu1
=
(
const
orgButtonMenu1
=
(
<
Menu
onClick
=
{
e
=>
addChange
(
e
)}
>
<
Menu
onClick
=
{
e
=>
addChange
(
e
)}
>
<
Menu
.
Item
key
=
"3"
onClick
=
{
editOrg
}
icon
=
{
<
EditOutlined
/>
}
>
<
Menu
.
Item
key
=
"3"
onClick
=
{
editOrg
}
icon
=
{
<
EditOutlined
/>
}
>
编辑当前机构
编辑当前机构
<
/Menu.Item
>
<
/Menu.Item
>
...
@@ -1231,7 +1221,7 @@ const UserManage = () => {
...
@@ -1231,7 +1221,7 @@ const UserManage = () => {
{
/* 左侧机构树 */
}
{
/* 左侧机构树 */
}
<
Spin
spinning
=
{
treeLoading
}
tip
=
"loading..."
>
<
Spin
spinning
=
{
treeLoading
}
tip
=
"loading..."
>
<
Card
<
Card
style
=
{{
overflowY
:
'hidden'
}}
style
=
{{
overflowY
:
'hidden'
}}
className
=
{
classnames
({
className
=
{
classnames
({
[
styles
.
orgContainer
]:
true
,
[
styles
.
orgContainer
]:
true
,
[
styles
.
orgContainerHide
]:
!
treeVisible
,
[
styles
.
orgContainerHide
]:
!
treeVisible
,
...
@@ -1242,7 +1232,7 @@ const UserManage = () => {
...
@@ -1242,7 +1232,7 @@ const UserManage = () => {
style
=
{{
style
=
{{
fontSize
:
'15px '
,
fontSize
:
'15px '
,
fontWeight
:
'bold'
,
fontWeight
:
'bold'
,
marginLeft
:
'15px'
marginLeft
:
'15px'
,
}}
}}
>
>
机构列表
机构列表
...
@@ -1254,11 +1244,13 @@ const UserManage = () => {
...
@@ -1254,11 +1244,13 @@ const UserManage = () => {
color
:
'#1890FF'
,
color
:
'#1890FF'
,
fontSize
:
'25px'
,
fontSize
:
'25px'
,
verticalAlign
:
'middle'
,
verticalAlign
:
'middle'
,
marginLeft
:
'67%'
marginLeft
:
'67%'
,
}}
}}
/
>
/
>
<
/Tooltip
>
<
/Tooltip
>
<
hr
style
=
{{
width
:
'95%'
,
color
:
'#eeecec'
,
marginLeft
:
'15px'
}}
/
>
<
hr
style
=
{{
width
:
'95%'
,
color
:
'#eeecec'
,
marginLeft
:
'15px'
}}
/
>
{
treeData
.
length
>
0
&&
(
{
treeData
.
length
>
0
&&
(
<
Tree
<
Tree
showIcon
=
"true"
showIcon
=
"true"
...
@@ -1271,7 +1263,7 @@ const UserManage = () => {
...
@@ -1271,7 +1263,7 @@ const UserManage = () => {
onSelect
=
{
onSelect
}
onSelect
=
{
onSelect
}
height
=
{
height
=
{
treeData
.
length
&&
treeData
.
length
>
30
treeData
.
length
&&
treeData
.
length
>
30
?
treeData
.
length
*
18
+
50
?
treeData
.
length
*
18
+
50
:
1000
:
1000
}
}
treeData
=
{
treeData
.
map
(
t
=>
mapTree
(
t
))}
treeData
=
{
treeData
.
map
(
t
=>
mapTree
(
t
))}
...
...
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