From ee78b36f1c0018a1b676aa2538acfbbcec895d4d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=F0=9D=91=BE=F0=9D=92=96=F0=9D=92=99=F0=9D=92=89?= Date: Fri, 20 Dec 2024 16:09:01 +0800 Subject: [PATCH] fix: Improve form error message display wait: https://github.com/ant-design/ant-design/pull/52068 fix: https://github.com/ant-design/pro-components/issues/8927 fix: https://github.com/ant-design/pro-components/issues/8895 close: https://github.com/ant-design/ant-design/issues/51829 --- .../form/src/components/FormItem/index.tsx | 174 ++++++++---------- 1 file changed, 78 insertions(+), 96 deletions(-) diff --git a/packages/form/src/components/FormItem/index.tsx b/packages/form/src/components/FormItem/index.tsx index 0a93deee682a..19c97b20d322 100644 --- a/packages/form/src/components/FormItem/index.tsx +++ b/packages/form/src/components/FormItem/index.tsx @@ -182,18 +182,64 @@ const WarpFormItem: React.FC< help, ...props }) => { - const formDom = useMemo(() => { - let getValuePropsFunc: any = (value: any) => { - const newValue = convertValue?.(value, props.name!) ?? value; - if (props.getValueProps) return props.getValueProps(newValue); - return { - [valuePropName || 'value']: newValue, + const formDom = useMemo(() => { + let getValuePropsFunc: any = (value: any) => { + const newValue = convertValue?.(value, props.name!) ?? value; + if (props.getValueProps) return props.getValueProps(newValue); + return { + [valuePropName || 'value']: newValue, + }; }; - }; - if (!convertValue && !props.getValueProps) { - getValuePropsFunc = undefined; - } - if (!addonAfter && !addonBefore) { + if (!convertValue && !props.getValueProps) { + getValuePropsFunc = undefined; + } + + const prepareItemRender = ( + inputProps: FormItemProps & { + errors: React.ReactNode[]; + warnings: React.ReactNode[]; + }, + doms: { + input: JSX.Element; + errorList: JSX.Element; + extra: JSX.Element; + }) => { + + const nextInput = (addonAfter || addonBefore) + ? ( +
+ {addonBefore ? ( +
{addonBefore}
+ ) : null} + {doms.input} + {addonAfter ? ( +
{addonAfter}
+ ) : null} +
+ ) + : doms.input + + const nextErrorList = typeof help === 'function' + ? help({ + errors: inputProps.errors, + warnings: inputProps.warnings, + }) + : doms.errorList + + return { + ...doms, + input: nextInput, + errorList: nextErrorList + } + } + return ( ( - <> - {doms.input} - {typeof help === 'function' - ? help({ - errors: inputProps.errors, - warnings: inputProps.warnings, - }) - : doms.errorList} - {doms.extra} - - ), + prepare: prepareItemRender, + // Legacy + render(...args: Parameters) { + const { input, errorList, extra } = prepareItemRender(...args); + return ( + <> + {input} + {errorList} + {extra} + + ) + } }} > {children} ); - } + // eslint-disable-next-line react-hooks/exhaustive-deps + }, [addonAfter, addonBefore, children, convertValue?.toString(), props]); return ( - ( - <> -
- {addonBefore ? ( -
{addonBefore}
- ) : null} - {doms.input} - {addonAfter ? ( -
{addonAfter}
- ) : null} -
- {typeof help === 'function' - ? help({ - errors: inputProps.errors, - warnings: inputProps.warnings, - }) - : doms.errorList} - {doms.extra} - - ), + - {children} -
+ {formDom} + ); - // eslint-disable-next-line react-hooks/exhaustive-deps - }, [addonAfter, addonBefore, children, convertValue?.toString(), props]); - - return ( - - {formDom} - - ); -}; + }; export type ProFormItemProps = FormItemProps & { ignoreFormItem?: boolean;