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