|  |  | @ -4,10 +4,11 @@ import { connect } from 'react-redux'; | 
			
		
	
		
			
				
					|  |  |  | import ProTable from '@ant-design/pro-table'; | 
			
		
	
		
			
				
					|  |  |  | import moment from 'moment'; | 
			
		
	
		
			
				
					|  |  |  | import MemberModal from '../components/memberModal'; | 
			
		
	
		
			
				
					|  |  |  | import ResetPasswordModal from '../components/resetPassword'; | 
			
		
	
		
			
				
					|  |  |  | import { useFsRequest, ApiTable } from '$utils'; | 
			
		
	
		
			
				
					|  |  |  | import './style.less'; | 
			
		
	
		
			
				
					|  |  |  | function Member(props) { | 
			
		
	
		
			
				
					|  |  |  |     const { loading, clientHeight, actions, dispatch, dataSources, adapters } = props; | 
			
		
	
		
			
				
					|  |  |  |     const { loading, clientHeight, actions, dispatch, member } = props; | 
			
		
	
		
			
				
					|  |  |  |     const [pageSize, setPageSize] = useState(10); | 
			
		
	
		
			
				
					|  |  |  |     const [currentPage, setCurrentPage] = useState(1); | 
			
		
	
		
			
				
					|  |  |  |     const [searchValue, setSearchValue] = useState('') | 
			
		
	
	
		
			
				
					|  |  | @ -19,10 +20,11 @@ function Member(props) { | 
			
		
	
		
			
				
					|  |  |  |         const query = { | 
			
		
	
		
			
				
					|  |  |  |             limit: search ? 10 : pageSize || 10, | 
			
		
	
		
			
				
					|  |  |  |             page: search ? 1 : currentPage || 1, | 
			
		
	
		
			
				
					|  |  |  |             name: searchValue | 
			
		
	
		
			
				
					|  |  |  |             name: searchValue, | 
			
		
	
		
			
				
					|  |  |  |             role: searchRole | 
			
		
	
		
			
				
					|  |  |  |         } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |         dispatch(actions.metadataAcquisition.getDataSources(query)); | 
			
		
	
		
			
				
					|  |  |  |         dispatch(actions.memberManagement.getUserList(query)); | 
			
		
	
		
			
				
					|  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  |     const { data: treeData = [] } = useFsRequest({ | 
			
		
	
		
			
				
					|  |  |  |         url: ApiTable.getResourceCatalog, | 
			
		
	
	
		
			
				
					|  |  | @ -30,16 +32,9 @@ function Member(props) { | 
			
		
	
		
			
				
					|  |  |  |     }); | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |     useEffect(() => { | 
			
		
	
		
			
				
					|  |  |  |         dispatch(actions.metadataAcquisition.getAdapters()) | 
			
		
	
		
			
				
					|  |  |  |         queryData(); | 
			
		
	
		
			
				
					|  |  |  |     }, [pageSize, currentPage]); | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |     const handleDelete = (id) => { | 
			
		
	
		
			
				
					|  |  |  |         dispatch(actions.metadataAcquisition.deleteDataSource(id)).then(() => { | 
			
		
	
		
			
				
					|  |  |  |             queryData(); | 
			
		
	
		
			
				
					|  |  |  |         }); | 
			
		
	
		
			
				
					|  |  |  |     }; | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |     const columns = [ | 
			
		
	
		
			
				
					|  |  |  |         { | 
			
		
	
		
			
				
					|  |  |  |             title: '序号', | 
			
		
	
	
		
			
				
					|  |  | @ -61,6 +56,9 @@ function Member(props) { | 
			
		
	
		
			
				
					|  |  |  |         { | 
			
		
	
		
			
				
					|  |  |  |             title: '状态', | 
			
		
	
		
			
				
					|  |  |  |             dataIndex: 'enabled', | 
			
		
	
		
			
				
					|  |  |  |             render: (text, record) => { | 
			
		
	
		
			
				
					|  |  |  |                 return <span style={{ color: record?.enabled ? '#87d068' : '#f50' }}>● {record?.enabled ? '正常' : '禁用'}</span> | 
			
		
	
		
			
				
					|  |  |  |             } | 
			
		
	
		
			
				
					|  |  |  |         }, | 
			
		
	
		
			
				
					|  |  |  |         { | 
			
		
	
		
			
				
					|  |  |  |             title: '操作', | 
			
		
	
	
		
			
				
					|  |  | @ -69,65 +67,71 @@ function Member(props) { | 
			
		
	
		
			
				
					|  |  |  |             valueType: 'option', | 
			
		
	
		
			
				
					|  |  |  |             render: (text, record) => { | 
			
		
	
		
			
				
					|  |  |  |                 const options = []; | 
			
		
	
		
			
				
					|  |  |  |                 options.push(<a onClick={() => { | 
			
		
	
		
			
				
					|  |  |  |                     setVisible(true) | 
			
		
	
		
			
				
					|  |  |  |                     setEditData(record) | 
			
		
	
		
			
				
					|  |  |  |                 }} style={{ marginRight: 8 }}>编辑</a>) | 
			
		
	
		
			
				
					|  |  |  |                 options.push(<MemberModal | 
			
		
	
		
			
				
					|  |  |  |                     editData={record} | 
			
		
	
		
			
				
					|  |  |  |                     triggerRender={<a>编辑</a>} | 
			
		
	
		
			
				
					|  |  |  |                     title="编辑用户" | 
			
		
	
		
			
				
					|  |  |  |                     onFinish={onFinish} | 
			
		
	
		
			
				
					|  |  |  |                     key="editUser" | 
			
		
	
		
			
				
					|  |  |  |                 />) | 
			
		
	
		
			
				
					|  |  |  |                 options.push( | 
			
		
	
		
			
				
					|  |  |  |                     <Popconfirm | 
			
		
	
		
			
				
					|  |  |  |                         key="del" | 
			
		
	
		
			
				
					|  |  |  |                         placement="top" | 
			
		
	
		
			
				
					|  |  |  |                         title={<><div>是否确认删除该数据源?</div> | 
			
		
	
		
			
				
					|  |  |  |                             <div>(将同步删除数据源下的元数据)</div></>} | 
			
		
	
		
			
				
					|  |  |  |                         title={<><div>是否确认删除该用户?</div> | 
			
		
	
		
			
				
					|  |  |  |                         </>} | 
			
		
	
		
			
				
					|  |  |  |                         onConfirm={() => handleDelete(record.id)} | 
			
		
	
		
			
				
					|  |  |  |                         okText="是" | 
			
		
	
		
			
				
					|  |  |  |                         cancelText="否" | 
			
		
	
		
			
				
					|  |  |  |                     > | 
			
		
	
		
			
				
					|  |  |  |                         <a>删除</a> | 
			
		
	
		
			
				
					|  |  |  |                     </Popconfirm>) | 
			
		
	
		
			
				
					|  |  |  |                 options.push(<ResetPasswordModal | 
			
		
	
		
			
				
					|  |  |  |                     editData={record} | 
			
		
	
		
			
				
					|  |  |  |                     triggerRender={<a>重置密码</a>} | 
			
		
	
		
			
				
					|  |  |  |                     title="重置密码" | 
			
		
	
		
			
				
					|  |  |  |                     onFinish={onFinish} | 
			
		
	
		
			
				
					|  |  |  |                     key="resetPassword" | 
			
		
	
		
			
				
					|  |  |  |                 />) | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |                 return options; | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |             }, | 
			
		
	
		
			
				
					|  |  |  |         }, | 
			
		
	
		
			
				
					|  |  |  |     ]; | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |     const onFinish = (values) => { | 
			
		
	
		
			
				
					|  |  |  |         const { stepOneValues, stepTwoValues, } = values; | 
			
		
	
		
			
				
					|  |  |  |         const adapterInfo = adapters?.find(x => x.adapterName == stepOneValues?.adapterName) | 
			
		
	
		
			
				
					|  |  |  |         if (adapterInfo) { | 
			
		
	
		
			
				
					|  |  |  |             const dataToSave = { | 
			
		
	
		
			
				
					|  |  |  |                 name: stepOneValues?.name, | 
			
		
	
		
			
				
					|  |  |  |                 audited: true, | 
			
		
	
		
			
				
					|  |  |  |                 adapterId: adapterInfo?.id, | 
			
		
	
		
			
				
					|  |  |  |                 mountPath: stepOneValues?.mountPath, | 
			
		
	
		
			
				
					|  |  |  |                 catalogKey: stepOneValues?.catalogKey, | 
			
		
	
		
			
				
					|  |  |  |                 description: stepOneValues?.description, | 
			
		
	
		
			
				
					|  |  |  |                 config: stepTwoValues, | 
			
		
	
		
			
				
					|  |  |  |                 time: moment() | 
			
		
	
		
			
				
					|  |  |  |             } | 
			
		
	
		
			
				
					|  |  |  |     const handleDelete = (id) => { | 
			
		
	
		
			
				
					|  |  |  |         dispatch(actions.memberManagement.deleteUser(id)).then(() => { | 
			
		
	
		
			
				
					|  |  |  |             queryData(); | 
			
		
	
		
			
				
					|  |  |  |         }); | 
			
		
	
		
			
				
					|  |  |  |     }; | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |     const onFinish = async (values, editData) => { | 
			
		
	
		
			
				
					|  |  |  |         if (editData) { | 
			
		
	
		
			
				
					|  |  |  |                 dispatch(actions.metadataAcquisition.modifyDataSource(editData?.id, dataToSave)).then(res => { | 
			
		
	
		
			
				
					|  |  |  |             const dataToSave = { ...values } | 
			
		
	
		
			
				
					|  |  |  |             return dispatch( | 
			
		
	
		
			
				
					|  |  |  |                 actions.memberManagement.modifyUser(editData.id, dataToSave, values?.msg || ''), | 
			
		
	
		
			
				
					|  |  |  |             ).then((res) => { | 
			
		
	
		
			
				
					|  |  |  |                 if (res.success) { | 
			
		
	
		
			
				
					|  |  |  |                         setVisible(false); | 
			
		
	
		
			
				
					|  |  |  |                         setEditData(null); | 
			
		
	
		
			
				
					|  |  |  |                     queryData(); | 
			
		
	
		
			
				
					|  |  |  |                     } | 
			
		
	
		
			
				
					|  |  |  |                 }) | 
			
		
	
		
			
				
					|  |  |  |                     return true; | 
			
		
	
		
			
				
					|  |  |  |                 } else { | 
			
		
	
		
			
				
					|  |  |  |                 dispatch(actions.metadataAcquisition.addDataSource(dataToSave)).then(res => { | 
			
		
	
		
			
				
					|  |  |  |                     if (res.success) { | 
			
		
	
		
			
				
					|  |  |  |                         setVisible(false); | 
			
		
	
		
			
				
					|  |  |  |                         setEditData(null); | 
			
		
	
		
			
				
					|  |  |  |                         queryData(); | 
			
		
	
		
			
				
					|  |  |  |                     } | 
			
		
	
		
			
				
					|  |  |  |                 }) | 
			
		
	
		
			
				
					|  |  |  |             } | 
			
		
	
		
			
				
					|  |  |  |                     return false; | 
			
		
	
		
			
				
					|  |  |  |                 } | 
			
		
	
		
			
				
					|  |  |  |             }); | 
			
		
	
		
			
				
					|  |  |  |         } | 
			
		
	
		
			
				
					|  |  |  |     const refresh = () => { | 
			
		
	
		
			
				
					|  |  |  |         // queryData();
 | 
			
		
	
		
			
				
					|  |  |  |         setRefreshTree(refreshTree + 1) | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |         return dispatch(actions.memberManagement.addUser({ | 
			
		
	
		
			
				
					|  |  |  |             ...values, | 
			
		
	
		
			
				
					|  |  |  |         })).then(res => { | 
			
		
	
		
			
				
					|  |  |  |             if (res.success) { | 
			
		
	
		
			
				
					|  |  |  |                 queryData(); | 
			
		
	
		
			
				
					|  |  |  |                 return true; | 
			
		
	
		
			
				
					|  |  |  |             } else { | 
			
		
	
		
			
				
					|  |  |  |                 return false; | 
			
		
	
		
			
				
					|  |  |  |             } | 
			
		
	
		
			
				
					|  |  |  |         }); | 
			
		
	
		
			
				
					|  |  |  |     }; | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |     return <Spin spinning={loading}> | 
			
		
	
		
			
				
					|  |  |  |         <Row className='protable-title'> | 
			
		
	
	
		
			
				
					|  |  | @ -145,6 +149,7 @@ function Member(props) { | 
			
		
	
		
			
				
					|  |  |  |                     style={{ width: 220, marginRight: 15 }} placeholder="请输入" /> | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |                 <span>角色: </span> <Select | 
			
		
	
		
			
				
					|  |  |  |                     allowClear | 
			
		
	
		
			
				
					|  |  |  |                     value={searchRole} onChange={e => { setSearchRole(e) }} | 
			
		
	
		
			
				
					|  |  |  |                     style={{ width: 220, marginRight: 15 }} placeholder="请选择" > | 
			
		
	
		
			
				
					|  |  |  |                     <Select.Option value={'系统管理员'}>系统管理员</Select.Option> | 
			
		
	
	
		
			
				
					|  |  | @ -171,7 +176,7 @@ function Member(props) { | 
			
		
	
		
			
				
					|  |  |  |             //1490 2256
 | 
			
		
	
		
			
				
					|  |  |  |             pagination={{ | 
			
		
	
		
			
				
					|  |  |  |                 size: 'large', | 
			
		
	
		
			
				
					|  |  |  |                 total: dataSources?.count, | 
			
		
	
		
			
				
					|  |  |  |                 total: member?.count, | 
			
		
	
		
			
				
					|  |  |  |                 showSizeChanger: true, | 
			
		
	
		
			
				
					|  |  |  |                 showQuickJumper: true, | 
			
		
	
		
			
				
					|  |  |  |                 current: currentPage, | 
			
		
	
	
		
			
				
					|  |  | @ -192,7 +197,7 @@ function Member(props) { | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |                 } | 
			
		
	
		
			
				
					|  |  |  |             }} | 
			
		
	
		
			
				
					|  |  |  |             dataSource={dataSources?.rows || []} | 
			
		
	
		
			
				
					|  |  |  |             dataSource={member?.rows || []} | 
			
		
	
		
			
				
					|  |  |  |             options={false} | 
			
		
	
		
			
				
					|  |  |  |         /> | 
			
		
	
		
			
				
					|  |  |  |     </Spin> | 
			
		
	
	
		
			
				
					|  |  | @ -201,14 +206,13 @@ function Member(props) { | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | function mapStateToProps(state) { | 
			
		
	
		
			
				
					|  |  |  |     const { | 
			
		
	
		
			
				
					|  |  |  |         auth, global, datasources, adapters | 
			
		
	
		
			
				
					|  |  |  |         auth, global, datasources, member | 
			
		
	
		
			
				
					|  |  |  |     } = state; | 
			
		
	
		
			
				
					|  |  |  |     return { | 
			
		
	
		
			
				
					|  |  |  |         loading: datasources.isRequesting || adapters?.isRequesting, | 
			
		
	
		
			
				
					|  |  |  |         loading: datasources.isRequesting, | 
			
		
	
		
			
				
					|  |  |  |         clientHeight: global.clientHeight, | 
			
		
	
		
			
				
					|  |  |  |         actions: global.actions, | 
			
		
	
		
			
				
					|  |  |  |         dataSources: datasources?.data || {}, | 
			
		
	
		
			
				
					|  |  |  |         adapters: adapters?.data || [] | 
			
		
	
		
			
				
					|  |  |  |         member: member?.data || {}, | 
			
		
	
		
			
				
					|  |  |  |     }; | 
			
		
	
		
			
				
					|  |  |  | } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
	
		
			
				
					|  |  | 
 |