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
0e9bfe4b
Commit
0e9bfe4b
authored
Oct 15, 2021
by
邓超
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
fix: 添加外部字段模块,修改表返回位置问题
parent
5946c5ef
Hide whitespace changes
Inline
Side-by-side
Showing
9 changed files
with
594 additions
and
454 deletions
+594
-454
index.jsx
src/pages/platformCenter/bsmanager/tablemanager/index.jsx
+528
-442
flowNode.jsx
...s/platformCenter/bsmanager/workFlow/flowNode/flowNode.jsx
+1
-1
flowNode.less
.../platformCenter/bsmanager/workFlow/flowNode/flowNode.less
+9
-0
NodeEdit.jsx
...manager/workFlow/flowNode/flowNodeComponents/NodeEdit.jsx
+21
-1
Fieldselection.jsx
.../flowNodeComponents/nodeEditComponents/Fieldselection.jsx
+1
-3
filedConfig.jsx
src/pages/platformCenter/filedConfig/filedConfig.jsx
+5
-3
editorModal.jsx
src/pages/platformCenter/standingBook/editorModal.jsx
+26
-2
utils.js
src/pages/webConfig/utils.js
+1
-0
bs.jsx
src/services/platform/bs.jsx
+2
-2
No files found.
src/pages/platformCenter/bsmanager/tablemanager/index.jsx
View file @
0e9bfe4b
import
React
,
{
useEffect
,
useState
}
from
'react'
import
React
,
{
useEffect
,
useState
}
from
'react'
;
import
classnames
from
'classnames'
;
import
classnames
from
'classnames'
;
import
{
import
{
// Tree,
// Tree,
Table
,
Table
,
Space
,
Space
,
Input
,
Input
,
Button
,
Button
,
Select
,
Select
,
Popconfirm
,
Popconfirm
,
notification
,
notification
,
Spin
,
Spin
,
Tooltip
,
Tooltip
,
Badge
,
Spac
Badge
,
Spac
,
}
from
'antd'
;
}
from
'antd'
;
import
{
EditOutlined
,
DeleteOutlined
,
FontColorsOutlined
,
PlusSquareOutlined
,
SortDescendingOutlined
,
PlusOutlined
,
BorderInnerOutlined
}
from
'@ant-design/icons'
;
import
{
EditOutlined
,
DeleteOutlined
,
FontColorsOutlined
,
PlusSquareOutlined
,
SortDescendingOutlined
,
PlusOutlined
,
BorderInnerOutlined
,
}
from
'@ant-design/icons'
;
import
PageContainer
from
'@/components/BasePageContainer'
;
import
PageContainer
from
'@/components/BasePageContainer'
;
import
{
CM_Table_LoadTable
,
removeTable
,
loadUnattachedTables
}
from
'@/services/platform/bs'
import
{
import
styles
from
'./index.less'
CM_Table_LoadTable
,
import
Editor
from
'./components/Field/editor'
removeTable
,
import
AddTablelList
from
'./components/Field/addTable'
loadUnattachedTables
,
import
AffiliateAdd
from
'./components/Field/affiliateAdd'
}
from
'@/services/platform/bs'
;
import
LoadGroup
from
'./components/Field/loadGroup'
import
styles
from
'./index.less'
;
import
Editor
from
'./components/Field/editor'
;
import
AddTablelList
from
'./components/Field/addTable'
;
import
AffiliateAdd
from
'./components/Field/affiliateAdd'
;
import
LoadGroup
from
'./components/Field/loadGroup'
;
import
{
useHistory
}
from
'react-router-dom'
;
import
{
useHistory
}
from
'react-router-dom'
;
const
{
Search
}
=
Input
;
const
{
Search
}
=
Input
;
const
{
Option
}
=
Select
;
const
{
Option
}
=
Select
;
const
placeholder
=
"请输入表名"
const
placeholder
=
'请输入表名'
;
const
TableManager
=
(
props
)
=>
{
const
history
=
useHistory
();
const
[
visible
,
setVisible
]
=
useState
(
false
);
// 弹窗
const
[
type
,
setType
]
=
useState
(
''
);
// 弹窗类型
const
[
formObj
,
setFormObj
]
=
useState
({});
const
[
flag
,
setFlag
]
=
useState
(
0
);
// 弹窗类型
const
[
searchValue
,
setSearchValue
]
=
useState
(
''
)
const
[
treeLoading
,
setTreeLoading
]
=
useState
(
true
)
const
[
tableList
,
setTableList
]
=
useState
([])
const
[
groupArr
,
setGroupArr
]
=
useState
([])
const
[
allData
,
setAllData
]
=
useState
([])
const
[
tableData
,
setTableData
]
=
useState
([])
const
[
select
,
setSelect
]
=
useState
([])
const
[
selectTableName
,
setSelectTableName
]
=
useState
({})
useEffect
((
record
)
=>
{
loadTable
(
searchValue
)
getField
()
if
(
props
.
history
.
location
.
state
)
{
let
template
=
props
.
history
.
location
.
state
.
template
setSelectTableName
(
template
)
}
},
[
flag
])
//附加
const
TableManager
=
props
=>
{
const
add
=
(
record
)
=>
{
const
history
=
useHistory
();
setFormObj
(
record
);
const
[
visible
,
setVisible
]
=
useState
(
false
);
// 弹窗
setType
(
'affiliateAdd'
);
const
[
type
,
setType
]
=
useState
(
''
);
// 弹窗类型
setVisible
(
true
);
const
[
formObj
,
setFormObj
]
=
useState
({});
}
const
[
flag
,
setFlag
]
=
useState
(
0
);
// 弹窗类型
//修改表名
const
[
searchValue
,
setSearchValue
]
=
useState
(
''
);
const
changeDesc
=
(
record
)
=>
{
const
[
treeLoading
,
setTreeLoading
]
=
useState
(
true
);
setType
(
'edit'
);
const
[
tableList
,
setTableList
]
=
useState
([]);
setVisible
(
true
);
const
[
groupArr
,
setGroupArr
]
=
useState
([]);
setFormObj
(
record
);
const
[
allData
,
setAllData
]
=
useState
([]);
}
const
[
tableData
,
setTableData
]
=
useState
([]);
//删除表
const
[
select
,
setSelect
]
=
useState
([]);
const
deleteChart
=
(
record
)
=>
{
const
[
selectTableName
,
setSelectTableName
]
=
useState
(
''
);
removeTable
({
tableID
:
record
.
tableID
,
removeFields
:
true
}).
then
(
res
=>
{
useEffect
(
if
(
res
.
msg
===
'Ok'
||
res
.
msg
===
''
)
{
record
=>
{
notification
.
success
({
loadTable
(
searchValue
);
message
:
'提示'
,
getField
();
duration
:
3
,
// if (props.history.location.query && selectTableName !== {}) {
description
:
'删除成功'
,
// let { template } = props.history.location.query;
});
// setSelectTableName(template);
setFlag
(
flag
+
1
)
// }
}
},
else
{
[
flag
],
notification
.
error
({
);
message
:
'提示'
,
// 重字段配置返回后需要返回到原来的位置
duration
:
3
,
useEffect
(()
=>
{
description
:
res
.
msg
,
let
arr
=
Object
.
keys
(
allData
);
});
console
.
log
(
selectTableName
,
'selectTableName'
);
}
console
.
log
(
arr
,
'arr'
);
})
console
.
log
(
props
.
history
.
location
.
query
,
'props.history.location.query'
);
if
(
arr
.
length
>
0
&&
props
.
history
.
location
.
query
&&
selectTableName
==
''
)
{
console
.
log
(
234534256342
);
let
{
tableScroll
,
template
}
=
props
.
history
.
location
.
query
;
setSelectTableName
(
template
);
setTimeout
(()
=>
{
document
.
querySelector
(
'.ant-table-body'
).
scrollTop
=
tableScroll
;
},
0
);
}
}
},
[
allData
]);
// 附加
const
add
=
record
=>
{
setFormObj
(
record
);
setType
(
'affiliateAdd'
);
setVisible
(
true
);
};
// 修改表名
const
changeDesc
=
record
=>
{
setType
(
'edit'
);
setVisible
(
true
);
setFormObj
(
record
);
};
// 删除表
const
deleteChart
=
record
=>
{
removeTable
({
tableID
:
record
.
tableID
,
removeFields
:
true
}).
then
(
res
=>
{
if
(
res
.
msg
===
'Ok'
||
res
.
msg
===
''
)
{
notification
.
success
({
message
:
'提示'
,
duration
:
3
,
description
:
'删除成功'
,
});
setFlag
(
flag
+
1
);
}
else
{
notification
.
error
({
message
:
'提示'
,
duration
:
3
,
description
:
res
.
msg
,
});
}
});
};
const
onSubmit
=
prop
=>
{
const
onSubmit
=
prop
=>
{
setVisible
(
false
);
setVisible
(
false
);
setFlag
(
flag
+
1
)
setFlag
(
flag
+
1
);
};
};
//建表
// 建表
const
AddTable
=
()
=>
{
const
AddTable
=
()
=>
{
setType
(
'add'
);
setType
(
'add'
);
setVisible
(
true
);
setVisible
(
true
);
}
};
//附加表
// 附加表
const
AffiliateAddTable
=
()
=>
{
const
AffiliateAddTable
=
()
=>
{
setType
(
'affiliateAdd'
);
setType
(
'affiliateAdd'
);
setFormObj
({});
setFormObj
({});
setVisible
(
true
);
setVisible
(
true
);
}
};
//字段配置
// 字段配置
const
fieldsConfig
=
(
record
,
e
)
=>
{
const
fieldsConfig
=
(
record
,
e
)
=>
{
e
.
stopPropagation
()
e
.
stopPropagation
();
setFormObj
(
record
);
setFormObj
(
record
);
history
.
push
({
pathname
:
`/platformCenter/bsmanger/filedConfig/
${
record
.
tableName
}
`
,
state
:
{
template
:
record
}
})
history
.
push
({
// setType('config');
pathname
:
`/platformCenter/bsmanger/filedConfig/
${
record
.
tableName
}
`
,
// setVisible(true);
state
:
{
}
template
:
record
,
//分组与排序
tableScroll
:
document
.
querySelector
(
'.ant-table-body'
).
scrollTop
,
const
sort
=
(
record
)
=>
{
},
setFormObj
(
record
);
});
setType
(
'sort'
);
// setType('config');
setVisible
(
true
);
// setVisible(true);
}
};
//搜索框改变时存储输入的值
// 分组与排序
const
handleChange
=
(
e
)
=>
{
const
sort
=
record
=>
{
setSearchValue
(
e
.
target
.
value
)
setFormObj
(
record
);
}
setType
(
'sort'
);
//搜索
setVisible
(
true
);
const
handleSearch
=
(
text
)
=>
{
};
loadTable
(
text
)
// 搜索框改变时存储输入的值
setSearchValue
(
text
)
const
handleChange
=
e
=>
{
}
setSearchValue
(
e
.
target
.
value
);
const
getField
=
()
=>
{
};
loadUnattachedTables
().
then
(
res
=>
{
// 搜索
if
(
res
.
data
.
root
&&
res
.
data
.
root
.
length
)
{
const
handleSearch
=
text
=>
{
setTableList
(
res
.
data
.
root
)
loadTable
(
text
);
}
setSearchValue
(
text
);
};
const
getField
=
()
=>
{
loadUnattachedTables
().
then
(
res
=>
{
if
(
res
.
data
.
root
&&
res
.
data
.
root
.
length
)
{
setTableList
(
res
.
data
.
root
);
}
});
};
// 加载表
const
loadTable
=
keyword
=>
{
setTreeLoading
(
true
);
CM_Table_LoadTable
({
_version
:
9999
,
filter
:
keyword
||
''
,
})
.
then
(
res
=>
{
setTreeLoading
(
false
);
if
(
res
.
msg
===
'Ok'
)
{
setTableData
(
res
.
data
.
root
);
let
groupData
=
formateArrDataA
(
res
.
data
.
root
,
'groupName'
);
let
newArr
=
[];
Object
.
keys
(
groupData
).
map
((
item
,
index
)
=>
{
newArr
.
push
({
type
:
item
,
key
:
index
});
});
})
setAllData
(
groupData
);
setGroupArr
(
newArr
);
setSelect
(
newArr
);
}
})
.
catch
(
e
=>
{
setTreeLoading
(
true
);
});
};
const
formateArrDataA
=
(
initialArr
,
name
)
=>
{
// 判定传参是否符合规则
if
(
!
(
initialArr
instanceof
Array
))
{
return
'请传入正确格式的数组'
;
}
}
//加载表
if
(
!
name
)
{
const
loadTable
=
(
keyword
)
=>
{
return
'请传入对象属性'
;
setTreeLoading
(
true
)
CM_Table_LoadTable
({
_version
:
9999
,
filter
:
keyword
||
''
}).
then
(
res
=>
{
setTreeLoading
(
false
)
if
(
res
.
msg
===
'Ok'
)
{
setTableData
(
res
.
data
.
root
)
let
groupData
=
formateArrDataA
(
res
.
data
.
root
,
'groupName'
)
let
newArr
=
[]
Object
.
keys
(
groupData
).
map
((
item
,
index
)
=>
{
newArr
.
push
({
type
:
item
,
key
:
index
})
})
setAllData
(
groupData
)
setGroupArr
(
newArr
)
setSelect
(
newArr
)
}
}
).
catch
(
e
=>
{
setTreeLoading
(
true
)
})
}
}
const
formateArrDataA
=
(
initialArr
,
name
)
=>
{
// 先获取一下这个数组中有多少个"name"
// 判定传参是否符合规则
let
nameArr
=
[];
if
(
!
(
initialArr
instanceof
Array
))
{
for
(
let
i
in
initialArr
)
{
return
'请传入正确格式的数组'
if
(
nameArr
.
indexOf
(
initialArr
[
i
][
`
${
name
}
`
])
===
-
1
)
{
}
nameArr
.
push
(
initialArr
[
i
][
`
${
name
}
`
]);
if
(
!
name
)
{
}
return
'请传入对象属性'
}
}
// 新建一个包含多个list的结果对象
//先获取一下这个数组中有多少个"name"
let
tempObj
=
{};
let
nameArr
=
[]
// 根据不同的"name"生成多个数组
for
(
let
i
in
initialArr
)
{
for
(
let
k
in
nameArr
)
{
if
(
nameArr
.
indexOf
(
initialArr
[
i
][
`
${
name
}
`
])
===
-
1
)
{
for
(
let
j
in
initialArr
)
{
nameArr
.
push
(
initialArr
[
i
][
`
${
name
}
`
])
if
(
initialArr
[
j
][
`
${
name
}
`
]
==
nameArr
[
k
])
{
}
// 每次外循环时新建一个对应"name"的数组, 内循环时当前数组不变
}
tempObj
[
nameArr
[
k
]]
=
tempObj
[
nameArr
[
k
]]
||
[];
//新建一个包含多个list的结果对象
tempObj
[
nameArr
[
k
]].
push
(
initialArr
[
j
]);
let
tempObj
=
{}
// 根据不同的"name"生成多个数组
for
(
let
k
in
nameArr
)
{
for
(
let
j
in
initialArr
)
{
if
(
initialArr
[
j
][
`
${
name
}
`
]
==
nameArr
[
k
])
{
// 每次外循环时新建一个对应"name"的数组, 内循环时当前数组不变
tempObj
[
nameArr
[
k
]]
=
tempObj
[
nameArr
[
k
]]
||
[]
tempObj
[
nameArr
[
k
]].
push
(
initialArr
[
j
])
}
}
}
for
(
let
keys
in
tempObj
)
{
let
arr
=
[]
tempObj
[
keys
].
map
((
item
,
index
)
=>
{
tempObj
[
keys
]
=
arr
;
item
.
key
=
index
arr
.
push
(
item
)
})
}
}
return
tempObj
}
}
}
const
setRowClassName
=
record
=>
for
(
let
keys
in
tempObj
)
{
Object
.
entries
(
record
).
toString
()
===
Object
.
entries
(
selectTableName
).
toString
()
?
styles
.
clickRowStyle
:
''
;
let
arr
=
[];
const
expandedRowRender
=
(
item
)
=>
{
tempObj
[
keys
].
map
((
item
,
index
)
=>
{
const
columns1
=
[
tempObj
[
keys
]
=
arr
;
{
item
.
key
=
index
;
title
:
'名称'
,
arr
.
push
(
item
);
dataIndex
:
'tableName'
,
});
key
:
'tableName'
,
}
width
:
300
,
return
tempObj
;
render
:
(
text
,
record
)
=>
<
div
onClick=
{
e
=>
fieldsConfig
(
record
,
e
)
}
>
{
text
}
</
div
>,
};
const
setRowClassName
=
record
=>
},
Object
.
entries
(
record
).
toString
()
===
{
Object
.
entries
(
selectTableName
).
toString
()
title
:
'别名'
,
?
styles
.
clickRowStyle
dataIndex
:
'tableAlias'
,
:
''
;
key
:
'tableAlias'
,
const
expandedRowRender
=
item
=>
{
align
:
'center'
,
const
columns1
=
[
},
{
{
title
:
'名称'
,
title
:
'表格样式'
,
dataIndex
:
'tableName'
,
dataIndex
:
'tableStyle'
,
key
:
'tableName'
,
key
:
'tableStyle'
,
width
:
300
,
align
:
'center'
render
:
(
text
,
record
)
=>
(
},
<
div
onClick=
{
e
=>
fieldsConfig
(
record
,
e
)
}
>
{
text
}
</
div
>
{
),
title
:
'附加字段'
,
},
dataIndex
:
'fieldCount'
,
{
key
:
'fieldCount'
,
title
:
'别名'
,
align
:
'center'
,
dataIndex
:
'tableAlias'
,
},
key
:
'tableAlias'
,
{
align
:
'center'
,
title
:
'缺少字段'
,
},
dataIndex
:
'missingFieldCount'
,
{
key
:
'missingFieldCount'
,
title
:
'表格样式'
,
align
:
'center'
,
dataIndex
:
'tableStyle'
,
render
:
text
=>
{
key
:
'tableStyle'
,
return
(<
div
className=
{
classnames
({
align
:
'center'
,
[
styles
.
lack
]:
text
!==
'(无)'
,
},
})
}
>
{
text
}
</
div
>)
{
}
title
:
'附加字段'
,
},
dataIndex
:
'fieldCount'
,
{
key
:
'fieldCount'
,
title
:
'未附加'
,
align
:
'center'
,
dataIndex
:
'extraFieldCount'
,
},
key
:
'extraFieldCount'
,
{
align
:
'center'
,
title
:
'缺少字段'
,
},
dataIndex
:
'missingFieldCount'
,
{
key
:
'missingFieldCount'
,
title
:
'分组数量'
,
align
:
'center'
,
dataIndex
:
'groupCount'
,
render
:
text
=>
{
key
:
'groupCount'
,
return
(
align
:
'center'
,
<
div
},
className=
{
classnames
({
{
[
styles
.
lack
]:
text
!==
'(无)'
,
title
:
'操作'
,
})
}
ellipsis
:
true
,
>
key
:
'tableID'
,
{
text
}
align
:
'center'
,
</
div
>
render
:
(
text
,
record
)
=>
(
);
<
Space
>
},
<
Tooltip
title=
"修改"
>
},
<
EditOutlined
{
onClick=
{
()
=>
changeDesc
(
record
)
}
title
:
'未附加'
,
style=
{
{
fontSize
:
'20px'
,
color
:
'#1890FF'
}
}
dataIndex
:
'extraFieldCount'
,
/>
key
:
'extraFieldCount'
,
</
Tooltip
>
align
:
'center'
,
<
Tooltip
title=
"字段配置"
>
},
<
FontColorsOutlined
{
onClick=
{
e
=>
fieldsConfig
(
record
,
e
)
}
title
:
'分组数量'
,
style=
{
{
fontSize
:
'16px'
,
color
:
'#1890FF'
}
}
dataIndex
:
'groupCount'
,
/>
key
:
'groupCount'
,
</
Tooltip
>
align
:
'center'
,
<
Tooltip
title=
"附加"
>
},
<
PlusSquareOutlined
{
onClick=
{
()
=>
add
(
record
)
}
title
:
'操作'
,
style=
{
{
fontSize
:
'16px'
,
color
:
'#1890FF'
}
}
ellipsis
:
true
,
/>
key
:
'tableID'
,
</
Tooltip
>
align
:
'center'
,
<
Tooltip
title=
"分组与排序"
>
render
:
(
text
,
record
)
=>
(
<
SortDescendingOutlined
<
Space
>
onClick=
{
()
=>
sort
(
record
)
}
<
Tooltip
title=
"修改"
>
style=
{
{
fontSize
:
'16px'
,
color
:
'#1890FF'
}
}
<
EditOutlined
/>
onClick=
{
()
=>
changeDesc
(
record
)
}
</
Tooltip
>
style=
{
{
fontSize
:
'20px'
,
color
:
'#1890FF'
}
}
<
div
onClick=
{
e
=>
e
.
stopPropagation
()
}
>
/>
<
Popconfirm
</
Tooltip
>
title=
"是否删除该表?"
<
Tooltip
title=
"字段配置"
>
okText=
"确认"
<
FontColorsOutlined
cancelText=
"取消"
onClick=
{
e
=>
fieldsConfig
(
record
,
e
)
}
onConfirm=
{
()
=>
{
style=
{
{
fontSize
:
'16px'
,
color
:
'#1890FF'
}
}
deleteChart
(
record
);
/>
}
}
</
Tooltip
>
>
<
Tooltip
title=
"附加"
>
<
Tooltip
title=
"删除"
>
<
PlusSquareOutlined
<
DeleteOutlined
onClick=
{
()
=>
add
(
record
)
}
style=
{
{
fontSize
:
'16px'
,
color
:
'#e86060'
}
}
style=
{
{
fontSize
:
'16px'
,
color
:
'#1890FF'
}
}
/>
/>
</
Tooltip
>
</
Tooltip
>
</
Popconfirm
>
<
Tooltip
title=
"分组与排序"
>
</
div
>
<
SortDescendingOutlined
</
Space
>
onClick=
{
()
=>
sort
(
record
)
}
),
style=
{
{
fontSize
:
'16px'
,
color
:
'#1890FF'
}
}
},
/>
</
Tooltip
>
];
<
div
onClick=
{
e
=>
e
.
stopPropagation
()
}
>
<
Popconfirm
title=
"是否删除该表?"
okText=
"确认"
cancelText=
"取消"
onConfirm=
{
()
=>
{
deleteChart
(
record
);
}
}
>
<
Tooltip
title=
"删除"
>
<
DeleteOutlined
style=
{
{
fontSize
:
'16px'
,
color
:
'#e86060'
}
}
/>
</
Tooltip
>
</
Popconfirm
>
</
div
>
</
Space
>
),
},
];
return
<
Table
columns=
{
columns1
}
bordered
size=
"small"
onRow=
{
record
=>
{
return
(
return
{
<
Table
onDoubleClick
:
event
=>
{
columns=
{
columns1
}
event
.
stopPropagation
()
bordered
history
.
push
({
pathname
:
`/platformCenter/bsmanger/filedConfig/${record.tableName}`
,
state
:
{
template
:
record
}
})
size=
"small"
onRow=
{
record
=>
{
return
{
onDoubleClick
:
event
=>
{
event
.
stopPropagation
();
history
.
push
({
pathname
:
`/platformCenter/bsmanger/filedConfig/${
record.tableName
}`
,
state
:
{
template
:
record
,
tableScroll
:
document
.
querySelector
(
'.ant-table-body'
)
.
scrollTop
,
},
},
onClick
:
event
=>
{
});
event
.
stopPropagation
()
setSelectTableName
(
record
)
},
// 点击行
}
}
}
rowClassName=
{
setRowClassName
}
showHeader=
{
false
}
dataSource=
{
allData
[
item
.
type
]
}
pagination=
{
false
}
/>;
};
const
columns
=
[
{
title
:
'名称'
,
dataIndex
:
'type'
,
key
:
'type'
,
render
:
text
=>
{
return
(<
a
style=
{
{
fontWeight
:
'bold'
}
}
>
{
text
}
(
{
allData
&&
allData
[
text
]
?
allData
[
text
].
length
:
0
}
个)
</
a
>)
},
},
width
:
260
,
onClick
:
event
=>
{
},
event
.
stopPropagation
();
{
setSelectTableName
(
record
);
title
:
'别名'
,
},
// 点击行
dataIndex
:
'tableAlias'
,
};
key
:
'tableAlias'
,
}
}
align
:
'center'
,
rowClassName=
{
setRowClassName
}
},
showHeader=
{
false
}
{
dataSource=
{
allData
[
item
.
type
]
}
title
:
'表格样式'
,
pagination=
{
false
}
dataIndex
:
'tableStyle'
,
/>
key
:
'tableStyle'
,
);
align
:
'center'
,
};
},
{
title
:
'附加字段'
,
dataIndex
:
'fieldCount'
,
key
:
'fieldCount'
,
align
:
'center'
,
},
{
title
:
'缺少字段'
,
dataIndex
:
'missingFieldCount'
,
key
:
'missingFieldCount'
,
align
:
'center'
,
render
:
text
=>
{
return
(<
div
>
{
text
}
</
div
>)
}
},
{
title
:
'未附加'
,
dataIndex
:
'extraFieldCount'
,
key
:
'extraFieldCount'
,
align
:
'center'
,
},
{
title
:
'分组数量'
,
dataIndex
:
'groupCount'
,
key
:
'groupCount'
,
align
:
'center'
,
},
{
title
:
'操作'
,
dataIndex
:
'title'
,
key
:
'title'
,
align
:
'center'
,
},
];
const
columns
=
[
const
onUnfold
=
(
expanded
,
record
)
=>
{
{
const
data
=
[...
select
]
title
:
'名称'
,
let
index
=
data
.
indexOf
(
record
)
dataIndex
:
'type'
,
if
(
expanded
)
{
key
:
'type'
,
data
.
push
(
record
)
render
:
text
=>
{
}
else
{
return
(
data
.
splice
(
index
,
1
)
<
a
style=
{
{
fontWeight
:
'bold'
}
}
>
}
{
text
}
(
{
allData
&&
allData
[
text
]
?
allData
[
text
].
length
:
0
}
个)
setSelect
(
data
)
</
a
>
);
},
width
:
260
,
},
{
title
:
'别名'
,
dataIndex
:
'tableAlias'
,
key
:
'tableAlias'
,
align
:
'center'
,
},
{
title
:
'表格样式'
,
dataIndex
:
'tableStyle'
,
key
:
'tableStyle'
,
align
:
'center'
,
},
{
title
:
'附加字段'
,
dataIndex
:
'fieldCount'
,
key
:
'fieldCount'
,
align
:
'center'
,
},
{
title
:
'缺少字段'
,
dataIndex
:
'missingFieldCount'
,
key
:
'missingFieldCount'
,
align
:
'center'
,
render
:
text
=>
{
return
<
div
>
{
text
}
</
div
>;
},
},
{
title
:
'未附加'
,
dataIndex
:
'extraFieldCount'
,
key
:
'extraFieldCount'
,
align
:
'center'
,
},
{
title
:
'分组数量'
,
dataIndex
:
'groupCount'
,
key
:
'groupCount'
,
align
:
'center'
,
},
{
title
:
'操作'
,
dataIndex
:
'title'
,
key
:
'title'
,
align
:
'center'
,
},
];
const
onUnfold
=
(
expanded
,
record
)
=>
{
const
data
=
[...
select
];
let
index
=
data
.
indexOf
(
record
);
if
(
expanded
)
{
data
.
push
(
record
);
}
else
{
data
.
splice
(
index
,
1
);
}
}
return
(
setSelect
(
data
);
<
Spin
tip=
"loading..."
spinning=
{
treeLoading
}
>
};
<
PageContainer
>
return
(
<
div
className=
{
styles
.
tablemanager_container
}
>
<
Spin
tip=
"loading..."
spinning=
{
treeLoading
}
>
<
div
className=
{
styles
.
operate_bar
}
>
<
PageContainer
>
<
div
className=
{
styles
.
fast_search
}
>
<
div
className=
{
styles
.
tablemanager_container
}
>
<
div
className=
{
styles
.
title
}
>
快速检索
</
div
>
<
div
className=
{
styles
.
operate_bar
}
>
<
Search
<
div
className=
{
styles
.
fast_search
}
>
allowClear
<
div
className=
{
styles
.
title
}
>
快速检索
</
div
>
placeholder=
{
placeholder
}
<
Search
onSearch=
{
handleSearch
}
allowClear
onChange=
{
handleChange
}
placeholder=
{
placeholder
}
value=
{
searchValue
}
onSearch=
{
handleSearch
}
enterButton
onChange=
{
handleChange
}
style=
{
{
width
:
"300px"
}
}
value=
{
searchValue
}
/>
enterButton
</
div
>
style=
{
{
width
:
'300px'
}
}
/>
<
Button
type=
"primary"
style=
{
{
marginLeft
:
"10px"
}
}
icon=
{
<
BorderInnerOutlined
/>
}
onClick=
{
AddTable
}
>
建表
</
Button
>
</
div
>
<
Button
type=
"primary"
style=
{
{
marginLeft
:
"10px"
}
}
icon=
{
<
PlusOutlined
/>
}
onClick=
{
AffiliateAddTable
}
>
附加表
</
Button
>
</
div
>
<
Button
<
div
style=
{
{
width
:
'100vm'
,
height
:
'calc(100vh - 150px) '
,
background
:
'#ffffff'
}
}
>
type=
"primary"
{
/* <Table
style=
{
{
marginLeft
:
'10px'
}
}
icon=
{
<
BorderInnerOutlined
/>
}
onClick=
{
AddTable
}
>
建表
</
Button
>
<
Button
type=
"primary"
style=
{
{
marginLeft
:
'10px'
}
}
icon=
{
<
PlusOutlined
/>
}
onClick=
{
AffiliateAddTable
}
>
附加表
</
Button
>
</
div
>
<
div
style=
{
{
width
:
'100vm'
,
height
:
'calc(100vh - 150px) '
,
background
:
'#ffffff'
,
}
}
>
{
/* <Table
columns={columns}
columns={columns}
dataSource={tableData}
dataSource={tableData}
//pagination={{ pageSize: 10 }}
//pagination={{ pageSize: 10 }}
...
@@ -420,61 +507,61 @@ const TableManager = (props) => {
...
@@ -420,61 +507,61 @@ const TableManager = (props) => {
showSizeChanger: true,
showSizeChanger: true,
}}
}}
/> */
}
/> */
}
<
Table
<
Table
className=
"components-table-demo-nested"
className=
"components-table-demo-nested"
columns=
{
columns
}
columns=
{
columns
}
expandable=
{
{
expandedRowRender
}
}
expandable=
{
{
expandedRowRender
}
}
expandedRowKeys=
{
select
.
map
(
item
=>
item
.
key
)
}
//展开的行
expandedRowKeys=
{
select
.
map
(
item
=>
item
.
key
)
}
// 展开的行
expandRowByClick=
{
true
}
expandRowByClick=
{
true
}
defaultExpandAllRows=
{
true
}
defaultExpandAllRows=
{
true
}
dataSource=
{
groupArr
}
dataSource=
{
groupArr
}
scroll=
{
{
y
:
'calc(100vh - 190px)'
}
}
scroll=
{
{
y
:
'calc(100vh - 190px)'
}
}
size=
"small"
size=
"small"
pagination=
{
false
}
pagination=
{
false
}
onExpand=
{
onUnfold
}
onExpand=
{
onUnfold
}
style=
{
{
height
:
'8rem'
}
}
style=
{
{
height
:
'8rem'
}
}
/>
/>
</
div
>
</
div
>
</
div
>
</
div
>
{
visible
&&
type
==
'edit'
&&
(
<
Editor
visible=
{
visible
}
onCancel=
{
()
=>
setVisible
(
false
)
}
callBackSubmit=
{
onSubmit
}
type=
{
type
}
formObj=
{
formObj
}
/>
)
}
{
visible
&&
type
===
'add'
&&
(
<
AddTablelList
type=
{
type
}
onCancel=
{
()
=>
setVisible
(
false
)
}
callBackSubmit=
{
onSubmit
}
/>
)
}
{
visible
&&
type
===
'affiliateAdd'
&&
(
<
AffiliateAdd
visible=
{
visible
}
tableList=
{
tableList
}
type=
{
type
}
onCancel=
{
()
=>
setVisible
(
false
)
}
callBackSubmit=
{
onSubmit
}
formObj=
{
formObj
}
/>
)
}
{
visible
&&
type
===
'sort'
&&
(
{
visible
&&
type
==
'edit'
&&
(
<
LoadGroup
<
Editor
visible=
{
visible
}
visible=
{
visible
}
type=
{
type
}
onCancel=
{
()
=>
setVisible
(
false
)
}
formObj=
{
formObj
}
callBackSubmit=
{
onSubmit
}
onCancel=
{
()
=>
setVisible
(
false
)
}
type=
{
type
}
callBackSubmit=
{
onSubmit
}
formObj=
{
formObj
}
/>
/>
)
}
)
}
</
PageContainer
>
{
visible
&&
type
===
'add'
&&
(
</
Spin
>
<
AddTablelList
)
type=
{
type
}
onCancel=
{
()
=>
setVisible
(
false
)
}
callBackSubmit=
{
onSubmit
}
/>
)
}
{
visible
&&
type
===
'affiliateAdd'
&&
(
<
AffiliateAdd
visible=
{
visible
}
tableList=
{
tableList
}
type=
{
type
}
onCancel=
{
()
=>
setVisible
(
false
)
}
callBackSubmit=
{
onSubmit
}
formObj=
{
formObj
}
/>
)
}
}
{
visible
&&
type
===
'sort'
&&
(
export
default
TableManager
;
<
LoadGroup
\ No newline at end of file
visible=
{
visible
}
type=
{
type
}
formObj=
{
formObj
}
onCancel=
{
()
=>
setVisible
(
false
)
}
callBackSubmit=
{
onSubmit
}
/>
)
}
</
PageContainer
>
</
Spin
>
);
};
export
default
TableManager
;
src/pages/platformCenter/bsmanager/workFlow/flowNode/flowNode.jsx
View file @
0e9bfe4b
...
@@ -85,7 +85,7 @@ const FlowNode = () => {
...
@@ -85,7 +85,7 @@ const FlowNode = () => {
// 控制表格的展开跟收起
// 控制表格的展开跟收起
const
onUnfold
=
(
expanded
,
record
)
=>
{
const
onUnfold
=
(
expanded
,
record
)
=>
{
const
data
=
[...
expandedRowKeys
];
const
data
=
[...
expandedRowKeys
];
let
index
=
data
.
indexOf
(
record
);
let
index
=
data
.
indexOf
(
record
.
GroupName
);
if
(
expanded
)
{
if
(
expanded
)
{
data
.
push
(
record
.
GroupName
);
data
.
push
(
record
.
GroupName
);
}
else
{
}
else
{
...
...
src/pages/platformCenter/bsmanager/workFlow/flowNode/flowNode.less
View file @
0e9bfe4b
...
@@ -113,7 +113,16 @@
...
@@ -113,7 +113,16 @@
margin-bottom: 10px;
margin-bottom: 10px;
font-weight: 700;
font-weight: 700;
color: #15428b;
color: #15428b;
line-height: 100%;
border-top-color: #99bbe8;
border-top-color: #99bbe8;
.groupName {
display: inline-block;
margin-right: 10px;
max-width: 200px;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
}
}
}
}
...
...
src/pages/platformCenter/bsmanager/workFlow/flowNode/flowNodeComponents/NodeEdit.jsx
View file @
0e9bfe4b
...
@@ -100,19 +100,36 @@ const NodeEdit = props => {
...
@@ -100,19 +100,36 @@ 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
allFields
=
[];
// 所有得字段用来判断是否为外部字段
// 处理树形结构
// 处理树形结构
let
checkList
=
res
.
data
.
map
(
item
=>
{
let
checkList
=
res
.
data
.
map
(
item
=>
{
let
plainOptions
=
[];
let
plainOptions
=
[];
// 存入没个组得字段
item
.
root
.
forEach
(
ele
=>
{
item
.
root
.
forEach
(
ele
=>
{
plainOptions
=
[...
plainOptions
,
ele
.
fieldName
];
plainOptions
=
[...
plainOptions
,
ele
.
fieldName
];
});
});
// 存所有得字段
allFields
=
[...
allFields
,
...
plainOptions
];
return
{
return
{
groupName
:
item
.
groupName
,
groupName
:
item
.
groupName
,
plainOptions
,
plainOptions
,
defaultCheckedList
:
[],
defaultCheckedList
:
[],
};
};
});
});
let
externalFields
=
{
groupName
:
'外部字段'
,
indeterminate
:
false
,
checkAll
:
true
,
plainOptions
:
[],
defaultCheckedList
:
[],
};
// 外部字段
defaultCheckedList
.
forEach
(
item
=>
{
defaultCheckedList
.
forEach
(
item
=>
{
// 添加外部字段
let
isExternal
=
allFields
.
some
(
checkName
=>
checkName
===
item
);
if
(
!
isExternal
)
{
externalFields
.
plainOptions
.
push
(
item
);
externalFields
.
defaultCheckedList
.
push
(
item
);
}
checkList
.
forEach
(
element
=>
{
checkList
.
forEach
(
element
=>
{
// 当前得模块是否有当前字段
// 当前得模块是否有当前字段
let
indeterminate
=
element
.
plainOptions
.
some
(
let
indeterminate
=
element
.
plainOptions
.
some
(
...
@@ -140,7 +157,10 @@ const NodeEdit = props => {
...
@@ -140,7 +157,10 @@ const NodeEdit = props => {
}
}
});
});
});
});
console
.
log
(
checkList
,
'checkList'
);
// 添加外部字段
if
(
externalFields
.
plainOptions
.
length
>
0
)
{
checkList
.
push
(
externalFields
);
}
setFieldList
(
checkList
);
setFieldList
(
checkList
);
setTimeout
(()
=>
{
setTimeout
(()
=>
{
setShowField
(
true
);
setShowField
(
true
);
...
...
src/pages/platformCenter/bsmanager/workFlow/flowNode/flowNodeComponents/nodeEditComponents/Fieldselection.jsx
View file @
0e9bfe4b
...
@@ -98,9 +98,7 @@ const Fieldselection = props => {
...
@@ -98,9 +98,7 @@ 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'
}
}
>
<
span
className=
{
styles
.
groupName
}
>
{
item
.
groupName
}
</
span
>
{
item
.
groupName
}
</
span
>
<
Checkbox
<
Checkbox
indeterminate=
{
item
.
indeterminate
}
indeterminate=
{
item
.
indeterminate
}
onChange=
{
e
=>
onCheckAllChange
(
e
,
index
)
}
onChange=
{
e
=>
onCheckAllChange
(
e
,
index
)
}
...
...
src/pages/platformCenter/filedConfig/filedConfig.jsx
View file @
0e9bfe4b
...
@@ -358,11 +358,13 @@ const AddModal = props => {
...
@@ -358,11 +358,13 @@ const AddModal = props => {
};
};
// 返回上一级
// 返回上一级
const
back
=
()
=>
{
const
back
=
()
=>
{
console
.
log
(
props
)
let
{
template
,
tableScroll
}
=
props
.
location
.
state
;
let
template
=
props
.
location
.
state
.
template
;
history
.
push
({
history
.
push
({
pathname
:
'/platformCenter/bsmanger/tablemanger'
,
pathname
:
'/platformCenter/bsmanger/tablemanger'
,
state
:
{
template
},
query
:
{
template
,
tableScroll
,
},
});
});
};
};
const
onUnfold
=
(
expanded
,
record
)
=>
{
const
onUnfold
=
(
expanded
,
record
)
=>
{
...
...
src/pages/platformCenter/standingBook/editorModal.jsx
View file @
0e9bfe4b
/* eslint-disable guard-for-in */
/* eslint-disable no-restricted-syntax */
import
React
,
{
useState
,
useEffect
}
from
'react'
;
import
React
,
{
useState
,
useEffect
}
from
'react'
;
import
{
import
{
Form
,
Form
,
...
@@ -64,6 +66,7 @@ const AddModal = props => {
...
@@ -64,6 +66,7 @@ const AddModal = props => {
const
[
Type
,
setType
]
=
useState
(
''
);
const
[
Type
,
setType
]
=
useState
(
''
);
const
[
characterValue
,
setCharacterValue
]
=
useState
(
''
);
const
[
characterValue
,
setCharacterValue
]
=
useState
(
''
);
const
[
standingType
,
setStandingType
]
=
useState
([
'台账'
,
'反馈'
,
'设备'
]);
const
[
standingType
,
setStandingType
]
=
useState
([
'台账'
,
'反馈'
,
'设备'
]);
const
[
allFileds
,
setAllFileds
]
=
useState
([]);
// 当前表所有的字段
const
[
form
]
=
Form
.
useForm
();
const
[
form
]
=
Form
.
useForm
();
const
{
Item
}
=
Form
;
const
{
Item
}
=
Form
;
// 提交
// 提交
...
@@ -166,14 +169,18 @@ const AddModal = props => {
...
@@ -166,14 +169,18 @@ const AddModal = props => {
if
(
!
name
)
{
if
(
!
name
)
{
return
'请传入对象属性'
;
return
'请传入对象属性'
;
}
}
//先获取一下这个数组中有多少个"name"
//
先获取一下这个数组中有多少个"name"
let
nameArr
=
[];
let
nameArr
=
[];
let
allFile
=
[];
for
(
let
i
in
initialArr
)
{
for
(
let
i
in
initialArr
)
{
allFile
.
push
(
initialArr
[
i
].
fieldName
);
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的结果对象
// 保存所有的字段用来比较是否有外部字段
setAllFileds
(
allFile
);
// 新建一个包含多个list的结果对象
let
tempObj
=
{};
let
tempObj
=
{};
// 根据不同的"name"生成多个数组
// 根据不同的"name"生成多个数组
console
.
log
(
initialArr
);
console
.
log
(
initialArr
);
...
@@ -204,9 +211,26 @@ const AddModal = props => {
...
@@ -204,9 +211,26 @@ const AddModal = props => {
setInputVaule
(
inputText
);
setInputVaule
(
inputText
);
};
};
const
pickFiled
=
fileds
=>
{
const
pickFiled
=
fileds
=>
{
// 添加外部字段
let
fil
=
{
...
filed
};
fil
[
'外部字段'
]
=
[];
let
isExternal
;
inputValue
[
fileds
].
split
(
','
).
forEach
(
item
=>
{
isExternal
=
allFileds
.
some
(
val
=>
val
===
item
);
if
(
!
isExternal
&&
item
!==
''
)
{
fil
[
'外部字段'
].
push
(
item
);
}
});
if
(
fil
[
'外部字段'
].
length
===
0
)
{
delete
fil
[
'外部字段'
];
}
setFiled
(
fil
);
setTypes
(
'add'
);
setTypes
(
'add'
);
setCharacterValue
(
inputValue
[
fileds
]);
setCharacterValue
(
inputValue
[
fileds
]);
setCheckedList
(
inputValue
[
fileds
].
split
(
','
));
setCheckedList
(
inputValue
[
fileds
].
split
(
','
));
setPickItem
(
fileds
);
setPickItem
(
fileds
);
setIsVisible
(
true
);
setIsVisible
(
true
);
};
};
...
...
src/pages/webConfig/utils.js
View file @
0e9bfe4b
...
@@ -69,6 +69,7 @@ export const defaultWebConfigObj = {
...
@@ -69,6 +69,7 @@ export const defaultWebConfigObj = {
mapPlan
:
''
,
mapPlan
:
''
,
qrcode
:
''
,
qrcode
:
''
,
loginTemplate
:
'Default.html'
,
loginTemplate
:
'Default.html'
,
alarmWays
:
notificationTypes
.
MQTT
,
};
};
export
const
getDefaultGetWebconfig
=
({
export
const
getDefaultGetWebconfig
=
({
...
...
src/services/platform/bs.jsx
View file @
0e9bfe4b
...
@@ -25,11 +25,11 @@ export const loadUnattachedTables = () =>
...
@@ -25,11 +25,11 @@ export const loadUnattachedTables = () =>
//7.附加表
//7.附加表
export
const
addTables
=
(
param
)
=>
export
const
addTables
=
(
param
)
=>
ge
t
(
`
${
PUBLISH_SERVICE
}
/CaseManage/AddTables`
,
param
);
pos
t
(
`
${
PUBLISH_SERVICE
}
/CaseManage/AddTables`
,
param
);
//8.添加表字段
//8.添加表字段
export
const
addFields
=
(
param
)
=>
export
const
addFields
=
(
param
)
=>
ge
t
(
`
${
PUBLISH_SERVICE
}
/CaseManage/AddFields`
,
param
);
pos
t
(
`
${
PUBLISH_SERVICE
}
/CaseManage/AddFields`
,
param
);
//9.获取表信息
//9.获取表信息
...
...
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