@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,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;
|