import React from 'react'; import { Form, Input, Button, Select } from 'antd'; import styles from './addForm.less'; import PicturesWall from '@/components/Upload/index'; import EditeConfigWrapper from './editConfigFileWrapper'; const { Item } = Form; const AddForm = props => { const { submitCallback, nodeObj, addType, submitLoading, configFiles, } = props; const [form] = Form.useForm(); const [otherForm] = Form.useForm(); const layout = { layout: 'horizontal', labelCol: { span: 4, offset: 1 }, wrapperCol: { span: 16 }, }; const submit = () => { if (addType === 1) { let obj = form.getFieldsValue(); submitCallback(obj, nodeObj); } if (addType === 2) { // 分组 let obj = otherForm.getFieldsValue(); submitCallback(obj, nodeObj); } }; const finish = () => { submit(); }; return ( <div> {addType === 1 && ( <Form form={form} name="groupform" {...layout} className={styles.formStyle} onFinish={finish} > <Item label="菜单名称" name="menuName" rules={[ { required: true, message: '请输入分组名称', }, ]} > <Input /> </Item> <Item label="菜单别名" name="shortName"> <Input /> </Item> <Item label="菜单图标" name="imageUrl" rules={[ { required: true, message: '请选择在线图标', }, ]} > <PicturesWall /> </Item> <Item label="功能路径" name="pageUrl"> <Input /> </Item> <Item label="配置文件" name="config"> <EditeConfigWrapper> <Select allowClear showSearch filterOption={(input, option) => option.children.toLowerCase().indexOf(input.toLowerCase()) >= 0 } > {configFiles.map(c => ( <Select.Option key={c.text} value={c.value}> {c.text} </Select.Option> ))} </Select> </EditeConfigWrapper> </Item> <Item wrapperCol={{ offset: 5 }} style={{ marginTop: '40px' }}> <Button type="primary" htmlType="submit" loading={submitLoading}> 提交 </Button> </Item> </Form> )} {addType === 2 && ( <Form form={otherForm} name="menuform" {...layout} onFinish={finish} className={styles.formStyle} > <Item label="菜单名称" name="menuName" rules={[ { required: true, message: '请输入菜单名称', }, ]} > <Input /> </Item> <Item label="菜单别名" name="shortName"> <Input /> </Item> <Item label="菜单图标" name="imageUrl" rules={[ { required: true, message: '请选择菜单图标', }, ]} > <PicturesWall /> </Item> <Item wrapperCol={{ offset: 5 }} style={{ marginTop: '40px' }}> <Button type="primary" htmlType="submit" loading={submitLoading}> 提交 </Button> </Item> </Form> )} </div> ); }; export default AddForm;