peng.peng
2 years ago
22 changed files with 887 additions and 25 deletions
After Width: | Height: | Size: 1.9 MiB |
After Width: | Height: | Size: 88 KiB |
After Width: | Height: | Size: 88 KiB |
@ -0,0 +1,78 @@ |
|||
'use strict'; |
|||
|
|||
import { basicAction } from '@peace/utils' |
|||
import { ApiTable } from '$utils' |
|||
|
|||
export function getStandardDocFolders (query = {}) { |
|||
return dispatch => basicAction({ |
|||
type: 'get', |
|||
query, |
|||
dispatch: dispatch, |
|||
actionType: 'GET_STANDARD_DOC_FOLDERS', |
|||
url: `${ApiTable.standardDocFolders}`, |
|||
msg: { error: '获取标准文档目录列表失败' }, |
|||
reducer: { name: '' } |
|||
}); |
|||
} |
|||
|
|||
|
|||
export function postStandardDocFolders (data = {}) { |
|||
return dispatch => basicAction({ |
|||
type: 'post', |
|||
data, |
|||
dispatch: dispatch, |
|||
actionType: 'POST_STANDARD_DOC_FOLDERS', |
|||
url: `${ApiTable.standardDocFolders}`, |
|||
msg: { option: '标准文档目录新增' }, |
|||
reducer: { name: '' } |
|||
}); |
|||
} |
|||
|
|||
export function postStandardDocs (data = {}) { |
|||
return dispatch => basicAction({ |
|||
type: 'post', |
|||
data, |
|||
dispatch: dispatch, |
|||
actionType: 'POST_STANDARD_DOCS', |
|||
url: `${ApiTable.standardDocs}`, |
|||
msg: { option: '新增标准文档' }, |
|||
reducer: { name: '' } |
|||
}); |
|||
} |
|||
|
|||
export function getStandardDocs (query = {}) { |
|||
return dispatch => basicAction({ |
|||
type: 'get', |
|||
query, |
|||
dispatch: dispatch, |
|||
actionType: 'GET_STANDARD_DOCS', |
|||
url: `${ApiTable.standardDocs}`, |
|||
msg: { error: '获取标准文档列表失败' }, |
|||
reducer: { name: '' } |
|||
}); |
|||
} |
|||
|
|||
export function postFolderFile (data) { |
|||
return dispatch => basicAction({ |
|||
type: 'post', |
|||
data, |
|||
dispatch: dispatch, |
|||
actionType: 'POST_FOLDER_FILE', |
|||
url: ApiTable.postFolderFile, |
|||
msg: { option: '删除文件夹或文件' }, |
|||
reducer: { name: '' } |
|||
}); |
|||
} |
|||
|
|||
export function fetchFiles (data = {}) { |
|||
return dispatch => basicAction({ |
|||
type: 'post', |
|||
data, |
|||
dispatch: dispatch, |
|||
actionType: 'POST_FETCH_FILES', |
|||
url: `${ApiTable.fetchFiles}`, |
|||
msg: { error: '获取文件夹下文件失败' }, |
|||
reducer: { name: '' } |
|||
}); |
|||
} |
|||
|
@ -0,0 +1,15 @@ |
|||
'use strict'; |
|||
|
|||
import { basicAction } from '@peace/utils' |
|||
import { ApiTable } from '$utils' |
|||
|
|||
// export function getMembers(orgId) {
|
|||
// return dispatch => basicAction({
|
|||
// type: 'get',
|
|||
// dispatch: dispatch,
|
|||
// actionType: 'GET_MEMBERS',
|
|||
// url: `${ApiTable.getEnterprisesMembers.replace('{enterpriseId}', orgId)}`,
|
|||
// msg: { error: '获取用户列表失败' },
|
|||
// reducer: { name: 'members' }
|
|||
// });
|
|||
// }
|
@ -0,0 +1,11 @@ |
|||
'use strict'; |
|||
|
|||
import * as example from './example' |
|||
import * as documentLibrary from './documentLibrary' |
|||
import * as ruleLibrary from './ruleLibrary' |
|||
|
|||
export default { |
|||
...example, |
|||
...documentLibrary, |
|||
...ruleLibrary, |
|||
} |
@ -0,0 +1,52 @@ |
|||
'use strict'; |
|||
|
|||
import { basicAction } from '@peace/utils' |
|||
import { ApiTable } from '$utils' |
|||
|
|||
export function postBusinessRules (data = {}) { |
|||
let reminder = data?.id ? '修改业务规则' : '新增业务规则' |
|||
return dispatch => basicAction({ |
|||
type: 'post', |
|||
data, |
|||
dispatch: dispatch, |
|||
actionType: 'POST_BUSINESS_RULES', |
|||
url: `${ApiTable.businessRules}`, |
|||
msg: { option: reminder }, |
|||
reducer: { name: '' } |
|||
}); |
|||
} |
|||
|
|||
export function getBusinessRules (query = {}) { |
|||
return dispatch => basicAction({ |
|||
type: 'get', |
|||
query, |
|||
dispatch: dispatch, |
|||
actionType: 'GET_BUSINESS_RULES', |
|||
url: `${ApiTable.businessRules}`, |
|||
msg: { error: '查询业务规则列表失败' }, |
|||
reducer: { name: '' } |
|||
}); |
|||
} |
|||
|
|||
export function delBusinessRules (id) { |
|||
return dispatch => basicAction({ |
|||
type: 'del', |
|||
dispatch: dispatch, |
|||
actionType: 'del_BUSINESS_RULES', |
|||
url: `${ApiTable.delBusinessRules.replace('{id}', id)}`, |
|||
msg: { option: '删除业务规则' }, |
|||
reducer: { name: '' } |
|||
}); |
|||
} |
|||
|
|||
export function getRegularBasis (query = {}) { |
|||
return dispatch => basicAction({ |
|||
type: 'get', |
|||
query, |
|||
dispatch: dispatch, |
|||
actionType: 'GET_REGULAR_BASIS', |
|||
url: `${ApiTable.regularBasis}`, |
|||
msg: { error: '查询规则依据列表失败' }, |
|||
reducer: { name: '' } |
|||
}); |
|||
} |
@ -0,0 +1,118 @@ |
|||
import React, { useEffect, useState } from 'react' |
|||
import { connect } from 'react-redux'; |
|||
import moment from 'moment'; |
|||
import { UploadLocal } from '$components'; |
|||
|
|||
|
|||
import { Tabs, Form, Input, DatePicker, Button, Modal, Select, Tag } from 'antd'; |
|||
|
|||
|
|||
function FileModal ({ loading, parent, user, actions, editData = {}, dispatch, close, success,remove }) { |
|||
|
|||
const { dataQuality } = actions |
|||
const [tabsKey, setTabsKey] = useState("stay") |
|||
const [query, setQuery] = useState({ page: 0, limit: 10 }); |
|||
const [proTableList, setProTableList] = useState({ rows: [], count: 0 }); |
|||
const [approve, setApprove] = useState() |
|||
|
|||
const [form] = Form.useForm(); |
|||
const [editUrl, setEditUrl] = useState([]); |
|||
useEffect(() => { |
|||
|
|||
}, []) |
|||
|
|||
|
|||
|
|||
const vsjunct = (params) => { |
|||
if (params.length) { |
|||
let appendix = [] |
|||
for (let p of params) { |
|||
appendix.push({ |
|||
fName: p.name, |
|||
size: p.size, |
|||
fileSize: p.size, |
|||
storageUrl: p.storageUrl,//必须有storageUrl
|
|||
}) |
|||
} |
|||
setEditUrl(appendix) |
|||
} else { |
|||
setEditUrl([]) |
|||
} |
|||
} |
|||
|
|||
return <> |
|||
<Modal title="标准文档上传" open={true} width={600} |
|||
onOk={e => { |
|||
form.validateFields().then(v => { |
|||
dispatch(dataQuality.postStandardDocs({ |
|||
...v, |
|||
path: v?.files[0]?.url, docName: v?.files[0]?.name, |
|||
folder: parent || null, |
|||
})).then(res => { |
|||
if (res.success) { |
|||
close() |
|||
success() |
|||
} |
|||
}) |
|||
}) |
|||
}} |
|||
onCancel={() => { |
|||
if (form.getFieldValue('files') && form.getFieldValue('files').length) { |
|||
remove(form.getFieldValue('files')[0]?.url) |
|||
} |
|||
close() |
|||
}} |
|||
> |
|||
<Form |
|||
style={{ marginLeft: 20 }} |
|||
form={form} |
|||
onValuesChange={v => { |
|||
|
|||
}} |
|||
autoComplete="off" |
|||
labelCol={{ span: 4 }} wrapperCol={{ span: 20 }} |
|||
> |
|||
<Form.Item label="标准类型" name="standardType" rules={[{ required: true, message: '请选择标准类型' }]}> |
|||
<Select style={{ width: 200, }} allowClear |
|||
options={[{ value: '国家标准', label: '国家标准', }, { value: '行业标准', label: '行业标准', }, { value: '地方标准', label: '地方标准', },]} |
|||
/> |
|||
</Form.Item> |
|||
<Form.Item label="标签" name="tags" > |
|||
<Input allowClear placeholder='请输入标签' maxLength={50} style={{ width: 300, marginRight: 16 }} /> |
|||
</Form.Item> |
|||
<Form.Item |
|||
label='文件' |
|||
name='files' |
|||
key='files' |
|||
rules={[{ required: true, message: '文件不可为空' }]}> |
|||
<UploadLocal |
|||
// addNew={editData.add || !editData.record.files.length}
|
|||
isLocal={true} |
|||
maxFilesNum={1} |
|||
maxFileSize={40} |
|||
onChange={vsjunct} |
|||
fileTypes={["jpg", "png", "gif", "txt", "doc", "docx", "pdf", "xls", "xlsx", "zip", "rar"]} |
|||
value={editUrl} |
|||
// fileList={editData.record.files || []}
|
|||
/> |
|||
</Form.Item> |
|||
<Form.Item style={{ marginLeft: 42 }} key='tip'> |
|||
<Tag color="orange">文件大小不超过40MB,开放资源包含多个文件,建议将文件进行压缩,形成压缩包再上传</Tag> |
|||
<Tag color="orange">支持的文件格式:jpg,png,gif,txt,doc,docx,pdf,xsl,xlsx,zip,rar</Tag> |
|||
</Form.Item> |
|||
</Form> |
|||
</Modal > |
|||
|
|||
</> |
|||
} |
|||
function mapStateToProps (state) { |
|||
const { global, auth, resourceCatalog } = state; |
|||
return { |
|||
user: auth.user, |
|||
actions: global.actions, |
|||
clientHeight: global.clientHeight, |
|||
// resourceCatalog: resourceCatalog?.data || [],
|
|||
// isRequesting: resourceCatalog.isRequesting
|
|||
}; |
|||
} |
|||
export default connect(mapStateToProps)(FileModal) |
@ -0,0 +1,66 @@ |
|||
import React, { useEffect, useState } from 'react' |
|||
import { connect } from 'react-redux'; |
|||
import moment from 'moment'; |
|||
import { v4 as uuidv4 } from 'uuid' |
|||
|
|||
import { Tabs, Form, Input, DatePicker, Button, Modal, Radio } from 'antd'; |
|||
|
|||
|
|||
function GroupModal ({ loading, parent, user, actions, dispatch, close, success, }) { |
|||
|
|||
const { dataQuality } = actions |
|||
|
|||
const [form] = Form.useForm(); |
|||
useEffect(() => { |
|||
|
|||
}, []) |
|||
|
|||
|
|||
|
|||
|
|||
return <> |
|||
<Modal title="新建分组" open={true} |
|||
onOk={e => { |
|||
form.validateFields().then(v => { |
|||
dispatch(dataQuality.postStandardDocFolders({ |
|||
...v, |
|||
parent: parent || null, |
|||
})).then(res => { |
|||
if (res.success) { |
|||
close() |
|||
success() |
|||
} |
|||
}) |
|||
}) |
|||
}} |
|||
onCancel={() => { |
|||
close() |
|||
}} |
|||
> |
|||
<Form |
|||
style={{ marginLeft: 20 }} |
|||
form={form} |
|||
onValuesChange={v => { |
|||
|
|||
}} |
|||
autoComplete="off" |
|||
> |
|||
<Form.Item label="名称" name="name" rules={[{ required: true, message: '请输入分组名称,最多50字', max: 50 },]}> |
|||
<Input allowClear placeholder='请输入分组名称' style={{ width: 300, }} /> |
|||
</Form.Item> |
|||
</Form> |
|||
</Modal > |
|||
|
|||
</> |
|||
} |
|||
function mapStateToProps (state) { |
|||
const { global, auth, resourceCatalog } = state; |
|||
return { |
|||
user: auth.user, |
|||
actions: global.actions, |
|||
clientHeight: global.clientHeight, |
|||
// resourceCatalog: resourceCatalog?.data || [],
|
|||
// isRequesting: resourceCatalog.isRequesting
|
|||
}; |
|||
} |
|||
export default connect(mapStateToProps)(GroupModal) |
@ -0,0 +1,104 @@ |
|||
import React, { useEffect, useState } from 'react' |
|||
import { connect } from 'react-redux'; |
|||
import moment from 'moment'; |
|||
import { v4 as uuidv4 } from 'uuid' |
|||
|
|||
import { Tabs, Form, Input, DatePicker, Button, Modal, Radio, Select, TreeSelect } from 'antd'; |
|||
const { TextArea } = Input; |
|||
const { Option, OptGroup } = Select; |
|||
function RuleModal ({ loading, parent, user, actions, dispatch, close, success, treeList, editData }) { |
|||
|
|||
const { dataQuality } = actions |
|||
const [tabsKey, setTabsKey] = useState("stay") |
|||
const [query, setQuery] = useState({ page: 0, limit: 10 }); |
|||
const [proTableList, setProTableList] = useState({ rows: [], count: 0 }); |
|||
const [approve, setApprove] = useState() |
|||
|
|||
const [form] = Form.useForm(); |
|||
useEffect(() => { |
|||
|
|||
}, []) |
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
return <> |
|||
<Modal title={editData?.id ? '编辑业务规则' : "新建业务规则"} open={true} |
|||
onOk={e => { |
|||
form.validateFields().then(v => { |
|||
// console.log(v);
|
|||
dispatch(dataQuality.postBusinessRules({ |
|||
...v, id: editData?.id |
|||
})).then(res => { |
|||
if (res.success) { |
|||
close() |
|||
success() |
|||
} |
|||
}) |
|||
}) |
|||
}} |
|||
onCancel={() => { |
|||
close() |
|||
}} |
|||
> |
|||
<Form |
|||
style={{ marginLeft: 20 }} |
|||
form={form} |
|||
onValuesChange={v => { |
|||
|
|||
}} |
|||
autoComplete="off" |
|||
labelCol={{ span: 4 }} wrapperCol={{ span: 20 }} |
|||
> |
|||
<Form.Item label="名称" name="name" initialValue={editData?.name} rules={[{ required: true, message: '请输入分组名称,最多50字', max: 50}]}> |
|||
<Input allowClear placeholder='请输入分组名称' style={{ width: 300 }} /> |
|||
</Form.Item> |
|||
<Form.Item label="描述" name="description" initialValue={editData?.description} rules={[{ required: true, message: '请输入分组名称' }]}> |
|||
<TextArea allowClear autoSize={{ minRows: 2 }} placeholder='描述' style={{ width: 300, }} /> |
|||
</Form.Item> |
|||
<Form.Item label="问题类型" name="problemType" initialValue={editData?.problemType} rules={[{ required: true, message: '请输入分组名称' }]}> |
|||
<Select style={{ width: 300, }} placeholder='问题类型' |
|||
options={[{ value: '一致性', label: '一致性', }, { value: '准确性', label: '准确性', }, { value: '完整性', label: '完整性', }, { value: '有效性', label: '有效性', }, { value: '及时性', label: '及时性', }, { value: '规范性', label: '规范性', },]} |
|||
/> |
|||
</Form.Item> |
|||
<Form.Item label="问题级别" name="problemLevel" initialValue={editData?.problemLevel} rules={[{ required: true, message: '请输入分组名称' }]}> |
|||
<Select style={{ width: 300, }} placeholder='问题级别' |
|||
options={[{ value: '一般', label: '一般', }, { value: '重要', label: '重要', }, { value: '严重', label: '严重', },]} |
|||
/> |
|||
</Form.Item> |
|||
<Form.Item label="制定依据" name="ruleBasis" initialValue={editData?.ruleBasis} rules={[{ required: true, message: '请输入分组名称' }]}> |
|||
<TreeSelect |
|||
showSearch |
|||
style={{ |
|||
width: 300, |
|||
}} |
|||
// value={}
|
|||
dropdownStyle={{ |
|||
maxHeight: 300, |
|||
overflow: 'auto', |
|||
}} |
|||
placeholder="" |
|||
allowClear |
|||
treeDefaultExpandAll |
|||
// onChange={onChange}
|
|||
treeData={treeList || []} |
|||
/> |
|||
</Form.Item> |
|||
</Form> |
|||
</Modal > |
|||
|
|||
</> |
|||
} |
|||
function mapStateToProps (state) { |
|||
const { global, auth, resourceCatalog } = state; |
|||
return { |
|||
user: auth.user, |
|||
actions: global.actions, |
|||
clientHeight: global.clientHeight, |
|||
// resourceCatalog: resourceCatalog?.data || [],
|
|||
// isRequesting: resourceCatalog.isRequesting
|
|||
}; |
|||
} |
|||
export default connect(mapStateToProps)(RuleModal) |
@ -0,0 +1,6 @@ |
|||
'use strict'; |
|||
|
|||
import ServiceView from './serviceView'; |
|||
import ServiceManagement from './serviceManagement'; |
|||
|
|||
export {ServiceManagement,ServiceView}; |
@ -0,0 +1,160 @@ |
|||
import React, { useEffect, useState } from 'react' |
|||
import { connect } from 'react-redux'; |
|||
import moment from 'moment'; |
|||
import { RouteRequest } from '@peace/utils'; |
|||
import { RouteTable } from '$utils' |
|||
|
|||
import { Tabs, Form, Input, Space, Button, Table, Popconfirm } from 'antd'; |
|||
const { Search } = Input; |
|||
import { CreditCardFilled, FilePdfOutlined } from '@ant-design/icons'; |
|||
import { agent } from 'superagent'; |
|||
|
|||
import RuleModal from '../components/ruleModal'; |
|||
|
|||
|
|||
function ServiceManagement ({ loading, clientHeight, actions, dispatch, }) { |
|||
|
|||
const { dataService } = actions |
|||
const [query, setQuery] = useState({ page: 0, limit: 10 }); |
|||
const [ruleModal, setRuleModal] = useState(false) |
|||
const [editData, setEditData] = useState({}) |
|||
const [keyword, setKeyword] = useState() |
|||
const [tableList, setTableList] = useState({ rows: [], count: 0 }); |
|||
const [treeList, setTreeLista] = useState([]) |
|||
useEffect(() => { |
|||
resourceData() |
|||
// dispatch(dataQuality.getRegularBasis()).then(res => {
|
|||
// if (res.success) {
|
|||
// setTreeLista(res.payload.data)
|
|||
// }
|
|||
// })
|
|||
}, []) |
|||
|
|||
|
|||
let resourceData = (data) => { |
|||
// let params = data || query
|
|||
// dispatch(dataService.getBusinessRules({ keyword: keyword, ...params, })).then(res => {
|
|||
// if (res.success) {
|
|||
// setTableList({ rows: res.payload.data?.rows, count: res.payload.data?.count })
|
|||
|
|||
// }
|
|||
// })
|
|||
} |
|||
|
|||
const columns = [{ |
|||
title: '接口名称', |
|||
dataIndex: 'name', |
|||
}, { |
|||
title: '接口路由', |
|||
dataIndex: 'description', |
|||
}, { |
|||
title: '接口类型', |
|||
dataIndex: 'problemType', |
|||
}, { |
|||
title: '状态', |
|||
dataIndex: 'problemLevel' |
|||
}, { |
|||
title: '操作', |
|||
dataIndex: 'handle', |
|||
// ellipsis: true,
|
|||
render: (text, record) => <div style={{ width: 126 }}> |
|||
<Button type="link" onClick={() => { |
|||
// setEditData(record)
|
|||
// setRuleModal(true);
|
|||
}}>查看详情</Button> |
|||
<Button type="link" onClick={() => { |
|||
// setEditData(record)
|
|||
// setRuleModal(true);
|
|||
}}>编辑</Button> |
|||
<Popconfirm |
|||
title="是否确认删除该业务规则?" |
|||
onConfirm={() => { |
|||
dispatch(dataQuality.delBusinessRules(record.id)).then(res => { |
|||
if (res.success) { |
|||
setQuery({ limit: 10, page: 0 }); |
|||
resourceData({ limit: 10, page: 0, keyword }) |
|||
} |
|||
}) |
|||
}} |
|||
> |
|||
<Button type="link">删除</Button> |
|||
</Popconfirm> |
|||
<Button type="link" onClick={() => { |
|||
// setEditData(record)
|
|||
// setRuleModal(true);
|
|||
}}>禁用</Button> |
|||
</div> |
|||
}, |
|||
]; |
|||
|
|||
|
|||
return <> |
|||
|
|||
<div style={{ display: 'flex', justifyContent: 'flex-end' }}> |
|||
<div style={{ display: 'flex', }}> |
|||
<Input |
|||
placeholder="接口名称" |
|||
value={keyword} |
|||
onChange={e => { |
|||
setKeyword(e?.target?.value) |
|||
}} |
|||
style={{ |
|||
width: 266, marginRight: 10 |
|||
}} |
|||
/> |
|||
<Button onClick={() => { |
|||
setQuery({ limit: 10, page: 0 }); |
|||
resourceData({ limit: 10, page: 0, keyword }) |
|||
}}>搜索</Button> |
|||
</div> |
|||
|
|||
</div> |
|||
|
|||
<Table |
|||
columns={columns} |
|||
dataSource={tableList?.rows || []} |
|||
scroll={{ scrollToFirstRowOnChange: true, y: clientHeight - 260 }} |
|||
pagination={{ |
|||
current: query?.page + 1, |
|||
pageSize: query?.limit, |
|||
total: tableList?.count, |
|||
showSizeChanger: true, |
|||
// showQuickJumper: true,
|
|||
showTotal: (total) => { return <span style={{ fontSize: 15 }}>{`共${Math.ceil(total / query?.limit)}页,${total}项`}</span> }, |
|||
onChange: (page, pageSize) => { |
|||
setQuery({ limit: pageSize, page: page - 1 }); |
|||
resourceData({ limit: pageSize, page: page - 1, keyword }); |
|||
} |
|||
}} |
|||
/> |
|||
|
|||
{ |
|||
ruleModal ? |
|||
<RuleModal |
|||
treeList={treeList} |
|||
editData={editData} |
|||
close={() => { |
|||
setRuleModal(false); |
|||
setEditData({}) |
|||
}} |
|||
success={() => { |
|||
resourceData({ limit: 10, page: 0, keyword }) |
|||
} |
|||
} |
|||
/> : "" |
|||
} |
|||
|
|||
|
|||
</> |
|||
} |
|||
function mapStateToProps (state) { |
|||
const { global, auth, resourceCatalog } = state; |
|||
return { |
|||
user: auth.user, |
|||
actions: global.actions, |
|||
clientHeight: global.clientHeight, |
|||
// resourceCatalog: resourceCatalog?.data || [],
|
|||
// isRequesting: resourceCatalog.isRequesting
|
|||
}; |
|||
} |
|||
export default connect(mapStateToProps)(ServiceManagement) |
@ -0,0 +1,158 @@ |
|||
import React, { useEffect, useState } from 'react' |
|||
import { connect } from 'react-redux'; |
|||
import moment from 'moment'; |
|||
import { RouteRequest } from '@peace/utils'; |
|||
import { RouteTable } from '$utils' |
|||
|
|||
import { Tabs, Form, Input, Space, Button, Table, Popconfirm } from 'antd'; |
|||
const { Search } = Input; |
|||
import { CreditCardFilled, FilePdfOutlined } from '@ant-design/icons'; |
|||
import { agent } from 'superagent'; |
|||
|
|||
import RuleModal from '../components/ruleModal'; |
|||
|
|||
|
|||
function ServiceView ({ loading, clientHeight, actions, dispatch, }) { |
|||
|
|||
const { dataService } = actions |
|||
const [query, setQuery] = useState({ page: 0, limit: 10 }); |
|||
const [ruleModal, setRuleModal] = useState(false) |
|||
const [editData, setEditData] = useState({}) |
|||
const [keyword, setKeyword] = useState() |
|||
const [tableList, setTableList] = useState({ rows: [], count: 0 }); |
|||
const [treeList, setTreeLista] = useState([]) |
|||
useEffect(() => { |
|||
resourceData() |
|||
// dispatch(dataQuality.getRegularBasis()).then(res => {
|
|||
// if (res.success) {
|
|||
// setTreeLista(res.payload.data)
|
|||
// }
|
|||
// })
|
|||
}, []) |
|||
|
|||
|
|||
let resourceData = (data) => { |
|||
// let params = data || query
|
|||
// dispatch(dataService.getBusinessRules({ keyword: keyword, ...params, })).then(res => {
|
|||
// if (res.success) {
|
|||
// setTableList({ rows: res.payload.data?.rows, count: res.payload.data?.count })
|
|||
|
|||
// }
|
|||
// })
|
|||
} |
|||
|
|||
const columns = [{ |
|||
title: '接口名称', |
|||
dataIndex: 'name', |
|||
}, { |
|||
title: '接口路由', |
|||
dataIndex: 'description', |
|||
}, { |
|||
title: '接口类型', |
|||
dataIndex: 'problemType', |
|||
}, { |
|||
title: '状态', |
|||
dataIndex: 'problemLevel' |
|||
}, { |
|||
title: '操作', |
|||
dataIndex: 'handle', |
|||
// ellipsis: true,
|
|||
render: (text, record) => <div style={{ width: 126 }}> |
|||
<Button type="link" onClick={() => { |
|||
// setEditData(record)
|
|||
// setRuleModal(true);
|
|||
}}>查看详情</Button> |
|||
<Button type="link" onClick={() => { |
|||
// setEditData(record)
|
|||
// setRuleModal(true);
|
|||
}}>编辑</Button> |
|||
<Popconfirm |
|||
title="是否确认删除该业务规则?" |
|||
onConfirm={() => { |
|||
dispatch(dataQuality.delBusinessRules(record.id)).then(res => { |
|||
if (res.success) { |
|||
setQuery({ limit: 10, page: 0 }); |
|||
resourceData({ limit: 10, page: 0, keyword }) |
|||
} |
|||
}) |
|||
}} |
|||
> |
|||
<Button type="link">删除</Button> |
|||
</Popconfirm> |
|||
<Button type="link" onClick={() => { |
|||
// setEditData(record)
|
|||
// setRuleModal(true);
|
|||
}}>禁用</Button> |
|||
</div> |
|||
}, |
|||
]; |
|||
|
|||
return <> |
|||
<div style={{ display: 'flex', justifyContent: 'flex-end' }}> |
|||
<div style={{ display: 'flex', }}> |
|||
<Input |
|||
placeholder="接口名称" |
|||
value={keyword} |
|||
onChange={e => { |
|||
setKeyword(e?.target?.value) |
|||
}} |
|||
style={{ |
|||
width: 266, marginRight: 10 |
|||
}} |
|||
/> |
|||
<Button onClick={() => { |
|||
setQuery({ limit: 10, page: 0 }); |
|||
resourceData({ limit: 10, page: 0, keyword }) |
|||
}}>搜索</Button> |
|||
</div> |
|||
|
|||
</div> |
|||
|
|||
<Table |
|||
columns={columns} |
|||
dataSource={tableList?.rows || []} |
|||
scroll={{ scrollToFirstRowOnChange: true, y: clientHeight - 260 }} |
|||
pagination={{ |
|||
current: query?.page + 1, |
|||
pageSize: query?.limit, |
|||
total: tableList?.count, |
|||
showSizeChanger: true, |
|||
// showQuickJumper: true,
|
|||
showTotal: (total) => { return <span style={{ fontSize: 15 }}>{`共${Math.ceil(total / query?.limit)}页,${total}项`}</span> }, |
|||
onChange: (page, pageSize) => { |
|||
setQuery({ limit: pageSize, page: page - 1 }); |
|||
resourceData({ limit: pageSize, page: page - 1, keyword }); |
|||
} |
|||
}} |
|||
/> |
|||
|
|||
{ |
|||
ruleModal ? |
|||
<RuleModal |
|||
treeList={treeList} |
|||
editData={editData} |
|||
close={() => { |
|||
setRuleModal(false); |
|||
setEditData({}) |
|||
}} |
|||
success={() => { |
|||
resourceData({ limit: 10, page: 0, keyword }) |
|||
} |
|||
} |
|||
/> : "" |
|||
} |
|||
|
|||
|
|||
</> |
|||
} |
|||
function mapStateToProps (state) { |
|||
const { global, auth, resourceCatalog } = state; |
|||
return { |
|||
user: auth.user, |
|||
actions: global.actions, |
|||
clientHeight: global.clientHeight, |
|||
// resourceCatalog: resourceCatalog?.data || [],
|
|||
// isRequesting: resourceCatalog.isRequesting
|
|||
}; |
|||
} |
|||
export default connect(mapStateToProps)(ServiceView) |
@ -0,0 +1,15 @@ |
|||
'use strict'; |
|||
|
|||
import reducers from './reducers'; |
|||
import routes from './routes'; |
|||
import actions from './actions'; |
|||
import { getNavItem } from './nav-item'; |
|||
|
|||
export default { |
|||
key: 'dataService', |
|||
name: '数据服务', |
|||
reducers: reducers, |
|||
routes: routes, |
|||
actions: actions, |
|||
getNavItem: getNavItem |
|||
}; |
@ -0,0 +1,19 @@ |
|||
import React from 'react'; |
|||
import { Link } from 'react-router-dom'; |
|||
import { Menu } from 'antd'; |
|||
import { CarryOutOutlined } from '@ant-design/icons'; |
|||
const SubMenu = Menu.SubMenu; |
|||
|
|||
export function getNavItem (user) { |
|||
return ( |
|||
<SubMenu key="dataService" icon={<CarryOutOutlined />} title='数据服务'> |
|||
|
|||
<Menu.Item key="serviceManagement"> |
|||
<Link to="/dataService/serviceManagement">服务管理</Link> |
|||
</Menu.Item> |
|||
<Menu.Item key="serviceView"> |
|||
<Link to="/dataService/serviceView">服务查看</Link> |
|||
</Menu.Item> |
|||
</ SubMenu > |
|||
); |
|||
} |
@ -0,0 +1,5 @@ |
|||
'use strict'; |
|||
|
|||
export default { |
|||
|
|||
} |
@ -0,0 +1,22 @@ |
|||
'use strict'; |
|||
import { ServiceManagement,ServiceView } from './containers'; |
|||
export default [{ |
|||
type: 'inner', |
|||
route: { |
|||
path: '/dataService', |
|||
key: 'dataService', |
|||
breadcrumb: '数据质量', |
|||
// 不设置 component 则面包屑禁止跳转
|
|||
childRoutes: [{ |
|||
path: '/serviceManagement', |
|||
key: 'serviceManagement', |
|||
component: ServiceManagement, |
|||
breadcrumb: '服务管理' |
|||
}, { |
|||
path: '/serviceView', |
|||
key: 'serviceView', |
|||
component: ServiceView, |
|||
breadcrumb: '服务查看' |
|||
}] |
|||
} |
|||
}]; |
Loading…
Reference in new issue