AuditModal.js 2.4 KB
import { Modal, Spin, Form } from 'antd';
import { useState, useEffect } from 'react';
import styles from '../../RenderForm/index.less';
import { getHistoryFormDetail } from '../../../Services';
import AuditButton from '@/webPublic/FormInsertDiy/AuditButton';
import HistoryForm from '@/webPublic/FormInsertDiy/HistoryForm';
import ButtonDiy from '@/baseComponent/ButtonDiy';
import { ModalInfo } from '@/baseComponent/Modal';
import { router } from 'umi';
import RenderForm from '../../RenderForm';

const isNewForm = true;

function AuditModal({ form, selectRows, children, getPage }) {
  const [visible, setVisible] = useState(false);

  function submitCb(res) {
    // ModalInfo(`提交${res ? '成功' : '失败'}!`, { onOk: () => router.goBack() });
    ModalInfo(`提交${res ? '成功' : '失败'}!`, {
      onOk: () => {
        setVisible(false);
        getPage();
      },
    });
  }
  const [data, setData] = useState(null);
  const [loading, setLoading] = useState(false);

  useEffect(
    () => {
      if (!visible) {
        return form.resetFields();
      }
      const code = selectRows && selectRows[0] && selectRows[0].code;
      if (typeof code === 'undefined') return;
      setLoading(true);
      getHistoryFormDetail({ code }).then(res => {
        setLoading(false);
        if (res && !res.errMsg) {
          setData({ ...res, hisTaskForm: { ...res.hisTaskForm, formKeys: [] } });
        }
      });
    },
    [visible]
  );

  const footer = data ? (
    <div style={{ padding: 16, textAlign: 'center' }}>
      <AuditButton
        data={data} // 为 'affair/getIdFormDetail' 接口请求到的数据
        callback={submitCb} // 提交完成后回调函数
        form={form} // form表单控件
        taskIds={selectRows.map(i => i.taskId)}
      />
    </div>
  ) : null;

  return (
    <>
      <Modal
        width={900}
        visible={visible}
        title="批量审核"
        footer={footer}
        onCancel={() => setVisible(false)}
      >
        <Spin spinning={loading}>
          {data && data.isHandle && !!data.taskFormKey ? (
            <RenderForm
              postData={data}
              get="web"
              isCg="no"
              obj={data.hisTaskForm.formData}
              table="new"
              form={form}
            />
          ) : null}
        </Spin>
      </Modal>
      {children({ onShow: () => setVisible(true) })}
    </>
  );
}
export default Form.create()(AuditModal);