@1money/react-ui 1.16.0 → 1.17.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (268) hide show
  1. package/AGENTS.md +393 -0
  2. package/es/components/CheckboxGroup/CheckboxGroup.d.ts +3 -3
  3. package/es/components/CheckboxGroup/CheckboxGroup.js +94 -91
  4. package/es/components/CheckboxGroup/interface.d.ts +21 -15
  5. package/es/components/CheckboxGroup/style/CheckboxGroup.scss +0 -7
  6. package/es/components/Form/Form.d.ts +29 -0
  7. package/es/components/Form/Form.js +188 -0
  8. package/es/components/Form/FormItem.d.ts +4 -0
  9. package/es/components/Form/FormItem.js +165 -0
  10. package/es/components/Form/FormItemContent.d.ts +18 -0
  11. package/es/components/Form/FormItemContent.js +146 -0
  12. package/es/components/Form/constants.d.ts +46 -0
  13. package/es/components/Form/constants.js +65 -0
  14. package/es/components/Form/helper.d.ts +120 -0
  15. package/es/components/Form/helper.js +284 -0
  16. package/es/components/Form/index.d.ts +20 -0
  17. package/es/components/Form/index.js +21 -0
  18. package/es/components/Form/interface.d.ts +238 -0
  19. package/es/components/Form/interface.js +2 -0
  20. package/es/components/Form/style/Form.css +1 -0
  21. package/es/components/Form/style/Form.scss +167 -0
  22. package/es/components/Form/style/css.js +2 -0
  23. package/es/components/Form/style/index.d.ts +1 -0
  24. package/es/components/Form/style/index.js +2 -0
  25. package/es/components/Form/useFormItemContext.d.ts +32 -0
  26. package/es/components/Form/useFormItemContext.js +55 -0
  27. package/es/components/Form/useFormItemWatch.d.ts +51 -0
  28. package/es/components/Form/useFormItemWatch.js +69 -0
  29. package/es/components/Form/useValidationTrigger.d.ts +40 -0
  30. package/es/components/Form/useValidationTrigger.js +74 -0
  31. package/es/components/Input/Input.js +72 -74
  32. package/es/components/Input/interface.d.ts +9 -9
  33. package/es/components/InputAmount/InputAmount.js +228 -276
  34. package/es/components/InputAmount/helper.d.ts +46 -0
  35. package/es/components/InputAmount/helper.js +115 -0
  36. package/es/components/ProForm/ProForm.d.ts +33 -0
  37. package/es/components/ProForm/ProForm.js +208 -0
  38. package/es/components/ProForm/ProFormDependency.d.ts +12 -0
  39. package/es/components/ProForm/ProFormDependency.js +61 -0
  40. package/es/components/ProForm/ProFormList.d.ts +19 -0
  41. package/es/components/ProForm/ProFormList.js +348 -0
  42. package/es/components/ProForm/Submitter.d.ts +21 -0
  43. package/es/components/ProForm/Submitter.js +76 -0
  44. package/es/components/ProForm/constants.d.ts +34 -0
  45. package/es/components/ProForm/constants.js +40 -0
  46. package/es/components/ProForm/fields/ProFormCheckbox.d.ts +6 -0
  47. package/es/components/ProForm/fields/ProFormCheckbox.js +11 -0
  48. package/es/components/ProForm/fields/ProFormCheckboxGroup.d.ts +6 -0
  49. package/es/components/ProForm/fields/ProFormCheckboxGroup.js +46 -0
  50. package/es/components/ProForm/fields/ProFormDigit.d.ts +6 -0
  51. package/es/components/ProForm/fields/ProFormDigit.js +15 -0
  52. package/es/components/ProForm/fields/ProFormMoney.d.ts +6 -0
  53. package/es/components/ProForm/fields/ProFormMoney.js +10 -0
  54. package/es/components/ProForm/fields/ProFormMultiSelect.d.ts +6 -0
  55. package/es/components/ProForm/fields/ProFormMultiSelect.js +27 -0
  56. package/es/components/ProForm/fields/ProFormPassword.d.ts +6 -0
  57. package/es/components/ProForm/fields/ProFormPassword.js +16 -0
  58. package/es/components/ProForm/fields/ProFormRadio.d.ts +6 -0
  59. package/es/components/ProForm/fields/ProFormRadio.js +13 -0
  60. package/es/components/ProForm/fields/ProFormSelect.d.ts +6 -0
  61. package/es/components/ProForm/fields/ProFormSelect.js +13 -0
  62. package/es/components/ProForm/fields/ProFormSwitch.d.ts +6 -0
  63. package/es/components/ProForm/fields/ProFormSwitch.js +11 -0
  64. package/es/components/ProForm/fields/ProFormText.d.ts +6 -0
  65. package/es/components/ProForm/fields/ProFormText.js +15 -0
  66. package/es/components/ProForm/fields/ProFormTextArea.d.ts +6 -0
  67. package/es/components/ProForm/fields/ProFormTextArea.js +16 -0
  68. package/es/components/ProForm/fields/createProFormField.d.ts +43 -0
  69. package/es/components/ProForm/fields/createProFormField.js +200 -0
  70. package/es/components/ProForm/fields/index.d.ts +12 -0
  71. package/es/components/ProForm/fields/index.js +13 -0
  72. package/es/components/ProForm/index.d.ts +7 -0
  73. package/es/components/ProForm/index.js +7 -0
  74. package/es/components/ProForm/interface.d.ts +306 -0
  75. package/es/components/ProForm/interface.js +2 -0
  76. package/es/components/ProForm/layouts/DrawerForm.d.ts +16 -0
  77. package/es/components/ProForm/layouts/DrawerForm.js +79 -0
  78. package/es/components/ProForm/layouts/ModalForm.d.ts +16 -0
  79. package/es/components/ProForm/layouts/ModalForm.js +89 -0
  80. package/es/components/ProForm/layouts/QueryFilter.d.ts +21 -0
  81. package/es/components/ProForm/layouts/QueryFilter.js +132 -0
  82. package/es/components/ProForm/layouts/StepsForm.d.ts +13 -0
  83. package/es/components/ProForm/layouts/StepsForm.js +295 -0
  84. package/es/components/ProForm/layouts/index.d.ts +4 -0
  85. package/es/components/ProForm/layouts/index.js +5 -0
  86. package/es/components/ProForm/layouts/useOverlayForm.d.ts +53 -0
  87. package/es/components/ProForm/layouts/useOverlayForm.js +143 -0
  88. package/es/components/ProForm/style/ProForm.module.css +1 -0
  89. package/es/components/ProForm/style/ProForm.module.scss +59 -0
  90. package/es/components/ProForm/style/css.js +3 -0
  91. package/es/components/ProForm/style/index.d.ts +1 -0
  92. package/es/components/ProForm/style/index.js +3 -0
  93. package/es/components/ProForm/utils.d.ts +72 -0
  94. package/es/components/ProForm/utils.js +206 -0
  95. package/es/components/RadioGroup/RadioGroup.js +46 -23
  96. package/es/components/RadioGroup/interface.d.ts +3 -1
  97. package/es/components/Select/Select.d.ts +1 -1
  98. package/es/components/Select/Select.js +113 -106
  99. package/es/components/Select/constants.d.ts +18 -0
  100. package/es/components/Select/constants.js +19 -0
  101. package/es/components/Sidebar/Sidebar.js +21 -23
  102. package/es/components/Sidebar/SidebarLogo.d.ts +7 -0
  103. package/es/components/Sidebar/SidebarLogo.js +33 -0
  104. package/es/components/Sidebar/SimplySidebar.d.ts +2 -2
  105. package/es/components/Sidebar/SimplySidebar.js +18 -22
  106. package/es/components/Sidebar/Stepper.js +14 -14
  107. package/es/components/Sidebar/constants.d.ts +16 -0
  108. package/es/components/Sidebar/constants.js +17 -0
  109. package/es/components/Sidebar/style/Stepper.css +1 -1
  110. package/es/components/Sidebar/style/Stepper.scss +11 -1
  111. package/es/components/Switch/Switch.js +28 -25
  112. package/es/components/Switch/interface.d.ts +9 -4
  113. package/es/components/useControlledState/index.d.ts +14 -0
  114. package/es/components/useControlledState/index.js +32 -0
  115. package/es/components/useEventCallback/index.d.ts +11 -0
  116. package/es/components/useEventCallback/index.js +17 -0
  117. package/es/components/useLayoutEffect/index.d.ts +11 -0
  118. package/es/components/useLayoutEffect/index.js +17 -0
  119. package/es/components/useLayoutState/index.d.ts +13 -0
  120. package/es/components/useLayoutState/index.js +71 -0
  121. package/es/components/useMemoizedFn/index.d.ts +12 -0
  122. package/es/components/useMemoizedFn/index.js +27 -0
  123. package/es/components/usePrevious/index.d.ts +11 -0
  124. package/es/components/usePrevious/index.js +19 -0
  125. package/es/components/useSafeState/index.d.ts +12 -0
  126. package/es/components/useSafeState/index.js +24 -0
  127. package/es/components/useSyncState/index.d.ts +14 -0
  128. package/es/components/useSyncState/index.js +37 -0
  129. package/es/components/useUpdateEffect/index.d.ts +9 -0
  130. package/es/components/useUpdateEffect/index.js +19 -0
  131. package/es/index.css +1 -1
  132. package/es/index.d.ts +21 -2
  133. package/es/index.js +19 -1
  134. package/jest.setup.d.ts +1 -0
  135. package/jest.setup.ts +1 -0
  136. package/lib/components/CheckboxGroup/CheckboxGroup.d.ts +3 -3
  137. package/lib/components/CheckboxGroup/CheckboxGroup.js +92 -89
  138. package/lib/components/CheckboxGroup/interface.d.ts +21 -15
  139. package/lib/components/CheckboxGroup/style/CheckboxGroup.scss +0 -7
  140. package/lib/components/Form/Form.d.ts +29 -0
  141. package/lib/components/Form/Form.js +199 -0
  142. package/lib/components/Form/FormItem.d.ts +4 -0
  143. package/lib/components/Form/FormItem.js +176 -0
  144. package/lib/components/Form/FormItemContent.d.ts +18 -0
  145. package/lib/components/Form/FormItemContent.js +156 -0
  146. package/lib/components/Form/constants.d.ts +46 -0
  147. package/lib/components/Form/constants.js +71 -0
  148. package/lib/components/Form/helper.d.ts +120 -0
  149. package/lib/components/Form/helper.js +290 -0
  150. package/lib/components/Form/index.d.ts +20 -0
  151. package/lib/components/Form/index.js +45 -0
  152. package/lib/components/Form/interface.d.ts +238 -0
  153. package/lib/components/Form/interface.js +6 -0
  154. package/lib/components/Form/style/Form.css +1 -0
  155. package/lib/components/Form/style/Form.scss +167 -0
  156. package/lib/components/Form/style/css.js +4 -0
  157. package/lib/components/Form/style/index.d.ts +1 -0
  158. package/lib/components/Form/style/index.js +4 -0
  159. package/lib/components/Form/useFormItemContext.d.ts +32 -0
  160. package/lib/components/Form/useFormItemContext.js +62 -0
  161. package/lib/components/Form/useFormItemWatch.d.ts +51 -0
  162. package/lib/components/Form/useFormItemWatch.js +76 -0
  163. package/lib/components/Form/useValidationTrigger.d.ts +40 -0
  164. package/lib/components/Form/useValidationTrigger.js +81 -0
  165. package/lib/components/Input/Input.js +71 -73
  166. package/lib/components/Input/interface.d.ts +9 -9
  167. package/lib/components/InputAmount/InputAmount.js +230 -278
  168. package/lib/components/InputAmount/helper.d.ts +46 -0
  169. package/lib/components/InputAmount/helper.js +122 -0
  170. package/lib/components/ProForm/ProForm.d.ts +33 -0
  171. package/lib/components/ProForm/ProForm.js +216 -0
  172. package/lib/components/ProForm/ProFormDependency.d.ts +12 -0
  173. package/lib/components/ProForm/ProFormDependency.js +67 -0
  174. package/lib/components/ProForm/ProFormList.d.ts +19 -0
  175. package/lib/components/ProForm/ProFormList.js +355 -0
  176. package/lib/components/ProForm/Submitter.d.ts +21 -0
  177. package/lib/components/ProForm/Submitter.js +83 -0
  178. package/lib/components/ProForm/constants.d.ts +34 -0
  179. package/lib/components/ProForm/constants.js +46 -0
  180. package/lib/components/ProForm/fields/ProFormCheckbox.d.ts +6 -0
  181. package/lib/components/ProForm/fields/ProFormCheckbox.js +18 -0
  182. package/lib/components/ProForm/fields/ProFormCheckboxGroup.d.ts +6 -0
  183. package/lib/components/ProForm/fields/ProFormCheckboxGroup.js +53 -0
  184. package/lib/components/ProForm/fields/ProFormDigit.d.ts +6 -0
  185. package/lib/components/ProForm/fields/ProFormDigit.js +22 -0
  186. package/lib/components/ProForm/fields/ProFormMoney.d.ts +6 -0
  187. package/lib/components/ProForm/fields/ProFormMoney.js +17 -0
  188. package/lib/components/ProForm/fields/ProFormMultiSelect.d.ts +6 -0
  189. package/lib/components/ProForm/fields/ProFormMultiSelect.js +34 -0
  190. package/lib/components/ProForm/fields/ProFormPassword.d.ts +6 -0
  191. package/lib/components/ProForm/fields/ProFormPassword.js +23 -0
  192. package/lib/components/ProForm/fields/ProFormRadio.d.ts +6 -0
  193. package/lib/components/ProForm/fields/ProFormRadio.js +20 -0
  194. package/lib/components/ProForm/fields/ProFormSelect.d.ts +6 -0
  195. package/lib/components/ProForm/fields/ProFormSelect.js +20 -0
  196. package/lib/components/ProForm/fields/ProFormSwitch.d.ts +6 -0
  197. package/lib/components/ProForm/fields/ProFormSwitch.js +18 -0
  198. package/lib/components/ProForm/fields/ProFormText.d.ts +6 -0
  199. package/lib/components/ProForm/fields/ProFormText.js +22 -0
  200. package/lib/components/ProForm/fields/ProFormTextArea.d.ts +6 -0
  201. package/lib/components/ProForm/fields/ProFormTextArea.js +23 -0
  202. package/lib/components/ProForm/fields/createProFormField.d.ts +43 -0
  203. package/lib/components/ProForm/fields/createProFormField.js +208 -0
  204. package/lib/components/ProForm/fields/index.d.ts +12 -0
  205. package/lib/components/ProForm/fields/index.js +90 -0
  206. package/lib/components/ProForm/index.d.ts +7 -0
  207. package/lib/components/ProForm/index.js +73 -0
  208. package/lib/components/ProForm/interface.d.ts +306 -0
  209. package/lib/components/ProForm/interface.js +6 -0
  210. package/lib/components/ProForm/layouts/DrawerForm.d.ts +16 -0
  211. package/lib/components/ProForm/layouts/DrawerForm.js +86 -0
  212. package/lib/components/ProForm/layouts/ModalForm.d.ts +16 -0
  213. package/lib/components/ProForm/layouts/ModalForm.js +96 -0
  214. package/lib/components/ProForm/layouts/QueryFilter.d.ts +21 -0
  215. package/lib/components/ProForm/layouts/QueryFilter.js +139 -0
  216. package/lib/components/ProForm/layouts/StepsForm.d.ts +13 -0
  217. package/lib/components/ProForm/layouts/StepsForm.js +302 -0
  218. package/lib/components/ProForm/layouts/index.d.ts +4 -0
  219. package/lib/components/ProForm/layouts/index.js +40 -0
  220. package/lib/components/ProForm/layouts/useOverlayForm.d.ts +53 -0
  221. package/lib/components/ProForm/layouts/useOverlayForm.js +150 -0
  222. package/lib/components/ProForm/style/ProForm.module.css +1 -0
  223. package/lib/components/ProForm/style/ProForm.module.scss +59 -0
  224. package/lib/components/ProForm/style/css.js +4 -0
  225. package/lib/components/ProForm/style/index.d.ts +1 -0
  226. package/lib/components/ProForm/style/index.js +4 -0
  227. package/lib/components/ProForm/utils.d.ts +72 -0
  228. package/lib/components/ProForm/utils.js +213 -0
  229. package/lib/components/RadioGroup/RadioGroup.js +45 -22
  230. package/lib/components/RadioGroup/interface.d.ts +3 -1
  231. package/lib/components/Select/Select.d.ts +1 -1
  232. package/lib/components/Select/Select.js +114 -107
  233. package/lib/components/Select/constants.d.ts +18 -0
  234. package/lib/components/Select/constants.js +25 -0
  235. package/lib/components/Sidebar/Sidebar.js +21 -23
  236. package/lib/components/Sidebar/SidebarLogo.d.ts +7 -0
  237. package/lib/components/Sidebar/SidebarLogo.js +39 -0
  238. package/lib/components/Sidebar/SimplySidebar.d.ts +2 -2
  239. package/lib/components/Sidebar/SimplySidebar.js +17 -21
  240. package/lib/components/Sidebar/Stepper.js +14 -14
  241. package/lib/components/Sidebar/constants.d.ts +16 -0
  242. package/lib/components/Sidebar/constants.js +23 -0
  243. package/lib/components/Sidebar/style/Stepper.css +1 -1
  244. package/lib/components/Sidebar/style/Stepper.scss +11 -1
  245. package/lib/components/Switch/Switch.js +27 -24
  246. package/lib/components/Switch/interface.d.ts +9 -4
  247. package/lib/components/useControlledState/index.d.ts +14 -0
  248. package/lib/components/useControlledState/index.js +39 -0
  249. package/lib/components/useEventCallback/index.d.ts +11 -0
  250. package/lib/components/useEventCallback/index.js +24 -0
  251. package/lib/components/useLayoutEffect/index.d.ts +11 -0
  252. package/lib/components/useLayoutEffect/index.js +23 -0
  253. package/lib/components/useLayoutState/index.d.ts +13 -0
  254. package/lib/components/useLayoutState/index.js +79 -0
  255. package/lib/components/useMemoizedFn/index.d.ts +12 -0
  256. package/lib/components/useMemoizedFn/index.js +33 -0
  257. package/lib/components/usePrevious/index.d.ts +11 -0
  258. package/lib/components/usePrevious/index.js +25 -0
  259. package/lib/components/useSafeState/index.d.ts +12 -0
  260. package/lib/components/useSafeState/index.js +31 -0
  261. package/lib/components/useSyncState/index.d.ts +14 -0
  262. package/lib/components/useSyncState/index.js +44 -0
  263. package/lib/components/useUpdateEffect/index.d.ts +9 -0
  264. package/lib/components/useUpdateEffect/index.js +25 -0
  265. package/lib/index.css +1 -1
  266. package/lib/index.d.ts +21 -2
  267. package/lib/index.js +213 -1
  268. package/package.json +16 -1
@@ -10,26 +10,32 @@ interface CheckboxGroupBaseProps {
10
10
  labelCls?: string;
11
11
  size?: 'sm' | 'md' | 'lg';
12
12
  }
13
+ interface CheckboxGroupNormalItem {
14
+ key: string;
15
+ label?: ReactNode;
16
+ defaultChecked?: boolean;
17
+ onChange?: (checked: boolean) => any;
18
+ }
19
+ interface CheckboxGroupTriStateItem {
20
+ key: string;
21
+ label?: ReactNode;
22
+ defaultValue?: boolean | null;
23
+ onChange?: (state: boolean | null) => any;
24
+ }
25
+ type NormalItem = CheckboxGroupNormalItem & Omit<PrimeCheckboxProps, 'key' | 'className' | 'checked' | 'value' | 'inputId' | 'onChange'>;
26
+ type TriStateItem = CheckboxGroupTriStateItem & Omit<TriStateCheckboxProps, 'key' | 'className' | 'checked' | 'value' | 'inputId' | 'onChange' | 'defaultValue'>;
27
+ export type CheckboxGroupItem = NormalItem | TriStateItem;
13
28
  interface CheckboxGroupNormalProps extends CheckboxGroupBaseProps {
14
29
  tristate?: false;
15
- onChange?: (checkedList: string[]) => any;
16
- items: ({
17
- key: string;
18
- label?: ReactNode;
19
- checked?: boolean;
20
- onChange?: (checked: boolean) => any;
21
- } & Omit<PrimeCheckboxProps, 'key' | 'className' | 'checked' | 'value' | 'inputId' | 'onChange'>)[];
30
+ value?: string[];
31
+ onChange?: (checkedList: string[]) => void;
32
+ items: NormalItem[];
22
33
  }
23
34
  interface CheckboxGroupTriStateProps extends CheckboxGroupBaseProps {
24
35
  tristate: true;
25
- onChange?: (itemsState: Record<string, boolean | null>) => any;
26
- items: ({
27
- key: string;
28
- label?: ReactNode;
29
- checked?: boolean;
30
- defaultValue?: boolean | null;
31
- onChange?: (state: boolean | null) => any;
32
- } & Omit<TriStateCheckboxProps, 'key' | 'className' | 'checked' | 'value' | 'inputId' | 'onChange' | 'defaultValue'>)[];
36
+ value?: Record<string, boolean | null>;
37
+ onChange?: (itemsState: Record<string, boolean | null>) => void;
38
+ items: TriStateItem[];
33
39
  }
34
40
  export type CheckboxGroupProps = CheckboxGroupNormalProps | CheckboxGroupTriStateProps;
35
41
  export {};
@@ -75,13 +75,6 @@ $component: 'checkboxgroup';
75
75
  border: 2px solid $color-primary;
76
76
  box-shadow: none;
77
77
  }
78
-
79
- // &:has(.p-checkbox-input:checked) {
80
- // .p-checkbox-box {
81
- // // background-color: $color-primary-active;
82
- // // border-color: $color-primary-active;
83
- // }
84
- // }
85
78
  }
86
79
 
87
80
  // 选中状态
@@ -0,0 +1,29 @@
1
+ import React from 'react';
2
+ import type { FieldValues } from 'react-hook-form';
3
+ import type { FormContextValue, FormProps } from './interface';
4
+ /** React context that distributes form layout and state to descendant `<FormItem>` components. */
5
+ export declare const FormContext: React.Context<FormContextValue | null>;
6
+ /**
7
+ * Form component that wraps `react-hook-form` with layout, context distribution,
8
+ * value-change subscriptions, and scroll-to-error behavior.
9
+ *
10
+ * Renders a `<FormProvider>` and native `<form>` element. All `<FormItem>` children
11
+ * receive form methods and layout configuration via {@link FormContext}.
12
+ *
13
+ * Supports both controlled mode (pass an external `form` instance) and uncontrolled
14
+ * mode (internal `useForm` is created automatically).
15
+ *
16
+ * @template TFieldValues - The shape of the form values.
17
+ * @param props - {@link FormProps}
18
+ *
19
+ * @example
20
+ * ```tsx
21
+ * <Form defaultValues={{ name: '' }} onFinish={(values) => save(values)}>
22
+ * <FormItem name="name" label="Name" rules={{ required: true }}>
23
+ * <Input />
24
+ * </FormItem>
25
+ * </Form>
26
+ * ```
27
+ */
28
+ export declare function Form<TFieldValues extends FieldValues = FieldValues>(props: FormProps<TFieldValues>): import("react/jsx-runtime").JSX.Element;
29
+ export default Form;
@@ -0,0 +1,188 @@
1
+ import _regeneratorRuntime from "@babel/runtime/regenerator";
2
+ var __awaiter = this && this.__awaiter || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) {
4
+ return value instanceof P ? value : new P(function (resolve) {
5
+ resolve(value);
6
+ });
7
+ }
8
+ return new (P || (P = Promise))(function (resolve, reject) {
9
+ function fulfilled(value) {
10
+ try {
11
+ step(generator.next(value));
12
+ } catch (e) {
13
+ reject(e);
14
+ }
15
+ }
16
+ function rejected(value) {
17
+ try {
18
+ step(generator["throw"](value));
19
+ } catch (e) {
20
+ reject(e);
21
+ }
22
+ }
23
+ function step(result) {
24
+ result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);
25
+ }
26
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
27
+ });
28
+ };
29
+ var __rest = this && this.__rest || function (s, e) {
30
+ var t = {};
31
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
32
+ if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
33
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
34
+ }
35
+ return t;
36
+ };
37
+ import { jsx as _jsx } from "react/jsx-runtime";
38
+ import React, { createContext, useEffect, useMemo } from 'react';
39
+ import { FormProvider, useForm } from 'react-hook-form';
40
+ import { default as classnames, joinCls } from '../../utils/classnames';
41
+ import useLatest from '../useLatest';
42
+ import useMemoizedFn from '../useMemoizedFn';
43
+ import { DEFAULT_LABEL_ALIGN, DEFAULT_LABEL_COL, DEFAULT_LAYOUT, DEFAULT_SIZE, DEFAULT_WRAPPER_COL } from './constants';
44
+ import { getFirstErrorPath, scrollToField } from './helper';
45
+ /** React context that distributes form layout and state to descendant `<FormItem>` components. */
46
+ export var FormContext = /*#__PURE__*/createContext(null);
47
+ /**
48
+ * Form component that wraps `react-hook-form` with layout, context distribution,
49
+ * value-change subscriptions, and scroll-to-error behavior.
50
+ *
51
+ * Renders a `<FormProvider>` and native `<form>` element. All `<FormItem>` children
52
+ * receive form methods and layout configuration via {@link FormContext}.
53
+ *
54
+ * Supports both controlled mode (pass an external `form` instance) and uncontrolled
55
+ * mode (internal `useForm` is created automatically).
56
+ *
57
+ * @template TFieldValues - The shape of the form values.
58
+ * @param props - {@link FormProps}
59
+ *
60
+ * @example
61
+ * ```tsx
62
+ * <Form defaultValues={{ name: '' }} onFinish={(values) => save(values)}>
63
+ * <FormItem name="name" label="Name" rules={{ required: true }}>
64
+ * <Input />
65
+ * </FormItem>
66
+ * </Form>
67
+ * ```
68
+ */
69
+ export function Form(props) {
70
+ var _this = this;
71
+ // Form is a thin wrapper over react-hook-form with layout + UX helpers.
72
+ var form = props.form,
73
+ defaultValues = props.defaultValues,
74
+ onFinish = props.onFinish,
75
+ onFinishFailed = props.onFinishFailed,
76
+ onValuesChange = props.onValuesChange,
77
+ watchNames = props.watchNames,
78
+ scrollToFirstError = props.scrollToFirstError,
79
+ _props$layout = props.layout,
80
+ layout = _props$layout === void 0 ? DEFAULT_LAYOUT : _props$layout,
81
+ _props$labelAlign = props.labelAlign,
82
+ labelAlign = _props$labelAlign === void 0 ? DEFAULT_LABEL_ALIGN : _props$labelAlign,
83
+ _props$labelCol = props.labelCol,
84
+ labelCol = _props$labelCol === void 0 ? DEFAULT_LABEL_COL : _props$labelCol,
85
+ _props$wrapperCol = props.wrapperCol,
86
+ wrapperCol = _props$wrapperCol === void 0 ? DEFAULT_WRAPPER_COL : _props$wrapperCol,
87
+ _props$size = props.size,
88
+ size = _props$size === void 0 ? DEFAULT_SIZE : _props$size,
89
+ disabled = props.disabled,
90
+ _props$colon = props.colon,
91
+ colon = _props$colon === void 0 ? true : _props$colon,
92
+ _props$requiredMark = props.requiredMark,
93
+ requiredMark = _props$requiredMark === void 0 ? true : _props$requiredMark,
94
+ className = props.className,
95
+ style = props.style,
96
+ children = props.children,
97
+ useFormProps = __rest(props, ["form", "defaultValues", "onFinish", "onFinishFailed", "onValuesChange", "watchNames", "scrollToFirstError", "layout", "labelAlign", "labelCol", "wrapperCol", "size", "disabled", "colon", "requiredMark", "className", "style", "children"]);
98
+ // Always create an internal form to keep hook ordering stable.
99
+ // When an external `form` is passed via the `form` prop, this instance is
100
+ // unused but must remain so that React's hook call order is consistent
101
+ // across renders. We pass `shouldUnregister: true` to minimize overhead
102
+ // of the unused form instance.
103
+ var internalMethods = useForm(Object.assign({
104
+ defaultValues: defaultValues,
105
+ shouldUnregister: true
106
+ }, useFormProps));
107
+ // Use provided form methods when controlled; otherwise use internal form state.
108
+ var methods = form !== null && form !== void 0 ? form : internalMethods;
109
+ var valuesChangeRef = useLatest(onValuesChange);
110
+ var watchNamesRef = useLatest((watchNames === null || watchNames === void 0 ? void 0 : watchNames.length) ? new Set(watchNames) : null);
111
+ // Provide layout + disabled state + form methods to FormItem via context.
112
+ var ctx = useMemo(function () {
113
+ return {
114
+ layout: layout,
115
+ labelAlign: labelAlign,
116
+ labelCol: labelCol,
117
+ wrapperCol: wrapperCol,
118
+ size: size,
119
+ disabled: disabled,
120
+ colon: colon,
121
+ requiredMark: requiredMark,
122
+ methods: methods
123
+ };
124
+ }, [layout, labelAlign, labelCol, wrapperCol, size, disabled, colon, requiredMark, methods]);
125
+ // Subscribe to all value changes when handler provided.
126
+ useEffect(function () {
127
+ if (!onValuesChange) return;
128
+ var subscription = methods.watch(function (values, info) {
129
+ var _a;
130
+ var watchSet = watchNamesRef.current;
131
+ if (watchSet) {
132
+ var name = info.name;
133
+ if (!name || !watchSet.has(name)) return;
134
+ }
135
+ (_a = valuesChangeRef.current) === null || _a === void 0 ? void 0 : _a.call(valuesChangeRef, values, {
136
+ name: info.name,
137
+ type: info.type
138
+ });
139
+ });
140
+ return function () {
141
+ return subscription.unsubscribe();
142
+ };
143
+ // `valuesChangeRef` and `watchNamesRef` are stable refs accessed via `.current`
144
+ // so they do not need to be in the dependency array.
145
+ }, [methods, onValuesChange]);
146
+ // Submit success handler.
147
+ var handleFinish = useMemoizedFn(function (values) {
148
+ return __awaiter(_this, void 0, void 0, /*#__PURE__*/_regeneratorRuntime.mark(function _callee() {
149
+ return _regeneratorRuntime.wrap(function _callee$(_context) {
150
+ while (1) switch (_context.prev = _context.next) {
151
+ case 0:
152
+ _context.next = 2;
153
+ return onFinish === null || onFinish === void 0 ? void 0 : onFinish(values);
154
+ case 2:
155
+ case "end":
156
+ return _context.stop();
157
+ }
158
+ }, _callee);
159
+ }));
160
+ });
161
+ // Submit failure handler with optional scroll-to-error.
162
+ var handleFinishFailed = useMemoizedFn(function (errors) {
163
+ var _a;
164
+ if (scrollToFirstError) {
165
+ var first = getFirstErrorPath(errors);
166
+ if (first) {
167
+ (_a = methods.setFocus) === null || _a === void 0 ? void 0 : _a.call(methods, first);
168
+ scrollToField(first, scrollToFirstError);
169
+ }
170
+ }
171
+ onFinishFailed === null || onFinishFailed === void 0 ? void 0 : onFinishFailed(errors);
172
+ });
173
+ var classes = classnames('form');
174
+ return _jsx(FormProvider, Object.assign({}, methods, {
175
+ children: _jsx(FormContext.Provider, {
176
+ value: ctx,
177
+ children: _jsx("form", {
178
+ className: classes('root', joinCls(className, classes("layout-".concat(layout)), classes("size-".concat(size)), labelAlign === 'left' && classes('label-left'))),
179
+ style: style,
180
+ onSubmit: methods.handleSubmit(handleFinish, handleFinishFailed),
181
+ noValidate: true,
182
+ children: children
183
+ })
184
+ })
185
+ }));
186
+ }
187
+ export default Form;
188
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["components/Form/Form.js","components/src/components/Form/Form.tsx"],"names":["__awaiter","thisArg","_arguments","P","generator","adopt","value","resolve","Promise","reject","fulfilled","step","next","e","rejected","result","done","then","apply","__rest","s","t","p","Object","prototype","hasOwnProperty","call","indexOf","getOwnPropertySymbols","i","length","propertyIsEnumerable","jsx","_jsx","React","createContext","useEffect","useMemo","FormProvider","useForm","default","classnames","joinCls","useLatest","useMemoizedFn","DEFAULT_LABEL_ALIGN","DEFAULT_LABEL_COL","DEFAULT_LAYOUT","DEFAULT_SIZE","DEFAULT_WRAPPER_COL","getFirstErrorPath","scrollToField","FormContext","Form","props","_this","form","defaultValues","onFinish","onFinishFailed","onValuesChange","watchNames","scrollToFirstError","_props$layout","layout","_props$labelAlign","labelAlign","_props$labelCol","labelCol","_props$wrapperCol","wrapperCol","_props$size","size","disabled","_props$colon","colon","_props$requiredMark","requiredMark","className","style","children","useFormProps","internalMethods","assign","shouldUnregister","methods","valuesChangeRef","watchNamesRef","Set","ctx","subscription","watch","values","info","_a","watchSet","current","name","has","type","unsubscribe","handleFinish","_regeneratorRuntime","mark","_callee","wrap","_callee$","_context","prev","stop","handleFinishFailed","errors","first","setFocus","classes","Provider","concat","onSubmit","handleSubmit","noValidate"],"mappings":"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","file":"components/Form/Form.js","sourcesContent":["var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n    return new (P || (P = Promise))(function (resolve, reject) {\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\n    });\n};\nvar __rest = (this && this.__rest) || function (s, e) {\n    var t = {};\n    for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\n        t[p] = s[p];\n    if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\n        for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n            if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\n                t[p[i]] = s[p[i]];\n        }\n    return t;\n};\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nimport React, { createContext, useEffect, useMemo } from 'react';\nimport { FormProvider, useForm } from 'react-hook-form';\nimport { default as classnames, joinCls } from '../../utils/classnames';\nimport useLatest from '../useLatest';\nimport useMemoizedFn from '../useMemoizedFn';\nimport { DEFAULT_LABEL_ALIGN, DEFAULT_LABEL_COL, DEFAULT_LAYOUT, DEFAULT_SIZE, DEFAULT_WRAPPER_COL, } from './constants';\nimport { getFirstErrorPath, scrollToField } from './helper';\n/** React context that distributes form layout and state to descendant `<FormItem>` components. */\nexport const FormContext = createContext(null);\n/**\n * Form component that wraps `react-hook-form` with layout, context distribution,\n * value-change subscriptions, and scroll-to-error behavior.\n *\n * Renders a `<FormProvider>` and native `<form>` element. All `<FormItem>` children\n * receive form methods and layout configuration via {@link FormContext}.\n *\n * Supports both controlled mode (pass an external `form` instance) and uncontrolled\n * mode (internal `useForm` is created automatically).\n *\n * @template TFieldValues - The shape of the form values.\n * @param props - {@link FormProps}\n *\n * @example\n * ```tsx\n * <Form defaultValues={{ name: '' }} onFinish={(values) => save(values)}>\n *   <FormItem name=\"name\" label=\"Name\" rules={{ required: true }}>\n *     <Input />\n *   </FormItem>\n * </Form>\n * ```\n */\nexport function Form(props) {\n    // Form is a thin wrapper over react-hook-form with layout + UX helpers.\n    const { form, defaultValues, onFinish, onFinishFailed, onValuesChange, watchNames, scrollToFirstError, layout = DEFAULT_LAYOUT, labelAlign = DEFAULT_LABEL_ALIGN, labelCol = DEFAULT_LABEL_COL, wrapperCol = DEFAULT_WRAPPER_COL, size = DEFAULT_SIZE, disabled, colon = true, requiredMark = true, className, style, children } = props, useFormProps = __rest(props, [\"form\", \"defaultValues\", \"onFinish\", \"onFinishFailed\", \"onValuesChange\", \"watchNames\", \"scrollToFirstError\", \"layout\", \"labelAlign\", \"labelCol\", \"wrapperCol\", \"size\", \"disabled\", \"colon\", \"requiredMark\", \"className\", \"style\", \"children\"]);\n    // Always create an internal form to keep hook ordering stable.\n    // When an external `form` is passed via the `form` prop, this instance is\n    // unused but must remain so that React's hook call order is consistent\n    // across renders. We pass `shouldUnregister: true` to minimize overhead\n    // of the unused form instance.\n    const internalMethods = useForm(Object.assign({ defaultValues, shouldUnregister: true }, useFormProps));\n    // Use provided form methods when controlled; otherwise use internal form state.\n    const methods = form !== null && form !== void 0 ? form : internalMethods;\n    const valuesChangeRef = useLatest(onValuesChange);\n    const watchNamesRef = useLatest((watchNames === null || watchNames === void 0 ? void 0 : watchNames.length) ? new Set(watchNames) : null);\n    // Provide layout + disabled state + form methods to FormItem via context.\n    const ctx = useMemo(() => ({\n        layout,\n        labelAlign,\n        labelCol,\n        wrapperCol,\n        size,\n        disabled,\n        colon,\n        requiredMark,\n        methods: methods,\n    }), [layout, labelAlign, labelCol, wrapperCol, size, disabled, colon, requiredMark, methods]);\n    // Subscribe to all value changes when handler provided.\n    useEffect(() => {\n        if (!onValuesChange)\n            return;\n        const subscription = methods.watch((values, info) => {\n            var _a;\n            const watchSet = watchNamesRef.current;\n            if (watchSet) {\n                const name = info.name;\n                if (!name || !watchSet.has(name))\n                    return;\n            }\n            (_a = valuesChangeRef.current) === null || _a === void 0 ? void 0 : _a.call(valuesChangeRef, values, { name: info.name, type: info.type });\n        });\n        return () => subscription.unsubscribe();\n        // `valuesChangeRef` and `watchNamesRef` are stable refs accessed via `.current`\n        // so they do not need to be in the dependency array.\n    }, [methods, onValuesChange]);\n    // Submit success handler.\n    const handleFinish = useMemoizedFn((values) => __awaiter(this, void 0, void 0, function* () {\n        yield (onFinish === null || onFinish === void 0 ? void 0 : onFinish(values));\n    }));\n    // Submit failure handler with optional scroll-to-error.\n    const handleFinishFailed = useMemoizedFn((errors) => {\n        var _a;\n        if (scrollToFirstError) {\n            const first = getFirstErrorPath(errors);\n            if (first) {\n                (_a = methods.setFocus) === null || _a === void 0 ? void 0 : _a.call(methods, first);\n                scrollToField(first, scrollToFirstError);\n            }\n        }\n        onFinishFailed === null || onFinishFailed === void 0 ? void 0 : onFinishFailed(errors);\n    });\n    const classes = classnames('form');\n    return (_jsx(FormProvider, Object.assign({}, methods, { children: _jsx(FormContext.Provider, { value: ctx, children: _jsx(\"form\", { className: classes('root', joinCls(className, classes(`layout-${layout}`), classes(`size-${size}`), labelAlign === 'left' && classes('label-left'))), style: style, onSubmit: methods.handleSubmit(handleFinish, handleFinishFailed), noValidate: true, children: children }) }) })));\n}\nexport default Form;",null],"sourceRoot":"../../../../../../../../../src"}
@@ -0,0 +1,4 @@
1
+ import type { FieldValues } from 'react-hook-form';
2
+ import type { FormItemProps } from './interface';
3
+ export declare function FormItem<TFieldValues extends FieldValues = FieldValues>(props: FormItemProps<TFieldValues>): import("react/jsx-runtime").JSX.Element;
4
+ export default FormItem;
@@ -0,0 +1,165 @@
1
+ import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
+ import { useContext, useMemo } from 'react';
4
+ import { default as classnames, joinCls } from '../../utils/classnames';
5
+ import Typography from '../Typography';
6
+ import { FormContext } from './Form';
7
+ import { CSS_VAR_LABEL_WIDTH, CSS_VAR_WRAPPER_WIDTH, DEFAULT_VALUE_PROP } from './constants';
8
+ import { toPercent, wrapValidate } from './helper';
9
+ import { FormItemContent } from './FormItemContent';
10
+ import { FallbackFormProvider, useFormItemContext } from './useFormItemContext';
11
+ import { useFormItemWatch } from './useFormItemWatch';
12
+ import { useValidationTrigger } from './useValidationTrigger';
13
+ /**
14
+ * Runtime type guard for render-prop children.
15
+ */
16
+ var isRenderFnChild = function isRenderFnChild(child) {
17
+ return typeof child === 'function';
18
+ };
19
+ /**
20
+ * Form field wrapper that bridges `react-hook-form`'s Controller with the Form
21
+ * layout system, validation status display, and configurable trigger behavior.
22
+ *
23
+ * When a `name` is provided, the field is registered with `react-hook-form` via
24
+ * a `Controller` and supports validation rules, dependencies, and status feedback.
25
+ * Without a `name`, it renders as a free wrapper for uncontrolled content.
26
+ *
27
+ * Supports two child patterns:
28
+ * - **React element**: automatically bound via `React.cloneElement` with value/onChange/onBlur.
29
+ * - **Render-prop function**: receives `{ field, fieldState, form, values }` for full control.
30
+ *
31
+ * @template TFieldValues - The shape of the form values.
32
+ * @param props - {@link FormItemProps}
33
+ *
34
+ * @example
35
+ * ```tsx
36
+ * // Element child (auto-bound)
37
+ * <FormItem name="email" label="Email" rules={{ required: true }}>
38
+ * <Input placeholder="Enter email" />
39
+ * </FormItem>
40
+ *
41
+ * // Render-prop child
42
+ * <FormItem name="agree">
43
+ * {({ field }) => <Checkbox {...field} />}
44
+ * </FormItem>
45
+ * ```
46
+ */
47
+ function FormItemInner(props) {
48
+ var name = props.name,
49
+ label = props.label,
50
+ required = props.required,
51
+ rules = props.rules,
52
+ defaultValue = props.defaultValue,
53
+ help = props.help,
54
+ extra = props.extra,
55
+ validateStatus = props.validateStatus,
56
+ dependencies = props.dependencies,
57
+ watchNames = props.watchNames,
58
+ shouldUpdate = props.shouldUpdate,
59
+ validateTrigger = props.validateTrigger,
60
+ validateFirst = props.validateFirst,
61
+ validateDebounce = props.validateDebounce,
62
+ noStyle = props.noStyle,
63
+ _props$valuePropName = props.valuePropName,
64
+ valuePropName = _props$valuePropName === void 0 ? DEFAULT_VALUE_PROP : _props$valuePropName,
65
+ className = props.className,
66
+ labelCol = props.labelCol,
67
+ wrapperCol = props.wrapperCol,
68
+ children = props.children;
69
+ var classes = classnames('form-item');
70
+ var _useFormItemContext = useFormItemContext(name),
71
+ ctx = _useFormItemContext.ctx,
72
+ methods = _useFormItemContext.methods,
73
+ control = _useFormItemContext.control,
74
+ trigger = _useFormItemContext.trigger;
75
+ var _useFormItemWatch = useFormItemWatch({
76
+ control: control,
77
+ methods: methods,
78
+ dependencies: dependencies,
79
+ watchNames: watchNames,
80
+ shouldUpdate: shouldUpdate,
81
+ name: name
82
+ }),
83
+ allValues = _useFormItemWatch.allValues,
84
+ depValues = _useFormItemWatch.depValues,
85
+ shouldRender = _useFormItemWatch.shouldRender;
86
+ var _useValidationTrigger = useValidationTrigger({
87
+ name: name,
88
+ trigger: trigger,
89
+ validateTrigger: validateTrigger,
90
+ validateDebounce: validateDebounce,
91
+ dependencies: dependencies,
92
+ depValues: depValues
93
+ }),
94
+ withTrigger = _useValidationTrigger.withTrigger;
95
+ var renderFn = isRenderFnChild(children) ? children : null;
96
+ var isRequired = required !== null && required !== void 0 ? required : !!(rules === null || rules === void 0 ? void 0 : rules.required);
97
+ var showRequired = (ctx === null || ctx === void 0 ? void 0 : ctx.requiredMark) !== false;
98
+ var labelWidth = useMemo(function () {
99
+ return toPercent(labelCol !== null && labelCol !== void 0 ? labelCol : ctx === null || ctx === void 0 ? void 0 : ctx.labelCol);
100
+ }, [labelCol, ctx === null || ctx === void 0 ? void 0 : ctx.labelCol]);
101
+ var wrapperWidth = useMemo(function () {
102
+ return toPercent(wrapperCol !== null && wrapperCol !== void 0 ? wrapperCol : ctx === null || ctx === void 0 ? void 0 : ctx.wrapperCol);
103
+ }, [wrapperCol, ctx === null || ctx === void 0 ? void 0 : ctx.wrapperCol]);
104
+ var mergedRules = useMemo(function () {
105
+ if (!(rules === null || rules === void 0 ? void 0 : rules.validate) || !validateFirst) return rules;
106
+ var validate = wrapValidate(rules.validate, validateFirst);
107
+ if (validate === rules.validate) return rules;
108
+ return Object.assign(Object.assign({}, rules), {
109
+ validate: validate
110
+ });
111
+ }, [rules, validateFirst]);
112
+ var contentProps = useMemo(function () {
113
+ return {
114
+ name: name,
115
+ control: control,
116
+ methods: methods,
117
+ rules: mergedRules,
118
+ defaultValue: defaultValue,
119
+ validateStatus: validateStatus,
120
+ valuePropName: valuePropName,
121
+ help: help,
122
+ extra: extra,
123
+ ctx: ctx,
124
+ children: children,
125
+ renderFn: renderFn,
126
+ allValues: allValues,
127
+ shouldUpdate: shouldUpdate,
128
+ shouldRender: shouldRender,
129
+ withTrigger: withTrigger
130
+ };
131
+ }, [name, control, methods, mergedRules, defaultValue, validateStatus, valuePropName, help, extra, ctx, children, renderFn, allValues, shouldUpdate, shouldRender, withTrigger]);
132
+ if (noStyle) {
133
+ return _jsx(FormItemContent, Object.assign({}, contentProps));
134
+ }
135
+ var rootStyle = _defineProperty(_defineProperty({}, CSS_VAR_LABEL_WIDTH, labelWidth), CSS_VAR_WRAPPER_WIDTH, wrapperWidth);
136
+ return _jsxs("div", {
137
+ className: classes('root', joinCls(className, (ctx === null || ctx === void 0 ? void 0 : ctx.layout) && classes("layout-".concat(ctx.layout)))),
138
+ "data-form-item-name": name ? String(name) : undefined,
139
+ style: rootStyle,
140
+ children: [label && _jsxs("div", {
141
+ className: classes('label', joinCls(showRequired && isRequired && classes('label-required'))),
142
+ children: [_jsx(Typography.Label, {
143
+ size: 's',
144
+ children: label
145
+ }), (ctx === null || ctx === void 0 ? void 0 : ctx.colon) && _jsx("span", {
146
+ className: classes('colon'),
147
+ children: ":"
148
+ })]
149
+ }), _jsx("div", {
150
+ className: classes('control'),
151
+ children: _jsx(FormItemContent, Object.assign({}, contentProps))
152
+ })]
153
+ });
154
+ }
155
+ export function FormItem(props) {
156
+ var ctx = useContext(FormContext);
157
+ if (ctx === null || ctx === void 0 ? void 0 : ctx.methods) {
158
+ return _jsx(FormItemInner, Object.assign({}, props));
159
+ }
160
+ return _jsx(FallbackFormProvider, {
161
+ children: _jsx(FormItemInner, Object.assign({}, props))
162
+ });
163
+ }
164
+ export default FormItem;
165
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["components/Form/FormItem.js","components/src/components/Form/FormItem.tsx"],"names":["jsx","_jsx","jsxs","_jsxs","useContext","useMemo","default","classnames","joinCls","Typography","FormContext","CSS_VAR_LABEL_WIDTH","CSS_VAR_WRAPPER_WIDTH","DEFAULT_VALUE_PROP","toPercent","wrapValidate","FormItemContent","FallbackFormProvider","useFormItemContext","useFormItemWatch","useValidationTrigger","isRenderFnChild","child","FormItemInner","props","name","label","required","rules","defaultValue","help","extra","validateStatus","dependencies","watchNames","shouldUpdate","validateTrigger","validateFirst","validateDebounce","noStyle","_props$valuePropName","valuePropName","className","labelCol","wrapperCol","children","classes","_useFormItemContext","ctx","methods","control","trigger","_useFormItemWatch","allValues","depValues","shouldRender","_useValidationTrigger","withTrigger","renderFn","isRequired","showRequired","requiredMark","labelWidth","wrapperWidth","mergedRules","validate","Object","assign","contentProps","rootStyle","_defineProperty","layout","concat","String","undefined","style","Label","size","colon","FormItem"],"mappings":"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","file":"components/Form/FormItem.js","sourcesContent":["import { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nimport { useContext, useMemo } from 'react';\nimport { default as classnames, joinCls } from '../../utils/classnames';\nimport Typography from '../Typography';\nimport { FormContext } from './Form';\nimport { CSS_VAR_LABEL_WIDTH, CSS_VAR_WRAPPER_WIDTH, DEFAULT_VALUE_PROP } from './constants';\nimport { toPercent, wrapValidate } from './helper';\nimport { FormItemContent } from './FormItemContent';\nimport { FallbackFormProvider, useFormItemContext } from './useFormItemContext';\nimport { useFormItemWatch } from './useFormItemWatch';\nimport { useValidationTrigger } from './useValidationTrigger';\n/**\n * Runtime type guard for render-prop children.\n */\nconst isRenderFnChild = (child) => typeof child === 'function';\n/**\n * Form field wrapper that bridges `react-hook-form`'s Controller with the Form\n * layout system, validation status display, and configurable trigger behavior.\n *\n * When a `name` is provided, the field is registered with `react-hook-form` via\n * a `Controller` and supports validation rules, dependencies, and status feedback.\n * Without a `name`, it renders as a free wrapper for uncontrolled content.\n *\n * Supports two child patterns:\n * - **React element**: automatically bound via `React.cloneElement` with value/onChange/onBlur.\n * - **Render-prop function**: receives `{ field, fieldState, form, values }` for full control.\n *\n * @template TFieldValues - The shape of the form values.\n * @param props - {@link FormItemProps}\n *\n * @example\n * ```tsx\n * // Element child (auto-bound)\n * <FormItem name=\"email\" label=\"Email\" rules={{ required: true }}>\n *   <Input placeholder=\"Enter email\" />\n * </FormItem>\n *\n * // Render-prop child\n * <FormItem name=\"agree\">\n *   {({ field }) => <Checkbox {...field} />}\n * </FormItem>\n * ```\n */\nfunction FormItemInner(props) {\n    const { name, label, required, rules, defaultValue, help, extra, validateStatus, dependencies, watchNames, shouldUpdate, validateTrigger, validateFirst, validateDebounce, noStyle, valuePropName = DEFAULT_VALUE_PROP, className, labelCol, wrapperCol, children, } = props;\n    const classes = classnames('form-item');\n    const { ctx, methods, control, trigger } = useFormItemContext(name);\n    const { allValues, depValues, shouldRender } = useFormItemWatch({\n        control,\n        methods,\n        dependencies,\n        watchNames,\n        shouldUpdate,\n        name,\n    });\n    const { withTrigger } = useValidationTrigger({\n        name,\n        trigger,\n        validateTrigger,\n        validateDebounce,\n        dependencies,\n        depValues,\n    });\n    const renderFn = isRenderFnChild(children) ? children : null;\n    const isRequired = required !== null && required !== void 0 ? required : !!(rules === null || rules === void 0 ? void 0 : rules.required);\n    const showRequired = (ctx === null || ctx === void 0 ? void 0 : ctx.requiredMark) !== false;\n    const labelWidth = useMemo(() => toPercent(labelCol !== null && labelCol !== void 0 ? labelCol : ctx === null || ctx === void 0 ? void 0 : ctx.labelCol), [labelCol, ctx === null || ctx === void 0 ? void 0 : ctx.labelCol]);\n    const wrapperWidth = useMemo(() => toPercent(wrapperCol !== null && wrapperCol !== void 0 ? wrapperCol : ctx === null || ctx === void 0 ? void 0 : ctx.wrapperCol), [wrapperCol, ctx === null || ctx === void 0 ? void 0 : ctx.wrapperCol]);\n    const mergedRules = useMemo(() => {\n        if (!(rules === null || rules === void 0 ? void 0 : rules.validate) || !validateFirst)\n            return rules;\n        const validate = wrapValidate(rules.validate, validateFirst);\n        if (validate === rules.validate)\n            return rules;\n        return Object.assign(Object.assign({}, rules), { validate });\n    }, [rules, validateFirst]);\n    const contentProps = useMemo(() => ({\n        name,\n        control,\n        methods,\n        rules: mergedRules,\n        defaultValue,\n        validateStatus,\n        valuePropName,\n        help,\n        extra,\n        ctx,\n        children,\n        renderFn,\n        allValues,\n        shouldUpdate,\n        shouldRender,\n        withTrigger,\n    }), [\n        name, control, methods, mergedRules, defaultValue, validateStatus,\n        valuePropName, help, extra, ctx, children, renderFn, allValues,\n        shouldUpdate, shouldRender, withTrigger,\n    ]);\n    if (noStyle) {\n        return _jsx(FormItemContent, Object.assign({}, contentProps));\n    }\n    const rootStyle = {\n        [CSS_VAR_LABEL_WIDTH]: labelWidth,\n        [CSS_VAR_WRAPPER_WIDTH]: wrapperWidth,\n    };\n    return (_jsxs(\"div\", { className: classes('root', joinCls(className, (ctx === null || ctx === void 0 ? void 0 : ctx.layout) && classes(`layout-${ctx.layout}`))), \"data-form-item-name\": name ? String(name) : undefined, style: rootStyle, children: [label && (_jsxs(\"div\", { className: classes('label', joinCls(showRequired && isRequired && classes('label-required'))), children: [_jsx(Typography.Label, { size: 's', children: label }), (ctx === null || ctx === void 0 ? void 0 : ctx.colon) && _jsx(\"span\", { className: classes('colon'), children: \":\" })] })), _jsx(\"div\", { className: classes('control'), children: _jsx(FormItemContent, Object.assign({}, contentProps)) })] }));\n}\nexport function FormItem(props) {\n    const ctx = useContext(FormContext);\n    if (ctx === null || ctx === void 0 ? void 0 : ctx.methods) {\n        return _jsx(FormItemInner, Object.assign({}, props));\n    }\n    return (_jsx(FallbackFormProvider, { children: _jsx(FormItemInner, Object.assign({}, props)) }));\n}\nexport default FormItem;",null],"sourceRoot":"../../../../../../../../../src"}
@@ -0,0 +1,18 @@
1
+ import type { FieldValues } from 'react-hook-form';
2
+ import type { FormItemContentProps } from './interface';
3
+ /**
4
+ * Renders the inner content of a `<FormItem>`.
5
+ *
6
+ * Handles two branches:
7
+ * - **Free branch** (no `name`): renders children directly or via a render-prop,
8
+ * optionally gated by `shouldUpdate`.
9
+ * - **Controlled branch** (has `name`): wraps children in a `react-hook-form`
10
+ * `Controller`, injecting field bindings and validation-trigger wrappers.
11
+ *
12
+ * Both branches render their output inside a {@link MetaWrapper} for consistent
13
+ * help/error/extra display.
14
+ *
15
+ * @template TFieldValues - The shape of the form values.
16
+ * @param props - {@link FormItemContentProps}
17
+ */
18
+ export declare function FormItemContent<TFieldValues extends FieldValues = FieldValues>({ name, control, methods, rules, defaultValue, validateStatus, valuePropName, help, extra, ctx, children, renderFn, allValues, shouldUpdate, shouldRender, withTrigger, }: FormItemContentProps<TFieldValues>): import("react/jsx-runtime").JSX.Element;