@ant-design/pro-form
Version:
432 lines (425 loc) • 18 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.StepFormProvide = void 0;
exports.StepsForm = StepsFormWarp;
exports.StepsFormProvide = void 0;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
var _regeneratorRuntime2 = _interopRequireDefault(require("@babel/runtime/helpers/regeneratorRuntime"));
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
var _proProvider = require("@ant-design/pro-provider");
var _proUtils = require("@ant-design/pro-utils");
var _antd = require("antd");
var _classnames = _interopRequireDefault(require("classnames"));
var _toArray = _interopRequireDefault(require("rc-util/lib/Children/toArray"));
var _useMergedState3 = _interopRequireDefault(require("rc-util/lib/hooks/useMergedState"));
var _react = _interopRequireWildcard(require("react"));
var _StepForm = _interopRequireDefault(require("./StepForm"));
var _style = require("./style");
var _jsxRuntime = require("react/jsx-runtime");
var _excluded = ["current", "onCurrentChange", "submitter", "stepsFormRender", "stepsRender", "stepFormRender", "stepsProps", "onFinish", "formProps", "containerStyle", "formRef", "formMapRef", "layoutRender"];
var StepsFormProvide = exports.StepsFormProvide = /*#__PURE__*/_react.default.createContext(undefined);
var StepsLayoutStrategy = {
horizontal: function horizontal(_ref) {
var stepsDom = _ref.stepsDom,
formDom = _ref.formDom;
return /*#__PURE__*/(0, _jsxRuntime.jsxs)(_jsxRuntime.Fragment, {
children: [/*#__PURE__*/(0, _jsxRuntime.jsx)(_antd.Row, {
gutter: {
xs: 8,
sm: 16,
md: 24
},
children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_antd.Col, {
span: 24,
children: stepsDom
})
}), /*#__PURE__*/(0, _jsxRuntime.jsx)(_antd.Row, {
gutter: {
xs: 8,
sm: 16,
md: 24
},
children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_antd.Col, {
span: 24,
children: formDom
})
})]
});
},
vertical: function vertical(_ref2) {
var stepsDom = _ref2.stepsDom,
formDom = _ref2.formDom;
return /*#__PURE__*/(0, _jsxRuntime.jsxs)(_antd.Row, {
align: "stretch",
wrap: true,
gutter: {
xs: 8,
sm: 16,
md: 24
},
children: [/*#__PURE__*/(0, _jsxRuntime.jsx)(_antd.Col, {
xxl: 4,
xl: 6,
lg: 7,
md: 8,
sm: 10,
xs: 12,
children: /*#__PURE__*/_react.default.cloneElement(stepsDom, {
style: {
height: '100%'
}
})
}), /*#__PURE__*/(0, _jsxRuntime.jsx)(_antd.Col, {
children: /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
style: {
display: 'flex',
alignItems: 'center',
width: '100%',
height: '100%'
},
children: formDom
})
})]
});
}
};
/**
* 给 StepForm 传递信息
*/
var StepFormProvide = exports.StepFormProvide = /*#__PURE__*/_react.default.createContext(null);
function StepsForm(props) {
var _useContext = (0, _react.useContext)(_antd.ConfigProvider.ConfigContext),
getPrefixCls = _useContext.getPrefixCls;
var prefixCls = getPrefixCls('pro-steps-form');
var _useStyle = (0, _style.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 = (0, _objectWithoutProperties2.default)(props, _excluded);
var formDataRef = (0, _react.useRef)(new Map());
var formMapRef = (0, _react.useRef)(new Map());
var formArrayRef = (0, _react.useRef)([]);
var _useState = (0, _react.useState)([]),
_useState2 = (0, _slicedToArray2.default)(_useState, 2),
formArray = _useState2[0],
setFormArray = _useState2[1];
var _useState3 = (0, _react.useState)(false),
_useState4 = (0, _slicedToArray2.default)(_useState3, 2),
loading = _useState4[0],
setLoading = _useState4[1];
var intl = (0, _proProvider.useIntl)();
/**
* 受控的方式来操作表单
*/
var _useMergedState = (0, _useMergedState3.default)(0, {
value: props.current,
onChange: props.onCurrentChange
}),
_useMergedState2 = (0, _slicedToArray2.default)(_useMergedState, 2),
step = _useMergedState2[0],
setStep = _useMergedState2[1];
var layoutRender = (0, _react.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 = (0, _react.useMemo)(function () {
return step === formArray.length - 1;
}, [formArray.length, step]);
/**
* 注册一个form进入,方便进行 props 的修改
*/
var regForm = (0, _react.useCallback)(function (name, childrenFormProps) {
if (!formMapRef.current.has(name)) {
setFormArray(function (oldFormArray) {
return [].concat((0, _toConsumableArray2.default)(oldFormArray), [name]);
});
}
formMapRef.current.set(name, childrenFormProps);
}, []);
/**
* 解除挂载掉这个 form,同时步数 -1
*/
var unRegForm = (0, _react.useCallback)(function (name) {
setFormArray(function (oldFormArray) {
return oldFormArray.filter(function (n) {
return n !== name;
});
});
formMapRef.current.delete(name);
formDataRef.current.delete(name);
}, []);
(0, _react.useImperativeHandle)(propsFormMapRef, function () {
return formArrayRef.current;
}, [formArrayRef.current]);
(0, _react.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 = (0, _react.useCallback)( /*#__PURE__*/function () {
var _ref3 = (0, _asyncToGenerator2.default)( /*#__PURE__*/(0, _regeneratorRuntime2.default)().mark(function _callee(name, formData) {
var values, success;
return (0, _regeneratorRuntime2.default)().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 = _proUtils.merge.apply(void 0, [{}].concat((0, _toConsumableArray2.default)(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 = (0, _react.useMemo)(function () {
var isNewAntd = (0, _proUtils.compareVersions)(_antd.version, '4.24.0') > -1;
var itemsProps = isNewAntd ? {
items: formArray.map(function (item) {
var itemProps = formMapRef.current.get(item);
return (0, _objectSpread2.default)({
key: item,
title: itemProps === null || itemProps === void 0 ? void 0 : itemProps.title
}, itemProps === null || itemProps === void 0 ? void 0 : itemProps.stepProps);
})
} : {};
return /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
className: "".concat(prefixCls, "-steps-container ").concat(hashId).trim(),
style: {
maxWidth: Math.min(formArray.length * 320, 1160)
},
children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_antd.Steps, (0, _objectSpread2.default)((0, _objectSpread2.default)((0, _objectSpread2.default)({}, stepsProps), itemsProps), {}, {
current: step,
onChange: undefined,
children: !isNewAntd && formArray.map(function (item) {
var itemProps = formMapRef.current.get(item);
return /*#__PURE__*/(0, _jsxRuntime.jsx)(_antd.Steps.Step, (0, _objectSpread2.default)({
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 = (0, _proUtils.useRefFunction)(function () {
var _from$current;
var from = formArrayRef.current[step];
(_from$current = from.current) === null || _from$current === void 0 || _from$current.submit();
});
/** 上一页功能 */
var prePage = (0, _proUtils.useRefFunction)(function () {
if (step < 1) return;
setStep(step - 1);
});
var next = (0, _react.useMemo)(function () {
return submitter !== false && /*#__PURE__*/(0, _jsxRuntime.jsx)(_antd.Button, (0, _objectSpread2.default)((0, _objectSpread2.default)({
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 = (0, _react.useMemo)(function () {
return submitter !== false && /*#__PURE__*/(0, _jsxRuntime.jsx)(_antd.Button, (0, _objectSpread2.default)((0, _objectSpread2.default)({}, 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 = (0, _react.useMemo)(function () {
return submitter !== false && /*#__PURE__*/(0, _jsxRuntime.jsx)(_antd.Button, (0, _objectSpread2.default)((0, _objectSpread2.default)({
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 = (0, _proUtils.useRefFunction)(function () {
if (step > formArray.length - 2) return;
setStep(step + 1);
});
var submitterDom = (0, _react.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.default.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 = (0, _react.useMemo)(function () {
return (0, _toArray.default)(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__*/(0, _jsxRuntime.jsx)("div", {
className: (0, _classnames.default)("".concat(prefixCls, "-step"), hashId, (0, _defineProperty2.default)({}, "".concat(prefixCls, "-step-active"), isShow)),
children: /*#__PURE__*/(0, _jsxRuntime.jsx)(StepFormProvide.Provider, {
value: (0, _objectSpread2.default)((0, _objectSpread2.default)((0, _objectSpread2.default)((0, _objectSpread2.default)({}, config), formProps), itemProps), {}, {
name: name,
step: index
}),
children: item
})
}, name);
});
}, [formProps, hashId, prefixCls, props.children, step, stepFormRender]);
var finalStepsDom = (0, _react.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 = (0, _react.useMemo)(function () {
return /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
className: "".concat(prefixCls, "-container ").concat(hashId).trim(),
style: containerStyle,
children: [formDom, stepsFormRender ? null : /*#__PURE__*/(0, _jsxRuntime.jsx)(_antd.Space, {
children: submitterDom
})]
});
}, [containerStyle, formDom, hashId, prefixCls, stepsFormRender, submitterDom]);
var stepsFormDom = (0, _react.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__*/(0, _jsxRuntime.jsx)("div", {
className: (0, _classnames.default)(prefixCls, hashId),
children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_antd.Form.Provider, (0, _objectSpread2.default)((0, _objectSpread2.default)({}, rest), {}, {
children: /*#__PURE__*/(0, _jsxRuntime.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__*/(0, _jsxRuntime.jsx)(_proProvider.ProConfigProvider, {
needDeps: true,
children: /*#__PURE__*/(0, _jsxRuntime.jsx)(StepsForm, (0, _objectSpread2.default)({}, props))
});
}
StepsFormWarp.StepForm = _StepForm.default;
StepsFormWarp.useForm = _antd.Form.useForm;