Commit 0e9bfe4b authored by 邓超's avatar 邓超

fix: 添加外部字段模块,修改表返回位置问题

parent 5946c5ef
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;
...@@ -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 {
......
...@@ -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;
}
} }
} }
......
...@@ -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);
......
...@@ -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)}
......
...@@ -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) => {
......
/* 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);
}; };
......
...@@ -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 = ({
......
...@@ -25,11 +25,11 @@ export const loadUnattachedTables = () => ...@@ -25,11 +25,11 @@ export const loadUnattachedTables = () =>
//7.附加表 //7.附加表
export const addTables = (param) => export const addTables = (param) =>
get(`${PUBLISH_SERVICE}/CaseManage/AddTables`, param); post(`${PUBLISH_SERVICE}/CaseManage/AddTables`, param);
//8.添加表字段 //8.添加表字段
export const addFields = (param) => export const addFields = (param) =>
get(`${PUBLISH_SERVICE}/CaseManage/AddFields`, param); post(`${PUBLISH_SERVICE}/CaseManage/AddFields`, param);
//9.获取表信息 //9.获取表信息
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment