@ant-design/pro-form
Version:
425 lines (419 loc) • 16.2 kB
JavaScript
import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
import _regeneratorRuntime from "@babel/runtime/helpers/esm/regeneratorRuntime";
import _asyncToGenerator from "@babel/runtime/helpers/esm/asyncToGenerator";
import _toConsumableArray from "@babel/runtime/helpers/esm/toConsumableArray";
import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
var _excluded = ["current", "onCurrentChange", "submitter", "stepsFormRender", "stepsRender", "stepFormRender", "stepsProps", "onFinish", "formProps", "containerStyle", "formRef", "formMapRef", "layoutRender"];
import { ProConfigProvider, useIntl } from '@ant-design/pro-provider';
import { compareVersions, merge, useRefFunction } from '@ant-design/pro-utils';
import { Button, Col, ConfigProvider, Form, Row, Space, Steps, version } from 'antd';
import classNames from 'classnames';
import toArray from "rc-util/es/Children/toArray";
import useMergedState from "rc-util/es/hooks/useMergedState";
import React, { useCallback, useContext, useImperativeHandle, useMemo, useRef, useState } from 'react';
import StepForm from "./StepForm";
import { useStyle } from "./style";
import { jsx as _jsx } from "react/jsx-runtime";
import { Fragment as _Fragment } from "react/jsx-runtime";
import { jsxs as _jsxs } from "react/jsx-runtime";
export var StepsFormProvide = /*#__PURE__*/React.createContext(undefined);
var StepsLayoutStrategy = {
horizontal: function horizontal(_ref) {
var stepsDom = _ref.stepsDom,
formDom = _ref.formDom;
return /*#__PURE__*/_jsxs(_Fragment, {
children: [/*#__PURE__*/_jsx(Row, {
gutter: {
xs: 8,
sm: 16,
md: 24
},
children: /*#__PURE__*/_jsx(Col, {
span: 24,
children: stepsDom
})
}), /*#__PURE__*/_jsx(Row, {
gutter: {
xs: 8,
sm: 16,
md: 24
},
children: /*#__PURE__*/_jsx(Col, {
span: 24,
children: formDom
})
})]
});
},
vertical: function vertical(_ref2) {
var stepsDom = _ref2.stepsDom,
formDom = _ref2.formDom;
return /*#__PURE__*/_jsxs(Row, {
align: "stretch",
wrap: true,
gutter: {
xs: 8,
sm: 16,
md: 24
},
children: [/*#__PURE__*/_jsx(Col, {
xxl: 4,
xl: 6,
lg: 7,
md: 8,
sm: 10,
xs: 12,
children: /*#__PURE__*/React.cloneElement(stepsDom, {
style: {
height: '100%'
}
})
}), /*#__PURE__*/_jsx(Col, {
children: /*#__PURE__*/_jsx("div", {
style: {
display: 'flex',
alignItems: 'center',
width: '100%',
height: '100%'
},
children: formDom
})
})]
});
}
};
/**
* 给 StepForm 传递信息
*/
export var StepFormProvide = /*#__PURE__*/React.createContext(null);
function StepsForm(props) {
var _useContext = useContext(ConfigProvider.ConfigContext),
getPrefixCls = _useContext.getPrefixCls;
var prefixCls = getPrefixCls('pro-steps-form');
var _useStyle = useStyle(prefixCls),
wrapSSR = _useStyle.wrapSSR,
hashId = _useStyle.hashId;
var current = props.current,
onCurrentChange = props.onCurrentChange,
submitter = props.submitter,
stepsFormRender = props.stepsFormRender,
stepsRender = props.stepsRender,
stepFormRender = props.stepFormRender,
stepsProps = props.stepsProps,
onFinish = props.onFinish,
formProps = props.formProps,
containerStyle = props.containerStyle,
formRef = props.formRef,
propsFormMapRef = props.formMapRef,
propsLayoutRender = props.layoutRender,
rest = _objectWithoutProperties(props, _excluded);
var formDataRef = useRef(new Map());
var formMapRef = useRef(new Map());
var formArrayRef = useRef([]);
var _useState = useState([]),
_useState2 = _slicedToArray(_useState, 2),
formArray = _useState2[0],
setFormArray = _useState2[1];
var _useState3 = useState(false),
_useState4 = _slicedToArray(_useState3, 2),
loading = _useState4[0],
setLoading = _useState4[1];
var intl = useIntl();
/**
* 受控的方式来操作表单
*/
var _useMergedState = useMergedState(0, {
value: props.current,
onChange: props.onCurrentChange
}),
_useMergedState2 = _slicedToArray(_useMergedState, 2),
step = _useMergedState2[0],
setStep = _useMergedState2[1];
var layoutRender = useMemo(function () {
return StepsLayoutStrategy[(stepsProps === null || stepsProps === void 0 ? void 0 : stepsProps.direction) || 'horizontal'];
}, [stepsProps === null || stepsProps === void 0 ? void 0 : stepsProps.direction]);
var lastStep = useMemo(function () {
return step === formArray.length - 1;
}, [formArray.length, step]);
/**
* 注册一个form进入,方便进行 props 的修改
*/
var regForm = useCallback(function (name, childrenFormProps) {
if (!formMapRef.current.has(name)) {
setFormArray(function (oldFormArray) {
return [].concat(_toConsumableArray(oldFormArray), [name]);
});
}
formMapRef.current.set(name, childrenFormProps);
}, []);
/**
* 解除挂载掉这个 form,同时步数 -1
*/
var unRegForm = useCallback(function (name) {
setFormArray(function (oldFormArray) {
return oldFormArray.filter(function (n) {
return n !== name;
});
});
formMapRef.current.delete(name);
formDataRef.current.delete(name);
}, []);
useImperativeHandle(propsFormMapRef, function () {
return formArrayRef.current;
}, [formArrayRef.current]);
useImperativeHandle(formRef, function () {
var _formArrayRef$current;
return (_formArrayRef$current = formArrayRef.current[step || 0]) === null || _formArrayRef$current === void 0 ? void 0 : _formArrayRef$current.current;
}, [step, formArrayRef.current]);
/**
* ProForm处理了一下 from 的数据,在其中做了一些操作 如果使用 Provider 自带的,自带的数据处理就无法生效了
*/
var onFormFinish = useCallback( /*#__PURE__*/function () {
var _ref3 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee(name, formData) {
var values, success;
return _regeneratorRuntime().wrap(function _callee$(_context) {
while (1) switch (_context.prev = _context.next) {
case 0:
formDataRef.current.set(name, formData);
// 如果不是最后一步
if (!(!lastStep || !onFinish)) {
_context.next = 3;
break;
}
return _context.abrupt("return");
case 3:
setLoading(true);
values = merge.apply(void 0, [{}].concat(_toConsumableArray(Array.from(formDataRef.current.values()))));
_context.prev = 5;
_context.next = 8;
return onFinish(values);
case 8:
success = _context.sent;
if (success) {
setStep(0);
formArrayRef.current.forEach(function (form) {
var _form$current;
return (_form$current = form.current) === null || _form$current === void 0 ? void 0 : _form$current.resetFields();
});
}
_context.next = 15;
break;
case 12:
_context.prev = 12;
_context.t0 = _context["catch"](5);
console.log(_context.t0);
case 15:
_context.prev = 15;
setLoading(false);
return _context.finish(15);
case 18:
case "end":
return _context.stop();
}
}, _callee, null, [[5, 12, 15, 18]]);
}));
return function (_x, _x2) {
return _ref3.apply(this, arguments);
};
}(), [lastStep, onFinish, setLoading, setStep]);
var stepsDom = useMemo(function () {
var isNewAntd = compareVersions(version, '4.24.0') > -1;
var itemsProps = isNewAntd ? {
items: formArray.map(function (item) {
var itemProps = formMapRef.current.get(item);
return _objectSpread({
key: item,
title: itemProps === null || itemProps === void 0 ? void 0 : itemProps.title
}, itemProps === null || itemProps === void 0 ? void 0 : itemProps.stepProps);
})
} : {};
return /*#__PURE__*/_jsx("div", {
className: "".concat(prefixCls, "-steps-container ").concat(hashId).trim(),
style: {
maxWidth: Math.min(formArray.length * 320, 1160)
},
children: /*#__PURE__*/_jsx(Steps, _objectSpread(_objectSpread(_objectSpread({}, stepsProps), itemsProps), {}, {
current: step,
onChange: undefined,
children: !isNewAntd && formArray.map(function (item) {
var itemProps = formMapRef.current.get(item);
return /*#__PURE__*/_jsx(Steps.Step, _objectSpread({
title: itemProps === null || itemProps === void 0 ? void 0 : itemProps.title
}, itemProps === null || itemProps === void 0 ? void 0 : itemProps.stepProps), item);
})
}))
});
}, [formArray, hashId, prefixCls, step, stepsProps]);
var onSubmit = useRefFunction(function () {
var _from$current;
var from = formArrayRef.current[step];
(_from$current = from.current) === null || _from$current === void 0 || _from$current.submit();
});
/** 上一页功能 */
var prePage = useRefFunction(function () {
if (step < 1) return;
setStep(step - 1);
});
var next = useMemo(function () {
return submitter !== false && /*#__PURE__*/_jsx(Button, _objectSpread(_objectSpread({
type: "primary",
loading: loading
}, submitter === null || submitter === void 0 ? void 0 : submitter.submitButtonProps), {}, {
onClick: function onClick() {
var _submitter$onSubmit;
submitter === null || submitter === void 0 || (_submitter$onSubmit = submitter.onSubmit) === null || _submitter$onSubmit === void 0 || _submitter$onSubmit.call(submitter);
onSubmit();
},
children: intl.getMessage('stepsForm.next', '下一步')
}), "next");
}, [intl, loading, onSubmit, submitter]);
var pre = useMemo(function () {
return submitter !== false && /*#__PURE__*/_jsx(Button, _objectSpread(_objectSpread({}, submitter === null || submitter === void 0 ? void 0 : submitter.resetButtonProps), {}, {
onClick: function onClick() {
var _submitter$onReset;
prePage();
submitter === null || submitter === void 0 || (_submitter$onReset = submitter.onReset) === null || _submitter$onReset === void 0 || _submitter$onReset.call(submitter);
},
children: intl.getMessage('stepsForm.prev', '上一步')
}), "pre");
}, [intl, prePage, submitter]);
var submit = useMemo(function () {
return submitter !== false && /*#__PURE__*/_jsx(Button, _objectSpread(_objectSpread({
type: "primary",
loading: loading
}, submitter === null || submitter === void 0 ? void 0 : submitter.submitButtonProps), {}, {
onClick: function onClick() {
var _submitter$onSubmit2;
submitter === null || submitter === void 0 || (_submitter$onSubmit2 = submitter.onSubmit) === null || _submitter$onSubmit2 === void 0 || _submitter$onSubmit2.call(submitter);
onSubmit();
},
children: intl.getMessage('stepsForm.submit', '提交')
}), "submit");
}, [intl, loading, onSubmit, submitter]);
var nextPage = useRefFunction(function () {
if (step > formArray.length - 2) return;
setStep(step + 1);
});
var submitterDom = useMemo(function () {
var buttons = [];
var index = step || 0;
if (index < 1) {
// 如果有且只有一个 StepForm 第一步就应该是提交按钮
if (formArray.length === 1) {
buttons.push(submit);
} else {
buttons.push(next);
}
} else if (index + 1 === formArray.length) {
buttons.push(pre, submit);
} else {
buttons.push(pre, next);
}
buttons = buttons.filter(React.isValidElement);
if (submitter && submitter.render) {
var _formArrayRef$current2;
var submitterProps = {
form: (_formArrayRef$current2 = formArrayRef.current[step]) === null || _formArrayRef$current2 === void 0 ? void 0 : _formArrayRef$current2.current,
onSubmit: onSubmit,
step: step,
onPre: prePage
};
return submitter.render(submitterProps, buttons);
}
if (submitter && (submitter === null || submitter === void 0 ? void 0 : submitter.render) === false) {
return null;
}
return buttons;
}, [formArray.length, next, onSubmit, pre, prePage, step, submit, submitter]);
var formDom = useMemo(function () {
return toArray(props.children).map(function (item, index) {
var itemProps = item.props;
var name = itemProps.name || "".concat(index);
/** 是否是当前的表单 */
var isShow = step === index;
var config = isShow ? {
contentRender: stepFormRender,
submitter: false
} : {};
return /*#__PURE__*/_jsx("div", {
className: classNames("".concat(prefixCls, "-step"), hashId, _defineProperty({}, "".concat(prefixCls, "-step-active"), isShow)),
children: /*#__PURE__*/_jsx(StepFormProvide.Provider, {
value: _objectSpread(_objectSpread(_objectSpread(_objectSpread({}, config), formProps), itemProps), {}, {
name: name,
step: index
}),
children: item
})
}, name);
});
}, [formProps, hashId, prefixCls, props.children, step, stepFormRender]);
var finalStepsDom = useMemo(function () {
if (stepsRender) {
return stepsRender(formArray.map(function (item) {
var _formMapRef$current$g;
return {
key: item,
title: (_formMapRef$current$g = formMapRef.current.get(item)) === null || _formMapRef$current$g === void 0 ? void 0 : _formMapRef$current$g.title
};
}), stepsDom);
}
return stepsDom;
}, [formArray, stepsDom, stepsRender]);
var formContainer = useMemo(function () {
return /*#__PURE__*/_jsxs("div", {
className: "".concat(prefixCls, "-container ").concat(hashId).trim(),
style: containerStyle,
children: [formDom, stepsFormRender ? null : /*#__PURE__*/_jsx(Space, {
children: submitterDom
})]
});
}, [containerStyle, formDom, hashId, prefixCls, stepsFormRender, submitterDom]);
var stepsFormDom = useMemo(function () {
var doms = {
stepsDom: finalStepsDom,
formDom: formContainer
};
if (stepsFormRender) {
if (propsLayoutRender) {
return stepsFormRender(propsLayoutRender(doms), submitterDom);
} else {
return stepsFormRender(layoutRender(doms), submitterDom);
}
}
if (propsLayoutRender) {
return propsLayoutRender(doms);
}
return layoutRender(doms);
}, [finalStepsDom, formContainer, layoutRender, stepsFormRender, submitterDom, propsLayoutRender]);
return wrapSSR( /*#__PURE__*/_jsx("div", {
className: classNames(prefixCls, hashId),
children: /*#__PURE__*/_jsx(Form.Provider, _objectSpread(_objectSpread({}, rest), {}, {
children: /*#__PURE__*/_jsx(StepsFormProvide.Provider, {
value: {
loading: loading,
setLoading: setLoading,
regForm: regForm,
keyArray: formArray,
next: nextPage,
formArrayRef: formArrayRef,
formMapRef: formMapRef,
lastStep: lastStep,
unRegForm: unRegForm,
onFormFinish: onFormFinish
},
children: stepsFormDom
})
}))
}));
}
function StepsFormWarp(props) {
return /*#__PURE__*/_jsx(ProConfigProvider, {
needDeps: true,
children: /*#__PURE__*/_jsx(StepsForm, _objectSpread({}, props))
});
}
StepsFormWarp.StepForm = StepForm;
StepsFormWarp.useForm = Form.useForm;
export { StepsFormWarp as StepsForm };