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
28545913
Commit
28545913
authored
Dec 17, 2021
by
邓超
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
fix: 重构表字段添加规则模块,消息平台推送测试模块右侧添加已选列表,重构消息推送组界面,web配置模块添加菜单组导入导出功能
parent
43cd3bb4
Hide whitespace changes
Inline
Side-by-side
Showing
12 changed files
with
780 additions
and
129 deletions
+780
-129
VerifyModal.jsx
src/pages/platformCenter/filedConfig/VerifyModal.jsx
+142
-0
fieldEditor.jsx
src/pages/platformCenter/filedConfig/fieldEditor.jsx
+28
-6
ProjectManage.jsx
...tformCenter/messageManage/projectManage/ProjectManage.jsx
+24
-7
CardCheck.jsx
...ageManage/projectManage/components/PushTest/CardCheck.jsx
+14
-4
PushTest.jsx
...sageManage/projectManage/components/PushTest/PushTest.jsx
+90
-65
PushTest.less
...ageManage/projectManage/components/PushTest/PushTest.less
+48
-35
RoleModal.jsx
...Manage/projectManage/components/RolseSelect/RoleModal.jsx
+129
-0
RoleModal.less
...anage/projectManage/components/RolseSelect/RoleModal.less
+42
-0
schemeDetail.jsx
src/pages/platformCenter/schemeDetail/schemeDetail.jsx
+64
-12
index.js
src/pages/webConfig/index.js
+1
-0
ImportOrExport.jsx
src/pages/webConfig/menuconfig/ImportOrExport.jsx
+160
-0
webMenu.jsx
src/pages/webConfig/menuconfig/webMenu.jsx
+38
-0
No files found.
src/pages/platformCenter/filedConfig/VerifyModal.jsx
0 → 100644
View file @
28545913
import
React
,
{
useState
,
useEffect
}
from
'react'
;
import
{
Modal
,
Radio
,
Checkbox
,
Input
,
Row
,
Col
,
message
}
from
'antd'
;
const
VerifyModal
=
props
=>
{
const
{
visible
,
onCancel
,
callBackSubmit
,
formObj
}
=
props
;
const
[
radioValue
,
setRadioValue
]
=
useState
();
const
[
radioOptions
]
=
useState
([
{
lable
:
'数值(number)'
,
value
:
'number'
},
{
lable
:
'整数(digits)'
,
value
:
'digits'
},
{
lable
:
'邮箱(email)'
,
value
:
'email'
},
{
lable
:
'身份证号(identity)'
,
value
:
'identity'
},
{
lable
:
'手机号(mobile)'
,
value
:
'mobile'
},
{
lable
:
'银行卡号(bankAccount)'
,
value
:
'bankAccount'
},
{
lable
:
'时间控制(timeControl)'
,
value
:
'timeControl'
},
]);
// 单选框数据
const
[
checkDefaultValue
,
setCheckDefaultValue
]
=
useState
([]);
// 复选框选择的数据
const
[
maxLengthVlaue
,
setMaxLengthVlaue
]
=
useState
(
''
);
// 最大字节长度值
const
[
hasMaxlength
,
setHasMaxlength
]
=
useState
();
// 是否有勾选最大字节长度规则
useEffect
(()
=>
{
if
(
visible
)
{
setRadioValue
(
formObj
.
numerical
);
let
chooseObj
=
formObj
.
rule
.
map
(
item
=>
{
if
(
item
.
indexOf
(
'maxLength'
)
!==
-
1
)
{
setMaxLengthVlaue
(
item
.
split
(
':'
)[
1
]);
return
'maxLength'
;
}
return
item
;
});
setCheckDefaultValue
(
chooseObj
);
}
},
[
visible
]);
useEffect
(()
=>
{
let
hasMax
=
checkDefaultValue
.
some
(
item
=>
item
===
'maxLength'
);
setHasMaxlength
(
hasMax
);
if
(
!
hasMax
)
{
setMaxLengthVlaue
(
''
);
}
},
[
checkDefaultValue
]);
// 单选框change事件
const
radioOnChange
=
e
=>
{
if
(
e
.
target
.
value
===
radioValue
)
{
setRadioValue
(
''
);
}
else
{
setRadioValue
(
e
.
target
.
value
);
}
};
// 复选框change事件
const
CheckboxOnChange
=
e
=>
{
setCheckDefaultValue
(
e
);
};
// maxleng值监听
const
maxLengthChange
=
e
=>
{
e
.
persist
();
setMaxLengthVlaue
(
e
.
target
.
value
);
};
// 保存选择规则
const
onOk
=
()
=>
{
let
checkList
=
JSON
.
parse
(
JSON
.
stringify
(
checkDefaultValue
));
checkList
=
checkList
.
map
(
item
=>
{
if
(
item
===
'maxLength'
)
{
return
`maxLength:
${
maxLengthVlaue
}
`
;
}
return
item
;
});
if
(
hasMaxlength
)
{
if
(
maxLengthVlaue
===
''
)
{
message
.
error
(
'请输入字节最大长度'
);
return
;
}
const
posReg
=
/^
\d
+$/
;
if
(
!
posReg
.
test
(
Number
(
maxLengthVlaue
)))
{
message
.
error
(
'请输入数字'
);
return
;
}
}
let
callValue
=
`
${
radioValue
?
`
${
radioValue
}
,`
:
''
}${
checkList
.
join
(
','
,
)}
`
;
callBackSubmit
(
callValue
);
};
return
(
<
div
>
<
Modal
width=
"600px"
title=
"选择验证规则"
visible=
{
visible
}
onOk=
{
onOk
}
onCancel=
{
onCancel
}
maskClosable=
{
false
}
destroyOnClose
>
<
Radio
.
Group
value=
{
radioValue
}
style=
{
{
display
:
'flex'
,
flexWrap
:
'wrap'
}
}
>
{
radioOptions
.
map
(
item
=>
(
<
Radio
value=
{
item
.
value
}
key=
{
item
.
value
}
onClick=
{
radioOnChange
}
style=
{
{
marginBottom
:
'10px'
}
}
>
{
item
.
lable
}
</
Radio
>
))
}
</
Radio
.
Group
>
<
Checkbox
.
Group
style=
{
{
width
:
'100%'
,
margin
:
'10px 0'
}
}
onChange=
{
CheckboxOnChange
}
defaultValue=
{
checkDefaultValue
}
>
<
Checkbox
value=
"required"
>
必填(required)
</
Checkbox
>
<
Checkbox
value=
"emphasis"
>
强调(emphasis)
</
Checkbox
>
<
Checkbox
value=
"sensitive"
style=
{
{
marginBottom
:
'10px'
}
}
>
敏感(sensitive)
</
Checkbox
>
<
br
/>
<
Input
.
Group
size=
"small"
>
<
Row
gutter=
{
16
}
>
<
Col
span=
{
9
}
>
<
Checkbox
value=
"maxLength"
>
字节最大长度(maxLength):
</
Checkbox
>
</
Col
>
<
Col
span=
{
8
}
>
<
Input
disabled=
{
!
hasMaxlength
}
value=
{
maxLengthVlaue
}
size=
"small"
style=
{
{
width
:
'150px'
}
}
onChange=
{
maxLengthChange
}
placeholder=
"请输入maxLength"
/>
</
Col
>
</
Row
>
</
Input
.
Group
>
</
Checkbox
.
Group
>
</
Modal
>
</
div
>
);
};
export
default
VerifyModal
;
src/pages/platformCenter/filedConfig/fieldEditor.jsx
View file @
28545913
...
...
@@ -22,6 +22,7 @@ import {
}
from
'@/services/platform/bs'
;
import
styles
from
'./index.less'
;
import
ChangeAdd
from
'./changeAdd'
;
import
VerifyModal
from
'./VerifyModal'
;
import
{
PlusSquareOutlined
}
from
'@ant-design/icons'
;
import
{
shape
}
from
'prop-types'
;
const
AddModal
=
props
=>
{
...
...
@@ -246,6 +247,7 @@ const AddModal = props => {
};
const
onOK
=
prop
=>
{
console
.
log
(
prop
,
'prop'
);
setVisible
(
false
);
if
(
type
===
'rule'
)
{
form
.
setFieldsValue
({
ValidationRule
:
prop
});
...
...
@@ -256,11 +258,18 @@ const AddModal = props => {
};
const
add
=
type
=>
{
let
obj
=
form
.
getFieldsValue
();
let
data
=
{
...
formObj
};
let
data
=
{
numerical
:
''
,
rule
:
[]
};
console
.
log
(
obj
.
ValidationRule
,
'ValidationRule'
);
if
(
obj
.
ValidationRule
)
{
let
arr
=
obj
.
ValidationRule
.
split
(
','
);
arr
.
map
(
item
=>
{
switch
(
item
)
{
arr
.
forEach
(
item
=>
{
let
value
;
if
(
item
.
indexOf
(
'maxLength'
)
!==
-
1
)
{
value
=
'maxLength'
;
}
else
{
value
=
item
;
}
switch
(
value
)
{
case
'required'
:
data
.
rule
.
push
(
item
);
break
;
...
...
@@ -270,6 +279,9 @@ const AddModal = props => {
case
'sensitive'
:
data
.
rule
.
push
(
item
);
break
;
case
'maxLength'
:
data
.
rule
.
push
(
item
);
break
;
default
:
data
.
numerical
=
item
;
}
...
...
@@ -690,7 +702,7 @@ const AddModal = props => {
</
div
>
</
Item
>
)
}
<
Item
label=
"异常值"
>
{
/*
<Item label="异常值">
<div className={styles.listEvent}>
<Input
style={{ width: '40%', height: '1.8rem' }}
...
...
@@ -748,10 +760,20 @@ const AddModal = props => {
/>
</Tooltip>
</div>
</
Item
>
</Item>
*/
}
</
Form
>
)
}
<
ChangeAdd
{
/* <ChangeAdd
visible={visible}
onCancel={() => setVisible(false)}
callBackSubmit={onOK}
newCheckedList={checkedList}
isType={type}
filed={filed}
characterValue={characterValue}
formObj={formObj}
/> */
}
<
VerifyModal
visible=
{
visible
}
onCancel=
{
()
=>
setVisible
(
false
)
}
callBackSubmit=
{
onOK
}
...
...
src/pages/platformCenter/messageManage/projectManage/ProjectManage.jsx
View file @
28545913
...
...
@@ -21,6 +21,7 @@ import {
DeleteOutlined
,
FundViewOutlined
,
FieldTimeOutlined
,
AlertTwoTone
,
}
from
'@ant-design/icons'
;
import
{
useHistory
}
from
'react-router-dom'
;
import
EditModal
from
'./components/EditModal'
;
...
...
@@ -36,7 +37,7 @@ import {
import
styles
from
'./ProjectManage.less'
;
const
{
Search
}
=
Input
;
const
{
Option
}
=
Select
;
const
ProjectManage
=
()
=>
{
const
ProjectManage
=
props
=>
{
const
history
=
useHistory
();
const
[
visibleParams
,
setvisibleParams
]
=
useState
({
addVisible
:
false
,
// 新增弹窗
...
...
@@ -60,6 +61,7 @@ const ProjectManage = () => {
const
[
showSearchStyle
,
setShowSearchStyle
]
=
useState
(
false
);
// 是否显示模糊查询样式
const
[
value
,
setValue
]
=
useState
(
''
);
const
[
pushTestMsg
,
setPushTestMsg
]
=
useState
(
''
);
const
[
currentPage
,
setCurrentPage
]
=
useState
(
1
);
const
columns
=
[
{
title
:
'方案名称'
,
...
...
@@ -68,8 +70,6 @@ const ProjectManage = () => {
render
:
(
text
,
record
)
=>
(
<
div
>
{
record
.
type
===
'定时推送'
?
(
searchStyle
(
text
)
)
:
(
<
div
style=
{
{
display
:
'flex'
,
alignItems
:
'center'
}
}
>
<
Tooltip
title=
{
text
}
>
<
FieldTimeOutlined
...
...
@@ -82,6 +82,15 @@ const ProjectManage = () => {
</
Tooltip
>
{
searchStyle
(
text
)
}
</
div
>
)
:
(
<
div
style=
{
{
display
:
'flex'
,
alignItems
:
'center'
}
}
>
<
Tooltip
title=
{
text
}
>
<
AlertTwoTone
style=
{
{
fontSize
:
'16px'
,
marginRight
:
'0.1rem'
}
}
/>
</
Tooltip
>
{
searchStyle
(
text
)
}
</
div
>
)
}
</
div
>
),
...
...
@@ -100,6 +109,7 @@ const ProjectManage = () => {
title
:
'推送组'
,
dataIndex
:
'receive_person'
,
key
:
'receive_person'
,
ellipsis
:
true
,
},
{
title
:
'是否启用'
,
...
...
@@ -155,8 +165,6 @@ const ProjectManage = () => {
// 模糊查询匹配的样式
const
searchStyle
=
val
=>
{
console
.
log
(
val
);
console
.
log
(
value
);
let
n
;
if
(
showSearchStyle
)
{
n
=
val
.
replace
(
...
...
@@ -166,7 +174,6 @@ const ProjectManage = () => {
}
else
{
n
=
val
;
}
console
.
log
(
val
);
return
<
div
dangerouslySetInnerHTML=
{
{
__html
:
n
}
}
/>;
};
...
...
@@ -179,7 +186,7 @@ const ProjectManage = () => {
setCurrentTempalte
(
record
);
history
.
push
({
pathname
:
`/platformCenter/schemeDetail`
,
state
:
{
template
:
record
},
state
:
{
template
:
record
,
currentPage
},
});
// handleShowModal("editVisible", true)
};
...
...
@@ -221,6 +228,7 @@ const ProjectManage = () => {
const
handleReset
=
()
=>
{
setCurrentType
(
'全部'
);
setCurrentName
(
'全部'
);
setCurrentPage
(
1
);
GetMessageList
({
pageSize
:
10
,
pageIndex
:
0
});
setShowSearchStyle
(
false
);
setValue
(
''
);
...
...
@@ -280,12 +288,17 @@ const ProjectManage = () => {
useEffect
(()
=>
{
setTreeLoading
(
true
);
GetMsgTypeList
().
then
(
res
=>
{
setTreeLoading
(
false
);
if
(
res
.
code
===
0
)
{
setMessageTypes
(
res
.
data
);
}
});
console
.
log
(
history
.
location
);
if
(
history
.
location
.
query
)
{
setCurrentPage
(
history
.
location
.
query
.
currentPage
);
}
},
[]);
useEffect
(()
=>
{
GetMessageList
({
pageIndex
,
pageSize
:
10
});
...
...
@@ -324,6 +337,10 @@ const ProjectManage = () => {
defaultPageSize
:
10
,
showQuickJumper
:
true
,
showSizeChanger
:
true
,
current
:
currentPage
,
onChange
:
page
=>
{
setCurrentPage
(
page
);
},
};
return
(
<
div
className=
{
styles
.
project_container
}
>
...
...
src/pages/platformCenter/messageManage/projectManage/components/PushTest/CardCheck.jsx
View file @
28545913
...
...
@@ -47,14 +47,18 @@ const CardCheck = props => {
// 添加新选中的元素
currentArr
.
forEach
(
item
=>
{
if
(
someArr
.
indexOf
(
item
)
===
-
1
)
{
newCheckList
.
push
(
item
);
let
checkName
=
plainOptions
.
find
(
ele
=>
ele
.
value
===
item
);
newCheckList
.
push
(
checkName
);
}
});
}
else
if
(
checkType
===
'del'
)
{
// 删除取消勾选的元素
preArr
.
forEach
(
item
=>
{
if
(
someArr
.
indexOf
(
item
)
===
-
1
)
{
newCheckList
.
splice
(
newCheckList
.
findIndex
(
ele
=>
ele
===
item
),
1
);
newCheckList
.
splice
(
newCheckList
.
findIndex
(
ele
=>
ele
.
value
===
item
),
1
,
);
}
});
}
...
...
@@ -88,10 +92,16 @@ const CardCheck = props => {
</
div
>
<
div
className=
{
styles
.
bottomCheckbox
}
>
<
CheckboxGroup
options=
{
plainOptions
}
value=
{
checkedList
}
onChange=
{
list
=>
onChange
(
list
)
}
/>
style=
{
{
display
:
'flex'
,
flexWrap
:
'wrap'
}
}
>
{
plainOptions
.
map
(
item
=>
(
<
Checkbox
key=
{
item
.
value
}
value=
{
item
.
value
}
>
{
item
.
label
}
</
Checkbox
>
))
}
</
CheckboxGroup
>
</
div
>
</
div
>
);
...
...
src/pages/platformCenter/messageManage/projectManage/components/PushTest/PushTest.jsx
View file @
28545913
import
React
,
{
useState
,
useEffect
,
useCallback
}
from
'react'
;
import
{
Modal
,
Form
,
Input
,
Button
,
message
,
Spin
,
Pagination
}
from
'antd'
;
import
{
Modal
,
Input
,
Button
,
message
,
Spin
,
Pagination
}
from
'antd'
;
import
{
GetGroupUserTree
,
TestPush
}
from
'@/services/platform/messagemanage'
;
import
styles
from
'./PushTest.less'
;
import
DragTable
from
'@/components/DragTable/DragTable'
;
import
CardCheck
from
'./CardCheck'
;
const
PushTest
=
props
=>
{
const
[
form
]
=
Form
.
useForm
();
const
{
confirmModal
,
onCancel
,
visible
,
pushTestMsg
}
=
props
;
const
[
allList
,
setAllist
]
=
useState
([]);
// 用于展示得数据
const
[
checkList
,
setCheckList
]
=
useState
([]);
// 选中得数据集合
...
...
@@ -13,15 +13,16 @@ const PushTest = props => {
const
[
total
,
setTotal
]
=
useState
();
const
[
currentPage
,
setCurrentPage
]
=
useState
(
1
);
const
[
pageSize
,
setPageSize
]
=
useState
(
10
);
const
[
searchName
,
setSearchName
]
=
useState
();
useEffect
(()
=>
{
if
(
visible
)
{
let
username
=
form
.
getFieldValue
(
'username'
);
setCurrentPage
(
1
);
getData
(
usern
ame
,
1
,
pageSize
);
getData
(
searchN
ame
,
1
,
pageSize
);
}
else
{
setCheckList
([]);
setAllist
([]);
form
.
setFieldsValue
({
username
:
''
}
);
setSearchName
(
''
);
}
},
[
visible
]);
// 选中后得回调函数
...
...
@@ -34,14 +35,14 @@ const PushTest = props => {
const
paginationChange
=
(
page
,
pageSizes
)
=>
{
setCurrentPage
(
page
);
setPageSize
(
pageSizes
);
let
username
=
form
.
getFieldValue
(
'username'
);
getData
(
username
,
page
,
pageSizes
);
getData
(
searchName
,
page
,
pageSizes
);
};
// 提交勾选的测试人员
const
onFinish
=
()
=>
{
TestPush
({
theme
:
pushTestMsg
.
ThemeName
,
msgType
:
pushTestMsg
.
MsgType
,
tousers
:
checkList
,
tousers
:
checkList
.
map
(
item
=>
item
.
value
)
,
pushPath
:
pushTestMsg
.
item
.
AgentConfig
?
pushTestMsg
.
item
.
AgentConfig
.
Url
:
''
,
...
...
@@ -61,15 +62,18 @@ const PushTest = props => {
};
// 搜索
const
onSearch
=
()
=>
{
let
username
=
form
.
getFieldValue
(
'username'
);
setCurrentPage
(
1
);
getData
(
usern
ame
,
1
,
pageSize
);
getData
(
searchN
ame
,
1
,
pageSize
);
};
// 重置
const
onReset
=
()
=>
{
setCurrentPage
(
1
);
getData
(
''
,
1
,
pageSize
);
form
.
setFieldsValue
({
username
:
''
});
setSearchName
(
''
);
};
// 搜索框监听
const
searchChange
=
e
=>
{
setSearchName
(
e
.
target
.
value
);
};
// 获取数据
const
getData
=
(
username
,
page
,
pageSizes
)
=>
{
...
...
@@ -90,8 +94,8 @@ const PushTest = props => {
let
checkAll
=
false
;
let
options
=
item
.
users
.
map
(
val
=>
{
checkList
.
forEach
(
ele
=>
{
if
(
val
.
userId
===
ele
)
{
checkedList
.
push
(
ele
);
if
(
val
.
userId
===
ele
.
value
)
{
checkedList
.
push
(
ele
.
value
);
}
});
return
{
...
...
@@ -99,10 +103,6 @@ const PushTest = props => {
value
:
val
.
userId
,
};
});
console
.
log
(
item
.
groupName
,
'名称'
);
console
.
log
(
checkList
,
'所有选择得列表'
);
console
.
log
(
checkedList
,
'当前组件勾选'
);
if
(
checkedList
.
length
===
options
.
length
&&
checkedList
.
length
>
0
...
...
@@ -131,70 +131,95 @@ const PushTest = props => {
message
.
error
(
'网络异常,请稍后再试'
);
});
};
// 拖拽后的回调函数
const
dragCallBack
=
val
=>
{
if
(
val
)
{
setCheckList
(
val
);
}
};
const
columns
=
[
{
title
:
'已选推送人'
,
dataIndex
:
'label'
,
key
:
'label'
,
width
:
300
,
},
];
return
(
<>
<
Modal
title=
"选择推送人"
visible=
{
visible
}
onOk=
{
onFinish
}
width=
"
7
00px"
width=
"
9
00px"
onCancel=
{
onCancel
}
maskClosable=
{
false
}
destroyOnClose
centered
>
{
/* 头部搜索框 */
}
<
div
className=
{
styles
.
searchHeader
}
>
<
Form
form=
{
form
}
layout=
"inline"
>
<
Form
.
Item
name=
"username"
>
<
Input
placeholder=
"请输入用户名称"
/>
</
Form
.
Item
>
<
Form
.
Item
>
<
Button
type=
"primary"
htmlType=
"submit"
onClick=
{
onSearch
}
style=
{
{
marginRight
:
'10px'
}
}
>
搜索
</
Button
>
<
div
className=
{
styles
.
pushTestContent
}
>
<
div
className=
{
styles
.
leftContent
}
>
{
/* 头部搜索框 */
}
<
div
className=
{
styles
.
searchHeader
}
>
<
Input
.
Search
value=
{
searchName
}
placeholder=
"请输入部门或用户"
onChange=
{
searchChange
}
onSearch=
{
onSearch
}
enterButton
style=
{
{
width
:
'300px'
,
marginRight
:
'15px'
}
}
/>
<
Button
type=
"primary"
htmlType=
"submit"
onClick=
{
onReset
}
>
重置
</
Button
>
</
Form
.
Item
>
</
Form
>
</
div
>
{
/* 复选框模块 */
}
<
Spin
spinning=
{
loading
}
>
<
div
className=
{
styles
.
checkContainer
}
>
{
allList
.
map
((
item
,
index
)
=>
(
<
div
className=
{
styles
.
checkBoxContent
}
key=
{
item
.
groupId
}
>
<
CardCheck
cardMsg=
{
item
}
cardIndex=
{
index
}
callback=
{
(
val
,
newCheckList
)
=>
checkCallBack
(
val
,
newCheckList
)
}
checkList=
{
checkList
}
/>
</
div
>
{
/* 复选框模块 */
}
<
Spin
spinning=
{
loading
}
>
<
div
className=
{
styles
.
checkContainer
}
>
{
allList
.
map
((
item
,
index
)
=>
(
<
div
className=
{
styles
.
checkBoxContent
}
key=
{
item
.
groupId
}
>
<
CardCheck
cardMsg=
{
item
}
cardIndex=
{
index
}
callback=
{
(
val
,
newCheckList
)
=>
checkCallBack
(
val
,
newCheckList
)
}
checkList=
{
checkList
}
/>
</
div
>
))
}
</
div
>
))
}
</
Spin
>
{
/* 分页 */
}
<
Pagination
total=
{
total
}
showTotal=
{
(
totals
,
range
)
=>
`第${range[0]}-${range[1]} 条/共 ${totals} 条`
}
defaultPageSize=
{
pageSize
}
defaultCurrent=
{
1
}
current=
{
currentPage
}
onChange=
{
paginationChange
}
style=
{
{
marginBottom
:
'10px'
,
width
:
'500px'
}
}
size=
"small"
showQuickJumper
/>
</
div
>
</
Spin
>
{
/* 分页 */
}
<
Pagination
total=
{
total
}
showTotal=
{
(
totals
,
range
)
=>
`第${range[0]}-${range[1]} 条/共 ${totals} 条`
}
defaultPageSize=
{
pageSiz
e
}
defaultCurrent=
{
1
}
current=
{
currentPage
}
onChange=
{
paginationChange
}
style=
{
{
marginBottom
:
'10px'
}
}
size=
"small"
showQuickJumper
/
>
<
div
className=
{
styles
.
tableRight
}
>
<
DragTable
bordered
style=
{
{
width
:
'350px'
,
overflowX
:
'hidden'
}
}
rowKey=
{
record
=>
record
.
value
}
columns=
{
columns
}
dataSource=
{
checkList
}
pagination=
{
fals
e
}
size=
"small"
dragCallBack=
{
dragCallBack
}
scroll=
{
{
y
:
530
}
}
ItemTypes=
"pushTest"
/>
</
div
>
</
div
>
</
Modal
>
</>
);
...
...
src/pages/platformCenter/messageManage/projectManage/components/PushTest/PushTest.less
View file @
28545913
.checkContainer {
height: 500px;
overflow-y: scroll;
margin: 20px 0;
padding-right: 5px;
}
.checkContent {
.pushTestContent {
display: flex;
width: 100%;
flex-direction: column;
border: 1px solid #c2cdfd;
border-radius: 5px;
margin-top: 20px;
min-height: 50px;
padding: 0 10px 10px 20px;
.ant-checkbox-wrapper {
background-color: #fff;
}
.topCheckbox {
height: 20px;
margin: -10px 0 0 0px;
line-height: 20px;
}
.topCheckbox > label :hover {
font-weight: 600;
.searchHeader {
display: flex;
}
.bottomCheckbox {
margin-top: 10px;
.ant-checkbox-group-item {
min-width: 150px !important;
}
.ant-checkbox-wrapper {
min-width: 150px !important;
.checkContainer {
height: 500px;
width: 500px;
overflow-y: scroll;
margin: 20px 0;
padding-right: 5px;
.checkContent {
display: flex;
width: 100%;
flex-direction: column;
border: 1px solid #c2cdfd;
border-radius: 5px;
margin-top: 20px;
min-height: 50px;
padding: 0 10px 10px 20px;
.ant-checkbox-wrapper {
background-color: #fff;
}
.topCheckbox {
height: 20px;
margin: -10px 0 0 0px;
line-height: 20px;
}
.topCheckbox > label :hover {
font-weight: 600;
}
.bottomCheckbox {
margin-top: 10px;
.ant-checkbox-wrapper {
min-width: 150px;
margin-left: 0;
}
// .ant-checkbox-group-item {
// min-width: 150px !important;
// }
// .ant-checkbox-wrapper {
// min-width: 150px !important;
// }
}
.checkdiv {
display: flex;
flex-wrap: wrap;
}
}
}
.checkdiv {
display: flex;
flex-wrap: wrap;
.tableRight {
margin-left: 10px;
}
}
src/pages/platformCenter/messageManage/projectManage/components/RolseSelect/RoleModal.jsx
0 → 100644
View file @
28545913
import
React
,
{
useEffect
,
useState
}
from
'react'
;
import
{
Modal
,
Checkbox
}
from
'antd'
;
import
{
RoleGroupList
}
from
'@/services/platform/messagemanage'
;
import
styles
from
'./RoleModal.less'
;
const
CheckboxGroup
=
Checkbox
.
Group
;
const
RoleModal
=
porps
=>
{
const
{
visible
,
rolCallBack
,
onCancel
,
selectValue
}
=
porps
;
const
[
roleList
,
setRoleList
]
=
useState
([]);
// 角色列表
useEffect
(()
=>
{
if
(
visible
)
{
let
hasCheckList
=
selectValue
?
selectValue
.
split
(
','
)
:
[];
RoleGroupList
().
then
(
res
=>
{
if
(
res
.
code
===
0
)
{
let
roleListData
=
res
.
data
.
roleList
;
// 给子角色分类放到外面来
roleListData
.
forEach
((
item
,
index
)
=>
{
if
(
item
.
child
.
length
>
0
)
{
item
.
child
.
forEach
((
val
,
i
)
=>
{
val
.
visibleTitle
=
`
${
item
.
visibleTitle
}
(
${
val
.
visibleTitle
}
)`
;
roleListData
.
splice
(
index
+
1
+
i
,
0
,
val
);
});
}
});
console
.
log
(
roleListData
,
'roleListData'
);
let
list
=
roleListData
.
map
(
item
=>
{
let
checkedList
=
[];
// 已选
let
options
=
[];
// 数据源
let
indeterminate
=
false
;
// 有选中但没全选样式
let
checkAll
=
false
;
// 全选样式
options
=
item
.
roleList
.
map
(
val
=>
{
hasCheckList
.
forEach
(
ele
=>
{
if
(
val
.
roleName
===
ele
)
{
checkedList
.
push
(
ele
);
}
});
return
val
.
roleName
;
});
if
(
checkedList
.
length
===
options
.
length
&&
checkedList
.
length
>
0
)
{
checkAll
=
true
;
}
if
(
checkedList
.
length
<
options
.
length
&&
checkedList
.
length
>
0
)
{
indeterminate
=
true
;
}
return
{
options
,
checkedList
,
checkAll
,
indeterminate
,
visibleTitle
:
item
.
visibleTitle
,
};
});
console
.
log
(
list
,
'list'
);
setRoleList
(
list
);
}
});
console
.
log
(
selectValue
,
'selectValue'
);
}
},
[
visible
]);
// 多选change事件
const
onCheckAllChange
=
(
e
,
index
)
=>
{
let
newCheckList
=
JSON
.
parse
(
JSON
.
stringify
(
roleList
));
newCheckList
[
index
].
checkedList
=
e
.
target
.
checked
?
newCheckList
[
index
].
options
:
[];
newCheckList
[
index
].
indeterminate
=
false
;
newCheckList
[
index
].
checkAll
=
e
.
target
.
checked
;
setRoleList
(
newCheckList
);
};
// 单选change事件
const
onChange
=
(
list
,
index
)
=>
{
let
newCheckList
=
JSON
.
parse
(
JSON
.
stringify
(
roleList
));
newCheckList
[
index
].
checkedList
=
list
;
newCheckList
[
index
].
indeterminate
=
!!
list
.
length
&&
list
.
length
<
newCheckList
[
index
].
options
.
length
;
newCheckList
[
index
].
checkAll
=
list
.
length
===
newCheckList
[
index
].
options
.
length
;
setRoleList
(
newCheckList
);
};
return
(
<
div
>
<
Modal
title=
"选择推送人"
visible=
{
visible
}
onOk=
{
()
=>
rolCallBack
(
roleList
)
}
width=
"900px"
onCancel=
{
onCancel
}
maskClosable=
{
false
}
destroyOnClose
centered
>
<
div
className=
{
styles
.
checkContainer
}
>
{
roleList
.
map
((
item
,
index
)
=>
(
<
div
className=
{
styles
.
checkContent
}
key=
{
item
.
visibleTitle
}
>
<
div
className=
{
styles
.
topCheckbox
}
>
<
Checkbox
indeterminate=
{
item
.
indeterminate
}
onChange=
{
e
=>
onCheckAllChange
(
e
,
index
)
}
checked=
{
item
.
checkAll
}
>
{
item
.
visibleTitle
}
</
Checkbox
>
</
div
>
<
div
className=
{
styles
.
bottomCheckbox
}
>
<
CheckboxGroup
value=
{
item
.
checkedList
}
onChange=
{
list
=>
onChange
(
list
,
index
)
}
style=
{
{
display
:
'flex'
,
flexWrap
:
'wrap'
}
}
>
{
item
.
options
.
map
(
val
=>
(
<
Checkbox
key=
{
val
}
value=
{
val
}
>
{
val
}
</
Checkbox
>
))
}
</
CheckboxGroup
>
</
div
>
</
div
>
))
}
</
div
>
</
Modal
>
</
div
>
);
};
export
default
RoleModal
;
src/pages/platformCenter/messageManage/projectManage/components/RolseSelect/RoleModal.less
0 → 100644
View file @
28545913
.checkContainer {
height: 500px;
width: 90%;
overflow-y: scroll;
// margin: 20px 0;
margin-left: 50%;
margin-bottom: 20px;
transform: translateX(-50%);
padding-right: 5px;
.checkContent {
display: flex;
width: 100%;
flex-direction: column;
border: 1px solid #c2cdfd;
border-radius: 5px;
margin-top: 20px;
min-height: 50px;
padding: 0 10px 10px 20px;
.ant-checkbox-wrapper {
background-color: #fff;
}
.topCheckbox {
height: 20px;
margin: -10px 0 0 0px;
line-height: 20px;
}
.topCheckbox > label :hover {
font-weight: 600;
}
.bottomCheckbox {
margin-top: 10px;
.ant-checkbox-wrapper {
min-width: 200px;
margin-left: 0;
}
}
.checkdiv {
display: flex;
flex-wrap: wrap;
}
}
}
src/pages/platformCenter/schemeDetail/schemeDetail.jsx
View file @
28545913
/* eslint-disable radix */
/* eslint-disable camelcase */
import
React
,
{
useState
,
useEffect
,
useRef
}
from
'react'
;
import
React
,
{
useState
,
useEffect
,
useRef
,
useCallback
}
from
'react'
;
import
SiteModal
from
'@/components/Modal/SiteModa'
;
import
{
Form
,
...
...
@@ -18,11 +18,12 @@ import { Switch } from 'react-router';
import
{
iteratee
}
from
'lodash'
;
import
v
from
'voca'
;
import
{
UsergroupDeleteOutlined
}
from
'@ant-design/icons'
;
import
{
UsergroupDeleteOutlined
,
IdcardOutlined
}
from
'@ant-design/icons'
;
import
moment
from
'moment'
;
import
{
useHistory
}
from
'react-router-dom'
;
import
VisibleRoleModal
from
'../messageManage/projectManage/components/RolseSelect/VisibleRoleModal'
;
import
VisibleIISAgentConfig
from
'../messageManage/projectManage/components/IISAgentConfig/VisibleIISAgentConfig'
;
import
RoleModal
from
'../messageManage/projectManage/components/RolseSelect/RoleModal'
;
import
{
GetMessageTemplate
,
UpdateMessageConfig
,
...
...
@@ -43,7 +44,7 @@ const EditModal = props => {
const
[
IISConfig
,
setIISConfig
]
=
useState
(
null
);
const
[
isUse
,
setIsUse
]
=
useState
(
'0'
);
const
[
btnType
,
setBtnType
]
=
useState
(
'定时推送'
);
const
{
template
,
confirmModal
}
=
props
.
location
.
state
;
const
{
template
,
confirmModal
,
currentPage
}
=
props
.
location
.
state
;
const
[
currentTrench
,
setCurrentTrench
]
=
useState
({
isMessageShow
:
false
,
isAPPShow
:
false
,
...
...
@@ -51,6 +52,7 @@ const EditModal = props => {
isWXShow
:
false
,
isEnterpriseWXShow
:
false
,
});
const
[
showRoleModal
,
setShowRoleModal
]
=
useState
(
false
);
// 推送组选择角色弹窗
// eslint-disable-next-line camelcase
const
[
APP_ITEMS
,
setAPP_ITEMS
]
=
useState
([]);
const
[
WEB_ITEMS
,
setWEB_ITEMS
]
=
useState
([]);
...
...
@@ -259,6 +261,7 @@ const EditModal = props => {
AddIISAgentConfig
(
IISConfig
).
then
(
res
=>
{
if
(
res
.
code
===
0
)
{
message
.
success
(
'保存成功'
);
back
();
}
else
{
notification
.
error
({
message
:
'提示'
,
...
...
@@ -268,6 +271,7 @@ const EditModal = props => {
}
});
}
else
{
back
();
message
.
success
(
'保存成功'
);
}
}
else
{
...
...
@@ -319,6 +323,7 @@ const EditModal = props => {
AddIISAgentConfig
(
IISConfig
).
then
(
res
=>
{
if
(
res
.
code
===
0
)
{
message
.
success
(
'保存成功'
);
back
();
}
else
{
notification
.
error
({
message
:
'提示'
,
...
...
@@ -328,6 +333,7 @@ const EditModal = props => {
}
});
}
else
{
back
();
message
.
success
(
'保存成功'
);
}
}
else
{
...
...
@@ -362,7 +368,12 @@ const EditModal = props => {
setIsUse
(
value
?
'1'
:
'0'
);
};
const
back
=
()
=>
{
history
.
push
(
'/platformCenter/notify'
);
history
.
push
({
pathname
:
'/platformCenter/notify'
,
query
:
{
currentPage
,
},
});
};
const
tailLayout
=
{
wrapperCol
:
{
offset
:
21
,
span
:
24
},
...
...
@@ -372,6 +383,23 @@ const EditModal = props => {
data
[
type
]
=
value
;
setCurrentTrench
(
data
);
};
// 推送组选择角色
const
rolCallBack
=
useCallback
(
list
=>
{
console
.
log
(
list
,
'list'
);
let
strList
=
[];
if
(
list
.
length
>
0
)
{
list
.
forEach
(
item
=>
{
console
.
log
(
item
,
'item'
);
item
.
checkedList
.
forEach
(
ele
=>
{
strList
.
push
(
ele
);
});
});
form
.
setFieldsValue
({
to_person
:
strList
.
join
(
','
)
});
setShowRoleModal
(
false
);
console
.
log
(
strList
.
join
(
','
));
}
});
return
(
<
div
className=
{
styles
.
editModal_container
}
>
<
Form
form=
{
form
}
{
...
layout
}
onFinish=
{
onSubmit
}
>
...
...
@@ -413,13 +441,29 @@ const EditModal = props => {
{
btnType
===
'定时推送'
&&
(
<
Card
title=
"推送信息"
style=
{
{
width
:
'100%'
,
marginTop
:
'1rem'
}
}
>
<
div
style=
{
{
display
:
'flex'
,
alignItems
:
'center'
}
}
>
<
Item
label=
"推送组"
name=
"to_person"
labelCol=
{
{
span
:
3
}
}
style=
{
{
paddingTop
:
'1.6rem'
,
width
:
'35rem'
}
}
>
<
VisibleRoleModal
<
Item
labelCol=
{
{
span
:
6
}
}
>
<
div
style=
{
{
display
:
'flex'
}
}
>
<
Item
label=
"推送组"
name=
"to_person"
style=
{
{
marginTop
:
'50px'
}
}
>
<
Input
disabled
/>
</
Item
>
<
IdcardOutlined
onClick=
{
()
=>
{
setShowRoleModal
(
true
);
}
}
style=
{
{
marginTop
:
'58px'
,
marginLeft
:
'10px'
,
fontSize
:
'22px'
,
color
:
'#1890FF'
,
cursor
:
'pointer'
,
}
}
/>
</
div
>
{
/* <VisibleRoleModal
style={{
display: 'flex',
width: '35rem',
...
...
@@ -432,7 +476,7 @@ const EditModal = props => {
title={
<UsergroupDeleteOutlined style={{ fontSize: '18px' }} />
}
/>
/>
*/
}
</
Item
>
<
div
...
...
@@ -676,6 +720,14 @@ const EditModal = props => {
</
Item
>
</
Form
>
<
div
/>
<
RoleModal
selectValue=
{
form
.
getFieldValue
(
'to_person'
)
}
visible=
{
showRoleModal
}
rolCallBack=
{
roleList
=>
rolCallBack
(
roleList
)
}
onCancel=
{
()
=>
{
setShowRoleModal
(
false
);
}
}
/>
</
div
>
);
};
...
...
src/pages/webConfig/index.js
View file @
28545913
...
...
@@ -52,6 +52,7 @@ const WebConfigPage = props => {
},
[]);
useEffect
(()
=>
{
console
.
log
(
curWeb
,
'curWeb'
);
let
canceled
=
{
cancel
:
false
};
if
(
!
curWeb
)
return
;
const
title
=
curWeb
.
text
;
...
...
src/pages/webConfig/menuconfig/ImportOrExport.jsx
0 → 100644
View file @
28545913
import
React
,
{
useEffect
,
useState
}
from
'react'
;
import
{
Modal
,
Upload
,
Button
,
Form
,
Input
,
message
,
Popconfirm
}
from
'antd'
;
import
{
UploadOutlined
,
DownloadOutlined
}
from
'@ant-design/icons'
;
import
{
UpLoadWebModuleTree
,
DownLoadWebModuleTree
,
}
from
'@/services/webConfig/api'
;
const
ImportOrExport
=
props
=>
{
const
{
visible
,
onFinish
,
onCancel
,
nodeObj
,
subSystemValue
}
=
props
;
const
[
form
]
=
Form
.
useForm
();
const
[
uploading
,
setUploading
]
=
useState
(
false
);
// 文件是否上传成功
const
[
file
,
setFile
]
=
useState
();
// 上传文件信息
useEffect
(()
=>
{
if
(
visible
)
{
form
.
setFieldsValue
({
fileName
:
''
});
}
},
[
visible
]);
// 本地上传文件
const
beforeUpload
=
val
=>
{
console
.
log
(
val
);
form
.
setFieldsValue
({
fileName
:
val
.
name
});
setFile
(
val
);
return
false
;
};
// 导出菜单
const
hadelExport
=
()
=>
{
window
.
location
.
href
=
DownLoadWebModuleTree
({
nodeId
:
nodeObj
?
nodeObj
.
menuID
:
'-1'
,
sysName
:
subSystemValue
,
});
};
// 提交上传文件
const
handleUpload
=
type
=>
{
if
(
!
form
.
getFieldValue
(
'fileName'
))
{
message
.
info
(
'请上传文件'
);
return
;
}
const
formData
=
new
FormData
();
formData
.
append
(
'_files'
,
file
);
formData
.
append
(
'type'
,
type
);
formData
.
append
(
'nodeId'
,
nodeObj
?
nodeObj
.
menuID
:
'-1'
);
formData
.
append
(
'visible'
,
subSystemValue
);
UpLoadWebModuleTree
(
formData
)
.
then
(
res
=>
{
console
.
log
(
res
);
if
(
res
.
code
===
0
)
{
message
.
success
(
'上传成功'
);
onCancel
();
}
else
{
message
.
error
(
res
.
msg
);
}
})
.
catch
(()
=>
{
message
.
error
(
'网络异常,请稍后再试'
);
});
};
return
(
<>
<
Modal
title=
"菜单组导入导出"
visible=
{
visible
}
onOk=
{
onFinish
}
width=
"550px"
onCancel=
{
onCancel
}
maskClosable=
{
false
}
destroyOnClose
centered
footer=
{
null
}
>
<
div
style=
{
{
paddingBottom
:
'15px'
}
}
>
<
Form
name=
"form"
labelCol=
{
{
span
:
4
}
}
wrapperCol=
{
{
span
:
20
}
}
form=
{
form
}
>
<
Form
.
Item
label=
"本地导出"
>
<
Button
type=
"primary"
onClick=
{
hadelExport
}
icon=
{
<
DownloadOutlined
/>
}
>
导出菜单配置
</
Button
>
</
Form
.
Item
>
<
Form
.
Item
label=
"本地导入"
>
<
div
style=
{
{
display
:
'flex'
}
}
>
<
Form
.
Item
name=
"fileName"
style=
{
{
marginBottom
:
'0'
}
}
>
<
Input
disabled
/>
</
Form
.
Item
>
<
Upload
beforeUpload=
{
beforeUpload
}
showUploadList=
{
false
}
accept=
".json"
>
<
Button
type=
"primary"
style=
{
{
marginLeft
:
'10px'
}
}
icon=
{
<
UploadOutlined
/>
}
shape=
"circle"
/>
</
Upload
>
<
Popconfirm
title=
{
<
span
>
导入操作会覆盖所有菜单配置并且使
<
br
/>
角色菜单权限失效是否继续导入?
</
span
>
}
onConfirm=
{
()
=>
handleUpload
(
1
)
}
onVisibleChange=
{
()
=>
console
.
log
(
'visible change'
)
}
>
<
Button
type=
"primary"
style=
{
{
marginLeft
:
'10px'
,
display
:
nodeObj
?
'none'
:
'block'
,
}
}
>
覆盖导入
</
Button
>
</
Popconfirm
>
<
Button
type=
"primary"
onClick=
{
()
=>
handleUpload
(
2
)
}
loading=
{
uploading
}
style=
{
{
marginLeft
:
'10px'
,
display
:
nodeObj
?
'none'
:
'block'
,
}
}
>
增量导入
</
Button
>
<
Button
type=
"primary"
onClick=
{
()
=>
handleUpload
(
2
)
}
loading=
{
uploading
}
style=
{
{
marginLeft
:
'10px'
,
display
:
nodeObj
?
'block'
:
'none'
,
}
}
>
开始导入
</
Button
>
</
div
>
</
Form
.
Item
>
</
Form
>
</
div
>
</
Modal
>
</>
);
};
export
default
ImportOrExport
;
src/pages/webConfig/menuconfig/webMenu.jsx
View file @
28545913
...
...
@@ -10,12 +10,14 @@ import {
FolderFilled
,
FileOutlined
,
DeleteTwoTone
,
DeliveredProcedureOutlined
,
}
from
'@ant-design/icons'
;
import
classnames
from
'classnames'
;
import
styles
from
'./webMenu.less'
;
import
AddForm
from
'./AddForm'
;
import
EditForm
from
'./editForm'
;
import
CheckList
from
'./checkBox'
;
import
ImportOrExport
from
'./ImportOrExport'
;
import
{
addWebMenu
,
// 增
deleteWebMenu
,
// 删
...
...
@@ -41,6 +43,7 @@ const MiniMenu = props => {
const
[
menuID
,
setMenuID
]
=
useState
(
''
);
// 选中的树ID
const
[
nodeType
,
setNodeType
]
=
useState
(
''
);
// 选中的节点类型
const
[
info
,
setInfo
]
=
useState
({});
const
[
importOrExportVisible
,
setImportOrExportVisible
]
=
useState
(
false
);
// 导入导出弹窗
const
[
addVisible
,
setAddVisible
]
=
useState
(
false
);
// 新增弹窗
const
[
addTwoVisible
,
setAddTwoVisible
]
=
useState
(
false
);
// 编辑弹窗
const
[
delVisible
,
setDelVisible
]
=
useState
(
false
);
// 删除弹窗
...
...
@@ -92,6 +95,14 @@ const MiniMenu = props => {
<
div
className=
{
styles
.
title
}
>
<
div
>
{
obj
.
text
}
</
div
>
<
div
className=
{
styles
.
tip
}
>
{
obj
.
menuType
===
'Web4MenuGroup'
&&
(
<
Tooltip
title=
"导入导出菜单组"
className=
{
styles
.
fs
}
>
<
DeliveredProcedureOutlined
style=
{
{
color
:
'#178BF7'
}
}
onClick=
{
e
=>
importAndExport
(
obj
,
e
)
}
/>
</
Tooltip
>
)
}
{
obj
.
menuType
===
'Web4MenuGroup'
&&
(
<
Tooltip
title=
"新增菜单组"
className=
{
styles
.
fs
}
>
<
FolderAddTwoTone
onClick=
{
e
=>
addMenuGroupTip
(
obj
,
e
)
}
/>
...
...
@@ -205,6 +216,12 @@ const MiniMenu = props => {
console
.
error
(
err
);
});
};
// 导入导出菜单组
const
importAndExport
=
(
val
,
e
)
=>
{
e
.
stopPropagation
();
setNodeObj
(
val
);
setImportOrExportVisible
(
true
);
};
// 新增菜单组
const
addMenuGroupTip
=
(
val
,
e
)
=>
{
e
.
stopPropagation
();
...
...
@@ -245,6 +262,8 @@ const MiniMenu = props => {
}
return
url
;
};
// 导入或导出弹窗回调
const
onFinishCallBack
=
()
=>
{};
// 新增提交的回调
const
submitCallback
=
(
prop
,
item
)
=>
{
console
.
log
(
subSystemValue
,
'subSystemValue'
);
...
...
@@ -507,6 +526,15 @@ const MiniMenu = props => {
>
菜单列表
<
div
className=
{
classnames
(
styles
.
tRight
)
}
>
<
Tooltip
title=
"导入导出菜单组"
className=
{
styles
.
fs
}
>
<
DeliveredProcedureOutlined
style=
{
{
color
:
'#178BF7'
,
marginRight
:
'10px'
}
}
onClick=
{
()
=>
{
setNodeObj
(
''
);
setImportOrExportVisible
(
true
);
}
}
/>
</
Tooltip
>
<
Tooltip
title=
"新增最上级菜单组"
>
<
FolderAddTwoTone
className=
{
`${styles.icon1} ${styles.icon}`
}
...
...
@@ -620,6 +648,16 @@ const MiniMenu = props => {
/>
)
}
</
div
>
<
ImportOrExport
visible=
{
importOrExportVisible
}
onFinish=
{
onFinishCallBack
}
onCancel=
{
()
=>
{
setImportOrExportVisible
(
false
);
getTree
();
}
}
subSystemValue=
{
subSystemValue
}
nodeObj=
{
nodeObj
}
/>
{
/* <div
className={classnames({
[styles.rightBox]: true,
...
...
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