@1money/react-ui 1.15.3 → 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 (378) 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/Flex/Flex.d.ts +5 -0
  7. package/es/components/Flex/Flex.js +50 -0
  8. package/es/components/Flex/constants.d.ts +41 -0
  9. package/es/components/Flex/constants.js +45 -0
  10. package/es/components/Flex/index.d.ts +5 -0
  11. package/es/components/Flex/index.js +6 -0
  12. package/es/components/Flex/interface.d.ts +13 -0
  13. package/es/components/Flex/interface.js +2 -0
  14. package/es/components/Flex/style/Flex.css +1 -0
  15. package/es/components/Flex/style/Flex.scss +70 -0
  16. package/es/components/Flex/style/css.js +2 -0
  17. package/es/components/Flex/style/index.d.ts +1 -0
  18. package/es/components/Flex/style/index.js +2 -0
  19. package/es/components/Form/Form.d.ts +29 -0
  20. package/es/components/Form/Form.js +188 -0
  21. package/es/components/Form/FormItem.d.ts +4 -0
  22. package/es/components/Form/FormItem.js +165 -0
  23. package/es/components/Form/FormItemContent.d.ts +18 -0
  24. package/es/components/Form/FormItemContent.js +146 -0
  25. package/es/components/Form/constants.d.ts +46 -0
  26. package/es/components/Form/constants.js +65 -0
  27. package/es/components/Form/helper.d.ts +120 -0
  28. package/es/components/Form/helper.js +284 -0
  29. package/es/components/Form/index.d.ts +20 -0
  30. package/es/components/Form/index.js +21 -0
  31. package/es/components/Form/interface.d.ts +238 -0
  32. package/es/components/Form/interface.js +2 -0
  33. package/es/components/Form/style/Form.css +1 -0
  34. package/es/components/Form/style/Form.scss +167 -0
  35. package/es/components/Form/style/css.js +2 -0
  36. package/es/components/Form/style/index.d.ts +1 -0
  37. package/es/components/Form/style/index.js +2 -0
  38. package/es/components/Form/useFormItemContext.d.ts +32 -0
  39. package/es/components/Form/useFormItemContext.js +55 -0
  40. package/es/components/Form/useFormItemWatch.d.ts +51 -0
  41. package/es/components/Form/useFormItemWatch.js +69 -0
  42. package/es/components/Form/useValidationTrigger.d.ts +40 -0
  43. package/es/components/Form/useValidationTrigger.js +74 -0
  44. package/es/components/Grid/Col.d.ts +5 -0
  45. package/es/components/Grid/Col.js +97 -0
  46. package/es/components/Grid/Grid.d.ts +12 -0
  47. package/es/components/Grid/Grid.js +12 -0
  48. package/es/components/Grid/Row.d.ts +5 -0
  49. package/es/components/Grid/Row.js +48 -0
  50. package/es/components/Grid/constants.d.ts +55 -0
  51. package/es/components/Grid/constants.js +66 -0
  52. package/es/components/Grid/helper.d.ts +10 -0
  53. package/es/components/Grid/helper.js +44 -0
  54. package/es/components/Grid/index.d.ts +7 -0
  55. package/es/components/Grid/index.js +8 -0
  56. package/es/components/Grid/interface.d.ts +38 -0
  57. package/es/components/Grid/interface.js +2 -0
  58. package/es/components/Grid/style/Grid.css +1 -0
  59. package/es/components/Grid/style/Grid.scss +196 -0
  60. package/es/components/Grid/style/css.js +2 -0
  61. package/es/components/Grid/style/index.d.ts +1 -0
  62. package/es/components/Grid/style/index.js +2 -0
  63. package/es/components/Input/Input.js +72 -74
  64. package/es/components/Input/interface.d.ts +9 -9
  65. package/es/components/InputAmount/InputAmount.js +228 -276
  66. package/es/components/InputAmount/helper.d.ts +46 -0
  67. package/es/components/InputAmount/helper.js +115 -0
  68. package/es/components/InputAmount/style/normal.css +1 -1
  69. package/es/components/InputAmount/style/normal.scss +2 -2
  70. package/es/components/InputAmount/style/primary.css +1 -1
  71. package/es/components/InputAmount/style/primary.scss +2 -2
  72. package/es/components/Message/style/Message.css +1 -1
  73. package/es/components/Message/style/Message.scss +3 -3
  74. package/es/components/ProForm/ProForm.d.ts +33 -0
  75. package/es/components/ProForm/ProForm.js +208 -0
  76. package/es/components/ProForm/ProFormDependency.d.ts +12 -0
  77. package/es/components/ProForm/ProFormDependency.js +61 -0
  78. package/es/components/ProForm/ProFormList.d.ts +19 -0
  79. package/es/components/ProForm/ProFormList.js +348 -0
  80. package/es/components/ProForm/Submitter.d.ts +21 -0
  81. package/es/components/ProForm/Submitter.js +76 -0
  82. package/es/components/ProForm/constants.d.ts +34 -0
  83. package/es/components/ProForm/constants.js +40 -0
  84. package/es/components/ProForm/fields/ProFormCheckbox.d.ts +6 -0
  85. package/es/components/ProForm/fields/ProFormCheckbox.js +11 -0
  86. package/es/components/ProForm/fields/ProFormCheckboxGroup.d.ts +6 -0
  87. package/es/components/ProForm/fields/ProFormCheckboxGroup.js +46 -0
  88. package/es/components/ProForm/fields/ProFormDigit.d.ts +6 -0
  89. package/es/components/ProForm/fields/ProFormDigit.js +15 -0
  90. package/es/components/ProForm/fields/ProFormMoney.d.ts +6 -0
  91. package/es/components/ProForm/fields/ProFormMoney.js +10 -0
  92. package/es/components/ProForm/fields/ProFormMultiSelect.d.ts +6 -0
  93. package/es/components/ProForm/fields/ProFormMultiSelect.js +27 -0
  94. package/es/components/ProForm/fields/ProFormPassword.d.ts +6 -0
  95. package/es/components/ProForm/fields/ProFormPassword.js +16 -0
  96. package/es/components/ProForm/fields/ProFormRadio.d.ts +6 -0
  97. package/es/components/ProForm/fields/ProFormRadio.js +13 -0
  98. package/es/components/ProForm/fields/ProFormSelect.d.ts +6 -0
  99. package/es/components/ProForm/fields/ProFormSelect.js +13 -0
  100. package/es/components/ProForm/fields/ProFormSwitch.d.ts +6 -0
  101. package/es/components/ProForm/fields/ProFormSwitch.js +11 -0
  102. package/es/components/ProForm/fields/ProFormText.d.ts +6 -0
  103. package/es/components/ProForm/fields/ProFormText.js +15 -0
  104. package/es/components/ProForm/fields/ProFormTextArea.d.ts +6 -0
  105. package/es/components/ProForm/fields/ProFormTextArea.js +16 -0
  106. package/es/components/ProForm/fields/createProFormField.d.ts +43 -0
  107. package/es/components/ProForm/fields/createProFormField.js +200 -0
  108. package/es/components/ProForm/fields/index.d.ts +12 -0
  109. package/es/components/ProForm/fields/index.js +13 -0
  110. package/es/components/ProForm/index.d.ts +7 -0
  111. package/es/components/ProForm/index.js +7 -0
  112. package/es/components/ProForm/interface.d.ts +306 -0
  113. package/es/components/ProForm/interface.js +2 -0
  114. package/es/components/ProForm/layouts/DrawerForm.d.ts +16 -0
  115. package/es/components/ProForm/layouts/DrawerForm.js +79 -0
  116. package/es/components/ProForm/layouts/ModalForm.d.ts +16 -0
  117. package/es/components/ProForm/layouts/ModalForm.js +89 -0
  118. package/es/components/ProForm/layouts/QueryFilter.d.ts +21 -0
  119. package/es/components/ProForm/layouts/QueryFilter.js +132 -0
  120. package/es/components/ProForm/layouts/StepsForm.d.ts +13 -0
  121. package/es/components/ProForm/layouts/StepsForm.js +295 -0
  122. package/es/components/ProForm/layouts/index.d.ts +4 -0
  123. package/es/components/ProForm/layouts/index.js +5 -0
  124. package/es/components/ProForm/layouts/useOverlayForm.d.ts +53 -0
  125. package/es/components/ProForm/layouts/useOverlayForm.js +143 -0
  126. package/es/components/ProForm/style/ProForm.module.css +1 -0
  127. package/es/components/ProForm/style/ProForm.module.scss +59 -0
  128. package/es/components/ProForm/style/css.js +3 -0
  129. package/es/components/ProForm/style/index.d.ts +1 -0
  130. package/es/components/ProForm/style/index.js +3 -0
  131. package/es/components/ProForm/utils.d.ts +72 -0
  132. package/es/components/ProForm/utils.js +206 -0
  133. package/es/components/RadioGroup/RadioGroup.js +46 -23
  134. package/es/components/RadioGroup/interface.d.ts +3 -1
  135. package/es/components/Select/Select.d.ts +1 -1
  136. package/es/components/Select/Select.js +113 -106
  137. package/es/components/Select/constants.d.ts +18 -0
  138. package/es/components/Select/constants.js +19 -0
  139. package/es/components/Sidebar/Sidebar.js +21 -23
  140. package/es/components/Sidebar/SidebarLogo.d.ts +7 -0
  141. package/es/components/Sidebar/SidebarLogo.js +33 -0
  142. package/es/components/Sidebar/SimplySidebar.d.ts +2 -2
  143. package/es/components/Sidebar/SimplySidebar.js +18 -22
  144. package/es/components/Sidebar/Stepper.js +14 -14
  145. package/es/components/Sidebar/constants.d.ts +16 -0
  146. package/es/components/Sidebar/constants.js +17 -0
  147. package/es/components/Sidebar/style/Sidebar.css +1 -1
  148. package/es/components/Sidebar/style/Sidebar.scss +1 -1
  149. package/es/components/Sidebar/style/SimplySidebar.css +1 -1
  150. package/es/components/Sidebar/style/SimplySidebar.scss +1 -1
  151. package/es/components/Sidebar/style/Stepper.css +1 -1
  152. package/es/components/Sidebar/style/Stepper.scss +11 -1
  153. package/es/components/Space/Space.d.ts +5 -0
  154. package/es/components/Space/Space.js +71 -0
  155. package/es/components/Space/constants.d.ts +33 -0
  156. package/es/components/Space/constants.js +37 -0
  157. package/es/components/Space/index.d.ts +5 -0
  158. package/es/components/Space/index.js +6 -0
  159. package/es/components/Space/interface.d.ts +12 -0
  160. package/es/components/Space/interface.js +2 -0
  161. package/es/components/Space/style/Space.css +1 -0
  162. package/es/components/Space/style/Space.scss +40 -0
  163. package/es/components/Space/style/css.js +2 -0
  164. package/es/components/Space/style/index.d.ts +1 -0
  165. package/es/components/Space/style/index.js +2 -0
  166. package/es/components/Switch/Switch.js +28 -25
  167. package/es/components/Switch/interface.d.ts +9 -4
  168. package/es/components/useControlledState/index.d.ts +14 -0
  169. package/es/components/useControlledState/index.js +32 -0
  170. package/es/components/useEventCallback/index.d.ts +11 -0
  171. package/es/components/useEventCallback/index.js +17 -0
  172. package/es/components/useLayoutEffect/index.d.ts +11 -0
  173. package/es/components/useLayoutEffect/index.js +17 -0
  174. package/es/components/useLayoutState/index.d.ts +13 -0
  175. package/es/components/useLayoutState/index.js +71 -0
  176. package/es/components/useMemoizedFn/index.d.ts +12 -0
  177. package/es/components/useMemoizedFn/index.js +27 -0
  178. package/es/components/usePrevious/index.d.ts +11 -0
  179. package/es/components/usePrevious/index.js +19 -0
  180. package/es/components/useSafeState/index.d.ts +12 -0
  181. package/es/components/useSafeState/index.js +24 -0
  182. package/es/components/useSyncState/index.d.ts +14 -0
  183. package/es/components/useSyncState/index.js +37 -0
  184. package/es/components/useUpdateEffect/index.d.ts +9 -0
  185. package/es/components/useUpdateEffect/index.js +19 -0
  186. package/es/index.css +1 -1
  187. package/es/index.d.ts +32 -2
  188. package/es/index.js +30 -1
  189. package/jest.setup.d.ts +1 -0
  190. package/jest.setup.ts +1 -0
  191. package/lib/components/CheckboxGroup/CheckboxGroup.d.ts +3 -3
  192. package/lib/components/CheckboxGroup/CheckboxGroup.js +92 -89
  193. package/lib/components/CheckboxGroup/interface.d.ts +21 -15
  194. package/lib/components/CheckboxGroup/style/CheckboxGroup.scss +0 -7
  195. package/lib/components/Flex/Flex.d.ts +5 -0
  196. package/lib/components/Flex/Flex.js +60 -0
  197. package/lib/components/Flex/constants.d.ts +41 -0
  198. package/lib/components/Flex/constants.js +51 -0
  199. package/lib/components/Flex/index.d.ts +5 -0
  200. package/lib/components/Flex/index.js +60 -0
  201. package/lib/components/Flex/interface.d.ts +13 -0
  202. package/lib/components/Flex/interface.js +6 -0
  203. package/lib/components/Flex/style/Flex.css +1 -0
  204. package/lib/components/Flex/style/Flex.scss +70 -0
  205. package/lib/components/Flex/style/css.js +4 -0
  206. package/lib/components/Flex/style/index.d.ts +1 -0
  207. package/lib/components/Flex/style/index.js +4 -0
  208. package/lib/components/Form/Form.d.ts +29 -0
  209. package/lib/components/Form/Form.js +199 -0
  210. package/lib/components/Form/FormItem.d.ts +4 -0
  211. package/lib/components/Form/FormItem.js +176 -0
  212. package/lib/components/Form/FormItemContent.d.ts +18 -0
  213. package/lib/components/Form/FormItemContent.js +156 -0
  214. package/lib/components/Form/constants.d.ts +46 -0
  215. package/lib/components/Form/constants.js +71 -0
  216. package/lib/components/Form/helper.d.ts +120 -0
  217. package/lib/components/Form/helper.js +290 -0
  218. package/lib/components/Form/index.d.ts +20 -0
  219. package/lib/components/Form/index.js +45 -0
  220. package/lib/components/Form/interface.d.ts +238 -0
  221. package/lib/components/Form/interface.js +6 -0
  222. package/lib/components/Form/style/Form.css +1 -0
  223. package/lib/components/Form/style/Form.scss +167 -0
  224. package/lib/components/Form/style/css.js +4 -0
  225. package/lib/components/Form/style/index.d.ts +1 -0
  226. package/lib/components/Form/style/index.js +4 -0
  227. package/lib/components/Form/useFormItemContext.d.ts +32 -0
  228. package/lib/components/Form/useFormItemContext.js +62 -0
  229. package/lib/components/Form/useFormItemWatch.d.ts +51 -0
  230. package/lib/components/Form/useFormItemWatch.js +76 -0
  231. package/lib/components/Form/useValidationTrigger.d.ts +40 -0
  232. package/lib/components/Form/useValidationTrigger.js +81 -0
  233. package/lib/components/Grid/Col.d.ts +5 -0
  234. package/lib/components/Grid/Col.js +107 -0
  235. package/lib/components/Grid/Grid.d.ts +12 -0
  236. package/lib/components/Grid/Grid.js +18 -0
  237. package/lib/components/Grid/Row.d.ts +5 -0
  238. package/lib/components/Grid/Row.js +58 -0
  239. package/lib/components/Grid/constants.d.ts +55 -0
  240. package/lib/components/Grid/constants.js +72 -0
  241. package/lib/components/Grid/helper.d.ts +10 -0
  242. package/lib/components/Grid/helper.js +51 -0
  243. package/lib/components/Grid/index.d.ts +7 -0
  244. package/lib/components/Grid/index.js +62 -0
  245. package/lib/components/Grid/interface.d.ts +38 -0
  246. package/lib/components/Grid/interface.js +6 -0
  247. package/lib/components/Grid/style/Grid.css +1 -0
  248. package/lib/components/Grid/style/Grid.scss +196 -0
  249. package/lib/components/Grid/style/css.js +4 -0
  250. package/lib/components/Grid/style/index.d.ts +1 -0
  251. package/lib/components/Grid/style/index.js +4 -0
  252. package/lib/components/Input/Input.js +71 -73
  253. package/lib/components/Input/interface.d.ts +9 -9
  254. package/lib/components/InputAmount/InputAmount.js +230 -278
  255. package/lib/components/InputAmount/helper.d.ts +46 -0
  256. package/lib/components/InputAmount/helper.js +122 -0
  257. package/lib/components/InputAmount/style/normal.css +1 -1
  258. package/lib/components/InputAmount/style/normal.scss +2 -2
  259. package/lib/components/InputAmount/style/primary.css +1 -1
  260. package/lib/components/InputAmount/style/primary.scss +2 -2
  261. package/lib/components/Message/style/Message.css +1 -1
  262. package/lib/components/Message/style/Message.scss +3 -3
  263. package/lib/components/ProForm/ProForm.d.ts +33 -0
  264. package/lib/components/ProForm/ProForm.js +216 -0
  265. package/lib/components/ProForm/ProFormDependency.d.ts +12 -0
  266. package/lib/components/ProForm/ProFormDependency.js +67 -0
  267. package/lib/components/ProForm/ProFormList.d.ts +19 -0
  268. package/lib/components/ProForm/ProFormList.js +355 -0
  269. package/lib/components/ProForm/Submitter.d.ts +21 -0
  270. package/lib/components/ProForm/Submitter.js +83 -0
  271. package/lib/components/ProForm/constants.d.ts +34 -0
  272. package/lib/components/ProForm/constants.js +46 -0
  273. package/lib/components/ProForm/fields/ProFormCheckbox.d.ts +6 -0
  274. package/lib/components/ProForm/fields/ProFormCheckbox.js +18 -0
  275. package/lib/components/ProForm/fields/ProFormCheckboxGroup.d.ts +6 -0
  276. package/lib/components/ProForm/fields/ProFormCheckboxGroup.js +53 -0
  277. package/lib/components/ProForm/fields/ProFormDigit.d.ts +6 -0
  278. package/lib/components/ProForm/fields/ProFormDigit.js +22 -0
  279. package/lib/components/ProForm/fields/ProFormMoney.d.ts +6 -0
  280. package/lib/components/ProForm/fields/ProFormMoney.js +17 -0
  281. package/lib/components/ProForm/fields/ProFormMultiSelect.d.ts +6 -0
  282. package/lib/components/ProForm/fields/ProFormMultiSelect.js +34 -0
  283. package/lib/components/ProForm/fields/ProFormPassword.d.ts +6 -0
  284. package/lib/components/ProForm/fields/ProFormPassword.js +23 -0
  285. package/lib/components/ProForm/fields/ProFormRadio.d.ts +6 -0
  286. package/lib/components/ProForm/fields/ProFormRadio.js +20 -0
  287. package/lib/components/ProForm/fields/ProFormSelect.d.ts +6 -0
  288. package/lib/components/ProForm/fields/ProFormSelect.js +20 -0
  289. package/lib/components/ProForm/fields/ProFormSwitch.d.ts +6 -0
  290. package/lib/components/ProForm/fields/ProFormSwitch.js +18 -0
  291. package/lib/components/ProForm/fields/ProFormText.d.ts +6 -0
  292. package/lib/components/ProForm/fields/ProFormText.js +22 -0
  293. package/lib/components/ProForm/fields/ProFormTextArea.d.ts +6 -0
  294. package/lib/components/ProForm/fields/ProFormTextArea.js +23 -0
  295. package/lib/components/ProForm/fields/createProFormField.d.ts +43 -0
  296. package/lib/components/ProForm/fields/createProFormField.js +208 -0
  297. package/lib/components/ProForm/fields/index.d.ts +12 -0
  298. package/lib/components/ProForm/fields/index.js +90 -0
  299. package/lib/components/ProForm/index.d.ts +7 -0
  300. package/lib/components/ProForm/index.js +73 -0
  301. package/lib/components/ProForm/interface.d.ts +306 -0
  302. package/lib/components/ProForm/interface.js +6 -0
  303. package/lib/components/ProForm/layouts/DrawerForm.d.ts +16 -0
  304. package/lib/components/ProForm/layouts/DrawerForm.js +86 -0
  305. package/lib/components/ProForm/layouts/ModalForm.d.ts +16 -0
  306. package/lib/components/ProForm/layouts/ModalForm.js +96 -0
  307. package/lib/components/ProForm/layouts/QueryFilter.d.ts +21 -0
  308. package/lib/components/ProForm/layouts/QueryFilter.js +139 -0
  309. package/lib/components/ProForm/layouts/StepsForm.d.ts +13 -0
  310. package/lib/components/ProForm/layouts/StepsForm.js +302 -0
  311. package/lib/components/ProForm/layouts/index.d.ts +4 -0
  312. package/lib/components/ProForm/layouts/index.js +40 -0
  313. package/lib/components/ProForm/layouts/useOverlayForm.d.ts +53 -0
  314. package/lib/components/ProForm/layouts/useOverlayForm.js +150 -0
  315. package/lib/components/ProForm/style/ProForm.module.css +1 -0
  316. package/lib/components/ProForm/style/ProForm.module.scss +59 -0
  317. package/lib/components/ProForm/style/css.js +4 -0
  318. package/lib/components/ProForm/style/index.d.ts +1 -0
  319. package/lib/components/ProForm/style/index.js +4 -0
  320. package/lib/components/ProForm/utils.d.ts +72 -0
  321. package/lib/components/ProForm/utils.js +213 -0
  322. package/lib/components/RadioGroup/RadioGroup.js +45 -22
  323. package/lib/components/RadioGroup/interface.d.ts +3 -1
  324. package/lib/components/Select/Select.d.ts +1 -1
  325. package/lib/components/Select/Select.js +114 -107
  326. package/lib/components/Select/constants.d.ts +18 -0
  327. package/lib/components/Select/constants.js +25 -0
  328. package/lib/components/Sidebar/Sidebar.js +21 -23
  329. package/lib/components/Sidebar/SidebarLogo.d.ts +7 -0
  330. package/lib/components/Sidebar/SidebarLogo.js +39 -0
  331. package/lib/components/Sidebar/SimplySidebar.d.ts +2 -2
  332. package/lib/components/Sidebar/SimplySidebar.js +17 -21
  333. package/lib/components/Sidebar/Stepper.js +14 -14
  334. package/lib/components/Sidebar/constants.d.ts +16 -0
  335. package/lib/components/Sidebar/constants.js +23 -0
  336. package/lib/components/Sidebar/style/Sidebar.css +1 -1
  337. package/lib/components/Sidebar/style/Sidebar.scss +1 -1
  338. package/lib/components/Sidebar/style/SimplySidebar.css +1 -1
  339. package/lib/components/Sidebar/style/SimplySidebar.scss +1 -1
  340. package/lib/components/Sidebar/style/Stepper.css +1 -1
  341. package/lib/components/Sidebar/style/Stepper.scss +11 -1
  342. package/lib/components/Space/Space.d.ts +5 -0
  343. package/lib/components/Space/Space.js +81 -0
  344. package/lib/components/Space/constants.d.ts +33 -0
  345. package/lib/components/Space/constants.js +43 -0
  346. package/lib/components/Space/index.d.ts +5 -0
  347. package/lib/components/Space/index.js +53 -0
  348. package/lib/components/Space/interface.d.ts +12 -0
  349. package/lib/components/Space/interface.js +6 -0
  350. package/lib/components/Space/style/Space.css +1 -0
  351. package/lib/components/Space/style/Space.scss +40 -0
  352. package/lib/components/Space/style/css.js +4 -0
  353. package/lib/components/Space/style/index.d.ts +1 -0
  354. package/lib/components/Space/style/index.js +4 -0
  355. package/lib/components/Switch/Switch.js +27 -24
  356. package/lib/components/Switch/interface.d.ts +9 -4
  357. package/lib/components/useControlledState/index.d.ts +14 -0
  358. package/lib/components/useControlledState/index.js +39 -0
  359. package/lib/components/useEventCallback/index.d.ts +11 -0
  360. package/lib/components/useEventCallback/index.js +24 -0
  361. package/lib/components/useLayoutEffect/index.d.ts +11 -0
  362. package/lib/components/useLayoutEffect/index.js +23 -0
  363. package/lib/components/useLayoutState/index.d.ts +13 -0
  364. package/lib/components/useLayoutState/index.js +79 -0
  365. package/lib/components/useMemoizedFn/index.d.ts +12 -0
  366. package/lib/components/useMemoizedFn/index.js +33 -0
  367. package/lib/components/usePrevious/index.d.ts +11 -0
  368. package/lib/components/usePrevious/index.js +25 -0
  369. package/lib/components/useSafeState/index.d.ts +12 -0
  370. package/lib/components/useSafeState/index.js +31 -0
  371. package/lib/components/useSyncState/index.d.ts +14 -0
  372. package/lib/components/useSyncState/index.js +44 -0
  373. package/lib/components/useUpdateEffect/index.d.ts +9 -0
  374. package/lib/components/useUpdateEffect/index.js +25 -0
  375. package/lib/index.css +1 -1
  376. package/lib/index.d.ts +32 -2
  377. package/lib/index.js +251 -1
  378. package/package.json +31 -1
@@ -0,0 +1,67 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports["default"] = exports.ProFormDependency = void 0;
7
+ var _jsxRuntime = require("react/jsx-runtime");
8
+ var _react = require("react");
9
+ var _reactHookForm = require("react-hook-form");
10
+ var _Form = require("../Form/Form");
11
+ var _useFormItemContext2 = require("../Form/useFormItemContext");
12
+ var __DEV__ = function () {
13
+ var _a, _b;
14
+ var maybeProcess = globalThis;
15
+ return ((_b = (_a = maybeProcess.process) === null || _a === void 0 ? void 0 : _a.env) === null || _b === void 0 ? void 0 : _b.NODE_ENV) !== 'production';
16
+ }();
17
+ var hasWarnedIsolatedDependency = false;
18
+ /**
19
+ * Watches one or more form fields and re-renders its children whenever
20
+ * the watched values change. Useful for conditional field visibility or
21
+ * cross-field derived content.
22
+ *
23
+ * @example
24
+ * ```tsx
25
+ * <ProFormDependency name={['country']}>
26
+ * {({ country }) => country === 'US' && <ProFormText name="state" label="State" />}
27
+ * </ProFormDependency>
28
+ * ```
29
+ */
30
+ var ProFormDependencyInner = function ProFormDependencyInner(props) {
31
+ var name = props.name,
32
+ children = props.children;
33
+ var _useFormItemContext = (0, _useFormItemContext2.useFormItemContext)(),
34
+ methods = _useFormItemContext.methods;
35
+ var watchedValues = (0, _reactHookForm.useWatch)({
36
+ control: methods.control,
37
+ name: name
38
+ });
39
+ var values = (0, _react.useMemo)(function () {
40
+ var names = name;
41
+ var list = watchedValues;
42
+ return names.reduce(function (acc, key, index) {
43
+ acc[key] = list[index];
44
+ return acc;
45
+ }, {});
46
+ }, [name, watchedValues]);
47
+ return (0, _jsxRuntime.jsx)(_jsxRuntime.Fragment, {
48
+ children: children(values)
49
+ });
50
+ };
51
+ var ProFormDependencyBase = function ProFormDependencyBase(props) {
52
+ var ctx = (0, _react.useContext)(_Form.FormContext);
53
+ if (!(ctx === null || ctx === void 0 ? void 0 : ctx.methods)) {
54
+ if (__DEV__ && !hasWarnedIsolatedDependency) {
55
+ hasWarnedIsolatedDependency = true;
56
+ console.warn('[ProFormDependencyBase] Missing FormContext methods. Rendering with FallbackFormProvider. ' + 'ProFormDependencyInner will use an isolated form instance, and useWatch may return undefined ' + 'for watched fields when ProFormDependency is used outside a Form.');
57
+ }
58
+ return (0, _jsxRuntime.jsx)(_useFormItemContext2.FallbackFormProvider, {
59
+ children: (0, _jsxRuntime.jsx)(ProFormDependencyInner, Object.assign({}, props))
60
+ });
61
+ }
62
+ return (0, _jsxRuntime.jsx)(ProFormDependencyInner, Object.assign({}, props));
63
+ };
64
+ ProFormDependencyBase.displayName = 'ProFormDependency';
65
+ var ProFormDependency = exports.ProFormDependency = /*#__PURE__*/(0, _react.memo)(ProFormDependencyBase);
66
+ var _default = exports["default"] = ProFormDependency;
67
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvUHJvRm9ybS9Qcm9Gb3JtRGVwZW5kZW5jeS5qcyIsImNvbXBvbmVudHMvc3JjL2NvbXBvbmVudHMvUHJvRm9ybS9Qcm9Gb3JtRGVwZW5kZW5jeS50c3giXSwibmFtZXMiOlsiX2pzeFJ1bnRpbWUiLCJyZXF1aXJlIiwiX3JlYWN0IiwiX3JlYWN0SG9va0Zvcm0iLCJfRm9ybSIsIl91c2VGb3JtSXRlbUNvbnRleHQyIiwiX19ERVZfXyIsIl9hIiwiX2IiLCJtYXliZVByb2Nlc3MiLCJnbG9iYWxUaGlzIiwicHJvY2VzcyIsImVudiIsIk5PREVfRU5WIiwiaGFzV2FybmVkSXNvbGF0ZWREZXBlbmRlbmN5IiwiUHJvRm9ybURlcGVuZGVuY3lJbm5lciIsInByb3BzIiwibmFtZSIsImNoaWxkcmVuIiwiX3VzZUZvcm1JdGVtQ29udGV4dCIsInVzZUZvcm1JdGVtQ29udGV4dCIsIm1ldGhvZHMiLCJ3YXRjaGVkVmFsdWVzIiwidXNlV2F0Y2giLCJjb250cm9sIiwidmFsdWVzIiwidXNlTWVtbyIsIm5hbWVzIiwibGlzdCIsInJlZHVjZSIsImFjYyIsImtleSIsImluZGV4IiwiX2pzeCIsIl9GcmFnbWVudCIsIlByb0Zvcm1EZXBlbmRlbmN5QmFzZSIsImN0eCIsInVzZUNvbnRleHQiLCJGb3JtQ29udGV4dCIsImNvbnNvbGUiLCJ3YXJuIiwiRmFsbGJhY2tGb3JtUHJvdmlkZXIiLCJPYmplY3QiLCJhc3NpZ24iLCJkaXNwbGF5TmFtZSIsIlByb0Zvcm1EZXBlbmRlbmN5IiwiZXhwb3J0cyIsIm1lbW8iLCJfZGVmYXVsdCJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsSUFBQUEsV0FBQSxHQUFBQyxPQUFBO0FDQUEsSUFBQUMsTUFBQSxHQUFBRCxPQUFBO0FBQ0EsSUFBQUUsY0FBQSxHQUFBRixPQUFBO0FBR0EsSUFBQUcsS0FBQSxHQUFBSCxPQUFBO0FBQ0EsSUFBQUksb0JBQUEsR0FBQUosT0FBQTtBQUVBLElBQU1LLE9BQU8sR0FBSSxZQUFL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QyxPQUFBLENBQUFELGlCQUFBLGdCQUFHLElBQUFFLFdBQUksRUFBQ1oscUJBQXFCLENBQUM7QUFBQyxJQUFBYSxRQUFBLEdBQUFGLE9BQUEsY0FFOUNELGlCQUFpQiIsImZpbGUiOiJjb21wb25lbnRzL1Byb0Zvcm0vUHJvRm9ybURlcGVuZGVuY3kuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGcmFnbWVudCBhcyBfRnJhZ21lbnQsIGpzeCBhcyBfanN4IH0gZnJvbSBcInJlYWN0L2pzeC1ydW50aW1lXCI7XG5pbXBvcnQgeyBtZW1vLCB1c2VDb250ZXh0LCB1c2VNZW1vIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgdXNlV2F0Y2ggfSBmcm9tICdyZWFjdC1ob29rLWZvcm0nO1xuaW1wb3J0IHsgRm9ybUNvbnRleHQgfSBmcm9tICcuLi9Gb3JtL0Zvcm0nO1xuaW1wb3J0IHsgRmFsbGJhY2tGb3JtUHJvdmlkZXIsIHVzZUZvcm1JdGVtQ29udGV4dCB9IGZyb20gJy4uL0Zvcm0vdXNlRm9ybUl0ZW1Db250ZXh0JztcbmNvbnN0IF9fREVWX18gPSAoKCkgPT4ge1xuICAgIHZhciBfYSwgX2I7XG4gICAgY29uc3QgbWF5YmVQcm9jZXNzID0gZ2xvYmFsVGhpcztcbiAgICByZXR1cm4gKChfYiA9IChfYSA9IG1heWJlUHJvY2Vzcy5wcm9jZXNzKSA9PT0gbnVsbCB8fCBfYSA9PT0gdm9pZCAwID8gdm9pZCAwIDogX2EuZW52KSA9PT0gbnVsbCB8fCBfYiA9PT0gdm9pZCAwID8gdm9pZCAwIDogX2IuTk9ERV9FTlYpICE9PSAncHJvZHVjdGlvbic7XG59KSgpO1xubGV0IGhhc1dhcm5lZElzb2xhdGVkRGVwZW5kZW5jeSA9IGZhbHNlO1xuLyoqXG4gKiBXYXRjaGVzIG9uZSBvciBtb3JlIGZvcm0gZmllbGRzIGFuZCByZS1yZW5kZXJzIGl0cyBjaGlsZHJlbiB3aGVuZXZlclxuICogdGhlIHdhdGNoZWQgdmFsdWVzIGNoYW5nZS4gVXNlZnVsIGZvciBjb25kaXRpb25hbCBmaWVsZCB2aXNpYmlsaXR5IG9yXG4gKiBjcm9zcy1maWVsZCBkZXJpdmVkIGNvbnRlbnQuXG4gKlxuICogQGV4YW1wbGVcbiAqIGBgYHRzeFxuICogPFByb0Zvcm1EZXBlbmRlbmN5IG5hbWU9e1snY291bnRyeSddfT5cbiAqICAgeyh7IGNvdW50cnkgfSkgPT4gY291bnRyeSA9PT0gJ1VTJyAmJiA8UHJvRm9ybVRleHQgbmFtZT1cInN0YXRlXCIgbGFiZWw9XCJTdGF0ZVwiIC8+fVxuICogPC9Qcm9Gb3JtRGVwZW5kZW5jeT5cbiAqIGBgYFxuICovXG5jb25zdCBQcm9Gb3JtRGVwZW5kZW5jeUlubmVyID0gKHByb3BzKSA9PiB7XG4gICAgY29uc3QgeyBuYW1lLCBjaGlsZHJlbiB9ID0gcHJvcHM7XG4gICAgY29uc3QgeyBtZXRob2RzIH0gPSB1c2VGb3JtSXRlbUNvbnRleHQoKTtcbiAgICBjb25zdCB3YXRjaGVkVmFsdWVzID0gdXNlV2F0Y2goeyBjb250cm9sOiBtZXRob2RzLmNvbnRyb2wsIG5hbWUgfSk7XG4gICAgY29uc3QgdmFsdWVzID0gdXNlTWVtbygoKSA9PiB7XG4gICAgICAgIGNvbnN0IG5hbWVzID0gbmFtZTtcbiAgICAgICAgY29uc3QgbGlzdCA9IHdhdGNoZWRWYWx1ZXM7XG4gICAgICAgIHJldHVybiBuYW1lcy5yZWR1Y2UoKGFjYywga2V5LCBpbmRleCkgPT4ge1xuICAgICAgICAgICAgYWNjW2tleV0gPSBsaXN0W2luZGV4XTtcbiAgICAgICAgICAgIHJldHVybiBhY2M7XG4gICAgICAgIH0sIHt9KTtcbiAgICB9LCBbbmFtZSwgd2F0Y2hlZFZhbHVlc10pO1xuICAgIHJldHVybiBfanN4KF9GcmFnbWVudCwgeyBjaGlsZHJlbjogY2hpbGRyZW4odmFsdWVzKSB9KTtcbn07XG5jb25zdCBQcm9Gb3JtRGVwZW5kZW5jeUJhc2UgPSAocHJvcHMpID0+IHtcbiAgICBjb25zdCBjdHggPSB1c2VDb250ZXh0KEZvcm1Db250ZXh0KTtcbiAgICBpZiAoIShjdHggPT09IG51bGwgfHwgY3R4ID09PSB2b2lkIDAgPyB2b2lkIDAgOiBjdHgubWV0aG9kcykpIHtcbiAgICAgICAgaWYgKF9fREVWX18gJiYgIWhhc1dhcm5lZElzb2xhdGVkRGVwZW5kZW5jeSkge1xuICAgICAgICAgICAgaGFzV2FybmVkSXNvbGF0ZWREZXBlbmRlbmN5ID0gdHJ1ZTtcbiAgICAgICAgICAgIGNvbnNvbGUud2FybignW1Byb0Zvcm1EZXBlbmRlbmN5QmFzZV0gTWlzc2luZyBGb3JtQ29udGV4dCBtZXRob2RzLiBSZW5kZXJpbmcgd2l0aCBGYWxsYmFja0Zvcm1Qcm92aWRlci4gJyArXG4gICAgICAgICAgICAgICAgJ1Byb0Zvcm1EZXBlbmRlbmN5SW5uZXIgd2lsbCB1c2UgYW4gaXNvbGF0ZWQgZm9ybSBpbnN0YW5jZSwgYW5kIHVzZVdhdGNoIG1heSByZXR1cm4gdW5kZWZpbmVkICcgK1xuICAgICAgICAgICAgICAgICdmb3Igd2F0Y2hlZCBmaWVsZHMgd2hlbiBQcm9Gb3JtRGVwZW5kZW5jeSBpcyB1c2VkIG91dHNpZGUgYSBGb3JtLicpO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiAoX2pzeChGYWxsYmFja0Zvcm1Qcm92aWRlciwgeyBjaGlsZHJlbjogX2pzeChQcm9Gb3JtRGVwZW5kZW5jeUlubmVyLCBPYmplY3QuYXNzaWduKHt9LCBwcm9wcykpIH0pKTtcbiAgICB9XG4gICAgcmV0dXJuIF9qc3goUHJvRm9ybURlcGVuZGVuY3lJbm5lciwgT2JqZWN0LmFzc2lnbih7fSwgcHJvcHMpKTtcbn07XG5Qcm9Gb3JtRGVwZW5kZW5jeUJhc2UuZGlzcGxheU5hbWUgPSAnUHJvRm9ybURlcGVuZGVuY3knO1xuZXhwb3J0IGNvbnN0IFByb0Zvcm1EZXBlbmRlbmN5ID0gbWVtbyhQcm9Gb3JtRGVwZW5kZW5jeUJhc2UpO1xuZXhwb3J0IGRlZmF1bHQgUHJvRm9ybURlcGVuZGVuY3k7IixudWxsXSwic291cmNlUm9vdCI6Ii4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3NyYyJ9
@@ -0,0 +1,19 @@
1
+ import type { DragEndEvent } from '@dnd-kit/core';
2
+ import type { FieldValues } from 'react-hook-form';
3
+ import type { ProFormListProps } from './interface';
4
+ /**
5
+ * Creates a `DndContext` `onDragEnd` handler that translates drag events
6
+ * into field array `move` calls.
7
+ *
8
+ * @param options.move - The `move` function from `useFieldArray`.
9
+ * @param options.fields - The current field array entries.
10
+ * @returns A drag-end event handler.
11
+ */
12
+ export declare const buildOnDragEnd: ({ move, fields, }: {
13
+ move: (from: number, to: number) => void;
14
+ fields: Array<{
15
+ id: string;
16
+ }>;
17
+ }) => ({ active, over }: DragEndEvent) => void;
18
+ export declare const ProFormList: import("react").NamedExoticComponent<ProFormListProps<FieldValues>>;
19
+ export default ProFormList;
@@ -0,0 +1,355 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports["default"] = exports.buildOnDragEnd = exports.ProFormList = void 0;
8
+ var _jsxRuntime = require("react/jsx-runtime");
9
+ var _core = require("@dnd-kit/core");
10
+ var _sortable = require("@dnd-kit/sortable");
11
+ var _utilities = require("@dnd-kit/utilities");
12
+ var _react = require("react");
13
+ var _classnames = require("../../utils/classnames");
14
+ var _useMemoizedFn = _interopRequireDefault(require("../useMemoizedFn"));
15
+ var _reactHookForm = require("react-hook-form");
16
+ var _Button = require("../Button");
17
+ var _constants = require("./constants");
18
+ var _ProFormModule = _interopRequireDefault(require("./style/ProForm.module.scss"));
19
+ var _utils = require("./utils");
20
+ var __rest = void 0 && (void 0).__rest || function (s, e) {
21
+ var t = {};
22
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
23
+ if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
24
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
25
+ }
26
+ return t;
27
+ };
28
+ /**
29
+ * Creates a `DndContext` `onDragEnd` handler that translates drag events
30
+ * into field array `move` calls.
31
+ *
32
+ * @param options.move - The `move` function from `useFieldArray`.
33
+ * @param options.fields - The current field array entries.
34
+ * @returns A drag-end event handler.
35
+ */
36
+ var buildOnDragEnd = exports.buildOnDragEnd = function buildOnDragEnd(_ref) {
37
+ var move = _ref.move,
38
+ fields = _ref.fields;
39
+ return function (_ref2) {
40
+ var active = _ref2.active,
41
+ over = _ref2.over;
42
+ if (!over || active.id === over.id) return;
43
+ var oldIndex = fields.findIndex(function (item) {
44
+ return item.id === String(active.id);
45
+ });
46
+ var newIndex = fields.findIndex(function (item) {
47
+ return item.id === String(over.id);
48
+ });
49
+ if (oldIndex >= 0 && newIndex >= 0) {
50
+ move(oldIndex, newIndex);
51
+ }
52
+ };
53
+ };
54
+ /** @internal Renders copy/delete action buttons for a single list row. */
55
+ var ProFormListRowBodyBase = function ProFormListRowBodyBase(_ref3) {
56
+ var fieldId = _ref3.fieldId,
57
+ index = _ref3.index,
58
+ record = _ref3.record,
59
+ copyIconProps = _ref3.copyIconProps,
60
+ deleteIconProps = _ref3.deleteIconProps,
61
+ canAdd = _ref3.canAdd,
62
+ canRemove = _ref3.canRemove,
63
+ copy = _ref3.copy,
64
+ removeAt = _ref3.removeAt,
65
+ action = _ref3.action,
66
+ actionRender = _ref3.actionRender,
67
+ itemRender = _ref3.itemRender;
68
+ var _a, _b;
69
+ var copyBtn = (0, _utils.extractButtonProps)(copyIconProps);
70
+ var deleteBtn = (0, _utils.extractButtonProps)(deleteIconProps);
71
+ var defaultDom = {
72
+ "delete": deleteIconProps === false ? null : (0, _jsxRuntime.jsx)(_Button.Button, Object.assign({}, deleteBtn.domProps, {
73
+ type: 'button',
74
+ severity: 'secondary',
75
+ onClick: function onClick(event) {
76
+ var _a;
77
+ removeAt(index);
78
+ (_a = deleteBtn.onClick) === null || _a === void 0 ? void 0 : _a.call(deleteBtn, event);
79
+ },
80
+ disabled: !canRemove || deleteBtn.disabled,
81
+ children: (_a = deleteBtn.children) !== null && _a !== void 0 ? _a : _constants.DEFAULT_TEXT["delete"]
82
+ }), "delete-".concat(fieldId)),
83
+ copy: copyIconProps === false ? null : (0, _jsxRuntime.jsx)(_Button.Button, Object.assign({}, copyBtn.domProps, {
84
+ type: 'button',
85
+ severity: 'secondary',
86
+ onClick: function onClick(event) {
87
+ var _a;
88
+ copy(index);
89
+ (_a = copyBtn.onClick) === null || _a === void 0 ? void 0 : _a.call(copyBtn, event);
90
+ },
91
+ disabled: !canAdd || copyBtn.disabled,
92
+ children: (_b = copyBtn.children) !== null && _b !== void 0 ? _b : _constants.DEFAULT_TEXT.copy
93
+ }), "copy-".concat(fieldId))
94
+ };
95
+ var renderedActions = actionRender ? actionRender({
96
+ index: index,
97
+ record: record
98
+ }, action, defaultDom) : [defaultDom.copy, defaultDom["delete"]].filter(Boolean);
99
+ var rowNode = (0, _jsxRuntime.jsx)("div", {
100
+ className: (0, _classnames.joinCls)(_ProFormModule["default"]['proform__list-row-actions'], "".concat(_constants.CSS_PREFIX, "-list-row-actions")),
101
+ children: renderedActions
102
+ });
103
+ if (!itemRender) return rowNode;
104
+ return (0, _jsxRuntime.jsx)(_jsxRuntime.Fragment, {
105
+ children: itemRender({
106
+ listDom: rowNode,
107
+ action: action
108
+ })
109
+ });
110
+ };
111
+ var ProFormListRowBody = /*#__PURE__*/(0, _react.memo)(ProFormListRowBodyBase);
112
+ /** @internal Drag-and-drop wrapper for a sortable list row. */
113
+ var SortableProFormListRowBase = function SortableProFormListRowBase(props) {
114
+ var fieldId = props.fieldId;
115
+ var _useSortable = (0, _sortable.useSortable)({
116
+ id: fieldId
117
+ }),
118
+ attributes = _useSortable.attributes,
119
+ listeners = _useSortable.listeners,
120
+ setNodeRef = _useSortable.setNodeRef,
121
+ transform = _useSortable.transform,
122
+ transition = _useSortable.transition,
123
+ isDragging = _useSortable.isDragging;
124
+ var style = {
125
+ transform: transform ? _utilities.CSS.Transform.toString(transform) : undefined,
126
+ transition: transition || undefined,
127
+ cursor: 'grab',
128
+ opacity: isDragging ? 0.8 : 1
129
+ };
130
+ return (0, _jsxRuntime.jsx)("div", Object.assign({
131
+ ref: setNodeRef,
132
+ style: style,
133
+ "data-sortable": 'true'
134
+ }, attributes, listeners, {
135
+ children: (0, _jsxRuntime.jsx)(ProFormListRowBody, Object.assign({}, props))
136
+ }));
137
+ };
138
+ var SortableProFormListRow = /*#__PURE__*/(0, _react.memo)(SortableProFormListRowBase);
139
+ /** @internal Renders the "add row" button for {@link ProFormList}. */
140
+ var CreatorButton = function CreatorButton(_ref4) {
141
+ var config = _ref4.config,
142
+ canAdd = _ref4.canAdd,
143
+ onAdd = _ref4.onAdd;
144
+ if (!config) return null;
145
+ var text = config.text,
146
+ _ = config.position,
147
+ _onClick = config.onClick,
148
+ disabled = config.disabled,
149
+ domProps = __rest(config, ["text", "position", "onClick", "disabled"]);
150
+ return (0, _jsxRuntime.jsx)(_Button.Button, Object.assign({}, domProps, {
151
+ type: 'button',
152
+ onClick: function onClick(event) {
153
+ onAdd();
154
+ _onClick === null || _onClick === void 0 ? void 0 : _onClick(event);
155
+ },
156
+ disabled: !canAdd || !!disabled,
157
+ children: text !== null && text !== void 0 ? text : _constants.DEFAULT_TEXT.add
158
+ }));
159
+ };
160
+ /**
161
+ * Dynamic, repeatable form field list with add, remove, copy, and
162
+ * drag-and-drop reordering capabilities.
163
+ *
164
+ * @example
165
+ * ```tsx
166
+ * <ProFormList name="items" min={1} max={5} sortable>
167
+ * {(fields) => fields.map(({ name, key }) => (
168
+ * <ProFormText key={key} name={`${name}.title`} label="Title" />
169
+ * ))}
170
+ * </ProFormList>
171
+ * ```
172
+ */
173
+ var ProFormListBase = function ProFormListBase(props) {
174
+ var _a;
175
+ var name = props.name,
176
+ label = props.label,
177
+ min = props.min,
178
+ max = props.max,
179
+ initialValue = props.initialValue,
180
+ copyIconProps = props.copyIconProps,
181
+ deleteIconProps = props.deleteIconProps,
182
+ creatorButtonProps = props.creatorButtonProps,
183
+ sortable = props.sortable,
184
+ itemRender = props.itemRender,
185
+ actionRender = props.actionRender,
186
+ children = props.children,
187
+ onAfterAdd = props.onAfterAdd,
188
+ onAfterRemove = props.onAfterRemove;
189
+ var initialApplied = (0, _react.useRef)(false);
190
+ var _useFormContext = (0, _reactHookForm.useFormContext)(),
191
+ control = _useFormContext.control;
192
+ var _useFieldArray = (0, _reactHookForm.useFieldArray)({
193
+ control: control,
194
+ name: name
195
+ }),
196
+ fields = _useFieldArray.fields,
197
+ append = _useFieldArray.append,
198
+ remove = _useFieldArray.remove,
199
+ move = _useFieldArray.move,
200
+ insert = _useFieldArray.insert,
201
+ replace = _useFieldArray.replace;
202
+ var watchedList = (0, _reactHookForm.useWatch)({
203
+ control: control,
204
+ name: name
205
+ });
206
+ var listSnapshot = (0, _react.useMemo)(function () {
207
+ return Array.isArray(watchedList) ? watchedList : [];
208
+ }, [watchedList]);
209
+ // Apply `initialValue` only once: `initialApplied.current` prevents re-entry,
210
+ // so even if future renders pass a new `initialValue` array reference, this
211
+ // effect will not call `replace` again once initialization has happened.
212
+ // If re-application on `initialValue` changes is desired, reset
213
+ // `initialApplied.current` intentionally (or remove this guard and diff values).
214
+ (0, _react.useEffect)(function () {
215
+ if (initialApplied.current) return;
216
+ if (fields.length !== 0) return;
217
+ if (!Array.isArray(initialValue) || initialValue.length === 0) return;
218
+ initialApplied.current = true;
219
+ replace(initialValue);
220
+ }, [fields.length, initialValue, replace]);
221
+ var canAdd = max == null || fields.length < max;
222
+ var canRemove = min == null || fields.length > min;
223
+ var add = (0, _useMemoizedFn["default"])(function (defaultValue, index) {
224
+ if (!canAdd) return;
225
+ var value = defaultValue !== null && defaultValue !== void 0 ? defaultValue : {};
226
+ if (typeof index === 'number') {
227
+ insert(index, value);
228
+ onAfterAdd === null || onAfterAdd === void 0 ? void 0 : onAfterAdd(value, index);
229
+ return;
230
+ }
231
+ append(value);
232
+ onAfterAdd === null || onAfterAdd === void 0 ? void 0 : onAfterAdd(value, fields.length);
233
+ });
234
+ var removeAt = (0, _useMemoizedFn["default"])(function (index) {
235
+ if (!canRemove) return;
236
+ remove(index);
237
+ onAfterRemove === null || onAfterRemove === void 0 ? void 0 : onAfterRemove(index);
238
+ });
239
+ var copy = (0, _useMemoizedFn["default"])(function (index) {
240
+ var _a;
241
+ if (!canAdd) return;
242
+ var value = (_a = listSnapshot[index]) !== null && _a !== void 0 ? _a : {};
243
+ add(value, index + 1);
244
+ });
245
+ var memoizedMove = (0, _useMemoizedFn["default"])(move);
246
+ var getList = (0, _useMemoizedFn["default"])(function () {
247
+ return listSnapshot;
248
+ });
249
+ var action = (0, _react.useMemo)(function () {
250
+ return {
251
+ add: add,
252
+ remove: removeAt,
253
+ move: memoizedMove,
254
+ copy: copy,
255
+ getList: getList
256
+ };
257
+ }, [add, copy, getList, memoizedMove, removeAt]);
258
+ var mappedFields = (0, _react.useMemo)(function () {
259
+ return fields.map(function (field, index) {
260
+ return {
261
+ name: "".concat(String(name), ".").concat(index),
262
+ key: field.id
263
+ };
264
+ });
265
+ }, [fields, name]);
266
+ var listDom = typeof children === 'function' ? children(mappedFields, action) : children;
267
+ var hasCreator = creatorButtonProps !== false;
268
+ var creatorConfig = hasCreator ? Object.assign({}, creatorButtonProps || {}) : undefined;
269
+ var creatorPosition = (_a = creatorConfig === null || creatorConfig === void 0 ? void 0 : creatorConfig.position) !== null && _a !== void 0 ? _a : 'bottom';
270
+ var addFromTopCreator = (0, _useMemoizedFn["default"])(function () {
271
+ return add({}, 0);
272
+ });
273
+ var addFromBottomCreator = (0, _useMemoizedFn["default"])(function () {
274
+ return add();
275
+ });
276
+ var actionRows = (0, _react.useMemo)(function () {
277
+ return fields.map(function (field, index) {
278
+ var rowRecord = listSnapshot[index];
279
+ if (sortable) {
280
+ return (0, _jsxRuntime.jsx)(SortableProFormListRow, {
281
+ fieldId: field.id,
282
+ index: index,
283
+ record: rowRecord,
284
+ copyIconProps: copyIconProps,
285
+ deleteIconProps: deleteIconProps,
286
+ canAdd: canAdd,
287
+ canRemove: canRemove,
288
+ copy: copy,
289
+ removeAt: removeAt,
290
+ action: action,
291
+ actionRender: actionRender,
292
+ itemRender: itemRender
293
+ }, field.id);
294
+ }
295
+ return (0, _jsxRuntime.jsx)(ProFormListRowBody, {
296
+ fieldId: field.id,
297
+ index: index,
298
+ record: rowRecord,
299
+ copyIconProps: copyIconProps,
300
+ deleteIconProps: deleteIconProps,
301
+ canAdd: canAdd,
302
+ canRemove: canRemove,
303
+ copy: copy,
304
+ removeAt: removeAt,
305
+ action: action,
306
+ actionRender: actionRender,
307
+ itemRender: itemRender
308
+ }, field.id);
309
+ });
310
+ }, [action, actionRender, canAdd, canRemove, copy, copyIconProps, deleteIconProps, fields, itemRender, listSnapshot, removeAt, sortable]);
311
+ var sortableIds = (0, _react.useMemo)(function () {
312
+ return fields.map(function (item) {
313
+ return item.id;
314
+ });
315
+ }, [fields]);
316
+ var dragEndHandler = (0, _react.useMemo)(function () {
317
+ return buildOnDragEnd({
318
+ move: move,
319
+ fields: fields
320
+ });
321
+ }, [fields, move]);
322
+ var actionsNode = sortable ? (0, _jsxRuntime.jsx)(_core.DndContext, {
323
+ onDragEnd: dragEndHandler,
324
+ children: (0, _jsxRuntime.jsx)(_sortable.SortableContext, {
325
+ items: sortableIds,
326
+ strategy: _sortable.verticalListSortingStrategy,
327
+ children: actionRows
328
+ })
329
+ }) : actionRows;
330
+ return (0, _jsxRuntime.jsxs)("div", {
331
+ className: (0, _classnames.joinCls)(_ProFormModule["default"]['proform__list'], "".concat(_constants.CSS_PREFIX, "-list")),
332
+ children: [label && (0, _jsxRuntime.jsx)("div", {
333
+ className: (0, _classnames.joinCls)(_ProFormModule["default"]['proform__list-label'], "".concat(_constants.CSS_PREFIX, "-list-label")),
334
+ children: label
335
+ }), creatorPosition === 'top' && (0, _jsxRuntime.jsx)(CreatorButton, {
336
+ config: creatorConfig,
337
+ canAdd: canAdd,
338
+ onAdd: addFromTopCreator
339
+ }), (0, _jsxRuntime.jsx)("div", {
340
+ className: "".concat(_constants.CSS_PREFIX, "-list-content"),
341
+ children: listDom
342
+ }), (0, _jsxRuntime.jsx)("div", {
343
+ className: "".concat(_constants.CSS_PREFIX, "-list-actions"),
344
+ children: actionsNode
345
+ }), creatorPosition === 'bottom' && (0, _jsxRuntime.jsx)(CreatorButton, {
346
+ config: creatorConfig,
347
+ canAdd: canAdd,
348
+ onAdd: addFromBottomCreator
349
+ })]
350
+ });
351
+ };
352
+ ProFormListBase.displayName = 'ProFormList';
353
+ var ProFormList = exports.ProFormList = /*#__PURE__*/(0, _react.memo)(ProFormListBase);
354
+ var _default = exports["default"] = ProFormList;
355
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["components/ProForm/ProFormList.js","components/src/components/ProForm/ProFormList.tsx"],"names":["_jsxRuntime","require","_core","_sortable","_utilities","_react","_classnames","_useMemoizedFn","_interopRequireDefault","_reactHookForm","_Button","_constants","_ProFormModule","_utils","__rest","s","e","t","p","Object","prototype","hasOwnProperty","call","indexOf","getOwnPropertySymbols","i","length","propertyIsEnumerable","buildOnDragEnd","exports","_ref","move","fields","_ref2","active","over","id","oldIndex","findIndex","item","String","newIndex","ProFormListRowBodyBase","_ref3","fieldId","index","record","copyIconProps","deleteIconProps","canAdd","canRemove","copy","removeAt","action","actionRender","itemRender","_a","_b","copyBtn","extractButtonProps","deleteBtn","defaultDom","_jsx","Button","assign","domProps","type","severity","onClick","event","disabled","children","DEFAULT_TEXT","concat","renderedActions","filter","Boolean","rowNode","className","joinCls","styles","CSS_PREFIX","_Fragment","listDom","ProFormListRowBody","memo","SortableProFormListRowBase","props","_useSortable","useSortable","attributes","listeners","setNodeRef","transform","transition","isDragging","style","CSS","Transform","toString","undefined","cursor","opacity","ref","SortableProFormListRow","CreatorButton","_ref4","config","onAdd","text","_","position","add","ProFormListBase","name","label","min","max","initialValue","creatorButtonProps","sortable","onAfterAdd","onAfterRemove","initialApplied","useRef","_useFormContext","useFormContext","control","_useFieldArray","useFieldArray","append","remove","insert","replace","watchedList","useWatch","listSnapshot","useMemo","Array","isArray","useEffect","current","useMemoizedFn","defaultValue","value","memoizedMove","getList","mappedFields","map","field","key","hasCreator","creatorConfig","creatorPosition","addFromTopCreator","addFromBottomCreator","actionRows","rowRecord","sortableIds","dragEndHandler","actionsNode","DndContext","onDragEnd","SortableContext","items","strategy","verticalListSortingStrategy","_jsxs","displayName","ProFormList","_default"],"mappings":"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","file":"components/ProForm/ProFormList.js","sourcesContent":["var __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, Fragment as _Fragment, jsxs as _jsxs } from \"react/jsx-runtime\";\nimport { DndContext } from '@dnd-kit/core';\nimport { SortableContext, useSortable, verticalListSortingStrategy } from '@dnd-kit/sortable';\nimport { CSS } from '@dnd-kit/utilities';\nimport { memo, useEffect, useMemo, useRef } from 'react';\nimport { joinCls } from '../../utils/classnames';\nimport useMemoizedFn from '../useMemoizedFn';\nimport { useFieldArray, useFormContext, useWatch } from 'react-hook-form';\nimport { Button } from '../Button';\nimport { CSS_PREFIX, DEFAULT_TEXT } from './constants';\nimport styles from './style/ProForm.module.scss';\nimport { extractButtonProps } from './utils';\n/**\n * Creates a `DndContext` `onDragEnd` handler that translates drag events\n * into field array `move` calls.\n *\n * @param options.move - The `move` function from `useFieldArray`.\n * @param options.fields - The current field array entries.\n * @returns A drag-end event handler.\n */\nexport const buildOnDragEnd = ({ move, fields, }) => {\n    return ({ active, over }) => {\n        if (!over || active.id === over.id)\n            return;\n        const oldIndex = fields.findIndex(item => item.id === String(active.id));\n        const newIndex = fields.findIndex(item => item.id === String(over.id));\n        if (oldIndex >= 0 && newIndex >= 0) {\n            move(oldIndex, newIndex);\n        }\n    };\n};\n/** @internal Renders copy/delete action buttons for a single list row. */\nconst ProFormListRowBodyBase = ({ fieldId, index, record, copyIconProps, deleteIconProps, canAdd, canRemove, copy, removeAt, action, actionRender, itemRender, }) => {\n    var _a, _b;\n    const copyBtn = extractButtonProps(copyIconProps);\n    const deleteBtn = extractButtonProps(deleteIconProps);\n    const defaultDom = {\n        delete: deleteIconProps === false\n            ? null\n            : (_jsx(Button, Object.assign({}, deleteBtn.domProps, { type: 'button', severity: 'secondary', onClick: (event) => {\n                    var _a;\n                    removeAt(index);\n                    (_a = deleteBtn.onClick) === null || _a === void 0 ? void 0 : _a.call(deleteBtn, event);\n                }, disabled: !canRemove || deleteBtn.disabled, children: (_a = deleteBtn.children) !== null && _a !== void 0 ? _a : DEFAULT_TEXT.delete }), `delete-${fieldId}`)),\n        copy: copyIconProps === false\n            ? null\n            : (_jsx(Button, Object.assign({}, copyBtn.domProps, { type: 'button', severity: 'secondary', onClick: (event) => {\n                    var _a;\n                    copy(index);\n                    (_a = copyBtn.onClick) === null || _a === void 0 ? void 0 : _a.call(copyBtn, event);\n                }, disabled: !canAdd || copyBtn.disabled, children: (_b = copyBtn.children) !== null && _b !== void 0 ? _b : DEFAULT_TEXT.copy }), `copy-${fieldId}`)),\n    };\n    const renderedActions = actionRender\n        ? actionRender({ index, record }, action, defaultDom)\n        : [defaultDom.copy, defaultDom.delete].filter(Boolean);\n    const rowNode = (_jsx(\"div\", { className: joinCls(styles['proform__list-row-actions'], `${CSS_PREFIX}-list-row-actions`), children: renderedActions }));\n    if (!itemRender)\n        return rowNode;\n    return _jsx(_Fragment, { children: itemRender({ listDom: rowNode, action }) });\n};\nconst ProFormListRowBody = memo(ProFormListRowBodyBase);\n/** @internal Drag-and-drop wrapper for a sortable list row. */\nconst SortableProFormListRowBase = (props) => {\n    const { fieldId } = props;\n    const { attributes, listeners, setNodeRef, transform, transition, isDragging, } = useSortable({ id: fieldId });\n    const style = {\n        transform: transform ? CSS.Transform.toString(transform) : undefined,\n        transition: transition || undefined,\n        cursor: 'grab',\n        opacity: isDragging ? 0.8 : 1,\n    };\n    return (_jsx(\"div\", Object.assign({ ref: setNodeRef, style: style, \"data-sortable\": 'true' }, attributes, listeners, { children: _jsx(ProFormListRowBody, Object.assign({}, props)) })));\n};\nconst SortableProFormListRow = memo(SortableProFormListRowBase);\n/** @internal Renders the \"add row\" button for {@link ProFormList}. */\nconst CreatorButton = ({ config, canAdd, onAdd }) => {\n    if (!config)\n        return null;\n    const { text, position: _, onClick, disabled } = config, domProps = __rest(config, [\"text\", \"position\", \"onClick\", \"disabled\"]);\n    return (_jsx(Button, Object.assign({}, domProps, { type: 'button', onClick: (event) => {\n            onAdd();\n            onClick === null || onClick === void 0 ? void 0 : onClick(event);\n        }, disabled: !canAdd || !!disabled, children: text !== null && text !== void 0 ? text : DEFAULT_TEXT.add })));\n};\n/**\n * Dynamic, repeatable form field list with add, remove, copy, and\n * drag-and-drop reordering capabilities.\n *\n * @example\n * ```tsx\n * <ProFormList name=\"items\" min={1} max={5} sortable>\n *   {(fields) => fields.map(({ name, key }) => (\n *     <ProFormText key={key} name={`${name}.title`} label=\"Title\" />\n *   ))}\n * </ProFormList>\n * ```\n */\nconst ProFormListBase = (props) => {\n    var _a;\n    const { name, label, min, max, initialValue, copyIconProps, deleteIconProps, creatorButtonProps, sortable, itemRender, actionRender, children, onAfterAdd, onAfterRemove, } = props;\n    const initialApplied = useRef(false);\n    const { control } = useFormContext();\n    const { fields, append, remove, move, insert, replace } = useFieldArray({\n        control,\n        name: name,\n    });\n    const watchedList = useWatch({ control, name: name });\n    const listSnapshot = useMemo(() => {\n        return Array.isArray(watchedList) ? watchedList : [];\n    }, [watchedList]);\n    // Apply `initialValue` only once: `initialApplied.current` prevents re-entry,\n    // so even if future renders pass a new `initialValue` array reference, this\n    // effect will not call `replace` again once initialization has happened.\n    // If re-application on `initialValue` changes is desired, reset\n    // `initialApplied.current` intentionally (or remove this guard and diff values).\n    useEffect(() => {\n        if (initialApplied.current)\n            return;\n        if (fields.length !== 0)\n            return;\n        if (!Array.isArray(initialValue) || initialValue.length === 0)\n            return;\n        initialApplied.current = true;\n        replace(initialValue);\n    }, [fields.length, initialValue, replace]);\n    const canAdd = max == null || fields.length < max;\n    const canRemove = min == null || fields.length > min;\n    const add = useMemoizedFn((defaultValue, index) => {\n        if (!canAdd)\n            return;\n        const value = defaultValue !== null && defaultValue !== void 0 ? defaultValue : {};\n        if (typeof index === 'number') {\n            insert(index, value);\n            onAfterAdd === null || onAfterAdd === void 0 ? void 0 : onAfterAdd(value, index);\n            return;\n        }\n        append(value);\n        onAfterAdd === null || onAfterAdd === void 0 ? void 0 : onAfterAdd(value, fields.length);\n    });\n    const removeAt = useMemoizedFn((index) => {\n        if (!canRemove)\n            return;\n        remove(index);\n        onAfterRemove === null || onAfterRemove === void 0 ? void 0 : onAfterRemove(index);\n    });\n    const copy = useMemoizedFn((index) => {\n        var _a;\n        if (!canAdd)\n            return;\n        const value = (_a = listSnapshot[index]) !== null && _a !== void 0 ? _a : {};\n        add(value, index + 1);\n    });\n    const memoizedMove = useMemoizedFn(move);\n    const getList = useMemoizedFn(() => listSnapshot);\n    const action = useMemo(() => ({\n        add,\n        remove: removeAt,\n        move: memoizedMove,\n        copy,\n        getList,\n    }), [add, copy, getList, memoizedMove, removeAt]);\n    const mappedFields = useMemo(() => {\n        return fields.map((field, index) => ({\n            name: `${String(name)}.${index}`,\n            key: field.id,\n        }));\n    }, [fields, name]);\n    const listDom = typeof children === 'function'\n        ? children(mappedFields, action)\n        : children;\n    const hasCreator = creatorButtonProps !== false;\n    const creatorConfig = hasCreator\n        ? Object.assign({}, (creatorButtonProps || {})) : undefined;\n    const creatorPosition = (_a = creatorConfig === null || creatorConfig === void 0 ? void 0 : creatorConfig.position) !== null && _a !== void 0 ? _a : 'bottom';\n    const addFromTopCreator = useMemoizedFn(() => add({}, 0));\n    const addFromBottomCreator = useMemoizedFn(() => add());\n    const actionRows = useMemo(() => {\n        return fields.map((field, index) => {\n            const rowRecord = listSnapshot[index];\n            if (sortable) {\n                return (_jsx(SortableProFormListRow, { fieldId: field.id, index: index, record: rowRecord, copyIconProps: copyIconProps, deleteIconProps: deleteIconProps, canAdd: canAdd, canRemove: canRemove, copy: copy, removeAt: removeAt, action: action, actionRender: actionRender, itemRender: itemRender }, field.id));\n            }\n            return (_jsx(ProFormListRowBody, { fieldId: field.id, index: index, record: rowRecord, copyIconProps: copyIconProps, deleteIconProps: deleteIconProps, canAdd: canAdd, canRemove: canRemove, copy: copy, removeAt: removeAt, action: action, actionRender: actionRender, itemRender: itemRender }, field.id));\n        });\n    }, [\n        action,\n        actionRender,\n        canAdd,\n        canRemove,\n        copy,\n        copyIconProps,\n        deleteIconProps,\n        fields,\n        itemRender,\n        listSnapshot,\n        removeAt,\n        sortable,\n    ]);\n    const sortableIds = useMemo(() => fields.map(item => item.id), [fields]);\n    const dragEndHandler = useMemo(() => buildOnDragEnd({ move, fields: fields }), [fields, move]);\n    const actionsNode = sortable\n        ? (_jsx(DndContext, { onDragEnd: dragEndHandler, children: _jsx(SortableContext, { items: sortableIds, strategy: verticalListSortingStrategy, children: actionRows }) }))\n        : actionRows;\n    return (_jsxs(\"div\", { className: joinCls(styles['proform__list'], `${CSS_PREFIX}-list`), children: [label && _jsx(\"div\", { className: joinCls(styles['proform__list-label'], `${CSS_PREFIX}-list-label`), children: label }), creatorPosition === 'top' && (_jsx(CreatorButton, { config: creatorConfig, canAdd: canAdd, onAdd: addFromTopCreator })), _jsx(\"div\", { className: `${CSS_PREFIX}-list-content`, children: listDom }), _jsx(\"div\", { className: `${CSS_PREFIX}-list-actions`, children: actionsNode }), creatorPosition === 'bottom' && (_jsx(CreatorButton, { config: creatorConfig, canAdd: canAdd, onAdd: addFromBottomCreator }))] }));\n};\nProFormListBase.displayName = 'ProFormList';\nexport const ProFormList = memo(ProFormListBase);\nexport default ProFormList;",null],"sourceRoot":"../../../../../../../../../src"}
@@ -0,0 +1,21 @@
1
+ import type { FieldValues, UseFormReturn } from 'react-hook-form';
2
+ import type { SubmitterProps } from './interface';
3
+ /** @internal Props used by the Submitter component, extending public {@link SubmitterProps} with internal callbacks. */
4
+ interface InnerSubmitterProps<TFieldValues extends FieldValues = FieldValues> extends SubmitterProps<TFieldValues> {
5
+ /** The `react-hook-form` instance (used for custom render functions). */
6
+ form?: UseFormReturn<TFieldValues>;
7
+ /** Internal callback to trigger form submission from a custom render. */
8
+ onSubmitForm?: () => void;
9
+ }
10
+ /**
11
+ * Renders the submit and reset buttons for a {@link ProForm}.
12
+ * Supports custom rendering via the `render` prop.
13
+ *
14
+ * @typeParam TFieldValues - The form values type.
15
+ */
16
+ declare function SubmitterBase<TFieldValues extends FieldValues = FieldValues>(props: InnerSubmitterProps<TFieldValues>): import("react/jsx-runtime").JSX.Element;
17
+ declare namespace SubmitterBase {
18
+ var displayName: string;
19
+ }
20
+ export declare const Submitter: typeof SubmitterBase;
21
+ export default Submitter;
@@ -0,0 +1,83 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports["default"] = exports.Submitter = void 0;
8
+ var _jsxRuntime = require("react/jsx-runtime");
9
+ var _react = require("react");
10
+ var _classnames = require("../../utils/classnames");
11
+ var _useMemoizedFn = _interopRequireDefault(require("../useMemoizedFn"));
12
+ var _Button = require("../Button");
13
+ var _constants = require("./constants");
14
+ var _ProFormModule = _interopRequireDefault(require("./style/ProForm.module.scss"));
15
+ /**
16
+ * Renders the submit and reset buttons for a {@link ProForm}.
17
+ * Supports custom rendering via the `render` prop.
18
+ *
19
+ * @typeParam TFieldValues - The form values type.
20
+ */
21
+ function SubmitterBase(props) {
22
+ var _a, _b, _c;
23
+ var _props$submitText = props.submitText,
24
+ submitText = _props$submitText === void 0 ? _constants.DEFAULT_TEXT.submit : _props$submitText,
25
+ _props$resetText = props.resetText,
26
+ resetText = _props$resetText === void 0 ? _constants.DEFAULT_TEXT.reset : _props$resetText,
27
+ render = props.render,
28
+ onSubmit = props.onSubmit,
29
+ onReset = props.onReset,
30
+ submitButtonProps = props.submitButtonProps,
31
+ resetButtonProps = props.resetButtonProps,
32
+ form = props.form,
33
+ onSubmitForm = props.onSubmitForm;
34
+ var handleSubmit = (0, _useMemoizedFn["default"])(function (event) {
35
+ var _a;
36
+ (_a = submitButtonProps === null || submitButtonProps === void 0 ? void 0 : submitButtonProps.onClick) === null || _a === void 0 ? void 0 : _a.call(submitButtonProps, event);
37
+ onSubmit === null || onSubmit === void 0 ? void 0 : onSubmit();
38
+ });
39
+ var handleReset = (0, _useMemoizedFn["default"])(function (event) {
40
+ var _a, _b;
41
+ if (event) {
42
+ (_a = resetButtonProps === null || resetButtonProps === void 0 ? void 0 : resetButtonProps.onClick) === null || _a === void 0 ? void 0 : _a.call(resetButtonProps, event);
43
+ } else {
44
+ (_b = resetButtonProps === null || resetButtonProps === void 0 ? void 0 : resetButtonProps.onClick) === null || _b === void 0 ? void 0 : _b.call(resetButtonProps);
45
+ }
46
+ onReset === null || onReset === void 0 ? void 0 : onReset();
47
+ });
48
+ var handleRenderSubmit = (0, _useMemoizedFn["default"])(function () {
49
+ if (onSubmitForm) {
50
+ onSubmitForm();
51
+ return;
52
+ }
53
+ onSubmit === null || onSubmit === void 0 ? void 0 : onSubmit();
54
+ });
55
+ var submitDom = (0, _jsxRuntime.jsx)(_Button.Button, Object.assign({}, submitButtonProps, {
56
+ type: (_a = submitButtonProps === null || submitButtonProps === void 0 ? void 0 : submitButtonProps.type) !== null && _a !== void 0 ? _a : 'submit',
57
+ onClick: handleSubmit,
58
+ children: submitText
59
+ }), 'submit');
60
+ var resetDom = (0, _jsxRuntime.jsx)(_Button.Button, Object.assign({}, resetButtonProps, {
61
+ type: (_b = resetButtonProps === null || resetButtonProps === void 0 ? void 0 : resetButtonProps.type) !== null && _b !== void 0 ? _b : 'button',
62
+ severity: (_c = resetButtonProps === null || resetButtonProps === void 0 ? void 0 : resetButtonProps.severity) !== null && _c !== void 0 ? _c : 'secondary',
63
+ onClick: handleReset,
64
+ children: resetText
65
+ }), 'reset');
66
+ // Button order: Reset first, Submit last (standard form UX pattern)
67
+ var dom = [resetDom, submitDom];
68
+ var renderedDom = render ? render({
69
+ form: form,
70
+ submit: handleRenderSubmit,
71
+ reset: function reset() {
72
+ return handleReset();
73
+ }
74
+ }, dom) : dom;
75
+ return (0, _jsxRuntime.jsx)("div", {
76
+ className: (0, _classnames.joinCls)(_ProFormModule["default"]['proform__submitter'], "".concat(_constants.CSS_PREFIX, "-submitter")),
77
+ children: renderedDom
78
+ });
79
+ }
80
+ SubmitterBase.displayName = 'Submitter';
81
+ var Submitter = exports.Submitter = /*#__PURE__*/(0, _react.memo)(SubmitterBase);
82
+ var _default = exports["default"] = Submitter;
83
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["components/ProForm/Submitter.js","components/src/components/ProForm/Submitter.tsx"],"names":["_jsxRuntime","require","_react","_classnames","_useMemoizedFn","_interopRequireDefault","_Button","_constants","_ProFormModule","SubmitterBase","props","_a","_b","_c","_props$submitText","submitText","DEFAULT_TEXT","submit","_props$resetText","resetText","reset","render","onSubmit","onReset","submitButtonProps","resetButtonProps","form","onSubmitForm","handleSubmit","useMemoizedFn","event","onClick","call","handleReset","handleRenderSubmit","submitDom","_jsx","Button","Object","assign","type","children","resetDom","severity","dom","renderedDom","className","joinCls","styles","concat","CSS_PREFIX","displayName","Submitter","exports","memo","_default"],"mappings":"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","file":"components/ProForm/Submitter.js","sourcesContent":["import { jsx as _jsx } from \"react/jsx-runtime\";\nimport { memo } from 'react';\nimport { joinCls } from '../../utils/classnames';\nimport useMemoizedFn from '../useMemoizedFn';\nimport { Button } from '../Button';\nimport { CSS_PREFIX, DEFAULT_TEXT } from './constants';\nimport styles from './style/ProForm.module.scss';\n/**\n * Renders the submit and reset buttons for a {@link ProForm}.\n * Supports custom rendering via the `render` prop.\n *\n * @typeParam TFieldValues - The form values type.\n */\nfunction SubmitterBase(props) {\n    var _a, _b, _c;\n    const { submitText = DEFAULT_TEXT.submit, resetText = DEFAULT_TEXT.reset, render, onSubmit, onReset, submitButtonProps, resetButtonProps, form, onSubmitForm, } = props;\n    const handleSubmit = useMemoizedFn((event) => {\n        var _a;\n        (_a = submitButtonProps === null || submitButtonProps === void 0 ? void 0 : submitButtonProps.onClick) === null || _a === void 0 ? void 0 : _a.call(submitButtonProps, event);\n        onSubmit === null || onSubmit === void 0 ? void 0 : onSubmit();\n    });\n    const handleReset = useMemoizedFn((event) => {\n        var _a, _b;\n        if (event) {\n            (_a = resetButtonProps === null || resetButtonProps === void 0 ? void 0 : resetButtonProps.onClick) === null || _a === void 0 ? void 0 : _a.call(resetButtonProps, event);\n        }\n        else {\n            (_b = resetButtonProps === null || resetButtonProps === void 0 ? void 0 : resetButtonProps.onClick) === null || _b === void 0 ? void 0 : _b.call(resetButtonProps);\n        }\n        onReset === null || onReset === void 0 ? void 0 : onReset();\n    });\n    const handleRenderSubmit = useMemoizedFn(() => {\n        if (onSubmitForm) {\n            onSubmitForm();\n            return;\n        }\n        onSubmit === null || onSubmit === void 0 ? void 0 : onSubmit();\n    });\n    const submitDom = (_jsx(Button, Object.assign({}, submitButtonProps, { type: (_a = submitButtonProps === null || submitButtonProps === void 0 ? void 0 : submitButtonProps.type) !== null && _a !== void 0 ? _a : 'submit', onClick: handleSubmit, children: submitText }), 'submit'));\n    const resetDom = (_jsx(Button, Object.assign({}, resetButtonProps, { type: (_b = resetButtonProps === null || resetButtonProps === void 0 ? void 0 : resetButtonProps.type) !== null && _b !== void 0 ? _b : 'button', severity: (_c = resetButtonProps === null || resetButtonProps === void 0 ? void 0 : resetButtonProps.severity) !== null && _c !== void 0 ? _c : 'secondary', onClick: handleReset, children: resetText }), 'reset'));\n    // Button order: Reset first, Submit last (standard form UX pattern)\n    const dom = [resetDom, submitDom];\n    const renderedDom = render\n        ? render({ form, submit: handleRenderSubmit, reset: () => handleReset() }, dom)\n        : dom;\n    return (_jsx(\"div\", { className: joinCls(styles['proform__submitter'], `${CSS_PREFIX}-submitter`), children: renderedDom }));\n}\nSubmitterBase.displayName = 'Submitter';\nexport const Submitter = memo(SubmitterBase);\nexport default Submitter;",null],"sourceRoot":"../../../../../../../../../src"}