1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124
| import React, { useState, useEffect } from 'react' import { Modal, Form, Checkbox } from 'antd'
const AutoModal = props => { const { visible, formItemLayout, customerFlag, csFlag } = props const [confirmLoading, setConfirmLoading] = useState(false) const [form] = Form.useForm() const [csFlagState, setCsFlagState] = useState(csFlag) const [customerFlagState, setCustomerFlagState] = useState(customerFlag) const handleFinish = async values => { try { setConfirmLoading(true) await handleOk(values) } catch (e) { console.error(e) } finally { setConfirmLoading(false) } } const handleOk = () => { form.submit() } const handleCancel = () => {} const handleCSFlagChange = e => { setCsFlagState(e.target.checked) } const handleCustomerFlagChange = e => { setCustomerFlagState(e.target.checked) } const checkFlag = () => { if (csFlagState || customerFlagState) { return Promise.resolve() } message.warning('服务客服或服务客户至少选一项') return Promise.reject(new Error('服务客服或服务客户至少选一项')) }
useEffect(() => { if (visible) { form.setFieldsValue({ newTskId: modifyObj.tskId, creIdList: modifyObj.creIdList, custIdList: modifyObj.custIdList, }) } }, [modifyObj, visible, form])
useEffect(() => { if (visible) { form.setFieldsValue({ csFlag, }) setCsFlagState(csFlag) } }, [csFlag, visible, form])
useEffect(() => { if (visible) { form.setFieldsValue({ customeFlag: customerFlag, }) setCustomerFlagState(customerFlag) } }, [customerFlag, visible, form])
return ( <Modal forceRender title={title} visible={visible} onOk={handleOk} confirmLoading={confirmLoading} onCancel={handleCancel} destroyOnClose > <Form form={form} preserve={false} onFinish={handleFinish} layout="horizontal" {...formItemLayout} > <Form.Item {...formItemLayout} style={{ marginBottom: 0 }} label={ <Form.Item noStyle name="csFlag" rules={[{ validator: checkFlag }]} validateTrigger="onSubmit" initialValue={csFlagState} valuePropName="checked" > <Checkbox onChange={handleCSFlagChange}>{csLabel}</Checkbox> </Form.Item> } ></Form.Item> <Form.Item {...formItemLayout} style={{ marginBottom: 0 }} label={ <Form.Item noStyle name="customeFlag" rules={[{ validator: checkFlag }]} validateTrigger="onSubmit" initialValue={customerFlagState} valuePropName="checked" > <Checkbox onChange={handleCustomerFlagChange}> {customerLabel} </Checkbox> </Form.Item> } ></Form.Item> </Form> </Modal> ) }
export default AutoModal
|