@1money/react-ui 1.16.0 → 1.17.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (268) hide show
  1. package/AGENTS.md +393 -0
  2. package/es/components/CheckboxGroup/CheckboxGroup.d.ts +3 -3
  3. package/es/components/CheckboxGroup/CheckboxGroup.js +94 -91
  4. package/es/components/CheckboxGroup/interface.d.ts +21 -15
  5. package/es/components/CheckboxGroup/style/CheckboxGroup.scss +0 -7
  6. package/es/components/Form/Form.d.ts +29 -0
  7. package/es/components/Form/Form.js +188 -0
  8. package/es/components/Form/FormItem.d.ts +4 -0
  9. package/es/components/Form/FormItem.js +165 -0
  10. package/es/components/Form/FormItemContent.d.ts +18 -0
  11. package/es/components/Form/FormItemContent.js +146 -0
  12. package/es/components/Form/constants.d.ts +46 -0
  13. package/es/components/Form/constants.js +65 -0
  14. package/es/components/Form/helper.d.ts +120 -0
  15. package/es/components/Form/helper.js +284 -0
  16. package/es/components/Form/index.d.ts +20 -0
  17. package/es/components/Form/index.js +21 -0
  18. package/es/components/Form/interface.d.ts +238 -0
  19. package/es/components/Form/interface.js +2 -0
  20. package/es/components/Form/style/Form.css +1 -0
  21. package/es/components/Form/style/Form.scss +167 -0
  22. package/es/components/Form/style/css.js +2 -0
  23. package/es/components/Form/style/index.d.ts +1 -0
  24. package/es/components/Form/style/index.js +2 -0
  25. package/es/components/Form/useFormItemContext.d.ts +32 -0
  26. package/es/components/Form/useFormItemContext.js +55 -0
  27. package/es/components/Form/useFormItemWatch.d.ts +51 -0
  28. package/es/components/Form/useFormItemWatch.js +69 -0
  29. package/es/components/Form/useValidationTrigger.d.ts +40 -0
  30. package/es/components/Form/useValidationTrigger.js +74 -0
  31. package/es/components/Input/Input.js +72 -74
  32. package/es/components/Input/interface.d.ts +9 -9
  33. package/es/components/InputAmount/InputAmount.js +228 -276
  34. package/es/components/InputAmount/helper.d.ts +46 -0
  35. package/es/components/InputAmount/helper.js +115 -0
  36. package/es/components/ProForm/ProForm.d.ts +33 -0
  37. package/es/components/ProForm/ProForm.js +208 -0
  38. package/es/components/ProForm/ProFormDependency.d.ts +12 -0
  39. package/es/components/ProForm/ProFormDependency.js +61 -0
  40. package/es/components/ProForm/ProFormList.d.ts +19 -0
  41. package/es/components/ProForm/ProFormList.js +348 -0
  42. package/es/components/ProForm/Submitter.d.ts +21 -0
  43. package/es/components/ProForm/Submitter.js +76 -0
  44. package/es/components/ProForm/constants.d.ts +34 -0
  45. package/es/components/ProForm/constants.js +40 -0
  46. package/es/components/ProForm/fields/ProFormCheckbox.d.ts +6 -0
  47. package/es/components/ProForm/fields/ProFormCheckbox.js +11 -0
  48. package/es/components/ProForm/fields/ProFormCheckboxGroup.d.ts +6 -0
  49. package/es/components/ProForm/fields/ProFormCheckboxGroup.js +46 -0
  50. package/es/components/ProForm/fields/ProFormDigit.d.ts +6 -0
  51. package/es/components/ProForm/fields/ProFormDigit.js +15 -0
  52. package/es/components/ProForm/fields/ProFormMoney.d.ts +6 -0
  53. package/es/components/ProForm/fields/ProFormMoney.js +10 -0
  54. package/es/components/ProForm/fields/ProFormMultiSelect.d.ts +6 -0
  55. package/es/components/ProForm/fields/ProFormMultiSelect.js +27 -0
  56. package/es/components/ProForm/fields/ProFormPassword.d.ts +6 -0
  57. package/es/components/ProForm/fields/ProFormPassword.js +16 -0
  58. package/es/components/ProForm/fields/ProFormRadio.d.ts +6 -0
  59. package/es/components/ProForm/fields/ProFormRadio.js +13 -0
  60. package/es/components/ProForm/fields/ProFormSelect.d.ts +6 -0
  61. package/es/components/ProForm/fields/ProFormSelect.js +13 -0
  62. package/es/components/ProForm/fields/ProFormSwitch.d.ts +6 -0
  63. package/es/components/ProForm/fields/ProFormSwitch.js +11 -0
  64. package/es/components/ProForm/fields/ProFormText.d.ts +6 -0
  65. package/es/components/ProForm/fields/ProFormText.js +15 -0
  66. package/es/components/ProForm/fields/ProFormTextArea.d.ts +6 -0
  67. package/es/components/ProForm/fields/ProFormTextArea.js +16 -0
  68. package/es/components/ProForm/fields/createProFormField.d.ts +43 -0
  69. package/es/components/ProForm/fields/createProFormField.js +200 -0
  70. package/es/components/ProForm/fields/index.d.ts +12 -0
  71. package/es/components/ProForm/fields/index.js +13 -0
  72. package/es/components/ProForm/index.d.ts +7 -0
  73. package/es/components/ProForm/index.js +7 -0
  74. package/es/components/ProForm/interface.d.ts +306 -0
  75. package/es/components/ProForm/interface.js +2 -0
  76. package/es/components/ProForm/layouts/DrawerForm.d.ts +16 -0
  77. package/es/components/ProForm/layouts/DrawerForm.js +79 -0
  78. package/es/components/ProForm/layouts/ModalForm.d.ts +16 -0
  79. package/es/components/ProForm/layouts/ModalForm.js +89 -0
  80. package/es/components/ProForm/layouts/QueryFilter.d.ts +21 -0
  81. package/es/components/ProForm/layouts/QueryFilter.js +132 -0
  82. package/es/components/ProForm/layouts/StepsForm.d.ts +13 -0
  83. package/es/components/ProForm/layouts/StepsForm.js +295 -0
  84. package/es/components/ProForm/layouts/index.d.ts +4 -0
  85. package/es/components/ProForm/layouts/index.js +5 -0
  86. package/es/components/ProForm/layouts/useOverlayForm.d.ts +53 -0
  87. package/es/components/ProForm/layouts/useOverlayForm.js +143 -0
  88. package/es/components/ProForm/style/ProForm.module.css +1 -0
  89. package/es/components/ProForm/style/ProForm.module.scss +59 -0
  90. package/es/components/ProForm/style/css.js +3 -0
  91. package/es/components/ProForm/style/index.d.ts +1 -0
  92. package/es/components/ProForm/style/index.js +3 -0
  93. package/es/components/ProForm/utils.d.ts +72 -0
  94. package/es/components/ProForm/utils.js +206 -0
  95. package/es/components/RadioGroup/RadioGroup.js +46 -23
  96. package/es/components/RadioGroup/interface.d.ts +3 -1
  97. package/es/components/Select/Select.d.ts +1 -1
  98. package/es/components/Select/Select.js +113 -106
  99. package/es/components/Select/constants.d.ts +18 -0
  100. package/es/components/Select/constants.js +19 -0
  101. package/es/components/Sidebar/Sidebar.js +21 -23
  102. package/es/components/Sidebar/SidebarLogo.d.ts +7 -0
  103. package/es/components/Sidebar/SidebarLogo.js +33 -0
  104. package/es/components/Sidebar/SimplySidebar.d.ts +2 -2
  105. package/es/components/Sidebar/SimplySidebar.js +18 -22
  106. package/es/components/Sidebar/Stepper.js +14 -14
  107. package/es/components/Sidebar/constants.d.ts +16 -0
  108. package/es/components/Sidebar/constants.js +17 -0
  109. package/es/components/Sidebar/style/Stepper.css +1 -1
  110. package/es/components/Sidebar/style/Stepper.scss +11 -1
  111. package/es/components/Switch/Switch.js +28 -25
  112. package/es/components/Switch/interface.d.ts +9 -4
  113. package/es/components/useControlledState/index.d.ts +14 -0
  114. package/es/components/useControlledState/index.js +32 -0
  115. package/es/components/useEventCallback/index.d.ts +11 -0
  116. package/es/components/useEventCallback/index.js +17 -0
  117. package/es/components/useLayoutEffect/index.d.ts +11 -0
  118. package/es/components/useLayoutEffect/index.js +17 -0
  119. package/es/components/useLayoutState/index.d.ts +13 -0
  120. package/es/components/useLayoutState/index.js +71 -0
  121. package/es/components/useMemoizedFn/index.d.ts +12 -0
  122. package/es/components/useMemoizedFn/index.js +27 -0
  123. package/es/components/usePrevious/index.d.ts +11 -0
  124. package/es/components/usePrevious/index.js +19 -0
  125. package/es/components/useSafeState/index.d.ts +12 -0
  126. package/es/components/useSafeState/index.js +24 -0
  127. package/es/components/useSyncState/index.d.ts +14 -0
  128. package/es/components/useSyncState/index.js +37 -0
  129. package/es/components/useUpdateEffect/index.d.ts +9 -0
  130. package/es/components/useUpdateEffect/index.js +19 -0
  131. package/es/index.css +1 -1
  132. package/es/index.d.ts +21 -2
  133. package/es/index.js +19 -1
  134. package/jest.setup.d.ts +1 -0
  135. package/jest.setup.ts +1 -0
  136. package/lib/components/CheckboxGroup/CheckboxGroup.d.ts +3 -3
  137. package/lib/components/CheckboxGroup/CheckboxGroup.js +92 -89
  138. package/lib/components/CheckboxGroup/interface.d.ts +21 -15
  139. package/lib/components/CheckboxGroup/style/CheckboxGroup.scss +0 -7
  140. package/lib/components/Form/Form.d.ts +29 -0
  141. package/lib/components/Form/Form.js +199 -0
  142. package/lib/components/Form/FormItem.d.ts +4 -0
  143. package/lib/components/Form/FormItem.js +176 -0
  144. package/lib/components/Form/FormItemContent.d.ts +18 -0
  145. package/lib/components/Form/FormItemContent.js +156 -0
  146. package/lib/components/Form/constants.d.ts +46 -0
  147. package/lib/components/Form/constants.js +71 -0
  148. package/lib/components/Form/helper.d.ts +120 -0
  149. package/lib/components/Form/helper.js +290 -0
  150. package/lib/components/Form/index.d.ts +20 -0
  151. package/lib/components/Form/index.js +45 -0
  152. package/lib/components/Form/interface.d.ts +238 -0
  153. package/lib/components/Form/interface.js +6 -0
  154. package/lib/components/Form/style/Form.css +1 -0
  155. package/lib/components/Form/style/Form.scss +167 -0
  156. package/lib/components/Form/style/css.js +4 -0
  157. package/lib/components/Form/style/index.d.ts +1 -0
  158. package/lib/components/Form/style/index.js +4 -0
  159. package/lib/components/Form/useFormItemContext.d.ts +32 -0
  160. package/lib/components/Form/useFormItemContext.js +62 -0
  161. package/lib/components/Form/useFormItemWatch.d.ts +51 -0
  162. package/lib/components/Form/useFormItemWatch.js +76 -0
  163. package/lib/components/Form/useValidationTrigger.d.ts +40 -0
  164. package/lib/components/Form/useValidationTrigger.js +81 -0
  165. package/lib/components/Input/Input.js +71 -73
  166. package/lib/components/Input/interface.d.ts +9 -9
  167. package/lib/components/InputAmount/InputAmount.js +230 -278
  168. package/lib/components/InputAmount/helper.d.ts +46 -0
  169. package/lib/components/InputAmount/helper.js +122 -0
  170. package/lib/components/ProForm/ProForm.d.ts +33 -0
  171. package/lib/components/ProForm/ProForm.js +216 -0
  172. package/lib/components/ProForm/ProFormDependency.d.ts +12 -0
  173. package/lib/components/ProForm/ProFormDependency.js +67 -0
  174. package/lib/components/ProForm/ProFormList.d.ts +19 -0
  175. package/lib/components/ProForm/ProFormList.js +355 -0
  176. package/lib/components/ProForm/Submitter.d.ts +21 -0
  177. package/lib/components/ProForm/Submitter.js +83 -0
  178. package/lib/components/ProForm/constants.d.ts +34 -0
  179. package/lib/components/ProForm/constants.js +46 -0
  180. package/lib/components/ProForm/fields/ProFormCheckbox.d.ts +6 -0
  181. package/lib/components/ProForm/fields/ProFormCheckbox.js +18 -0
  182. package/lib/components/ProForm/fields/ProFormCheckboxGroup.d.ts +6 -0
  183. package/lib/components/ProForm/fields/ProFormCheckboxGroup.js +53 -0
  184. package/lib/components/ProForm/fields/ProFormDigit.d.ts +6 -0
  185. package/lib/components/ProForm/fields/ProFormDigit.js +22 -0
  186. package/lib/components/ProForm/fields/ProFormMoney.d.ts +6 -0
  187. package/lib/components/ProForm/fields/ProFormMoney.js +17 -0
  188. package/lib/components/ProForm/fields/ProFormMultiSelect.d.ts +6 -0
  189. package/lib/components/ProForm/fields/ProFormMultiSelect.js +34 -0
  190. package/lib/components/ProForm/fields/ProFormPassword.d.ts +6 -0
  191. package/lib/components/ProForm/fields/ProFormPassword.js +23 -0
  192. package/lib/components/ProForm/fields/ProFormRadio.d.ts +6 -0
  193. package/lib/components/ProForm/fields/ProFormRadio.js +20 -0
  194. package/lib/components/ProForm/fields/ProFormSelect.d.ts +6 -0
  195. package/lib/components/ProForm/fields/ProFormSelect.js +20 -0
  196. package/lib/components/ProForm/fields/ProFormSwitch.d.ts +6 -0
  197. package/lib/components/ProForm/fields/ProFormSwitch.js +18 -0
  198. package/lib/components/ProForm/fields/ProFormText.d.ts +6 -0
  199. package/lib/components/ProForm/fields/ProFormText.js +22 -0
  200. package/lib/components/ProForm/fields/ProFormTextArea.d.ts +6 -0
  201. package/lib/components/ProForm/fields/ProFormTextArea.js +23 -0
  202. package/lib/components/ProForm/fields/createProFormField.d.ts +43 -0
  203. package/lib/components/ProForm/fields/createProFormField.js +208 -0
  204. package/lib/components/ProForm/fields/index.d.ts +12 -0
  205. package/lib/components/ProForm/fields/index.js +90 -0
  206. package/lib/components/ProForm/index.d.ts +7 -0
  207. package/lib/components/ProForm/index.js +73 -0
  208. package/lib/components/ProForm/interface.d.ts +306 -0
  209. package/lib/components/ProForm/interface.js +6 -0
  210. package/lib/components/ProForm/layouts/DrawerForm.d.ts +16 -0
  211. package/lib/components/ProForm/layouts/DrawerForm.js +86 -0
  212. package/lib/components/ProForm/layouts/ModalForm.d.ts +16 -0
  213. package/lib/components/ProForm/layouts/ModalForm.js +96 -0
  214. package/lib/components/ProForm/layouts/QueryFilter.d.ts +21 -0
  215. package/lib/components/ProForm/layouts/QueryFilter.js +139 -0
  216. package/lib/components/ProForm/layouts/StepsForm.d.ts +13 -0
  217. package/lib/components/ProForm/layouts/StepsForm.js +302 -0
  218. package/lib/components/ProForm/layouts/index.d.ts +4 -0
  219. package/lib/components/ProForm/layouts/index.js +40 -0
  220. package/lib/components/ProForm/layouts/useOverlayForm.d.ts +53 -0
  221. package/lib/components/ProForm/layouts/useOverlayForm.js +150 -0
  222. package/lib/components/ProForm/style/ProForm.module.css +1 -0
  223. package/lib/components/ProForm/style/ProForm.module.scss +59 -0
  224. package/lib/components/ProForm/style/css.js +4 -0
  225. package/lib/components/ProForm/style/index.d.ts +1 -0
  226. package/lib/components/ProForm/style/index.js +4 -0
  227. package/lib/components/ProForm/utils.d.ts +72 -0
  228. package/lib/components/ProForm/utils.js +213 -0
  229. package/lib/components/RadioGroup/RadioGroup.js +45 -22
  230. package/lib/components/RadioGroup/interface.d.ts +3 -1
  231. package/lib/components/Select/Select.d.ts +1 -1
  232. package/lib/components/Select/Select.js +114 -107
  233. package/lib/components/Select/constants.d.ts +18 -0
  234. package/lib/components/Select/constants.js +25 -0
  235. package/lib/components/Sidebar/Sidebar.js +21 -23
  236. package/lib/components/Sidebar/SidebarLogo.d.ts +7 -0
  237. package/lib/components/Sidebar/SidebarLogo.js +39 -0
  238. package/lib/components/Sidebar/SimplySidebar.d.ts +2 -2
  239. package/lib/components/Sidebar/SimplySidebar.js +17 -21
  240. package/lib/components/Sidebar/Stepper.js +14 -14
  241. package/lib/components/Sidebar/constants.d.ts +16 -0
  242. package/lib/components/Sidebar/constants.js +23 -0
  243. package/lib/components/Sidebar/style/Stepper.css +1 -1
  244. package/lib/components/Sidebar/style/Stepper.scss +11 -1
  245. package/lib/components/Switch/Switch.js +27 -24
  246. package/lib/components/Switch/interface.d.ts +9 -4
  247. package/lib/components/useControlledState/index.d.ts +14 -0
  248. package/lib/components/useControlledState/index.js +39 -0
  249. package/lib/components/useEventCallback/index.d.ts +11 -0
  250. package/lib/components/useEventCallback/index.js +24 -0
  251. package/lib/components/useLayoutEffect/index.d.ts +11 -0
  252. package/lib/components/useLayoutEffect/index.js +23 -0
  253. package/lib/components/useLayoutState/index.d.ts +13 -0
  254. package/lib/components/useLayoutState/index.js +79 -0
  255. package/lib/components/useMemoizedFn/index.d.ts +12 -0
  256. package/lib/components/useMemoizedFn/index.js +33 -0
  257. package/lib/components/usePrevious/index.d.ts +11 -0
  258. package/lib/components/usePrevious/index.js +25 -0
  259. package/lib/components/useSafeState/index.d.ts +12 -0
  260. package/lib/components/useSafeState/index.js +31 -0
  261. package/lib/components/useSyncState/index.d.ts +14 -0
  262. package/lib/components/useSyncState/index.js +44 -0
  263. package/lib/components/useUpdateEffect/index.d.ts +9 -0
  264. package/lib/components/useUpdateEffect/index.js +25 -0
  265. package/lib/index.css +1 -1
  266. package/lib/index.d.ts +21 -2
  267. package/lib/index.js +213 -1
  268. package/package.json +16 -1
@@ -0,0 +1,348 @@
1
+ var __rest = this && this.__rest || function (s, e) {
2
+ var t = {};
3
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
4
+ if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
5
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
6
+ }
7
+ return t;
8
+ };
9
+ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
10
+ import { DndContext } from '@dnd-kit/core';
11
+ import { SortableContext, useSortable, verticalListSortingStrategy } from '@dnd-kit/sortable';
12
+ import { CSS } from '@dnd-kit/utilities';
13
+ import { memo, useEffect, useMemo, useRef } from 'react';
14
+ import { joinCls } from '../../utils/classnames';
15
+ import useMemoizedFn from '../useMemoizedFn';
16
+ import { useFieldArray, useFormContext, useWatch } from 'react-hook-form';
17
+ import { Button } from '../Button';
18
+ import { CSS_PREFIX, DEFAULT_TEXT } from './constants';
19
+ import styles from './style/ProForm.module.scss';
20
+ import { extractButtonProps } from './utils';
21
+ /**
22
+ * Creates a `DndContext` `onDragEnd` handler that translates drag events
23
+ * into field array `move` calls.
24
+ *
25
+ * @param options.move - The `move` function from `useFieldArray`.
26
+ * @param options.fields - The current field array entries.
27
+ * @returns A drag-end event handler.
28
+ */
29
+ export var buildOnDragEnd = function buildOnDragEnd(_ref) {
30
+ var move = _ref.move,
31
+ fields = _ref.fields;
32
+ return function (_ref2) {
33
+ var active = _ref2.active,
34
+ over = _ref2.over;
35
+ if (!over || active.id === over.id) return;
36
+ var oldIndex = fields.findIndex(function (item) {
37
+ return item.id === String(active.id);
38
+ });
39
+ var newIndex = fields.findIndex(function (item) {
40
+ return item.id === String(over.id);
41
+ });
42
+ if (oldIndex >= 0 && newIndex >= 0) {
43
+ move(oldIndex, newIndex);
44
+ }
45
+ };
46
+ };
47
+ /** @internal Renders copy/delete action buttons for a single list row. */
48
+ var ProFormListRowBodyBase = function ProFormListRowBodyBase(_ref3) {
49
+ var fieldId = _ref3.fieldId,
50
+ index = _ref3.index,
51
+ record = _ref3.record,
52
+ copyIconProps = _ref3.copyIconProps,
53
+ deleteIconProps = _ref3.deleteIconProps,
54
+ canAdd = _ref3.canAdd,
55
+ canRemove = _ref3.canRemove,
56
+ copy = _ref3.copy,
57
+ removeAt = _ref3.removeAt,
58
+ action = _ref3.action,
59
+ actionRender = _ref3.actionRender,
60
+ itemRender = _ref3.itemRender;
61
+ var _a, _b;
62
+ var copyBtn = extractButtonProps(copyIconProps);
63
+ var deleteBtn = extractButtonProps(deleteIconProps);
64
+ var defaultDom = {
65
+ "delete": deleteIconProps === false ? null : _jsx(Button, Object.assign({}, deleteBtn.domProps, {
66
+ type: 'button',
67
+ severity: 'secondary',
68
+ onClick: function onClick(event) {
69
+ var _a;
70
+ removeAt(index);
71
+ (_a = deleteBtn.onClick) === null || _a === void 0 ? void 0 : _a.call(deleteBtn, event);
72
+ },
73
+ disabled: !canRemove || deleteBtn.disabled,
74
+ children: (_a = deleteBtn.children) !== null && _a !== void 0 ? _a : DEFAULT_TEXT["delete"]
75
+ }), "delete-".concat(fieldId)),
76
+ copy: copyIconProps === false ? null : _jsx(Button, Object.assign({}, copyBtn.domProps, {
77
+ type: 'button',
78
+ severity: 'secondary',
79
+ onClick: function onClick(event) {
80
+ var _a;
81
+ copy(index);
82
+ (_a = copyBtn.onClick) === null || _a === void 0 ? void 0 : _a.call(copyBtn, event);
83
+ },
84
+ disabled: !canAdd || copyBtn.disabled,
85
+ children: (_b = copyBtn.children) !== null && _b !== void 0 ? _b : DEFAULT_TEXT.copy
86
+ }), "copy-".concat(fieldId))
87
+ };
88
+ var renderedActions = actionRender ? actionRender({
89
+ index: index,
90
+ record: record
91
+ }, action, defaultDom) : [defaultDom.copy, defaultDom["delete"]].filter(Boolean);
92
+ var rowNode = _jsx("div", {
93
+ className: joinCls(styles['proform__list-row-actions'], "".concat(CSS_PREFIX, "-list-row-actions")),
94
+ children: renderedActions
95
+ });
96
+ if (!itemRender) return rowNode;
97
+ return _jsx(_Fragment, {
98
+ children: itemRender({
99
+ listDom: rowNode,
100
+ action: action
101
+ })
102
+ });
103
+ };
104
+ var ProFormListRowBody = /*#__PURE__*/memo(ProFormListRowBodyBase);
105
+ /** @internal Drag-and-drop wrapper for a sortable list row. */
106
+ var SortableProFormListRowBase = function SortableProFormListRowBase(props) {
107
+ var fieldId = props.fieldId;
108
+ var _useSortable = useSortable({
109
+ id: fieldId
110
+ }),
111
+ attributes = _useSortable.attributes,
112
+ listeners = _useSortable.listeners,
113
+ setNodeRef = _useSortable.setNodeRef,
114
+ transform = _useSortable.transform,
115
+ transition = _useSortable.transition,
116
+ isDragging = _useSortable.isDragging;
117
+ var style = {
118
+ transform: transform ? CSS.Transform.toString(transform) : undefined,
119
+ transition: transition || undefined,
120
+ cursor: 'grab',
121
+ opacity: isDragging ? 0.8 : 1
122
+ };
123
+ return _jsx("div", Object.assign({
124
+ ref: setNodeRef,
125
+ style: style,
126
+ "data-sortable": 'true'
127
+ }, attributes, listeners, {
128
+ children: _jsx(ProFormListRowBody, Object.assign({}, props))
129
+ }));
130
+ };
131
+ var SortableProFormListRow = /*#__PURE__*/memo(SortableProFormListRowBase);
132
+ /** @internal Renders the "add row" button for {@link ProFormList}. */
133
+ var CreatorButton = function CreatorButton(_ref4) {
134
+ var config = _ref4.config,
135
+ canAdd = _ref4.canAdd,
136
+ onAdd = _ref4.onAdd;
137
+ if (!config) return null;
138
+ var text = config.text,
139
+ _ = config.position,
140
+ _onClick = config.onClick,
141
+ disabled = config.disabled,
142
+ domProps = __rest(config, ["text", "position", "onClick", "disabled"]);
143
+ return _jsx(Button, Object.assign({}, domProps, {
144
+ type: 'button',
145
+ onClick: function onClick(event) {
146
+ onAdd();
147
+ _onClick === null || _onClick === void 0 ? void 0 : _onClick(event);
148
+ },
149
+ disabled: !canAdd || !!disabled,
150
+ children: text !== null && text !== void 0 ? text : DEFAULT_TEXT.add
151
+ }));
152
+ };
153
+ /**
154
+ * Dynamic, repeatable form field list with add, remove, copy, and
155
+ * drag-and-drop reordering capabilities.
156
+ *
157
+ * @example
158
+ * ```tsx
159
+ * <ProFormList name="items" min={1} max={5} sortable>
160
+ * {(fields) => fields.map(({ name, key }) => (
161
+ * <ProFormText key={key} name={`${name}.title`} label="Title" />
162
+ * ))}
163
+ * </ProFormList>
164
+ * ```
165
+ */
166
+ var ProFormListBase = function ProFormListBase(props) {
167
+ var _a;
168
+ var name = props.name,
169
+ label = props.label,
170
+ min = props.min,
171
+ max = props.max,
172
+ initialValue = props.initialValue,
173
+ copyIconProps = props.copyIconProps,
174
+ deleteIconProps = props.deleteIconProps,
175
+ creatorButtonProps = props.creatorButtonProps,
176
+ sortable = props.sortable,
177
+ itemRender = props.itemRender,
178
+ actionRender = props.actionRender,
179
+ children = props.children,
180
+ onAfterAdd = props.onAfterAdd,
181
+ onAfterRemove = props.onAfterRemove;
182
+ var initialApplied = useRef(false);
183
+ var _useFormContext = useFormContext(),
184
+ control = _useFormContext.control;
185
+ var _useFieldArray = useFieldArray({
186
+ control: control,
187
+ name: name
188
+ }),
189
+ fields = _useFieldArray.fields,
190
+ append = _useFieldArray.append,
191
+ remove = _useFieldArray.remove,
192
+ move = _useFieldArray.move,
193
+ insert = _useFieldArray.insert,
194
+ replace = _useFieldArray.replace;
195
+ var watchedList = useWatch({
196
+ control: control,
197
+ name: name
198
+ });
199
+ var listSnapshot = useMemo(function () {
200
+ return Array.isArray(watchedList) ? watchedList : [];
201
+ }, [watchedList]);
202
+ // Apply `initialValue` only once: `initialApplied.current` prevents re-entry,
203
+ // so even if future renders pass a new `initialValue` array reference, this
204
+ // effect will not call `replace` again once initialization has happened.
205
+ // If re-application on `initialValue` changes is desired, reset
206
+ // `initialApplied.current` intentionally (or remove this guard and diff values).
207
+ useEffect(function () {
208
+ if (initialApplied.current) return;
209
+ if (fields.length !== 0) return;
210
+ if (!Array.isArray(initialValue) || initialValue.length === 0) return;
211
+ initialApplied.current = true;
212
+ replace(initialValue);
213
+ }, [fields.length, initialValue, replace]);
214
+ var canAdd = max == null || fields.length < max;
215
+ var canRemove = min == null || fields.length > min;
216
+ var add = useMemoizedFn(function (defaultValue, index) {
217
+ if (!canAdd) return;
218
+ var value = defaultValue !== null && defaultValue !== void 0 ? defaultValue : {};
219
+ if (typeof index === 'number') {
220
+ insert(index, value);
221
+ onAfterAdd === null || onAfterAdd === void 0 ? void 0 : onAfterAdd(value, index);
222
+ return;
223
+ }
224
+ append(value);
225
+ onAfterAdd === null || onAfterAdd === void 0 ? void 0 : onAfterAdd(value, fields.length);
226
+ });
227
+ var removeAt = useMemoizedFn(function (index) {
228
+ if (!canRemove) return;
229
+ remove(index);
230
+ onAfterRemove === null || onAfterRemove === void 0 ? void 0 : onAfterRemove(index);
231
+ });
232
+ var copy = useMemoizedFn(function (index) {
233
+ var _a;
234
+ if (!canAdd) return;
235
+ var value = (_a = listSnapshot[index]) !== null && _a !== void 0 ? _a : {};
236
+ add(value, index + 1);
237
+ });
238
+ var memoizedMove = useMemoizedFn(move);
239
+ var getList = useMemoizedFn(function () {
240
+ return listSnapshot;
241
+ });
242
+ var action = useMemo(function () {
243
+ return {
244
+ add: add,
245
+ remove: removeAt,
246
+ move: memoizedMove,
247
+ copy: copy,
248
+ getList: getList
249
+ };
250
+ }, [add, copy, getList, memoizedMove, removeAt]);
251
+ var mappedFields = useMemo(function () {
252
+ return fields.map(function (field, index) {
253
+ return {
254
+ name: "".concat(String(name), ".").concat(index),
255
+ key: field.id
256
+ };
257
+ });
258
+ }, [fields, name]);
259
+ var listDom = typeof children === 'function' ? children(mappedFields, action) : children;
260
+ var hasCreator = creatorButtonProps !== false;
261
+ var creatorConfig = hasCreator ? Object.assign({}, creatorButtonProps || {}) : undefined;
262
+ var creatorPosition = (_a = creatorConfig === null || creatorConfig === void 0 ? void 0 : creatorConfig.position) !== null && _a !== void 0 ? _a : 'bottom';
263
+ var addFromTopCreator = useMemoizedFn(function () {
264
+ return add({}, 0);
265
+ });
266
+ var addFromBottomCreator = useMemoizedFn(function () {
267
+ return add();
268
+ });
269
+ var actionRows = useMemo(function () {
270
+ return fields.map(function (field, index) {
271
+ var rowRecord = listSnapshot[index];
272
+ if (sortable) {
273
+ return _jsx(SortableProFormListRow, {
274
+ fieldId: field.id,
275
+ index: index,
276
+ record: rowRecord,
277
+ copyIconProps: copyIconProps,
278
+ deleteIconProps: deleteIconProps,
279
+ canAdd: canAdd,
280
+ canRemove: canRemove,
281
+ copy: copy,
282
+ removeAt: removeAt,
283
+ action: action,
284
+ actionRender: actionRender,
285
+ itemRender: itemRender
286
+ }, field.id);
287
+ }
288
+ return _jsx(ProFormListRowBody, {
289
+ fieldId: field.id,
290
+ index: index,
291
+ record: rowRecord,
292
+ copyIconProps: copyIconProps,
293
+ deleteIconProps: deleteIconProps,
294
+ canAdd: canAdd,
295
+ canRemove: canRemove,
296
+ copy: copy,
297
+ removeAt: removeAt,
298
+ action: action,
299
+ actionRender: actionRender,
300
+ itemRender: itemRender
301
+ }, field.id);
302
+ });
303
+ }, [action, actionRender, canAdd, canRemove, copy, copyIconProps, deleteIconProps, fields, itemRender, listSnapshot, removeAt, sortable]);
304
+ var sortableIds = useMemo(function () {
305
+ return fields.map(function (item) {
306
+ return item.id;
307
+ });
308
+ }, [fields]);
309
+ var dragEndHandler = useMemo(function () {
310
+ return buildOnDragEnd({
311
+ move: move,
312
+ fields: fields
313
+ });
314
+ }, [fields, move]);
315
+ var actionsNode = sortable ? _jsx(DndContext, {
316
+ onDragEnd: dragEndHandler,
317
+ children: _jsx(SortableContext, {
318
+ items: sortableIds,
319
+ strategy: verticalListSortingStrategy,
320
+ children: actionRows
321
+ })
322
+ }) : actionRows;
323
+ return _jsxs("div", {
324
+ className: joinCls(styles['proform__list'], "".concat(CSS_PREFIX, "-list")),
325
+ children: [label && _jsx("div", {
326
+ className: joinCls(styles['proform__list-label'], "".concat(CSS_PREFIX, "-list-label")),
327
+ children: label
328
+ }), creatorPosition === 'top' && _jsx(CreatorButton, {
329
+ config: creatorConfig,
330
+ canAdd: canAdd,
331
+ onAdd: addFromTopCreator
332
+ }), _jsx("div", {
333
+ className: "".concat(CSS_PREFIX, "-list-content"),
334
+ children: listDom
335
+ }), _jsx("div", {
336
+ className: "".concat(CSS_PREFIX, "-list-actions"),
337
+ children: actionsNode
338
+ }), creatorPosition === 'bottom' && _jsx(CreatorButton, {
339
+ config: creatorConfig,
340
+ canAdd: canAdd,
341
+ onAdd: addFromBottomCreator
342
+ })]
343
+ });
344
+ };
345
+ ProFormListBase.displayName = 'ProFormList';
346
+ export var ProFormList = /*#__PURE__*/memo(ProFormListBase);
347
+ export default ProFormList;
348
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["components/ProForm/ProFormList.js","components/src/components/ProForm/ProFormList.tsx"],"names":["__rest","s","e","t","p","Object","prototype","hasOwnProperty","call","indexOf","getOwnPropertySymbols","i","length","propertyIsEnumerable","jsx","_jsx","Fragment","_Fragment","jsxs","_jsxs","DndContext","SortableContext","useSortable","verticalListSortingStrategy","CSS","memo","useEffect","useMemo","useRef","joinCls","useMemoizedFn","useFieldArray","useFormContext","useWatch","Button","CSS_PREFIX","DEFAULT_TEXT","styles","extractButtonProps","buildOnDragEnd","_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","deleteBtn","defaultDom","assign","domProps","type","severity","onClick","event","disabled","children","concat","renderedActions","filter","Boolean","rowNode","className","listDom","ProFormListRowBody","SortableProFormListRowBase","props","_useSortable","attributes","listeners","setNodeRef","transform","transition","isDragging","style","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","_useFormContext","control","_useFieldArray","append","remove","insert","replace","watchedList","listSnapshot","Array","isArray","current","defaultValue","value","memoizedMove","getList","mappedFields","map","field","key","hasCreator","creatorConfig","creatorPosition","addFromTopCreator","addFromBottomCreator","actionRows","rowRecord","sortableIds","dragEndHandler","actionsNode","onDragEnd","items","strategy","displayName","ProFormList"],"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,76 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { memo } from 'react';
3
+ import { joinCls } from '../../utils/classnames';
4
+ import useMemoizedFn from '../useMemoizedFn';
5
+ import { Button } from '../Button';
6
+ import { CSS_PREFIX, DEFAULT_TEXT } from './constants';
7
+ import styles from './style/ProForm.module.scss';
8
+ /**
9
+ * Renders the submit and reset buttons for a {@link ProForm}.
10
+ * Supports custom rendering via the `render` prop.
11
+ *
12
+ * @typeParam TFieldValues - The form values type.
13
+ */
14
+ function SubmitterBase(props) {
15
+ var _a, _b, _c;
16
+ var _props$submitText = props.submitText,
17
+ submitText = _props$submitText === void 0 ? DEFAULT_TEXT.submit : _props$submitText,
18
+ _props$resetText = props.resetText,
19
+ resetText = _props$resetText === void 0 ? DEFAULT_TEXT.reset : _props$resetText,
20
+ render = props.render,
21
+ onSubmit = props.onSubmit,
22
+ onReset = props.onReset,
23
+ submitButtonProps = props.submitButtonProps,
24
+ resetButtonProps = props.resetButtonProps,
25
+ form = props.form,
26
+ onSubmitForm = props.onSubmitForm;
27
+ var handleSubmit = useMemoizedFn(function (event) {
28
+ var _a;
29
+ (_a = submitButtonProps === null || submitButtonProps === void 0 ? void 0 : submitButtonProps.onClick) === null || _a === void 0 ? void 0 : _a.call(submitButtonProps, event);
30
+ onSubmit === null || onSubmit === void 0 ? void 0 : onSubmit();
31
+ });
32
+ var handleReset = useMemoizedFn(function (event) {
33
+ var _a, _b;
34
+ if (event) {
35
+ (_a = resetButtonProps === null || resetButtonProps === void 0 ? void 0 : resetButtonProps.onClick) === null || _a === void 0 ? void 0 : _a.call(resetButtonProps, event);
36
+ } else {
37
+ (_b = resetButtonProps === null || resetButtonProps === void 0 ? void 0 : resetButtonProps.onClick) === null || _b === void 0 ? void 0 : _b.call(resetButtonProps);
38
+ }
39
+ onReset === null || onReset === void 0 ? void 0 : onReset();
40
+ });
41
+ var handleRenderSubmit = useMemoizedFn(function () {
42
+ if (onSubmitForm) {
43
+ onSubmitForm();
44
+ return;
45
+ }
46
+ onSubmit === null || onSubmit === void 0 ? void 0 : onSubmit();
47
+ });
48
+ var submitDom = _jsx(Button, Object.assign({}, submitButtonProps, {
49
+ type: (_a = submitButtonProps === null || submitButtonProps === void 0 ? void 0 : submitButtonProps.type) !== null && _a !== void 0 ? _a : 'submit',
50
+ onClick: handleSubmit,
51
+ children: submitText
52
+ }), 'submit');
53
+ var resetDom = _jsx(Button, Object.assign({}, resetButtonProps, {
54
+ type: (_b = resetButtonProps === null || resetButtonProps === void 0 ? void 0 : resetButtonProps.type) !== null && _b !== void 0 ? _b : 'button',
55
+ severity: (_c = resetButtonProps === null || resetButtonProps === void 0 ? void 0 : resetButtonProps.severity) !== null && _c !== void 0 ? _c : 'secondary',
56
+ onClick: handleReset,
57
+ children: resetText
58
+ }), 'reset');
59
+ // Button order: Reset first, Submit last (standard form UX pattern)
60
+ var dom = [resetDom, submitDom];
61
+ var renderedDom = render ? render({
62
+ form: form,
63
+ submit: handleRenderSubmit,
64
+ reset: function reset() {
65
+ return handleReset();
66
+ }
67
+ }, dom) : dom;
68
+ return _jsx("div", {
69
+ className: joinCls(styles['proform__submitter'], "".concat(CSS_PREFIX, "-submitter")),
70
+ children: renderedDom
71
+ });
72
+ }
73
+ SubmitterBase.displayName = 'Submitter';
74
+ export var Submitter = /*#__PURE__*/memo(SubmitterBase);
75
+ export default Submitter;
76
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["components/ProForm/Submitter.js","components/src/components/ProForm/Submitter.tsx"],"names":["jsx","_jsx","memo","joinCls","useMemoizedFn","Button","CSS_PREFIX","DEFAULT_TEXT","styles","SubmitterBase","props","_a","_b","_c","_props$submitText","submitText","submit","_props$resetText","resetText","reset","render","onSubmit","onReset","submitButtonProps","resetButtonProps","form","onSubmitForm","handleSubmit","event","onClick","call","handleReset","handleRenderSubmit","submitDom","Object","assign","type","children","resetDom","severity","dom","renderedDom","className","concat","displayName","Submitter"],"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"}
@@ -0,0 +1,34 @@
1
+ /** CSS class name prefix used for all ProForm-related components. */
2
+ export declare const CSS_PREFIX = "om-react-ui-proform";
3
+ /** Default column span for grid layout (full width). */
4
+ export declare const DEFAULT_COL_SPAN = 24;
5
+ /** Default number of visible columns in {@link QueryFilter} before collapsing. */
6
+ export declare const DEFAULT_COLS_NUMBER = 3;
7
+ /**
8
+ * Default UI text for buttons and actions.
9
+ * Centralized here for i18n support.
10
+ */
11
+ export declare const DEFAULT_TEXT: {
12
+ readonly submit: "Submit";
13
+ readonly reset: "Reset";
14
+ readonly search: "Search";
15
+ readonly add: "Add";
16
+ readonly delete: "Delete";
17
+ readonly copy: "Copy";
18
+ readonly collapse: "Collapse";
19
+ readonly expand: "Expand";
20
+ readonly previous: "Previous";
21
+ readonly next: "Next";
22
+ readonly yes: "Yes";
23
+ readonly no: "No";
24
+ readonly empty: "-";
25
+ };
26
+ /**
27
+ * Width presets for form fields mapped to pixel values.
28
+ *
29
+ * - `sm` — 160px
30
+ * - `md` — 240px
31
+ * - `lg` — 320px
32
+ * - `xl` — 420px
33
+ */
34
+ export declare const WIDTH_SIZE_MAP: Record<string, number>;
@@ -0,0 +1,40 @@
1
+ /** CSS class name prefix used for all ProForm-related components. */
2
+ export var CSS_PREFIX = 'om-react-ui-proform';
3
+ /** Default column span for grid layout (full width). */
4
+ export var DEFAULT_COL_SPAN = 24;
5
+ /** Default number of visible columns in {@link QueryFilter} before collapsing. */
6
+ export var DEFAULT_COLS_NUMBER = 3;
7
+ /**
8
+ * Default UI text for buttons and actions.
9
+ * Centralized here for i18n support.
10
+ */
11
+ export var DEFAULT_TEXT = {
12
+ submit: 'Submit',
13
+ reset: 'Reset',
14
+ search: 'Search',
15
+ add: 'Add',
16
+ "delete": 'Delete',
17
+ copy: 'Copy',
18
+ collapse: 'Collapse',
19
+ expand: 'Expand',
20
+ previous: 'Previous',
21
+ next: 'Next',
22
+ yes: 'Yes',
23
+ no: 'No',
24
+ empty: '-'
25
+ };
26
+ /**
27
+ * Width presets for form fields mapped to pixel values.
28
+ *
29
+ * - `sm` — 160px
30
+ * - `md` — 240px
31
+ * - `lg` — 320px
32
+ * - `xl` — 420px
33
+ */
34
+ export var WIDTH_SIZE_MAP = {
35
+ sm: 160,
36
+ md: 240,
37
+ lg: 320,
38
+ xl: 420
39
+ };
40
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvc3JjL2NvbXBvbmVudHMvUHJvRm9ybS9jb25zdGFudHMudHMiLCJjb21wb25lbnRzL1Byb0Zvcm0vY29uc3RhbnRzLmpzIl0sIm5hbWVzIjpbIkNTU19QUkVGSVgiLCJERUZBVUxUX0NPTF9TUEFOIiwiREVGQVVMVF9DT0xTX05VTUJFUiIsIkRFRkFVTFRfVEVYVCIsInN1Ym1pdCIsInJlc2V0Iiwic2VhcmNoIiwiYWRkIiwiY29weSIsImNvbGxhcHNlIiwiZXhwYW5kIiwicHJldmlvdXMiLCJuZXh0IiwieWVzIiwibm8iLCJlbXB0eSIsIldJRFRIX1NJWkVfTUFQIiwic20iLCJtZCIsImxnIiwieGwiXSwibWFwcGluZ3MiOiJBQUFBO0FBQ0EsT0FBTyxJQUFNQSxVQUFVLEdBQUcscUJBQXFCO0FBRS9DO0FBQ0EsT0FBTyxJQUFNQyxnQkFBZ0IsR0FBRyxFQUFFO0FBRWxDO0FBQ0EsT0FBTyxJQUFNQyxtQkFBbUIsR0FBRyxDQUFDO0FBRXBDO0FDRkE7QUFDQTtBQUNBO0FESUEsT0FBTyxJQUFNQyxZQUFZLEdBQUc7RUFDMUJDLE1BQU0sRUFBRSxRQUFRO0VBQ2hCQyxLQUFLLEVBQUUsT0FBTztFQUNkQyxNQUFNLEVBQUUsUUFBUTtFQUNoQkMsR0FBRyxFQUFFLEtBQUs7RUFDVixVQUFRLFFBQVE7RUFDaEJDLElBQUksRUFBRSxNQUFNO0VBQ1pDLFFBQVEsRUFBRSxVQUFVO0VBQ3BCQyxNQUFNLEVBQUUsUUFBUTtFQUNoQkMsUUFBUSxFQUFFLFVBQVU7RUFDcEJDLElBQUksRUFBRSxNQUFNO0VBQ1pDLEdBQUcsRUFBRSxLQUFLO0VBQ1ZDLEVBQUUsRUFBRSxJQUFJO0VBQ1JDLEtBQUssRUFBRTtBQ0ZULENER1U7QUFFVjtBQ0hBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FES0EsT0FBTyxJQUFNQyxjQUFjLEdBQTJCO0VBQ3BEQyxFQUFFLEVBQUUsR0FBRztFQUNQQyxFQUFFLEVBQUUsR0FBRztFQUNQQyxFQUFFLEVBQUUsR0FBRztFQUNQQyxFQUFFLEVBQUU7QUNITixDRElDIiwiZmlsZSI6ImNvbXBvbmVudHMvUHJvRm9ybS9jb25zdGFudHMuanMiLCJzb3VyY2VzQ29udGVudCI6W251bGwsIi8qKiBDU1MgY2xhc3MgbmFtZSBwcmVmaXggdXNlZCBmb3IgYWxsIFByb0Zvcm0tcmVsYXRlZCBjb21wb25lbnRzLiAqL1xuZXhwb3J0IGNvbnN0IENTU19QUkVGSVggPSAnb20tcmVhY3QtdWktcHJvZm9ybSc7XG4vKiogRGVmYXVsdCBjb2x1bW4gc3BhbiBmb3IgZ3JpZCBsYXlvdXQgKGZ1bGwgd2lkdGgpLiAqL1xuZXhwb3J0IGNvbnN0IERFRkFVTFRfQ09MX1NQQU4gPSAyNDtcbi8qKiBEZWZhdWx0IG51bWJlciBvZiB2aXNpYmxlIGNvbHVtbnMgaW4ge0BsaW5rIFF1ZXJ5RmlsdGVyfSBiZWZvcmUgY29sbGFwc2luZy4gKi9cbmV4cG9ydCBjb25zdCBERUZBVUxUX0NPTFNfTlVNQkVSID0gMztcbi8qKlxuICogRGVmYXVsdCBVSSB0ZXh0IGZvciBidXR0b25zIGFuZCBhY3Rpb25zLlxuICogQ2VudHJhbGl6ZWQgaGVyZSBmb3IgaTE4biBzdXBwb3J0LlxuICovXG5leHBvcnQgY29uc3QgREVGQVVMVF9URVhUID0ge1xuICAgIHN1Ym1pdDogJ1N1Ym1pdCcsXG4gICAgcmVzZXQ6ICdSZXNldCcsXG4gICAgc2VhcmNoOiAnU2VhcmNoJyxcbiAgICBhZGQ6ICdBZGQnLFxuICAgIGRlbGV0ZTogJ0RlbGV0ZScsXG4gICAgY29weTogJ0NvcHknLFxuICAgIGNvbGxhcHNlOiAnQ29sbGFwc2UnLFxuICAgIGV4cGFuZDogJ0V4cGFuZCcsXG4gICAgcHJldmlvdXM6ICdQcmV2aW91cycsXG4gICAgbmV4dDogJ05leHQnLFxuICAgIHllczogJ1llcycsXG4gICAgbm86ICdObycsXG4gICAgZW1wdHk6ICctJyxcbn07XG4vKipcbiAqIFdpZHRoIHByZXNldHMgZm9yIGZvcm0gZmllbGRzIG1hcHBlZCB0byBwaXhlbCB2YWx1ZXMuXG4gKlxuICogLSBgc21gIOKAlCAxNjBweFxuICogLSBgbWRgIOKAlCAyNDBweFxuICogLSBgbGdgIOKAlCAzMjBweFxuICogLSBgeGxgIOKAlCA0MjBweFxuICovXG5leHBvcnQgY29uc3QgV0lEVEhfU0laRV9NQVAgPSB7XG4gICAgc206IDE2MCxcbiAgICBtZDogMjQwLFxuICAgIGxnOiAzMjAsXG4gICAgeGw6IDQyMCxcbn07Il0sInNvdXJjZVJvb3QiOiIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMifQ==
@@ -0,0 +1,6 @@
1
+ /** ProForm field for a single boolean checkbox. Wraps {@link Checkbox} using `checked` as value prop. */
2
+ export declare const ProFormCheckbox: {
3
+ (props: import("../interface").ProFormFieldProps<import("react").PropsWithChildren<import("../../Checkbox").CheckboxProps>, import("react-hook-form").FieldValues> & import("../utils").UnknownRecord): import("react/jsx-runtime").JSX.Element | null;
4
+ displayName: string;
5
+ };
6
+ export default ProFormCheckbox;
@@ -0,0 +1,11 @@
1
+ import { Checkbox } from '../../Checkbox';
2
+ import { renderBooleanReadonly } from '../utils';
3
+ import createProFormField from './createProFormField';
4
+ /** ProForm field for a single boolean checkbox. Wraps {@link Checkbox} using `checked` as value prop. */
5
+ export var ProFormCheckbox = createProFormField({
6
+ component: Checkbox,
7
+ valuePropName: 'checked',
8
+ renderReadonly: renderBooleanReadonly
9
+ });
10
+ export default ProFormCheckbox;
11
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvUHJvRm9ybS9zcmMvY29tcG9uZW50cy9Qcm9Gb3JtL2ZpZWxkcy9Qcm9Gb3JtQ2hlY2tib3gudHN4IiwiY29tcG9uZW50cy9Qcm9Gb3JtL2ZpZWxkcy9Qcm9Gb3JtQ2hlY2tib3guanMiXSwibmFtZXMiOlsiQ2hlY2tib3giLCJyZW5kZXJCb29sZWFuUmVhZG9ubHkiLCJjcmVhdGVQcm9Gb3JtRmllbGQiLCJQcm9Gb3JtQ2hlY2tib3giLCJjb21wb25lbnQiLCJ2YWx1ZVByb3BOYW1lIiwicmVuZGVyUmVhZG9ubHkiXSwibWFwcGluZ3MiOiJBQUFBLFNBQVNBLFFBQVEsUUFBUSxnQkFBZ0I7QUFDekMsU0FBU0MscUJBQXFCLFFBQVEsVUFBVTtBQUNoRCxPQUFPQyxrQkFBa0IsTUFBTSxzQkFBc0I7QUFFckQ7QUFDQSxPQUFPLElBQU1DLGVBQWUsR0FBR0Qsa0JBQWtCLENBQUM7RUFDaERFLFNBQVMsRUFBRUosUUFBUTtFQUNuQkssYUFBYSxFQUFFLFNBQVM7RUFDeEJDLGNBQWMsRUFBRUw7QUNBbEIsQ0RDQyxDQUFDO0FBRUYsZUFBZUUsZUFBZSIsImZpbGUiOiJjb21wb25lbnRzL1Byb0Zvcm0vZmllbGRzL1Byb0Zvcm1DaGVja2JveC5qcyIsInNvdXJjZXNDb250ZW50IjpbbnVsbCwiaW1wb3J0IHsgQ2hlY2tib3ggfSBmcm9tICcuLi8uLi9DaGVja2JveCc7XG5pbXBvcnQgeyByZW5kZXJCb29sZWFuUmVhZG9ubHkgfSBmcm9tICcuLi91dGlscyc7XG5pbXBvcnQgY3JlYXRlUHJvRm9ybUZpZWxkIGZyb20gJy4vY3JlYXRlUHJvRm9ybUZpZWxkJztcbi8qKiBQcm9Gb3JtIGZpZWxkIGZvciBhIHNpbmdsZSBib29sZWFuIGNoZWNrYm94LiBXcmFwcyB7QGxpbmsgQ2hlY2tib3h9IHVzaW5nIGBjaGVja2VkYCBhcyB2YWx1ZSBwcm9wLiAqL1xuZXhwb3J0IGNvbnN0IFByb0Zvcm1DaGVja2JveCA9IGNyZWF0ZVByb0Zvcm1GaWVsZCh7XG4gICAgY29tcG9uZW50OiBDaGVja2JveCxcbiAgICB2YWx1ZVByb3BOYW1lOiAnY2hlY2tlZCcsXG4gICAgcmVuZGVyUmVhZG9ubHk6IHJlbmRlckJvb2xlYW5SZWFkb25seSxcbn0pO1xuZXhwb3J0IGRlZmF1bHQgUHJvRm9ybUNoZWNrYm94OyJdLCJzb3VyY2VSb290IjoiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vc3JjIn0=
@@ -0,0 +1,6 @@
1
+ /** ProForm field for multi-choice checkbox group. Wraps {@link CheckboxGroup}. */
2
+ export declare const ProFormCheckboxGroup: {
3
+ (props: import("../interface").ProFormFieldProps<import("../../CheckboxGroup").CheckboxGroupProps, import("react-hook-form").FieldValues> & import("../utils").UnknownRecord): import("react/jsx-runtime").JSX.Element | null;
4
+ displayName: string;
5
+ };
6
+ export default ProFormCheckboxGroup;