import React, { useState, useEffect } from 'react'; import { Form, Modal, Input, Select, notification } from 'antd'; import { addMySQLConnString, editMySQLConnString, } from '@/services/database/api'; const { Item } = Form; const { Option } = Select; const AddModal = props => { console.log(props); const { callBackSubmit = () => {}, type, formObj, visible } = props; const [loading, setLoading] = useState(false); const [form] = Form.useForm(); // 提交 const onSubmit = () => { form.validateFields().then(validate => { if (validate) { setLoading(true); let obj = form.getFieldsValue(); if (type === 'add') { addMySQLConnString({ _version: 9999, _dc: Date.now(), ...obj, }) .then(res => { setLoading(false); if (res.success) { form.resetFields(); callBackSubmit(); notification.success({ message: '提示', duration: 3, description: res.message || '新增成功', }); } else { notification.error({ message: '提示', duration: 3, description: res.message || '新增失败', }); } }) .catch(err => { setLoading(false); console.error(err); }); } else if (type === 'edit') { handleEdit(); } } }); }; const handleEdit = () => { let obj = form.getFieldsValue(); editMySQLConnString({ _version: 9999, _dc: Date.now(), ...obj, oldName: formObj.name, }) .then(res => { setLoading(false); if (res.success) { form.resetFields(); callBackSubmit(); notification.success({ message: '提示', duration: 3, description: res.message || '编辑成功', }); } else { notification.error({ message: '提示', duration: 3, description: res.message || '编辑失败', }); } }) .catch(err => setLoading(false)); }; const onFinish = value => { console.log(value, 'value'); }; useEffect(() => { console.log(type); switch (type) { case 'add': form.resetFields(); break; case 'edit': form.setFieldsValue({ ...formObj }); break; default: break; } }, [visible]); const layout = { layout: 'horizontal', labelCol: { span: 4, }, wrapperCol: { span: 16, }, }; return ( <Modal title={`${type === 'add' ? '添加' : '编辑'}MySQL数据库配置连接`} bodyStyle={{ width: '100%', minHeight: '100px' }} style={{ top: '150px' }} width="700px" destroyOnClose maskClosable={false} cancelText="取消" okText="确认" {...props} onOk={() => onSubmit()} confirmLoading={loading} > {visible && ( <Form form={form} {...layout} onFinish={onFinish}> <Item label="标签" name="name" rules={[{ required: true, message: '请输入标签' }]} > <Input placeholder="请输入标签" allowClear /> </Item> <Item label="IP" name="ip" rules={[{ required: true, message: '请输入IP' }]} > <Input placeholder="请输入IP" allowClear /> </Item> <Item label="数据库名" name="dbName" rules={[{ required: true, message: '请输入数据库名' }]} > <Input placeholder="请输入数据库名" allowClear /> </Item> <Item label="用户名" name="userName" rules={[{ required: true, message: '请输入用户名' }]} > <Input placeholder="请输入用户名" allowClear /> </Item> <Item label="密码" name="password" rules={[{ required: true, message: '请输入密码' }]} > <Input placeholder="请输入密码" allowClear /> </Item> </Form> )} </Modal> ); }; export default AddModal;