Commit 79311bc5 authored by 邓超's avatar 邓超

fix: 对运维平台进行优化,修改测试到的问题

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