@para-ui/core 5.0.0-beta.12 → 5.0.0-beta.14

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 (565) hide show
  1. package/AGENTS.md +315 -0
  2. package/AlignBox/component.json +89 -0
  3. package/Anchor/component.json +130 -0
  4. package/Argv/component.json +216 -0
  5. package/AutoBox/component.json +133 -0
  6. package/AutoButton/component.json +109 -0
  7. package/AutoTips/component.json +121 -0
  8. package/Badge/component.json +92 -0
  9. package/Breadcrumbs/component.json +142 -0
  10. package/Button/component.json +168 -0
  11. package/ButtonGroup/component.json +132 -0
  12. package/Card/component.json +162 -0
  13. package/Carousel/component.json +142 -0
  14. package/Cascader/component.json +196 -0
  15. package/Checkbox/component.json +138 -0
  16. package/CheckboxGroup/component.json +152 -0
  17. package/CodeEditor/component.json +189 -0
  18. package/Collapse/component.json +166 -0
  19. package/CollapseBox/component.json +84 -0
  20. package/CollapseLayout/component.json +155 -0
  21. package/ColorPicker/component.json +142 -0
  22. package/ComboSelect/component.json +181 -0
  23. package/Container/component.json +111 -0
  24. package/ContentBox/component.json +81 -0
  25. package/CopyText/component.json +118 -0
  26. package/CycleSelector/component.json +98 -0
  27. package/DatePicker/component.json +192 -0
  28. package/Descriptions/component.json +142 -0
  29. package/Desktop/component.json +171 -0
  30. package/DragVerify/component.json +114 -0
  31. package/Drawer/component.json +200 -0
  32. package/Dropdown/component.json +147 -0
  33. package/DynamicMultiBox/component.json +278 -0
  34. package/Empty/component.json +123 -0
  35. package/FieldForm/component.json +196 -0
  36. package/Form/component.json +161 -0
  37. package/FormItem/component.json +171 -0
  38. package/FunctionModal/component.json +197 -0
  39. package/Help/component.json +118 -0
  40. package/HelperText/component.json +126 -0
  41. package/Image/component.json +165 -0
  42. package/InputCode/component.json +191 -0
  43. package/InputLang/component.json +205 -0
  44. package/InputNumber/component.json +162 -0
  45. package/Label/component.json +126 -0
  46. package/Loading/component.json +91 -0
  47. package/Menu/component.json +180 -0
  48. package/Message/component.json +246 -0
  49. package/Modal/component.json +277 -0
  50. package/MultiBox/component.json +216 -0
  51. package/Notification/component.json +184 -0
  52. package/OperateBtn/component.json +134 -0
  53. package/PageHeader/component.json +112 -0
  54. package/Pagination/component.json +181 -0
  55. package/PasswordRules/component.json +105 -0
  56. package/PopConfirm/component.json +227 -0
  57. package/PopMenu/component.json +131 -0
  58. package/Popover/component.json +165 -0
  59. package/Progress/component.json +161 -0
  60. package/Prompt/component.json +144 -0
  61. package/Querying/component.json +96 -0
  62. package/QuickReply/component.json +129 -0
  63. package/Radio/component.json +136 -0
  64. package/RadioGroup/component.json +149 -0
  65. package/RangeInput/component.json +198 -0
  66. package/Result/component.json +104 -0
  67. package/ScrollBar/component.json +115 -0
  68. package/Search/component.json +177 -0
  69. package/Select/component.json +244 -0
  70. package/SelectInput/component.json +184 -0
  71. package/Selector/component.json +203 -0
  72. package/SelectorPicker/component.json +179 -0
  73. package/SingleBox/component.json +151 -0
  74. package/Slider/component.json +181 -0
  75. package/SortBox/component.json +108 -0
  76. package/Status/component.json +104 -0
  77. package/Stepper/component.json +129 -0
  78. package/Switch/component.json +207 -0
  79. package/Table/component.json +547 -0
  80. package/Tabs/component.json +227 -0
  81. package/Tag/component.json +221 -0
  82. package/TextEditor/component.json +186 -0
  83. package/TextField/component.json +290 -0
  84. package/TimePicker/component.json +176 -0
  85. package/Timeline/component.json +110 -0
  86. package/Title/component.json +156 -0
  87. package/ToggleButton/component.json +153 -0
  88. package/Tooltip/component.json +176 -0
  89. package/Transfer/component.json +157 -0
  90. package/Tree/component.json +512 -0
  91. package/Upload/component.json +450 -0
  92. package/ai-workflows/01-crud-list-multi-drawer.md +278 -0
  93. package/ai-workflows/02-rbac-operation-buttons.md +290 -0
  94. package/ai-workflows/03-complex-form-async-cascade.md +350 -0
  95. package/ai-workflows/04-array-field-form.md +281 -0
  96. package/ai-workflows/05-popconfirm-async-message-queue.md +333 -0
  97. package/ai-workflows/06-modal-drawer-form-workflow.md +385 -0
  98. package/ai-workflows/07-search-filter-table-trio.md +387 -0
  99. package/ai-workflows/08-table-advanced-features.md +365 -0
  100. package/ai-workflows/09-batch-operation-export-progress.md +367 -0
  101. package/ai-workflows/10-cross-component-state-coordination.md +412 -0
  102. package/codemods/modal-onCancel-to-onDismiss.js +69 -0
  103. package/es/AlignBox/component.json +89 -0
  104. package/es/AlignBox/index.css +1 -1
  105. package/es/AlignBox/index.d.ts +6 -2
  106. package/es/AlignBox/index.js +1 -1
  107. package/es/AlignBox/style/index.css +1 -1
  108. package/es/Anchor/anchorMenu/index.d.ts +2 -1
  109. package/es/Anchor/anchorMenu/index.js +36 -33
  110. package/es/Anchor/component.json +130 -0
  111. package/es/Anchor/index.js +50 -47
  112. package/es/Anchor/type.d.ts +8 -4
  113. package/es/Argv/component.json +216 -0
  114. package/es/Argv/index.d.ts +5 -6
  115. package/es/AutoBox/component.json +133 -0
  116. package/es/AutoBox/index.d.ts +3 -3
  117. package/es/AutoBox/index.js +1 -1
  118. package/es/AutoBox/protal.d.ts +2 -2
  119. package/es/AutoBox/protal.js +32 -29
  120. package/es/AutoButton/component.json +109 -0
  121. package/es/AutoButton/index.js +1 -1
  122. package/es/AutoTips/autoTipsMultiline/index.d.ts +1 -1
  123. package/es/AutoTips/autoTipsMultiline/index.js +1 -1
  124. package/es/AutoTips/component.json +121 -0
  125. package/es/Badge/component.json +92 -0
  126. package/es/Breadcrumbs/component.json +142 -0
  127. package/es/Breadcrumbs/index.js +1 -1
  128. package/es/Button/SplitButton.d.ts +2 -2
  129. package/es/Button/component.json +168 -0
  130. package/es/Button/index.js +44 -44
  131. package/es/ButtonGroup/component.json +132 -0
  132. package/es/ButtonGroup/index.d.ts +1 -1
  133. package/es/Card/component.json +162 -0
  134. package/es/Card/index.d.ts +2 -2
  135. package/es/Card/index.js +2 -2
  136. package/es/Carousel/component.json +142 -0
  137. package/es/Carousel/index.d.ts +1 -1
  138. package/es/Cascader/Cascader.js +188 -180
  139. package/es/Cascader/component.json +196 -0
  140. package/es/Cascader/hooks/useEntities.js +7 -7
  141. package/es/Cascader/interface.d.ts +1 -0
  142. package/es/Cascader/utils/commonUtil.d.ts +1 -1
  143. package/es/Cascader/utils/commonUtil.js +16 -16
  144. package/es/Cascader/utils/treeUtil.d.ts +14 -5
  145. package/es/Cascader/utils/treeUtil.js +1 -1
  146. package/es/Checkbox/component.json +138 -0
  147. package/es/CheckboxGroup/component.json +152 -0
  148. package/es/CodeEditor/component.json +189 -0
  149. package/es/CodeEditor/index.d.ts +10 -9
  150. package/es/Collapse/component.json +166 -0
  151. package/es/Collapse/index.d.ts +1 -1
  152. package/es/Collapse/index.js +41 -33
  153. package/es/CollapseBox/component.json +84 -0
  154. package/es/CollapseLayout/component.json +155 -0
  155. package/es/ColorPicker/component.json +142 -0
  156. package/es/ComboSelect/component.json +181 -0
  157. package/es/ComboSelect/index.js +299 -287
  158. package/es/ComboSelect/interface.d.ts +6 -3
  159. package/es/ComboSelect/utils.d.ts +3 -3
  160. package/es/ComboSelect/utils.js +1 -1
  161. package/es/Container/component.json +111 -0
  162. package/es/ContentBox/component.json +81 -0
  163. package/es/CopyText/component.json +118 -0
  164. package/es/CycleSelector/component.json +98 -0
  165. package/es/CycleSelector/index.js +14 -13
  166. package/es/DatePicker/component.json +192 -0
  167. package/es/DatePicker/generatePicker/generateRangePicker.d.ts +0 -8
  168. package/es/DatePicker/generatePicker/generateRangePicker.js +73 -65
  169. package/es/DatePicker/generatePicker/generateSinglePicker.js +1 -1
  170. package/es/DatePicker/generatePicker/index.d.ts +11 -4
  171. package/es/Descriptions/component.json +142 -0
  172. package/es/Descriptions/index.d.ts +1 -1
  173. package/es/Desktop/component.json +171 -0
  174. package/es/DragVerify/component.json +114 -0
  175. package/es/DragVerify/index.js +19 -19
  176. package/es/Drawer/component.json +200 -0
  177. package/es/Drawer/index.js +86 -86
  178. package/es/Drawer/interface.d.ts +1 -1
  179. package/es/Drawer/util.d.ts +1 -6
  180. package/es/Drawer/util.js +9 -6
  181. package/es/Dropdown/component.json +147 -0
  182. package/es/DynamicMultiBox/component.json +278 -0
  183. package/es/DynamicMultiBox/formItem.d.ts +1 -1
  184. package/es/DynamicMultiBox/rowForm.d.ts +2 -2
  185. package/es/Empty/component.json +123 -0
  186. package/es/Empty/index.css +1 -1
  187. package/es/Empty/index.d.ts +2 -2
  188. package/es/Empty/index.js +27 -26
  189. package/es/Empty/style/index.css +1 -1
  190. package/es/FieldForm/FieldFormItem/MemoInput.d.ts +2 -2
  191. package/es/FieldForm/FieldFormItem/index.d.ts +6 -6
  192. package/es/FieldForm/Form.d.ts +2 -2
  193. package/es/FieldForm/FormList.d.ts +2 -2
  194. package/es/FieldForm/component.json +196 -0
  195. package/es/FieldForm/context.d.ts +5 -1
  196. package/es/FieldForm/context.js +2 -2
  197. package/es/FieldForm/hooks/useForm.d.ts +4 -3
  198. package/es/FieldForm/hooks/useFormInstance.d.ts +1 -1
  199. package/es/FieldForm/hooks/useFormItemStatus.d.ts +9 -5
  200. package/es/FieldForm/hooks/useFormItemStatus.js +2 -2
  201. package/es/FieldForm/hooks/useItemRef.d.ts +1 -1
  202. package/es/FieldForm/hooks/useItemRef.js +6 -6
  203. package/es/Form/component.json +161 -0
  204. package/es/Form/index.d.ts +52 -49
  205. package/es/FormItem/compoments/defaultCompoments/index.d.ts +5 -5
  206. package/es/FormItem/compoments/defaultCompoments/index.js +12 -11
  207. package/es/FormItem/compoments/formCheckboxGroup/index.d.ts +2 -2
  208. package/es/FormItem/compoments/formFile/index.js +8 -8
  209. package/es/FormItem/compoments/formRadioGroup/index.d.ts +1 -1
  210. package/es/FormItem/compoments/formSelect/index.d.ts +1 -1
  211. package/es/FormItem/component.json +171 -0
  212. package/es/FormItem/index.d.ts +5 -5
  213. package/es/FormItem/index.js +23 -23
  214. package/es/FormItem/itemType.js +1 -1
  215. package/es/FunctionModal/component.json +197 -0
  216. package/es/FunctionModal/dialog.d.ts +1 -1
  217. package/es/FunctionModal/modalContext.d.ts +4 -1
  218. package/es/Help/component.json +118 -0
  219. package/es/HelperText/component.json +126 -0
  220. package/es/Image/component.json +165 -0
  221. package/es/InputCode/component.json +191 -0
  222. package/es/InputCode/index.d.ts +2 -2
  223. package/es/InputLang/component.json +205 -0
  224. package/es/InputLang/index.js +1 -1
  225. package/es/InputNumber/component.json +162 -0
  226. package/es/Label/component.json +126 -0
  227. package/es/Label/index.d.ts +2 -2
  228. package/es/Loading/component.json +91 -0
  229. package/es/Menu/component.json +180 -0
  230. package/es/Message/component.json +246 -0
  231. package/es/Message/index.d.ts +2 -2
  232. package/es/Message/index.js +2 -2
  233. package/es/Modal/Confirm/index.d.ts +1 -1
  234. package/es/Modal/Confirm/index.js +81 -75
  235. package/es/Modal/component.json +277 -0
  236. package/es/Modal/index.d.ts +97 -6
  237. package/es/Modal/index.js +174 -122
  238. package/es/Modal/interface.d.ts +1 -0
  239. package/es/MultiBox/component.json +216 -0
  240. package/es/MultiBox/index.js +19 -14
  241. package/es/Notification/component.json +184 -0
  242. package/es/OperateBtn/component.json +134 -0
  243. package/es/OperateBtn/index.d.ts +3 -3
  244. package/es/PageHeader/component.json +112 -0
  245. package/es/Pagination/component.json +181 -0
  246. package/es/Pagination/index.js +15 -15
  247. package/es/PasswordRules/component.json +105 -0
  248. package/es/PasswordRules/index.d.ts +4 -4
  249. package/es/PopConfirm/component.json +227 -0
  250. package/es/PopConfirm/index.d.ts +1 -1
  251. package/es/PopConfirm/index.js +1 -1
  252. package/es/PopMenu/component.json +131 -0
  253. package/es/PopMenu/hooks.d.ts +1 -1
  254. package/es/PopMenu/index.js +8 -8
  255. package/es/Popover/component.json +165 -0
  256. package/es/Popover/index.js +1 -1
  257. package/es/Progress/component.json +161 -0
  258. package/es/Prompt/component.json +144 -0
  259. package/es/Querying/component.json +96 -0
  260. package/es/Querying/index.css +1 -1
  261. package/es/Querying/index.d.ts +2 -2
  262. package/es/Querying/index.js +20 -19
  263. package/es/Querying/style/index.css +1 -1
  264. package/es/QuickReply/component.json +129 -0
  265. package/es/QuickReply/index.d.ts +1 -1
  266. package/es/Radio/component.json +136 -0
  267. package/es/RadioGroup/component.json +149 -0
  268. package/es/RangeInput/component.json +198 -0
  269. package/es/RangeInput/index.js +1 -1
  270. package/es/Result/component.json +104 -0
  271. package/es/ScrollBar/component.json +115 -0
  272. package/es/Search/component.json +177 -0
  273. package/es/Search/index.d.ts +1 -1
  274. package/es/Select/component.json +244 -0
  275. package/es/Select/index.js +113 -113
  276. package/es/SelectInput/component.json +184 -0
  277. package/es/Selector/component.json +203 -0
  278. package/es/Selector/index.js +28 -27
  279. package/es/Selector/interface.d.ts +1 -1
  280. package/es/Selector/selectorMain/index.js +2 -2
  281. package/es/Selector/selectorNode/index.js +1 -1
  282. package/es/Selector/util.d.ts +2 -2
  283. package/es/SelectorPicker/component.json +179 -0
  284. package/es/SelectorPicker/index.d.ts +5 -5
  285. package/es/SelectorPicker/index.js +15 -15
  286. package/es/SingleBox/component.json +151 -0
  287. package/es/SingleBox/index.d.ts +2 -2
  288. package/es/Slider/component.json +181 -0
  289. package/es/SortBox/component.json +108 -0
  290. package/es/Status/component.json +104 -0
  291. package/es/Stepper/component.json +129 -0
  292. package/es/Stepper/index.d.ts +2 -2
  293. package/es/Switch/component.json +207 -0
  294. package/es/Switch/index.css +1 -1
  295. package/es/Switch/index.d.ts +3 -2
  296. package/es/Switch/index.js +60 -59
  297. package/es/Switch/style/index.css +1 -1
  298. package/es/Table/component.json +547 -0
  299. package/es/Table/index.d.ts +2 -2
  300. package/es/Table/index.js +414 -414
  301. package/es/Table/interface.d.ts +6 -0
  302. package/es/Tabs/component.json +227 -0
  303. package/es/Tag/component.json +221 -0
  304. package/es/Tag/index.css +1 -1
  305. package/es/Tag/index.d.ts +1 -1
  306. package/es/Tag/index.js +20 -20
  307. package/es/Tag/style/index.css +1 -1
  308. package/es/TextEditor/component.json +186 -0
  309. package/es/TextEditor/index.d.ts +5 -5
  310. package/es/TextField/component.json +290 -0
  311. package/es/TextField/index.d.ts +2 -2
  312. package/es/TimePicker/component.json +176 -0
  313. package/es/Timeline/component.json +110 -0
  314. package/es/Title/component.json +156 -0
  315. package/es/ToggleButton/component.json +153 -0
  316. package/es/Tooltip/component.json +176 -0
  317. package/es/Tooltip/index.js +74 -63
  318. package/es/Tooltip/interface.d.ts +14 -1
  319. package/es/Tooltip/utils.js +6 -6
  320. package/es/Transfer/component.json +157 -0
  321. package/es/Tree/component.json +512 -0
  322. package/es/Upload/component.json +450 -0
  323. package/es/Utils/type.d.ts +0 -2
  324. package/es/index.d.ts +2 -0
  325. package/es/index.js +1 -1
  326. package/es/locale/en_US.d.ts +361 -0
  327. package/es/locale/en_US.js +364 -0
  328. package/es/locale/index.d.ts +1 -723
  329. package/es/locale/index2.js +10 -0
  330. package/es/locale/zh_CN.d.ts +361 -0
  331. package/es/locale/zh_CN.js +364 -0
  332. package/lib/AlignBox/component.json +89 -0
  333. package/lib/AlignBox/index.css +1 -1
  334. package/lib/AlignBox/index.d.ts +6 -2
  335. package/lib/AlignBox/index.js +1 -1
  336. package/lib/AlignBox/style/index.css +1 -1
  337. package/lib/Anchor/anchorMenu/index.d.ts +2 -1
  338. package/lib/Anchor/anchorMenu/index.js +1 -1
  339. package/lib/Anchor/component.json +130 -0
  340. package/lib/Anchor/index.js +1 -1
  341. package/lib/Anchor/type.d.ts +8 -4
  342. package/lib/Argv/component.json +216 -0
  343. package/lib/Argv/index.d.ts +5 -6
  344. package/lib/AutoBox/component.json +133 -0
  345. package/lib/AutoBox/index.d.ts +3 -3
  346. package/lib/AutoBox/index.js +1 -1
  347. package/lib/AutoBox/protal.d.ts +2 -2
  348. package/lib/AutoBox/protal.js +1 -1
  349. package/lib/AutoButton/component.json +109 -0
  350. package/lib/AutoButton/index.js +1 -1
  351. package/lib/AutoTips/autoTipsMultiline/index.d.ts +1 -1
  352. package/lib/AutoTips/autoTipsMultiline/index.js +1 -1
  353. package/lib/AutoTips/component.json +121 -0
  354. package/lib/Badge/component.json +92 -0
  355. package/lib/Breadcrumbs/component.json +142 -0
  356. package/lib/Breadcrumbs/index.js +1 -1
  357. package/lib/Button/SplitButton.d.ts +2 -2
  358. package/lib/Button/component.json +168 -0
  359. package/lib/Button/index.js +1 -1
  360. package/lib/ButtonGroup/component.json +132 -0
  361. package/lib/ButtonGroup/index.d.ts +1 -1
  362. package/lib/Card/component.json +162 -0
  363. package/lib/Card/index.d.ts +2 -2
  364. package/lib/Card/index.js +1 -1
  365. package/lib/Carousel/component.json +142 -0
  366. package/lib/Carousel/index.d.ts +1 -1
  367. package/lib/Cascader/Cascader.js +1 -1
  368. package/lib/Cascader/component.json +196 -0
  369. package/lib/Cascader/hooks/useEntities.js +1 -1
  370. package/lib/Cascader/interface.d.ts +1 -0
  371. package/lib/Cascader/utils/commonUtil.d.ts +1 -1
  372. package/lib/Cascader/utils/commonUtil.js +1 -1
  373. package/lib/Cascader/utils/treeUtil.d.ts +14 -5
  374. package/lib/Cascader/utils/treeUtil.js +1 -1
  375. package/lib/Checkbox/component.json +138 -0
  376. package/lib/CheckboxGroup/component.json +152 -0
  377. package/lib/CodeEditor/component.json +189 -0
  378. package/lib/CodeEditor/index.d.ts +10 -9
  379. package/lib/Collapse/component.json +166 -0
  380. package/lib/Collapse/index.d.ts +1 -1
  381. package/lib/Collapse/index.js +1 -1
  382. package/lib/CollapseBox/component.json +84 -0
  383. package/lib/CollapseLayout/component.json +155 -0
  384. package/lib/ColorPicker/component.json +142 -0
  385. package/lib/ComboSelect/component.json +181 -0
  386. package/lib/ComboSelect/index.js +1 -1
  387. package/lib/ComboSelect/interface.d.ts +6 -3
  388. package/lib/ComboSelect/utils.d.ts +3 -3
  389. package/lib/ComboSelect/utils.js +1 -1
  390. package/lib/Container/component.json +111 -0
  391. package/lib/ContentBox/component.json +81 -0
  392. package/lib/CopyText/component.json +118 -0
  393. package/lib/CycleSelector/component.json +98 -0
  394. package/lib/CycleSelector/index.js +1 -1
  395. package/lib/DatePicker/component.json +192 -0
  396. package/lib/DatePicker/generatePicker/generateRangePicker.d.ts +0 -8
  397. package/lib/DatePicker/generatePicker/generateRangePicker.js +1 -1
  398. package/lib/DatePicker/generatePicker/generateSinglePicker.js +1 -1
  399. package/lib/DatePicker/generatePicker/index.d.ts +11 -4
  400. package/lib/Descriptions/component.json +142 -0
  401. package/lib/Descriptions/index.d.ts +1 -1
  402. package/lib/Desktop/component.json +171 -0
  403. package/lib/DragVerify/component.json +114 -0
  404. package/lib/DragVerify/index.js +1 -1
  405. package/lib/Drawer/component.json +200 -0
  406. package/lib/Drawer/index.js +1 -1
  407. package/lib/Drawer/interface.d.ts +1 -1
  408. package/lib/Drawer/util.d.ts +1 -6
  409. package/lib/Drawer/util.js +1 -1
  410. package/lib/Dropdown/component.json +147 -0
  411. package/lib/DynamicMultiBox/component.json +278 -0
  412. package/lib/DynamicMultiBox/formItem.d.ts +1 -1
  413. package/lib/DynamicMultiBox/rowForm.d.ts +2 -2
  414. package/lib/Empty/component.json +123 -0
  415. package/lib/Empty/index.css +1 -1
  416. package/lib/Empty/index.d.ts +2 -2
  417. package/lib/Empty/index.js +1 -1
  418. package/lib/Empty/style/index.css +1 -1
  419. package/lib/FieldForm/FieldFormItem/MemoInput.d.ts +2 -2
  420. package/lib/FieldForm/FieldFormItem/index.d.ts +6 -6
  421. package/lib/FieldForm/Form.d.ts +2 -2
  422. package/lib/FieldForm/FormList.d.ts +2 -2
  423. package/lib/FieldForm/component.json +196 -0
  424. package/lib/FieldForm/context.d.ts +5 -1
  425. package/lib/FieldForm/context.js +1 -1
  426. package/lib/FieldForm/hooks/useForm.d.ts +4 -3
  427. package/lib/FieldForm/hooks/useFormInstance.d.ts +1 -1
  428. package/lib/FieldForm/hooks/useFormItemStatus.d.ts +9 -5
  429. package/lib/FieldForm/hooks/useFormItemStatus.js +1 -1
  430. package/lib/FieldForm/hooks/useItemRef.d.ts +1 -1
  431. package/lib/FieldForm/hooks/useItemRef.js +1 -1
  432. package/lib/Form/component.json +161 -0
  433. package/lib/Form/index.d.ts +52 -49
  434. package/lib/FormItem/compoments/defaultCompoments/index.d.ts +5 -5
  435. package/lib/FormItem/compoments/defaultCompoments/index.js +1 -1
  436. package/lib/FormItem/compoments/formCheckboxGroup/index.d.ts +2 -2
  437. package/lib/FormItem/compoments/formFile/index.js +1 -1
  438. package/lib/FormItem/compoments/formRadioGroup/index.d.ts +1 -1
  439. package/lib/FormItem/compoments/formSelect/index.d.ts +1 -1
  440. package/lib/FormItem/component.json +171 -0
  441. package/lib/FormItem/index.d.ts +5 -5
  442. package/lib/FormItem/index.js +1 -1
  443. package/lib/FormItem/itemType.js +1 -1
  444. package/lib/FunctionModal/component.json +197 -0
  445. package/lib/FunctionModal/dialog.d.ts +1 -1
  446. package/lib/FunctionModal/modalContext.d.ts +4 -1
  447. package/lib/Help/component.json +118 -0
  448. package/lib/HelperText/component.json +126 -0
  449. package/lib/Image/component.json +165 -0
  450. package/lib/InputCode/component.json +191 -0
  451. package/lib/InputCode/index.d.ts +2 -2
  452. package/lib/InputLang/component.json +205 -0
  453. package/lib/InputLang/index.js +1 -1
  454. package/lib/InputNumber/component.json +162 -0
  455. package/lib/Label/component.json +126 -0
  456. package/lib/Label/index.d.ts +2 -2
  457. package/lib/Loading/component.json +91 -0
  458. package/lib/Menu/component.json +180 -0
  459. package/lib/Message/component.json +246 -0
  460. package/lib/Message/index.d.ts +2 -2
  461. package/lib/Message/index.js +1 -1
  462. package/lib/Modal/Confirm/index.d.ts +1 -1
  463. package/lib/Modal/Confirm/index.js +1 -1
  464. package/lib/Modal/component.json +277 -0
  465. package/lib/Modal/index.d.ts +97 -6
  466. package/lib/Modal/index.js +1 -1
  467. package/lib/Modal/interface.d.ts +1 -0
  468. package/lib/MultiBox/component.json +216 -0
  469. package/lib/MultiBox/index.js +1 -1
  470. package/lib/Notification/component.json +184 -0
  471. package/lib/OperateBtn/component.json +134 -0
  472. package/lib/OperateBtn/index.d.ts +3 -3
  473. package/lib/PageHeader/component.json +112 -0
  474. package/lib/Pagination/component.json +181 -0
  475. package/lib/Pagination/index.js +1 -1
  476. package/lib/PasswordRules/component.json +105 -0
  477. package/lib/PasswordRules/index.d.ts +4 -4
  478. package/lib/PopConfirm/component.json +227 -0
  479. package/lib/PopConfirm/index.d.ts +1 -1
  480. package/lib/PopConfirm/index.js +1 -1
  481. package/lib/PopMenu/component.json +131 -0
  482. package/lib/PopMenu/hooks.d.ts +1 -1
  483. package/lib/PopMenu/index.js +1 -1
  484. package/lib/Popover/component.json +165 -0
  485. package/lib/Popover/index.js +1 -1
  486. package/lib/Progress/component.json +161 -0
  487. package/lib/Prompt/component.json +144 -0
  488. package/lib/Querying/component.json +96 -0
  489. package/lib/Querying/index.css +1 -1
  490. package/lib/Querying/index.d.ts +2 -2
  491. package/lib/Querying/index.js +1 -1
  492. package/lib/Querying/style/index.css +1 -1
  493. package/lib/QuickReply/component.json +129 -0
  494. package/lib/QuickReply/index.d.ts +1 -1
  495. package/lib/Radio/component.json +136 -0
  496. package/lib/RadioGroup/component.json +149 -0
  497. package/lib/RangeInput/component.json +198 -0
  498. package/lib/RangeInput/index.js +1 -1
  499. package/lib/Result/component.json +104 -0
  500. package/lib/ScrollBar/component.json +115 -0
  501. package/lib/Search/component.json +177 -0
  502. package/lib/Search/index.d.ts +1 -1
  503. package/lib/Select/component.json +244 -0
  504. package/lib/Select/index.js +1 -1
  505. package/lib/SelectInput/component.json +184 -0
  506. package/lib/Selector/component.json +203 -0
  507. package/lib/Selector/index.js +1 -1
  508. package/lib/Selector/interface.d.ts +1 -1
  509. package/lib/Selector/selectorMain/index.js +1 -1
  510. package/lib/Selector/selectorNode/index.js +1 -1
  511. package/lib/Selector/util.d.ts +2 -2
  512. package/lib/SelectorPicker/component.json +179 -0
  513. package/lib/SelectorPicker/index.d.ts +5 -5
  514. package/lib/SelectorPicker/index.js +1 -1
  515. package/lib/SingleBox/component.json +151 -0
  516. package/lib/SingleBox/index.d.ts +2 -2
  517. package/lib/Slider/component.json +181 -0
  518. package/lib/SortBox/component.json +108 -0
  519. package/lib/Status/component.json +104 -0
  520. package/lib/Stepper/component.json +129 -0
  521. package/lib/Stepper/index.d.ts +2 -2
  522. package/lib/Switch/component.json +207 -0
  523. package/lib/Switch/index.css +1 -1
  524. package/lib/Switch/index.d.ts +3 -2
  525. package/lib/Switch/index.js +1 -1
  526. package/lib/Switch/style/index.css +1 -1
  527. package/lib/Table/component.json +547 -0
  528. package/lib/Table/index.d.ts +2 -2
  529. package/lib/Table/index.js +1 -1
  530. package/lib/Table/interface.d.ts +6 -0
  531. package/lib/Tabs/component.json +227 -0
  532. package/lib/Tag/component.json +221 -0
  533. package/lib/Tag/index.css +1 -1
  534. package/lib/Tag/index.d.ts +1 -1
  535. package/lib/Tag/index.js +1 -1
  536. package/lib/Tag/style/index.css +1 -1
  537. package/lib/TextEditor/component.json +186 -0
  538. package/lib/TextEditor/index.d.ts +5 -5
  539. package/lib/TextField/component.json +290 -0
  540. package/lib/TextField/index.d.ts +2 -2
  541. package/lib/TimePicker/component.json +176 -0
  542. package/lib/Timeline/component.json +110 -0
  543. package/lib/Title/component.json +156 -0
  544. package/lib/ToggleButton/component.json +153 -0
  545. package/lib/Tooltip/component.json +176 -0
  546. package/lib/Tooltip/index.js +1 -1
  547. package/lib/Tooltip/interface.d.ts +14 -1
  548. package/lib/Tooltip/utils.js +1 -1
  549. package/lib/Transfer/component.json +157 -0
  550. package/lib/Tree/component.json +512 -0
  551. package/lib/Upload/component.json +450 -0
  552. package/lib/Utils/type.d.ts +0 -2
  553. package/lib/index.d.ts +2 -0
  554. package/lib/index.js +1 -1
  555. package/lib/locale/en_US.d.ts +361 -0
  556. package/lib/locale/en_US.js +2 -0
  557. package/lib/locale/index.d.ts +1 -723
  558. package/lib/locale/index2.js +2 -0
  559. package/lib/locale/zh_CN.d.ts +361 -0
  560. package/lib/locale/zh_CN.js +2 -0
  561. package/package.json +10 -3
  562. /package/es/{Utils/Hooks → Hooks}/useResizeObserver.d.ts +0 -0
  563. /package/es/{Utils/Hooks → Hooks}/useResizeObserver.js +0 -0
  564. /package/lib/{Utils/Hooks → Hooks}/useResizeObserver.d.ts +0 -0
  565. /package/lib/{Utils/Hooks → Hooks}/useResizeObserver.js +0 -0
@@ -1,9 +1,9 @@
1
1
  import { default as React } from 'react';
2
2
  interface MemoInputProps {
3
3
  control: object;
4
- update: any;
4
+ update: unknown;
5
5
  children: React.ReactNode;
6
- childProps: any[];
6
+ childProps: unknown[];
7
7
  }
8
8
  declare const _default: React.MemoExoticComponent<({ children }: MemoInputProps) => JSX.Element>;
9
9
  export default _default;
@@ -6,9 +6,9 @@ import { FormItemInputProps } from '../FormItemInput';
6
6
  import { FormItemLabelProps } from '../FormItemLabel';
7
7
  import { ReportMetaChange } from '../context';
8
8
  import { default as useFormItemStatus } from '../hooks/useFormItemStatus';
9
- type RenderChildren<Values = any> = (form: FormInstance<Values>) => ReactNode;
10
- type RcFieldProps<Values = any> = Omit<FieldProps<Values>, 'children'>;
11
- type ChildrenType<Values = any> = RenderChildren<Values> | ReactNode;
9
+ type RenderChildren<Values = unknown> = (form: FormInstance<Values>) => ReactNode;
10
+ type RcFieldProps<Values = unknown> = Omit<FieldProps<Values>, 'children'>;
11
+ type ChildrenType<Values = unknown> = RenderChildren<Values> | ReactNode;
12
12
  declare const ValidateStatuses: readonly ["success", "warning", "error", "validating", ""];
13
13
  export type ValidateStatus = (typeof ValidateStatuses)[number];
14
14
  export type FeedbackIcons = (itemStatus: {
@@ -18,7 +18,7 @@ export type FeedbackIcons = (itemStatus: {
18
18
  }) => {
19
19
  [key in ValidateStatus]?: ReactNode;
20
20
  };
21
- export interface FormItemProps<Values = any> extends FormItemLabelProps, FormItemInputProps, RcFieldProps<Values> {
21
+ export interface FormItemProps<Values = unknown> extends FormItemLabelProps, FormItemInputProps, RcFieldProps<Values> {
22
22
  noStyle?: boolean;
23
23
  style?: CSSProperties;
24
24
  className?: string;
@@ -28,7 +28,7 @@ export interface FormItemProps<Values = any> extends FormItemLabelProps, FormIte
28
28
  validateStatus?: ValidateStatus;
29
29
  required?: boolean;
30
30
  hidden?: boolean;
31
- initialValue?: any;
31
+ initialValue?: unknown;
32
32
  messageVariables?: Record<string, string>;
33
33
  layout?: FormItemLayout;
34
34
  hideError?: boolean;
@@ -45,7 +45,7 @@ export interface ItemHolderProps extends FormItemProps {
45
45
  isRequired?: boolean;
46
46
  onSubItemMetaChange: ReportMetaChange;
47
47
  }
48
- declare function InternalFormItem<Values = any>(props: FormItemProps<Values>): ReactElement;
48
+ declare function InternalFormItem<Values = unknown>(props: FormItemProps<Values>): ReactElement;
49
49
  type InternalFormItemType = typeof InternalFormItem;
50
50
  type CompoundedComponent = InternalFormItemType & {
51
51
  useStatus: typeof useFormItemStatus;
@@ -10,7 +10,7 @@ export type RequiredMark = boolean | 'optional' | ((labelNode: ReactNode, info:
10
10
  }) => ReactNode);
11
11
  export type FormLayout = 'horizontal' | 'vertical';
12
12
  export type FormItemLayout = 'horizontal' | 'vertical';
13
- export interface FormProps<Values = any> extends Omit<RcFormProps<Values>, 'form'> {
13
+ export interface FormProps<Values = unknown> extends Omit<RcFormProps<Values>, 'form'> {
14
14
  colon?: boolean;
15
15
  name?: string;
16
16
  layout?: FormLayout;
@@ -23,6 +23,6 @@ export interface FormProps<Values = any> extends Omit<RcFormProps<Values>, 'form
23
23
  requiredMark?: RequiredMark;
24
24
  size?: 'small' | 'medium' | 'large';
25
25
  }
26
- declare const FieldForm: (<Values = any>(props: PropsWithChildren<FormProps<Values>> & RefAttributes<FormRef<Values>>) => ReactElement) & Pick<FC, "displayName">;
26
+ declare const FieldForm: (<Values = unknown>(props: PropsWithChildren<FormProps<Values>> & RefAttributes<FormRef<Values>>) => ReactElement) & Pick<FC, "displayName">;
27
27
  export { useForm, useWatch, type FormInstance };
28
28
  export default FieldForm;
@@ -3,7 +3,7 @@ import { StoreValue, ValidatorRule } from 'rc-field-form/lib/interface';
3
3
  export interface FormListFieldData {
4
4
  name: number;
5
5
  key: number;
6
- error?: any;
6
+ error?: unknown;
7
7
  }
8
8
  export interface FormListOperation {
9
9
  add: (defaultValue?: StoreValue, insertIndex?: number) => void;
@@ -13,7 +13,7 @@ export interface FormListOperation {
13
13
  export interface FormListProps {
14
14
  name: string | number | (string | number)[];
15
15
  rules?: ValidatorRule[];
16
- initialValue?: any[];
16
+ initialValue?: unknown[];
17
17
  children: (fields: FormListFieldData[], operation: FormListOperation, meta: {
18
18
  errors: ReactNode[];
19
19
  warnings: ReactNode[];
@@ -0,0 +1,196 @@
1
+ {
2
+ "name": "FieldForm",
3
+ "category": "Data Entry",
4
+ "description": "表单组件,提供完整的表单解决方案(基于 rc-field-form;内部 cloneElement 注入 value/onChange/error 到 Item.children)",
5
+ "semantic": {
6
+ "intent": [
7
+ "表单管理",
8
+ "数据录入"
9
+ ],
10
+ "useCases": [
11
+ "用户注册",
12
+ "数据编辑",
13
+ "配置页面"
14
+ ],
15
+ "riskLevel": "normal"
16
+ },
17
+ "variants": {
18
+ "horizontal": {
19
+ "meaning": "水平布局"
20
+ },
21
+ "vertical": {
22
+ "meaning": "垂直布局"
23
+ }
24
+ },
25
+ "states": [
26
+ "default",
27
+ "disabled",
28
+ "validating",
29
+ "error"
30
+ ],
31
+ "idealProps": {
32
+ "form": {
33
+ "type": "FormInstance",
34
+ "description": "由 useForm() 创建的表单实例:`const [form] = FieldForm.useForm();` 仅在父组件需外部调用 submit/resetFields/setFieldsValue 时需要;**类型别名注意**:`FormInstance`(api.ts) ≡ `FieldFormInstance`(src/FieldForm 导出)两个名字指同一类型,推荐用 `FieldFormInstance`(更精确不与其他库混淆)"
35
+ },
36
+ "initialValues": {
37
+ "type": "object",
38
+ "objectShape": {
39
+ "[fieldName: string]": { "type": "any", "description": "字段名 → 初始值,例:{ username: '张三', age: 25 }" }
40
+ },
41
+ "completeExample": "{ username: '张三', email: 'zs@example.com' }",
42
+ "description": "表单初始默认值(仅 mount 时灌入;**后续动态变化需用 form.setFieldsValue,不能修改 initialValues prop**);典型用法 `<FieldForm initialValues={{ name: '张三', age: 25 }}>`"
43
+ },
44
+ "onFinish": {
45
+ "type": "(values: any) => void",
46
+ "description": "校验通过后触发:values 是表单全部字段的扁平对象(包含 FieldForm.Item.name 收集的所有字段);**触发时机**:点击 `<Button type=\"submit\">` 或调用 `form.submit()` 后,内部跑校验通过 → onFinish"
47
+ },
48
+ "onFinishFailed": {
49
+ "type": "({ values, errorFields, outOfDate }) => void",
50
+ "description": "校验失败后触发;errorFields 是失败字段数组"
51
+ },
52
+ "layout": {
53
+ "type": "enum",
54
+ "values": [
55
+ "horizontal",
56
+ "vertical"
57
+ ],
58
+ "default": "vertical",
59
+ "description": "vertical=label 在字段上方(默认,省略即生效);horizontal=label 在左侧"
60
+ },
61
+ "children": {
62
+ "type": "ReactNode",
63
+ "description": "FieldForm 接收任意 ReactNode(包括 FieldForm.Item / Button type=submit / 自定义包装);**但每个 Item 的 child 必须是支持 value/onChange/error/disabled 的自定义组件**(TextField / Select / Checkbox / Switch / DatePicker / InputNumber 等);**不可用原生 input/textarea/select/button — 会触发 React non-boolean-attribute warning**(因 cloneElement 注入 error={false} 给原生 DOM 元素时,React 视 error 为 DOM attr → 报错);见 childrenContract.FormItem"
64
+ }
65
+ },
66
+ "childrenContract": {
67
+ "FormItem": {
68
+ "rule": "FieldForm.Item 的 children 必须是支持 value/onChange/error/disabled prop 的自定义组件",
69
+ "recommended": [
70
+ "TextField",
71
+ "Select",
72
+ "Switch",
73
+ "Checkbox",
74
+ "InputNumber",
75
+ "DatePicker",
76
+ "TextEditor",
77
+ "RangeInput",
78
+ "RadioGroup",
79
+ "CheckboxGroup",
80
+ "Slider"
81
+ ],
82
+ "forbidden": [
83
+ "原生 <input>",
84
+ "原生 <textarea>",
85
+ "原生 <select>",
86
+ "包一层 <div>"
87
+ ],
88
+ "reason": "Item 用 cloneElement 注入 value/onChange/error/disabled/size 等 prop;原生 DOM 元素不消费 error: boolean,React 会报 non-boolean attribute warning(运行时 console error,demo 验证 fail)"
89
+ },
90
+ "submit": {
91
+ "rule": "提交用 <Button type=\"submit\"> 或 form.submit()",
92
+ "trigger": "<Button>(来自 @para-ui/core/Button)渲染为 <button type='submit'>,会触发 form 的 submit 事件 → 跑校验 → onFinish/onFinishFailed",
93
+ "wrapper": "提交按钮通常用 FieldForm.Item(不带 name)包裹做布局,如 `<FieldForm.Item><Button type='submit'>提交</Button></FieldForm.Item>`;Item 不带 name 时不会注入 value/onChange/error(纯布局容器),不会触发 non-boolean-attribute warning;**也可不包 Item 直接放 Button**(看布局需求)"
94
+ }
95
+ },
96
+ "interpretivePriority": {
97
+ "principle": "**当需求描述中的'范围约束'(如 '仅使用 FieldForm 本身' / '不引入其他组件')与 childrenContract 冲突时,优先服从 childrenContract**",
98
+ "reason": "childrenContract 决定 runtime 是否报 React warning;需求'仅使用 FieldForm 本身'通常指**目标包装组件**(如 EditDataForm / SearchHorizontalForm)的**实现层 import 限制**(不在该包装组件内部 import 其他组件),**不限制 Demo 入口层或 children 子组件**;若字面理解为'整个文件只能 import FieldForm',会导致 Item.children 只能用原生 <input> → 触发 non-boolean warning → 运行时 fail",
99
+ "resolution": "标准解读:'仅使用 FieldForm 本身' = '目标包装组件(EditDataForm 等)的实现 import 列表只有 FieldForm';**Demo 渲染入口 (`const Demo: FC = () => ...`) 可自由 import TextField / Button / Select 等推荐子组件作为 children 传入包装组件**;**包装组件接收 children: ReactNode 直接透传给 FieldForm 即可,不需要内部 import 字段组件**",
100
+ "antiPatterns": [
101
+ "❌ 整个 demo 文件只 import FieldForm,FieldForm.Item.children 用原生 <input>",
102
+ "❌ 整个 demo 文件只 import FieldForm,提交按钮用原生 <button type='submit'>",
103
+ "❌ 把'仅使用 FieldForm 本身'解读为'禁止 import TextField/Button'"
104
+ ],
105
+ "correctPatterns": [
106
+ "✅ 包装组件 (EditDataForm) 实现层只 import FieldForm,接收 children: ReactNode",
107
+ "✅ Demo 渲染入口 import TextField + Button,构造 <FieldForm.Item><TextField/></FieldForm.Item> 作为 children 传入",
108
+ "✅ 提交按钮:Demo 入口 import Button,<FieldForm.Item><Button type='submit'>提交</Button></FieldForm.Item>"
109
+ ]
110
+ },
111
+ "commonMisconceptions": {
112
+ "M1": {
113
+ "wrong": "FieldForm.Item.children 用原生 <input>",
114
+ "result": "React 报 `Received 'false' for a non-boolean attribute 'error'` warning → ai-test runtime fail",
115
+ "fix": "改用 TextField (或其他 recommended 组件)"
116
+ },
117
+ "M2": {
118
+ "wrong": "提交按钮用原生 `<button type='submit'>` 包在 FieldForm.Item 内",
119
+ "result": "Item cloneElement 注入 error={false} 到原生 button → React warning → ai-test fail",
120
+ "fix": "改用 `<Button type='submit'>` 或不包 FieldForm.Item 直接放原生 button(Item 在不包裹时不注入 error)"
121
+ },
122
+ "M3": {
123
+ "wrong": "需求 '仅使用 FieldForm 本身' 被解读为整个 demo 文件只 import FieldForm",
124
+ "result": "Item children 退化为原生 <input> → M1 warning",
125
+ "fix": "见 interpretivePriority.resolution(包装组件实现层 vs Demo 入口层的区分)"
126
+ }
127
+ },
128
+ "completeExample": "// R23 议题修补:R22 4/5 fail 根因 sub-agent 误解'仅使用 FieldForm 本身'\n// 标准完整示例(initialValues + useForm + onFinish + Item + TextField + Button submit):\n\nimport React, { FC } from 'react';\nimport FieldForm from '@para-ui/core/FieldForm';\nimport type { FieldFormInstance } from '@para-ui/core/FieldForm';\nimport TextField from '@para-ui/core/TextField';\nimport Button from '@para-ui/core/Button';\n\n// === 1. 目标包装组件(实现层只 import FieldForm + 类型) ===\ninterface EditDataFormProps {\n initialData?: Record<string, any>;\n children: React.ReactNode;\n onSubmitSuccess: (values: any) => void;\n}\nconst EditDataForm: FC<EditDataFormProps> = ({ initialData, children, onSubmitSuccess }) => {\n const [form] = FieldForm.useForm();\n return (\n <FieldForm\n form={form}\n initialValues={initialData}\n onFinish={onSubmitSuccess}\n layout='vertical'\n >\n {children}\n </FieldForm>\n );\n};\n\n// === 2. Demo 渲染入口(可自由 import TextField + Button 作为 children) ===\nconst Demo: FC = () => (\n <EditDataForm\n initialData={{ username: '张三', email: 'zs@example.com' }}\n onSubmitSuccess={(values) => console.log('submitted', values)}\n >\n <FieldForm.Item name='username' label='用户名' rules={[{ required: true }]}>\n <TextField placeholder='请输入用户名' />\n </FieldForm.Item>\n <FieldForm.Item name='email' label='邮箱' rules={[{ required: true, type: 'email' }]}>\n <TextField placeholder='请输入邮箱' />\n </FieldForm.Item>\n <FieldForm.Item>\n <Button type='submit'>保存修改</Button>\n </FieldForm.Item>\n </EditDataForm>\n);\nexport default Demo;",
129
+ "do": [
130
+ "**Demo 入口层**必须 import TextField / Button 等推荐组件给 Item.children(即使需求说'仅使用 FieldForm 本身',这是包装组件实现层约束,不是 Demo 入口约束)",
131
+ "使用 useForm() 管理表单实例;父组件需要外部调用 submit/resetFields/setFieldsValue 时通过 form prop 传入",
132
+ "完整 demo 模板见 completeExample(initialValues + onFinish + FieldForm.Item + TextField + Button)",
133
+ "提供完整的校验规则(rules: [{ required: true }, { type: 'email' }, { pattern: /.../ }])"
134
+ ],
135
+ "dont": [
136
+ "FieldForm.Item.children 用原生 <input> / <textarea> / <select> / <button>(触发 non-boolean-attribute warning,见 childrenContract.FormItem.reason)",
137
+ "把'仅使用 FieldForm 本身'解读为'整个文件不能 import TextField/Button'(见 interpretivePriority.resolution)",
138
+ "字段过多不分组",
139
+ "忽略异步校验",
140
+ "在 mount 后修改 initialValues prop(应用 form.setFieldsValue;initialValues 仅 mount 时灌入)"
141
+ ],
142
+ "events": {
143
+ "onFinish": {
144
+ "signature": "(values: any) => void",
145
+ "asyncSupported": false,
146
+ "examples": [
147
+ "校验全部通过后触发:values 是全部 FieldForm.Item.name 收集到的字段扁平对象",
148
+ "点击 <Button type='submit'> 或调用 form.submit() 后跑校验,通过才触发 onFinish",
149
+ "values 结构与 initialValues 形状一致,key = 每个 Item 的 name 字段值"
150
+ ],
151
+ "commonMistakes": [
152
+ "假设 onFinish 会在校验失败时也触发——只有全部通过才触发,失败时触发 onFinishFailed",
153
+ "假设 onFinish 签名是 (e: FormEvent) => void——实际只有 (values: any) 一个参数",
154
+ "假设 submit 时直接拿到 event.preventDefault()——FieldForm 内部已处理,不需要手动 preventDefault"
155
+ ]
156
+ },
157
+ "onFinishFailed": {
158
+ "signature": "({ values, errorFields, outOfDate }: ValidateErrorEntity) => void",
159
+ "asyncSupported": false,
160
+ "examples": [
161
+ "校验失败时触发:errorFields 是 { name: NamePath; errors: string[] }[] 数组",
162
+ "values 包含当前所有字段值(含未通过校验的字段)"
163
+ ],
164
+ "commonMistakes": [
165
+ "假设参数是 (errors: string[]) 而不是对象——实际是 { values, errorFields, outOfDate } 解构对象",
166
+ "假设只有 onFinish 就够了——校验失败场景必须处理 onFinishFailed 才能给用户提示"
167
+ ]
168
+ }
169
+ },
170
+ "typescriptPitfalls": [
171
+ {
172
+ "issue": "FieldFormInstance 与 FormInstance 是同一类型的两个别名,推荐用 FieldFormInstance 避免与其他库冲突",
173
+ "wrong": "import type { FormInstance } from 'rc-field-form'; // 直接用 rc-field-form 的类型",
174
+ "right": "import type { FieldFormInstance } from '@para-ui/core/FieldForm'; const [form] = FieldForm.useForm<FieldFormInstance>();"
175
+ },
176
+ {
177
+ "issue": "FieldForm.Item 的 children 必须是自定义组件(支持 value/onChange/error prop),不能是原生 DOM 元素",
178
+ "wrong": "<FieldForm.Item name='age'><input type='number' /></FieldForm.Item> // error prop 会被注入到原生 input,React 报 non-boolean warning",
179
+ "right": "<FieldForm.Item name='age'><InputNumber /></FieldForm.Item> // 使用支持 error: boolean 的自定义组件"
180
+ },
181
+ {
182
+ "issue": "initialValues 仅在 mount 时生效,mount 后动态修改 initialValues prop 不会刷新表单",
183
+ "wrong": "// 动态修改 initialValues 期望刷新表单\n<FieldForm initialValues={dynamicData} /> // 后续 dynamicData 变化不会更新表单",
184
+ "right": "// 需要动态回填时用 form.setFieldsValue(newData)\nconst [form] = FieldForm.useForm();\nuseEffect(() => { form.setFieldsValue(dynamicData); }, [dynamicData]);"
185
+ },
186
+ {
187
+ "issue": "rules 中的 validator 函数签名必须返回 Promise(rc-field-form 约定),不是同步返回",
188
+ "wrong": "rules={[{ validator: (_, val) => val > 0 ? true : false }]} // 同步返回 boolean 不被识别",
189
+ "right": "rules={[{ validator: (_, val) => val > 0 ? Promise.resolve() : Promise.reject('必须大于 0') }]}"
190
+ }
191
+ ],
192
+ "mapping": {
193
+ "realComponent": "FieldForm",
194
+ "adapter": null
195
+ }
196
+ }
@@ -20,7 +20,11 @@ export interface FormContextProps {
20
20
  size?: 'small' | 'medium' | 'large';
21
21
  }
22
22
  export declare const FormContext: React.Context<FormContextProps>;
23
- export type ReportMetaChange = (meta: Meta, uniqueKeys: Key[]) => void;
23
+ /** rc-field-form 在销毁字段时会传入带 destroy 标记的 meta(官方 Meta 类型未声明此字段) */
24
+ export type MetaWithDestroy = Meta & {
25
+ destroy?: boolean;
26
+ };
27
+ export type ReportMetaChange = (meta: MetaWithDestroy, uniqueKeys: Key[]) => void;
24
28
  export declare const NoStyleItemContext: React.Context<ReportMetaChange | null>;
25
29
  export interface FormItemStatusContextProps {
26
30
  isFormItemInput?: boolean;
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const r=require("../_virtual/jsx-runtime.js"),t=require("react"),n=require("rc-field-form"),i=require("rc-util/lib/omit"),c=e=>{const o=i(e,["prefixCls"]);return r.jsxRuntimeExports.jsx(n.FormProvider,{...o})},m=t.createContext({labelAlign:"left",layout:"vertical",itemRef:(()=>{})}),s=t.createContext(null),l=t.createContext({});exports.FormContext=m;exports.FormItemInputContext=l;exports.FormProvider=c;exports.NoStyleItemContext=s;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const r=require("../_virtual/jsx-runtime.js"),t=require("react"),n=require("rc-field-form"),i=require("rc-util/lib/omit"),c=e=>{const o=i(e,["prefixCls"]);return r.jsxRuntimeExports.jsx(n.FormProvider,{...o})},m=t.createContext({labelAlign:"left",layout:"vertical",itemRef:()=>()=>{}}),s=t.createContext(null),l=t.createContext({});exports.FormContext=m;exports.FormItemInputContext=l;exports.FormProvider=c;exports.NoStyleItemContext=s;
2
2
  //# sourceMappingURL=context.js.map
@@ -1,6 +1,7 @@
1
+ import { ReactElement } from 'react';
1
2
  import { FormInstance as RcFormInstance } from 'rc-field-form';
2
3
  import { NamePath } from '../interface';
3
- export interface FormInstance<Values = any> extends RcFormInstance<Values> {
4
- getFieldInstance: (name: NamePath) => any;
4
+ export interface FormInstance<Values = unknown> extends RcFormInstance<Values> {
5
+ getFieldInstance: (name: NamePath) => ReactElement | undefined;
5
6
  }
6
- export default function useForm<Values = any>(form?: FormInstance<Values>): [FormInstance<Values>];
7
+ export default function useForm<Values = unknown>(form?: FormInstance<Values>): [FormInstance<Values>];
@@ -1,2 +1,2 @@
1
1
  import { FormInstance } from './useForm';
2
- export default function useFormInstance<Value = any>(): FormInstance<Value>;
2
+ export default function useFormInstance<Value = unknown>(): FormInstance<Value>;
@@ -1,9 +1,13 @@
1
1
  import { ReactNode } from 'react';
2
2
  import { ValidateStatus } from '../FieldFormItem';
3
- type UseFormItemStatus = () => {
4
- status?: ValidateStatus;
5
- errors: ReactNode[];
6
- warnings: ReactNode[];
7
- };
3
+ import { FormItemInputContext } from '../context';
4
+ interface UseFormItemStatus {
5
+ (): {
6
+ status?: ValidateStatus;
7
+ errors: ReactNode[];
8
+ warnings: ReactNode[];
9
+ };
10
+ Context: typeof FormItemInputContext;
11
+ }
8
12
  declare const useFormItemStatus: UseFormItemStatus;
9
13
  export default useFormItemStatus;
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const u=require("react"),t=require("../context.js"),e=()=>{const{status:o,errors:r=[],warnings:n=[]}=u.useContext(t.FormItemInputContext);return{status:o,errors:r,warnings:n}};e.Context=t.FormItemInputContext;exports.default=e;
1
+ "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const u=require("react"),t=require("../context.js"),e=(()=>{const{status:o,errors:r=[],warnings:n=[]}=u.useContext(t.FormItemInputContext);return{status:o,errors:r,warnings:n}});e.Context=t.FormItemInputContext;exports.default=e;
2
2
  //# sourceMappingURL=useFormItemStatus.js.map
@@ -1,3 +1,3 @@
1
1
  import { default as React } from 'react';
2
2
  import { InternalNamePath } from '../interface';
3
- export default function useItemRef(): (name: InternalNamePath, children: any) => React.Ref<any> | undefined;
3
+ export default function useItemRef(): (name: InternalNamePath, children: React.ReactNode) => React.Ref<unknown> | undefined;
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const u=require("react"),i=require("rc-util/lib/ref"),s=require("../context.js");function R(){const{itemRef:c}=u.useContext(s.FormContext),e=u.useRef({});function f(n,t){const r=t&&typeof t=="object"&&t.ref,o=n.join("_");return(e.current.name!==o||e.current.originRef!==r)&&(e.current.name=o,e.current.originRef=r,e.current.ref=i.composeRef(c(n),r)),e.current.ref}return f}exports.default=R;
1
+ "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const c=require("react"),i=require("rc-util/lib/ref"),s=require("../context.js");function R(){const{itemRef:u}=c.useContext(s.FormContext),e=c.useRef({});function f(n,t){const r=t&&typeof t=="object"&&t.ref,o=n.join("_");return(e.current.name!==o||e.current.originRef!==r)&&(e.current.name=o,e.current.originRef=r,e.current.ref=i.composeRef(u(n),r)),e.current.ref}return f}exports.default=R;
2
2
  //# sourceMappingURL=useItemRef.js.map
@@ -0,0 +1,161 @@
1
+ {
2
+ "name": "Form",
3
+ "category": "Data Entry",
4
+ "description": "基于配置的高性能表单组件",
5
+ "semantic": {
6
+ "intent": [
7
+ "数据录入",
8
+ "数据编辑",
9
+ "数据校验"
10
+ ],
11
+ "useCases": [
12
+ "登录注册",
13
+ "配置设置",
14
+ "信息填写"
15
+ ],
16
+ "riskLevel": "high"
17
+ },
18
+ "variants": {
19
+ "horizontal": {
20
+ "meaning": "水平布局表单"
21
+ },
22
+ "vertical": {
23
+ "meaning": "垂直布局表单"
24
+ }
25
+ },
26
+ "states": [
27
+ "loading",
28
+ "submitting",
29
+ "error"
30
+ ],
31
+ "idealProps": {
32
+ "configList": {
33
+ "type": "configListProps",
34
+ "description": "表单项配置数组(`type configListProps = Array<FormItemProps>`,src/Form/index.tsx:20 已 export)。**FormItemProps 核心字段(完整见 docs/view/form/api.ts apiDataFormItemProps)**:\n• `name: string`(必填,唯一标识;onChange / backData 的 key 都对应该值)\n• `label: string | ((props: FormItemProps) => ReactNode)`(显示文案)\n• `InputType: 'default' | 'number' | 'textarea' | 'select' | 'radioGroup' | 'checkGroup' | 'switch' | 'file' | FC<ItemTypeProps>`(⚠️ 控件类型用 **InputType**,不是 type;type 是布局覆盖)\n• `defaultValue: any`(字段初始值;backData[name] 优先级更高)\n• `rules: { validate: { required?, maxlength?, minLength?, pattern?, [customKey]? }, message: { [key]: string } }`(⚠️ **注意大小写**:`maxlength` 小写 l;`minLength` 驼峰 L——src 命名不一致,写错会导致校验规则被忽略)\n• `list: Array<{label, name?|value?}>`(radioGroup/checkGroup 子项用 `name`;select 子项用 `value`)\n• `disabled: boolean`(单项禁用)\n• `hide: boolean`(隐藏该项)\n• `hideError: boolean`(隐藏该项内置 error UI)\n• `type: 'vertical' | 'horizontal'`(单项布局覆盖;与顶层 type 同名,仅控制布局,不影响控件类型)"
35
+ },
36
+ "backData": {
37
+ "type": "{ [name: string]: any }",
38
+ "description": "整表回填数据。比 configList 中每项的 defaultValue 优先级更高;切换到该新对象会刷新表单。常配合 form.refreshForm(undefined, newBackData) 实现『换数据源』场景"
39
+ },
40
+ "type": {
41
+ "type": "enum",
42
+ "values": [
43
+ "vertical",
44
+ "horizontal"
45
+ ],
46
+ "default": "horizontal",
47
+ "description": "**布局类型**(vertical=竖 / horizontal=横);configList 中每项的 `type` 字段可覆盖顶层布局。⚠️ **此处 type 仅控制布局,与控件类型无关**——控件类型用 FormItemProps.`InputType`(default/select/radioGroup 等)"
48
+ },
49
+ "disabled": {
50
+ "type": "boolean",
51
+ "default": false,
52
+ "description": "是否全局禁用所有 FormItem 输入控件——对所有 InputType(default/textarea/number/file/switch/select/radioGroup/checkGroup/自定义函数)都生效,FormItem 内部把顶层 disabled 透传给每项。disabled 期间用户交互被屏蔽,onChange 不触发;不影响 form.current.check / reset / clear 等命令式调用"
53
+ },
54
+ "onChange": {
55
+ "type": "function",
56
+ "signature": "(name: string, value: any) => void",
57
+ "description": "表单值改变回调——任意字段(任意 InputType)变化都触发。**name 参数 = 对应 configList 该项的 `name` 字段值**;value 为该字段当前值。**触发时机**:input 类等价 onInput 实时(非 onBlur);select/radioGroup/checkGroup 在用户选中瞬时;switch 在 toggle 瞬时。**初始 backData 注入不触发 onChange**(仅用户交互或 form.current.refreshForm 才触发)。该回调不携带校验状态,需校验请用 form.current.check?.()"
58
+ },
59
+ "form": {
60
+ "type": "React.MutableRefObject<FormRefObject>",
61
+ "description": "**命令式 ref**——通过 form.current 调用 check / reset / clear / refreshForm / getValidValues 等方法。**FormRefObject 字段完整列表**(DEFECT-001/002):check(校验,**返回 false | { [name]: any }**——失败返 false 不抛错;**成功返回的对象 key = configList 每项的 `name` 字段值**,扁平结构非嵌套)/ reset(重置到初始 backData/defaultValue)/ clear(清空全部或指定字段,签名 `(name?: string | string[]) => void`)/ items({ [name]: ItemTypeProps })/ values / refreshForm / refData / getValidValues(过滤 hide=true 与未通过校验的字段)。docs/view/form/api.ts 末尾 RefObject 表列出全部字段。**5.x 仅整表 check,无 checkField(name) 单字段校验 API**——逐字段实时校验需在父组件用 onChange 桥接 + 业务方复刻 validate 逻辑。**FormRefObject 已公开 export**(Form-DEFECT-001 起),通过 `import { FormRefObject } from '@para-ui/core'` 或 `import { FormRefObject } from '@para-ui/core/Form'` 获取精确类型;推荐声明:`const formRef = useRef<FormRefObject>({} as FormRefObject)`"
62
+ },
63
+ "getCheckForm": {
64
+ "type": "function",
65
+ "signature": "(checkFrom: Function) => void",
66
+ "description": "**与 form ref 是同一能力的双通路(DEFECT-005)**。回调式:组件挂载后调用 getCheckForm(check) 把 check 函数交给父组件。**推荐统一用 form ref**——getCheckForm 是历史回调式 API"
67
+ },
68
+ "getForcedRefresh": {
69
+ "type": "function",
70
+ "signature": "(setConfigHook: (configList: configListProps, bData?: { [name: string]: any }) => void) => void",
71
+ "description": "强制刷新配置回调(src/Form/index.tsx:96-102 interface 实证):组件挂载后将内部 setConfig 方法交给父组件;父组件可通过 setConfigHook(newConfigList, newBackData) 命令式刷新整个表单结构和回填数据。⚠️ **推荐改用 form ref.refreshForm**——getForcedRefresh 是历史 API,与 form ref 功能重叠"
72
+ },
73
+ "disOnlySpace": {
74
+ "type": "boolean",
75
+ "description": "是否禁止纯空格提交(src/Form/index.tsx:111 interface 实证):true 时 rules.validate.required + 纯空格内容也会校验失败"
76
+ },
77
+ "className": {
78
+ "type": "string",
79
+ "description": "表单容器自定义类名(src/Form/index.tsx:122 interface 实证)"
80
+ },
81
+ "labelWidth": {
82
+ "type": "number",
83
+ "description": "Label 区块宽度,仅在顶层 type='vertical' 时生效(src/Form/index.tsx:131 interface 实证)"
84
+ }
85
+ },
86
+ "do": [
87
+ "使用 configList 进行配置化开发以减少模版代码",
88
+ "利用 form ref 进行手动校验和数据获取(推荐 form 单一通路而非 getCheckForm 双通路)",
89
+ "提交场景:`const values = formRef.current.check?.(); if (!values) return; submit(values);`——check 校验失败返 false,不抛错",
90
+ "重置场景:调用 form.current.reset?.() 而非 refreshForm(schema, {})(DEFECT-002 reset 是真实存在的 API)",
91
+ "FormItem 字段默认值用 FormItemProps.defaultValue(DEFECT-003 已实现,docs api.ts apiDataFormItemProps 已补)",
92
+ "**FormItemProps.list 子项 key 命名按 InputType 选用**(DEFECT-008 + src 实证):radioGroup / checkGroup 用 `{ label, name }`(用户选中产生的值 = name);select 用 `{ label, value }`(用户选中产生的值 = value)",
93
+ "**rules.validate 合法 key**(src/FormItem/index.tsx:54-60 实证):`required` / **`maxlength`**(小写 L)/ **`minLength`**(驼峰 L,与 maxlength 命名不一致是 src 现状)/ `pattern` / `disOnlySpace` / 任意自定义 key(值为 `(item, val) => boolean | string`)。message 中 key 与 validate key 一一对应",
94
+ "需要把同步 `check()` 包成 Promise 时:`async () => { const v = formRef.current.check?.(); return v || null; }`——失败返 null 而非 reject,避免业务方两套错误处理(参见 codeString.ts asyncCheckDemo)",
95
+ "需要逐字段实时校验:用顶层 onChange 桥接(任意字段变化都触发)+ 业务方在父组件复刻一份 validate 逻辑——5.x 没有 checkField(name) 单字段校验 API",
96
+ "需要父组件接管错误显示(服务端 / 异步校验):更新 configList 对应项的 `errorMessage` 字段注入自定义错误文案(FormItem 优先展示此值,check() 内部错误被覆盖);清除时传 `errorMessage: ''` 或 `undefined`。若需彻底隐藏内置 error UI 改用外部渲染,则配合 `hideError: true` + 父组件自定义 UI(议题 discussions/Form-error-takeover.md)"
97
+ ],
98
+ "dont": [
99
+ "在 render 中动态改变 configList 结构(应保持引用稳定)",
100
+ "混用受控和非受控模式",
101
+ "不要假设 check() 失败抛异常或返回 undefined——失败时返回 false(DEFECT-006)",
102
+ "不要既传 form 又传 getCheckForm 混用双通路(DEFECT-005)——选 form 即可",
103
+ "**不要在 select 子项里用 `{ label, name }`**——select 内部读 `value` 字段,用 name 会导致选中后 onChange 不传值;checkGroup/radioGroup 反过来要用 name 不能用 value(DEFECT-008 + src 实证)",
104
+ "**不要在 rules.validate 中把 maxlength 写成 maxLength(驼峰 L)或把 minLength 写成 minlength(小写 L)**——src 字段名严格匹配,写错会导致校验规则被忽略;不一致是 src 现状",
105
+ "不要假设 onChange 触发时携带校验状态——onChange 仅传 (name, value),校验状态需主动调 form.current.check?.()",
106
+ "不要假设初始 backData 注入触发 onChange——src 实证仅用户交互或 form.current.refreshForm 触发"
107
+ ],
108
+ "events": {
109
+ "onChange": {
110
+ "signature": "(name: string, value: any) => void",
111
+ "asyncSupported": false,
112
+ "examples": [
113
+ "任意 FormItem 字段值变化时触发,name 是 configList 该项的 name 字段值",
114
+ "input 类等价 onInput 实时触发,select/radioGroup 在选中瞬时,switch 在 toggle 瞬时",
115
+ "桥接逐字段实时校验:拿到 (name, value) 后调 formRef.current.check?.() 触发整表校验"
116
+ ],
117
+ "commonMistakes": [
118
+ "假设回调签名是 (e, value) 类似 antd → 实际只有 (name, value) 两个参数",
119
+ "在 onChange 里直接做副作用而不通过 setState(破坏受控模式)",
120
+ "假设初始 backData 注入会触发 onChange → 不会,仅用户交互或 refreshForm 触发",
121
+ "假设 onChange 携带校验状态 → 不携带,需主动调 check?.()"
122
+ ]
123
+ }
124
+ },
125
+ "typescriptPitfalls": [
126
+ {
127
+ "issue": "FormRefObject 必须显式声明类型,否则 ref.current 推断为 unknown",
128
+ "wrong": "const formRef = useRef(null); formRef.current.check(); // 报 unknown 类型错",
129
+ "right": "import { FormRefObject } from '@para-ui/core'; const formRef = useRef<FormRefObject>({} as FormRefObject);"
130
+ },
131
+ {
132
+ "issue": "FormItem 控件类型字段叫 InputType 不是 type(type 是布局覆盖)",
133
+ "wrong": "configList: [{ name: 'age', label: '年龄', type: 'number' }] // type 在这里是布局,不是控件",
134
+ "right": "configList: [{ name: 'age', label: '年龄', InputType: 'number' }]"
135
+ },
136
+ {
137
+ "issue": "rules.validate 字段名大小写不一致(src 现状)",
138
+ "wrong": "rules: { validate: { maxLength: 10, minlength: 2 } } // 写错被忽略",
139
+ "right": "rules: { validate: { maxlength: 10, minLength: 2 } } // 注意:maxlength 小写 L,minLength 驼峰 L"
140
+ },
141
+ {
142
+ "issue": "list 子项的 key 名称按 InputType 选用",
143
+ "wrong": "InputType: 'select', list: [{ label: 'A', name: 'a' }] // select 读 value,name 被忽略",
144
+ "right": "InputType: 'select' → list: [{ label: 'A', value: 'a' }] // radioGroup/checkGroup 反过来用 name"
145
+ },
146
+ {
147
+ "issue": "check() 返回类型是 false | object,不是 boolean 也不抛异常",
148
+ "wrong": "const ok = formRef.current.check?.(); if (!ok) throw new Error('fail'); // ok 是 false | object",
149
+ "right": "const values = formRef.current.check?.(); if (!values) return; submit(values); // false 表失败,object 表成功并含字段值"
150
+ },
151
+ {
152
+ "issue": "configList 不接受 undefined (TS2345),空状态用 '' 或 []",
153
+ "wrong": "<Form configList={someUndefined} /> // 触发 TS2345: Argument of type 'undefined' is not assignable to '\"\" | FormItemProps[]'",
154
+ "right": "<Form configList={someValue || []} /> // 或 configList=''"
155
+ }
156
+ ],
157
+ "mapping": {
158
+ "realComponent": "Form",
159
+ "adapter": null
160
+ }
161
+ }