index.jsx 1.45 KB
Newer Older
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
import InitForm from '../InitForm';
import { Modal } from 'antd';
import React, { useState, memo } from 'react';
import DetailPro from '../DetailPro';
import PropTypes from 'prop-types';

function ModalPro(props) {
  let pushSettingFlag = props.pushSettingFlag;
  let newProps = { ...props };
  delete newProps.children;
  delete newProps.style;
  const detailprops = {
    ...newProps,
    detailpath: props.detailpath,
    fields: props.fields,
    detailData: props.detailData,
  };

  return (
    <Modal
      maskClosable={false}
      closable={true}
      width={1000}
      destroyOnClose={true}
      {...props}
      onCancel={() => props?.onClose?.()}
      footer={false}
    >
      {props.val == 'only' ? (
        props.children
      ) : props.val == 'detail' ? (
        <DetailPro {...detailprops} />
      ) : props.val == 'detailaddon' ? (
        <div>
          <DetailPro {...detailprops} />
          {props?.children}
        </div>
      ) : (
        <InitForm {...newProps} />
      )}

      {pushSettingFlag ? (
        <a
          id="pushSettingBtn"
          onClick={() => {
            props.checkVariableOpen();
          }}
        >
          查看变量
        </a>
      ) : null}
    </Modal>
  );
}

ModalPro.propTypes = {
  detailpath: PropTypes.string, //详情
  params: PropTypes.object, //详情|表单编辑 参数
  fields: PropTypes.array, //详情列表
  detailData: PropTypes.object, //详情数据
};

export default ModalPro;