Browse Source

(*)表业务元数据展示、配置修改

master
zmh 2 years ago
parent
commit
fe33ef5348
  1. BIN
      web/client/assets/images/favicon.ico
  2. 2
      web/client/src/layout/components/header/index.js
  3. 26
      web/client/src/sections/metadataManagement/actions/businessMetadata.js
  4. 36
      web/client/src/sections/metadataManagement/components/businessDatabaseModal.js
  5. 28
      web/client/src/sections/metadataManagement/containers/businessDatabaseTable.js
  6. 1
      web/client/src/sections/metadataManagement/containers/businessMetadata.js
  7. 12
      web/client/src/sections/metadataManagement/containers/databasesTable.js
  8. 6
      web/client/src/sections/metadataManagement/containers/restapisTable.js
  9. 8
      web/client/src/utils/webapi.js

BIN
web/client/assets/images/favicon.ico

Binary file not shown.

After

Width:  |  Height:  |  Size: 4.2 KiB

2
web/client/src/layout/components/header/index.js

@ -39,7 +39,7 @@ const Header = props => {
} }
</span> </span>
<div className={styles['header-title']} style={{}}> <div className={styles['header-title']} style={{}}>
<img src='/assets/images/logo.png' style={{ margin: '0 12px 4px 12px', height: 42, borderRadius: 4 }} />政务数据资源中心 <img src='/assets/images/favicon.ico' style={{ margin: '0 12px 4px 12px', height: 42, borderRadius: 4 }} />政务数据资源中心
</div> </div>
</div> </div>
<div id="nav" className={styles['header-nav']}> <div id="nav" className={styles['header-nav']}>

26
web/client/src/sections/metadataManagement/actions/businessMetadata.js

@ -3,49 +3,49 @@
import { basicAction } from '@peace/utils' import { basicAction } from '@peace/utils'
import { ApiTable } from '$utils' import { ApiTable } from '$utils'
export function getBusinessMetadata(params) { export function getBusinessMetadataDatabases(params) {
return dispatch => basicAction({ return dispatch => basicAction({
type: 'get', type: 'get',
dispatch: dispatch, dispatch: dispatch,
query: params, query: params,
actionType: 'GET_BUSINESS_METADATA_LIST', actionType: 'GET_BUSINESS_METADATA_DATABASES_LIST',
url: ApiTable.getBusinessMetadata, url: ApiTable.getBusinessMetadataDatabases,
msg: { error: '获取业务元数据列表失败' }, msg: { error: '获取业务元数据列表失败' },
reducer: { name: 'metadataDatabases' } reducer: { name: 'businessMetadataDatabases' }
}); });
} }
export function postBusinessMetadata(data) { export function postBusinessMetadataDatabases(data) {
return dispatch => basicAction({ return dispatch => basicAction({
type: 'post', type: 'post',
data: data, data: data,
dispatch: dispatch, dispatch: dispatch,
actionType: 'POST_BUSINESS_METADATA', actionType: 'POST_BUSINESS_METADATA_DATABASES',
url: ApiTable.postBusinessMetadata, url: ApiTable.postBusinessMetadataDatabases,
msg: { option: '新建业务元数据' }, msg: { option: '新建业务元数据' },
reducer: {} reducer: {}
}); });
} }
export function putBusinessMetadata(id, data) { export function putBusinessMetadataDatabases(id, data) {
return dispatch => basicAction({ return dispatch => basicAction({
type: 'put', type: 'put',
data: data, data: data,
dispatch, dispatch,
actionType: 'PUT_BUSINESS_METADATA', actionType: 'PUT_BUSINESS_METADATA_DATABASES',
url: ApiTable.putBusinessMetadata.replace('{id}', id), url: ApiTable.putBusinessMetadataDatabases.replace('{id}', id),
msg: { msg: {
option: '修改业务元数据', option: '修改业务元数据',
} }
}); });
} }
export function delBusinessMetadata(id) { export function delBusinessMetadataDatabases(id) {
return dispatch => basicAction({ return dispatch => basicAction({
type: 'del', type: 'del',
dispatch, dispatch,
actionType: 'DELETE_BUSINESS_METADATA', actionType: 'DELETE_BUSINESS_METADATA_DATABASES',
url: ApiTable.delBusinessMetadata.replace('{id}', id), url: ApiTable.delBusinessMetadataDatabases.replace('{id}', id),
msg: { msg: {
option: '删除业务元数据', option: '删除业务元数据',
} }

36
web/client/src/sections/metadataManagement/components/businessDatabaseModal.js

@ -19,24 +19,39 @@ const BusinessDatabaseModal = (props) => {
return Promise.resolve(); return Promise.resolve();
} }
const renderBasicInfo = (databasesRecord) => { const renderBasicInfo = (databasesRecord) => {
let path = '/' + resourceCatalogPath.join('/');
return <div> return <div>
<Row><Col span={12}> <Row><Col span={12}>
<div style={{ color: '#3BB19C', fontSize: 18 }}>基本信息</div> <div style={{ color: '#3BB19C', fontSize: 18 }}>基本信息</div>
<div style={{ lineHeight: '35px', marginLeft: 32 }}> <div style={{ lineHeight: '35px', marginLeft: 32 }}>
<div> 元数据名称<span style={{ color: '#7F7F7F' }}>{databasesRecord.name}</span></div> {[{ name: '元数据名称:', key: 'name' },
<div> 元数据代码<span style={{ color: '#7F7F7F' }}>{databasesRecord.code}</span></div> { name: '元数据代码:', key: 'code' },
<div> 元数据类型<span style={{ color: '#7F7F7F' }}>{databasesRecord.type}</span></div> { name: '元数据类型:', key: 'type' },
<div> 上下文路径<span style={{ color: '#7F7F7F' }}>{'/' + resourceCatalogPath.join('/')}</span></div> { name: '上下文路径:', key: 'path' },
<div> 元数据详情<span style={{ color: '#7F7F7F' }}>{databasesRecord.description}</span></div> { name: '元数据详情:', key: 'description' }].map(item => {
if (item.key != 'path')
return <div>{item.name}<span style={{ color: '#7F7F7F' }} title={databasesRecord[item.key]}>{
databasesRecord[item.key] && databasesRecord[item.key].length > (item.key === 'description' ? 40 : 15) ?
databasesRecord[item.key].substring(0, (item.key === 'description' ? 40 : 15)) + '...' : databasesRecord[item.key]}</span></div>
else
return <div>{item.name}<span style={{ color: '#7F7F7F' }} title={path} >{path && path.length > 15 ?
path.substring(0, 15) + '...' : path}</span></div>
})}
</div> </div>
</Col> </Col>
<Col span={12}> <Col span={12}>
<div style={{ color: '#3BB19C', fontSize: 18 }}>属性</div> <div style={{ color: '#3BB19C', fontSize: 18 }}>属性</div>
<div style={{ lineHeight: '35px', marginLeft: 32 }}> <div style={{ lineHeight: '35px', marginLeft: 32 }}>
{metadataModels && metadataModels.filter(mm => mm.modelType === '表').map(mm => {metadataModels && metadataModels.filter(mm => mm.modelType === '表').map(mm => {
<div title={mm.attributeName}> {mm.attributeName.length > 10 ? mm.attributeName.substring(0, 10) + '...' : let str = ''
if (databasesRecord.attributesParam && databasesRecord.attributesParam[mm.attributeCode]) {
str = databasesRecord.attributesParam[mm.attributeCode];
}
return <div title={mm.attributeName}> {mm.attributeName.length > 6 ? mm.attributeName.substring(0, 6) + '...' :
mm.attributeName} mm.attributeName}
<span style={{ color: '#7F7F7F' }}>{databasesRecord.attributesParam && databasesRecord.attributesParam[mm.attributeCode] || ""}</span></div>)} <span style={{ color: '#7F7F7F' }} title={str}>{str && str.length > 15 ? str.substring(0, 15) + '...' : str}</span></div>
})
}
</div> </div>
</Col> </Col>
</Row> </Row>
@ -48,10 +63,11 @@ const BusinessDatabaseModal = (props) => {
okText='确定' width={800} okText='确定' width={800}
onOk={() => handleOk(null)} onOk={() => handleOk(null)}
onCancel={onCancel}> onCancel={onCancel}>
{editData.record.businessMetadataDatabases.length ? {editData.record && editData.record.businessMetadataDatabases.length ?
renderBasicInfo(editData.record) : null renderBasicInfo(editData.record) : null
} }
<Form form={form} labelCol={{ span: 6 }} wrapperCol={{ span: 18 }} initialValues={editData.record.businessMetadataDatabases || {}}> <Form form={form} labelCol={{ span: 6 }} wrapperCol={{ span: 18 }} initialValues={editData.record && editData.record.businessMetadataDatabases.length &&
editData.record.businessMetadataDatabases[0] || {}}>
{[{ name: '信息资源名称', key: 'resourceName' }, {[{ name: '信息资源名称', key: 'resourceName' },
{ name: '信息资源摘要', key: 'resourceAbstract' }, { name: '信息资源摘要', key: 'resourceAbstract' },
{ name: '信息资源提供方', key: 'resourceProvider' }, { name: '信息资源提供方', key: 'resourceProvider' },

28
web/client/src/sections/metadataManagement/containers/businessDatabaseTable.js

@ -5,7 +5,7 @@ import moment from 'moment';
import FileSaver from 'file-saver'; import FileSaver from 'file-saver';
import BusinessDatabaseModal from '../components/businessDatabaseModal'; import BusinessDatabaseModal from '../components/businessDatabaseModal';
const BusinessDatabaseTable = (props) => { const BusinessDatabaseTable = (props) => {
const { user, dispatch, actions, clientHeight, resourceCatalogId, resourceCatalogKey, const { user, dispatch, actions, clientHeight, resourceCatalogId,
resourceCatalogPath, isRequesting, metadataModels } = props; resourceCatalogPath, isRequesting, metadataModels } = props;
const { metadataManagement } = actions; const { metadataManagement } = actions;
const SortValues = { 'ascend': 'asc', 'descend': 'desc' }; const SortValues = { 'ascend': 'asc', 'descend': 'desc' };
@ -22,11 +22,11 @@ const BusinessDatabaseTable = (props) => {
useEffect(() => { useEffect(() => {
setUpdateAtSort('descend'); setUpdateAtSort('descend');
initData({ limit, offset: currentPage - 1, orderDirection: SortValues[updateAtSort] }); onSearch('descend');
}, [resourceCatalogId]); }, [resourceCatalogId]);
const initData = (query = {}) => { const initData = (query = {}) => {
dispatch(metadataManagement.getBusinessMetadata({ catalog: resourceCatalogId, keywords, orderBy: 'updateAt', ...query })).then(res => { dispatch(metadataManagement.getBusinessMetadataDatabases({ catalog: resourceCatalogId, keywords, orderBy: 'updateAt', ...query })).then(res => {
if (res.success) { if (res.success) {
setTableData(res.payload.data.rows); setTableData(res.payload.data.rows);
setTableDataCount(res.payload.data.count); setTableDataCount(res.payload.data.count);
@ -39,13 +39,13 @@ const BusinessDatabaseTable = (props) => {
if (!add) if (!add)
setEditData({ title: '查看业务元数据', record: { path: '/' + resourceCatalogPath.join('/'), ...record, ...record.attributesParam } }); setEditData({ title: '查看业务元数据', record: { path: '/' + resourceCatalogPath.join('/'), ...record, ...record.attributesParam } });
else else
setEditData({ add: true, title: '新建业务元数据', record: { path: '/' + resourceCatalogPath.join('/'), ...record, ...record.attributesParam } }); setEditData({ add: true, title: '新建业务元数据', record: { ...record } });
setModalVisible(true); setModalVisible(true);
} }
}) })
} }
const confirmDelete = (id) => { const confirmDelete = (id) => {
dispatch(metadataManagement.delBusinessMetadata(id)).then(res => { dispatch(metadataManagement.delBusinessMetadataDatabases(id)).then(res => {
if (res.success) { if (res.success) {
onSearch(); setModalVisible(false); onSearch(); setModalVisible(false);
} }
@ -211,18 +211,18 @@ const BusinessDatabaseTable = (props) => {
} }
}]; }];
const onSearch = () => { const onSearch = (sort) => {
setSelectedRowKeys([]); setSelectedRowKeys([]);
setSelectedRows([]); setSelectedRows([]);
setCurrentPage(1); setCurrentPage(1);
initData({ limit, offset: 0, orderDirection: SortValues[updateAtSort] }); initData({ limit, offset: 0, orderDirection: SortValues[sort || updateAtSort] });
} }
const handleExport = (isAll = false) => { const handleExport = (isAll = false) => {
let tableHeader = `<tr>`; let tableHeader = `<tr>`;
columns.filter(c => c.dataIndex != 'action').map(c => { tableHeader += `<th><div>${c.title}</div></th>`; }); columns.filter(c => c.dataIndex != 'action').map(c => { tableHeader += `<th><div>${c.title}</div></th>`; });
tableHeader += '</tr>'; tableHeader += '</tr>';
if (isAll) { if (isAll) {
dispatch(metadataManagement.getBusinessMetadata({ catalog: resourceCatalogId })).then(res => { dispatch(metadataManagement.getBusinessMetadataDatabases({ catalog: resourceCatalogId })).then(res => {
if (res.success) { if (res.success) {
handleExportTable(tableHeader, res.payload.data.rows); handleExportTable(tableHeader, res.payload.data.rows);
} }
@ -270,12 +270,14 @@ const BusinessDatabaseTable = (props) => {
let obj = {} let obj = {}
if (editData.add) { if (editData.add) {
obj = { createBy: user.id, metadataDatabaseId: editData.record.id, ...values } obj = { createBy: user.id, metadataDatabaseId: editData.record.id, ...values }
dispatch(metadataManagement.postBusinessMetadata(obj)).then(() => { dispatch(metadataManagement.postBusinessMetadataDatabases(obj)).then(res => {
onSearch(); setModalVisible(false); if (res.success) {
onSearch(); setModalVisible(false);
}
}); });
} else { } else {
obj = { ...values } obj = { ...values }
dispatch(metadataManagement.putBusinessMetadata(editData.record.businessMetadataDatabases[0].id, obj)).then(res => { dispatch(metadataManagement.putBusinessMetadataDatabases(editData.record.businessMetadataDatabases[0].id, obj)).then(res => {
if (res.success) { if (res.success) {
onSearch(); setModalVisible(false); onSearch(); setModalVisible(false);
} }
@ -332,12 +334,12 @@ const BusinessDatabaseTable = (props) => {
</Spin > </Spin >
} }
function mapStateToProps(state) { function mapStateToProps(state) {
const { global, auth, metadataDatabases, metadataModels } = state; const { global, auth, businessMetadataDatabases, metadataModels } = state;
return { return {
user: auth.user, user: auth.user,
actions: global.actions, actions: global.actions,
clientHeight: global.clientHeight, clientHeight: global.clientHeight,
isRequesting: metadataDatabases.isRequesting || metadataModels.isRequesting, isRequesting: businessMetadataDatabases.isRequesting || metadataModels.isRequesting,
metadataModels: metadataModels.data metadataModels: metadataModels.data
}; };
} }

1
web/client/src/sections/metadataManagement/containers/businessMetadata.js

@ -12,7 +12,6 @@ const BusinessMetadata = (props) => {
const [resourceCatalogData, setResourceCatalogData] = useState([]); const [resourceCatalogData, setResourceCatalogData] = useState([]);
const [selectedKeys, setSelectedKeys] = useState([]); const [selectedKeys, setSelectedKeys] = useState([]);
const [expandedKeys, setExpandedKeys] = useState([]); const [expandedKeys, setExpandedKeys] = useState([]);
const [modalVisible, setModalVisible] = useState(false);
const [resourceCatalogId, setResourceCatalogId] = useState(''); const [resourceCatalogId, setResourceCatalogId] = useState('');
const [resourceCatalogKey, setResourceCatalogKey] = useState(''); const [resourceCatalogKey, setResourceCatalogKey] = useState('');
const [resourceCatalogPath, setResourceCatalogPath] = useState([]); const [resourceCatalogPath, setResourceCatalogPath] = useState([]);

12
web/client/src/sections/metadataManagement/containers/databasesTable.js

@ -32,7 +32,7 @@ const DatabaseTable = (props) => {
useEffect(() => { useEffect(() => {
dispatch(metadataManagement.getTagList()); dispatch(metadataManagement.getTagList());
setCreateAtSort('descend'); setCreateAtSort('descend');
initData({ limit, offset: currentPage - 1, orderDirection: SortValues[createAtSort] }); onSearch('descend');
}, [resourceCatalogId]); }, [resourceCatalogId]);
const initData = (query = {}) => { const initData = (query = {}) => {
@ -186,11 +186,11 @@ const DatabaseTable = (props) => {
} }
}]; }];
const onSearch = () => { const onSearch = (sort) => {
setSelectedRowKeys([]); setSelectedRowKeys([]);
setSelectedRows([]); setSelectedRows([]);
setCurrentPage(1); setCurrentPage(1);
initData({ limit, offset: 0, orderDirection: SortValues[createAtSort] }); initData({ limit, offset: 0, orderDirection: SortValues[sort || createAtSort] });
} }
const handleExport = (isAll = false) => { const handleExport = (isAll = false) => {
let tableHeader = `<tr>`; let tableHeader = `<tr>`;
@ -237,8 +237,10 @@ const DatabaseTable = (props) => {
let obj = {} let obj = {}
if (editData.add) { if (editData.add) {
obj = { createBy: user.id, catalog: resourceCatalogId, catalogKey: resourceCatalogKey, ...values } obj = { createBy: user.id, catalog: resourceCatalogId, catalogKey: resourceCatalogKey, ...values }
dispatch(metadataManagement.postMetadataDatabases(obj)).then(() => { dispatch(metadataManagement.postMetadataDatabases(obj)).then(res => {
onSearch(); setModalVisible(false); if (res.success) {
onSearch(); setModalVisible(false);
}
}); });
} else { } else {
obj = { catalog: resourceCatalogId, catalogKey: resourceCatalogKey, ...values } obj = { catalog: resourceCatalogId, catalogKey: resourceCatalogKey, ...values }

6
web/client/src/sections/metadataManagement/containers/restapisTable.js

@ -165,8 +165,10 @@ const RestapisTable = (props) => {
let obj = {} let obj = {}
if (editData.add) { if (editData.add) {
obj = { createBy: user.id, catalog: resourceCatalogId, catalogKey: resourceCatalogKey, ...values } obj = { createBy: user.id, catalog: resourceCatalogId, catalogKey: resourceCatalogKey, ...values }
dispatch(metadataManagement.postMetadataRestapis(obj)).then(() => { dispatch(metadataManagement.postMetadataRestapis(obj)).then(res => {
onSearch(); setModalVisible(false); if (res.success) {
onSearch(); setModalVisible(false);
}
}); });
} else { } else {
obj = { catalog: resourceCatalogId, catalogKey: resourceCatalogKey, ...values } obj = { catalog: resourceCatalogId, catalogKey: resourceCatalogKey, ...values }

8
web/client/src/utils/webapi.js

@ -46,10 +46,10 @@ export const ApiTable = {
delMetadataRestapis: 'metadata/restapis/{id}', delMetadataRestapis: 'metadata/restapis/{id}',
//业务元数据管理 //业务元数据管理
getBusinessMetadata: 'business/metadata', getBusinessMetadataDatabases: 'business/metadata/databases',
postBusinessMetadata: 'business/metadata', postBusinessMetadataDatabases: 'business/metadata/databases',
putBusinessMetadata: 'business/metadata/{id}', putBusinessMetadataDatabases: 'business/metadata/databases/{id}',
delBusinessMetadata: 'business/metadata/{id}', delBusinessMetadataDatabases: 'business/metadata/databases/{id}',
//元数据采集-数据源管理 //元数据采集-数据源管理
pgCheckConnect: 'adapter/check/connect', pgCheckConnect: 'adapter/check/connect',

Loading…
Cancel
Save