@zat-design/sisyphus-react 3.3.2 → 3.3.3-beta.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (87) hide show
  1. package/dist/index.esm.css +11 -8
  2. package/es/ProConfigProvider/index.js +0 -1
  3. package/es/ProDrawerForm/components/ProModal/index.js +0 -1
  4. package/es/ProEditLabel/index.js +2 -3
  5. package/es/ProEditTable/components/ActionButton/index.js +6 -6
  6. package/es/ProEditTable/components/RenderField/index.js +5 -5
  7. package/es/ProEditTable/style/index.less +0 -1
  8. package/es/ProEditTable/utils/index.js +2 -4
  9. package/es/ProForm/components/ProFormGroup/index.d.ts +13 -0
  10. package/es/ProForm/components/ProFormGroup/index.js +27 -0
  11. package/es/ProForm/components/base/Switch/index.js +0 -1
  12. package/es/ProForm/components/base/TextArea/index.js +9 -5
  13. package/es/ProForm/components/combination/Container/index.js +4 -2
  14. package/es/ProForm/components/combination/Container/propsType.d.ts +2 -0
  15. package/es/ProForm/components/combination/FormList/components/ActionButton.js +2 -2
  16. package/es/ProForm/components/combination/ProCombination/index.js +0 -1
  17. package/es/ProForm/components/combination/ProModalSelect/index.js +1 -2
  18. package/es/ProForm/components/combination/ProTimeLimit/index.d.ts +1 -0
  19. package/es/ProForm/components/combination/ProTimeLimit/index.js +2 -2
  20. package/es/ProForm/components/render/Render.js +4 -5
  21. package/es/ProForm/components/render/RenderFields.js +5 -0
  22. package/es/ProForm/components/render/propsType.d.ts +1 -0
  23. package/es/ProForm/components/render/propsType.js +1 -0
  24. package/es/ProForm/index.js +27 -7
  25. package/es/ProForm/propsType.d.ts +2 -0
  26. package/es/ProForm/style/index.less +6 -3
  27. package/es/ProForm/utils/index.js +10 -6
  28. package/es/ProForm/utils/useChanged.js +1 -1
  29. package/es/ProForm/utils/useForm.js +48 -75
  30. package/es/ProForm/utils/useListChanged.js +22 -10
  31. package/es/ProLayout/components/ProCollapse/index.js +1 -0
  32. package/es/ProLayout/components/ProCollapse/style/index.less +49 -39
  33. package/es/ProStep/index.js +0 -1
  34. package/es/ProThemeTools/index.js +0 -1
  35. package/es/ProThemeTools/utils/index.js +0 -1
  36. package/es/ProTree/components/Tree.js +0 -1
  37. package/es/ProTreeModal/index.js +5 -1
  38. package/es/ProTreeSelect/index.js +2 -4
  39. package/es/ProUpload/index.js +0 -1
  40. package/es/index.d.ts +1 -0
  41. package/es/index.js +1 -0
  42. package/es/old/ProEditableTable/index.js +1 -1
  43. package/es/style/theme/antd.less +1 -1
  44. package/lib/ProConfigProvider/index.js +0 -1
  45. package/lib/ProDrawerForm/components/ProModal/index.js +0 -1
  46. package/lib/ProEditLabel/index.js +2 -3
  47. package/lib/ProEditTable/components/ActionButton/index.js +6 -6
  48. package/lib/ProEditTable/components/RenderField/index.js +5 -5
  49. package/lib/ProEditTable/style/index.less +0 -1
  50. package/lib/ProEditTable/utils/index.js +2 -4
  51. package/lib/ProForm/components/ProFormGroup/index.d.ts +13 -0
  52. package/lib/ProForm/components/ProFormGroup/index.js +35 -0
  53. package/lib/ProForm/components/base/TextArea/index.js +9 -5
  54. package/lib/ProForm/components/combination/Container/index.js +4 -2
  55. package/lib/ProForm/components/combination/Container/propsType.d.ts +2 -0
  56. package/lib/ProForm/components/combination/FormList/components/ActionButton.js +2 -2
  57. package/lib/ProForm/components/combination/ProCombination/index.js +0 -1
  58. package/lib/ProForm/components/combination/ProModalSelect/index.js +1 -2
  59. package/lib/ProForm/components/combination/ProTimeLimit/index.d.ts +1 -0
  60. package/lib/ProForm/components/combination/ProTimeLimit/index.js +2 -3
  61. package/lib/ProForm/components/old/InputRange/index.js +1 -0
  62. package/lib/ProForm/components/render/Render.js +4 -5
  63. package/lib/ProForm/components/render/RenderFields.js +5 -0
  64. package/lib/ProForm/components/render/propsType.d.ts +1 -0
  65. package/lib/ProForm/components/render/propsType.js +2 -1
  66. package/lib/ProForm/index.js +24 -4
  67. package/lib/ProForm/propsType.d.ts +2 -0
  68. package/lib/ProForm/style/index.less +6 -3
  69. package/lib/ProForm/utils/index.js +10 -6
  70. package/lib/ProForm/utils/useChanged.js +1 -1
  71. package/lib/ProForm/utils/useForm.js +48 -75
  72. package/lib/ProForm/utils/useListChanged.js +22 -10
  73. package/lib/ProLayout/components/ProCollapse/index.js +1 -0
  74. package/lib/ProLayout/components/ProCollapse/style/index.less +49 -39
  75. package/lib/ProStep/index.js +0 -1
  76. package/lib/ProThemeTools/index.js +0 -1
  77. package/lib/ProThemeTools/utils/index.js +0 -1
  78. package/lib/ProTree/components/Tree.js +0 -1
  79. package/lib/ProTree/index.js +1 -0
  80. package/lib/ProTreeModal/index.js +5 -1
  81. package/lib/ProTreeSelect/index.js +2 -4
  82. package/lib/ProUpload/index.js +0 -1
  83. package/lib/index.d.ts +1 -0
  84. package/lib/index.js +15 -0
  85. package/lib/old/ProEditableTable/index.js +1 -1
  86. package/lib/style/theme/antd.less +1 -1
  87. package/package.json +3 -2
@@ -751,6 +751,9 @@
751
751
  .pro-collapse.pro-collapse-level2 .pro-collapse-level2-collapse .ant-collapse-expand-icon {
752
752
  display: block;
753
753
  }
754
+ .pro-collapse.pro-collapse-level2 .pro-collapse-level2-no-collapse .ant-collapse-expand-icon {
755
+ display: none;
756
+ }
754
757
  .pro-collapse .ant-collapse-extra .extra-info {
755
758
  margin-right: 24px;
756
759
  }
@@ -2565,20 +2568,24 @@ span.ant-input-group-compact.pro-range-limit .forever-checkbox {
2565
2568
  }
2566
2569
  .pro-form .ant-form-item.pro-form-item-changed span.ant-input-affix-wrapper,
2567
2570
  .pro-form .ant-form-item.pro-form-item-changed .ant-select-selector,
2568
- .pro-form .ant-form-item.pro-form-item-changed .ant-picker {
2571
+ .pro-form .ant-form-item.pro-form-item-changed .ant-picker,
2572
+ .pro-form .ant-form-item.pro-form-item-changed .ant-input-number {
2569
2573
  background: var(--zaui-contract-bg, #fffaa1) !important;
2570
2574
  }
2571
2575
  .pro-form .ant-form-item.pro-form-item-changed span.ant-input-affix-wrapper input,
2572
2576
  .pro-form .ant-form-item.pro-form-item-changed .ant-select-selector input,
2573
- .pro-form .ant-form-item.pro-form-item-changed .ant-picker input {
2577
+ .pro-form .ant-form-item.pro-form-item-changed .ant-picker input,
2578
+ .pro-form .ant-form-item.pro-form-item-changed .ant-input-number input {
2574
2579
  background: var(--zaui-contract-bg, #fffaa1);
2575
2580
  }
2576
2581
  .pro-form .ant-form-item.pro-form-item-changed span.ant-input-affix-wrapper .ant-select-selection-placeholder,
2577
2582
  .pro-form .ant-form-item.pro-form-item-changed .ant-select-selector .ant-select-selection-placeholder,
2578
- .pro-form .ant-form-item.pro-form-item-changed .ant-picker .ant-select-selection-placeholder {
2583
+ .pro-form .ant-form-item.pro-form-item-changed .ant-picker .ant-select-selection-placeholder,
2584
+ .pro-form .ant-form-item.pro-form-item-changed .ant-input-number .ant-select-selection-placeholder {
2579
2585
  z-index: 9;
2580
2586
  }
2581
- .pro-form .ant-form-item.pro-form-item-changed .ant-form-item-control-input-content > .pro-form-view-container {
2587
+ .pro-form .ant-form-item.pro-form-item-changed .ant-form-item-control-input-content > span,
2588
+ .pro-form .ant-form-item.pro-form-item-changed .pro-form-view-container {
2582
2589
  padding: 4px 8px;
2583
2590
  background: var(--zaui-contract-bg, #fffaa1);
2584
2591
  border-radius: 4px;
@@ -4213,9 +4220,6 @@ span.ant-input-group-compact.pro-range-limit .forever-checkbox {
4213
4220
  position: absolute;
4214
4221
  bottom: var(--zaui-space-size-md, 16px);
4215
4222
  }
4216
- .pro-edit-table-toolbar {
4217
- margin-top: var(--zaui-space-size-md, 16px);
4218
- }
4219
4223
  .pro-edit-table-toolbar .ant-space {
4220
4224
  gap: var(--zaui-space-size-sm, 8px);
4221
4225
  }
@@ -5470,7 +5474,6 @@ input[type='button'] {
5470
5474
  width: calc(100% - 18px);
5471
5475
  margin-bottom: 0;
5472
5476
  text-align: right;
5473
- background: #fff;
5474
5477
  }
5475
5478
  .ant-space.ant-space-vertical {
5476
5479
  display: -webkit-box;
@@ -26,7 +26,6 @@ var antdLangMap = {
26
26
  'zh-CN': zhCN,
27
27
  'en-US': enUS // en-US
28
28
  };
29
-
30
29
  var reducer = function reducer(state, action) {
31
30
  var _state$ProEnum;
32
31
  switch (action.type) {
@@ -175,7 +175,6 @@ var ProModal = function ProModal(_ref) {
175
175
  footer: renderFooter(),
176
176
  okText: okText,
177
177
  cancelText: cancelText,
178
- centered: true,
179
178
  closeIcon: _jsx(ReactSVG, {
180
179
  className: "close-icon",
181
180
  src: closeSvg
@@ -22,7 +22,6 @@ import { omit } from 'lodash';
22
22
  import RenderProForm from './components/RenderProForm';
23
23
  import { matchFormValue } from './utils';
24
24
  var ProEditLabel = function ProEditLabel(_ref) {
25
- var _classnames;
26
25
  var _ref$open = _ref.open,
27
26
  open = _ref$open === void 0 ? false : _ref$open,
28
27
  _ref$disabled = _ref.disabled,
@@ -128,9 +127,9 @@ var ProEditLabel = function ProEditLabel(_ref) {
128
127
  }
129
128
  }
130
129
  }, [confirmValue, mode]);
131
- var cls = classnames((_classnames = {
130
+ var cls = classnames(_defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty({
132
131
  'pro-edit-label': true
133
- }, _defineProperty(_classnames, "trigger-".concat(trigger), trigger), _defineProperty(_classnames, 'pro-edit-label-small', size === 'small'), _defineProperty(_classnames, 'pro-edit-label-middle', size === 'middle'), _defineProperty(_classnames, 'pro-edit-label-large', size === 'large'), _defineProperty(_classnames, "".concat(className), className), _classnames));
132
+ }, "trigger-".concat(trigger), trigger), 'pro-edit-label-small', size === 'small'), 'pro-edit-label-middle', size === 'middle'), 'pro-edit-label-large', size === 'large'), "".concat(className), className));
134
133
  /**
135
134
  * pop确认回调
136
135
  */
@@ -82,24 +82,24 @@ var ActionButton = function ActionButton(_ref) {
82
82
  disabled: isDisabled,
83
83
  okText: locale.ProEditTable.confirm,
84
84
  cancelText: locale.ProEditTable.cancel,
85
- children: /*#__PURE__*/React.isValidElement(btnConfig.label) ? /*#__PURE__*/React.cloneElement(btnConfig.label, _objectSpread(_objectSpread({}, omit(delBtnProps, ['buttonProps', 'isEditable'])), {}, {
85
+ children: /*#__PURE__*/React.isValidElement(btnConfig.label) ? ( /*#__PURE__*/React.cloneElement(btnConfig.label, _objectSpread(_objectSpread({}, omit(delBtnProps, ['buttonProps', 'isEditable'])), {}, {
86
86
  record: record,
87
87
  index: index,
88
88
  disabled: isDisabled
89
- })) : _jsx(_Button, _objectSpread(_objectSpread({}, omit(delBtnProps, ['buttonProps', 'isEditable'])), {}, {
89
+ }))) : _jsx(_Button, _objectSpread(_objectSpread({}, omit(delBtnProps, ['buttonProps', 'isEditable'])), {}, {
90
90
  disabled: isDisabled,
91
91
  type: "link",
92
92
  children: btnConfig.label
93
93
  }))
94
94
  }) : _jsx(_Fragment, {
95
- children: /*#__PURE__*/React.isValidElement(btnConfig.label) ? /*#__PURE__*/React.cloneElement(btnConfig.label, _objectSpread(_objectSpread({}, omit(delBtnProps, ['buttonProps', 'isEditable'])), {}, {
95
+ children: /*#__PURE__*/React.isValidElement(btnConfig.label) ? ( /*#__PURE__*/React.cloneElement(btnConfig.label, _objectSpread(_objectSpread({}, omit(delBtnProps, ['buttonProps', 'isEditable'])), {}, {
96
96
  record: record,
97
97
  index: index,
98
98
  disabled: isDisabled,
99
99
  onClick: function onClick() {
100
100
  btnConfig.onEvent(record, index);
101
101
  }
102
- })) : _jsx(_Button, _objectSpread(_objectSpread({}, omit(delBtnProps, ['buttonProps', 'isEditable'])), {}, {
102
+ }))) : _jsx(_Button, _objectSpread(_objectSpread({}, omit(delBtnProps, ['buttonProps', 'isEditable'])), {}, {
103
103
  disabled: isDisabled,
104
104
  type: "link",
105
105
  onClick: function onClick() {
@@ -109,10 +109,10 @@ var ActionButton = function ActionButton(_ref) {
109
109
  }))
110
110
  })
111
111
  }) : _jsx(_Fragment, {
112
- children: /*#__PURE__*/React.isValidElement(btnConfig.label) ? /*#__PURE__*/React.cloneElement(btnConfig.label, _objectSpread(_objectSpread({}, omit(actionBtnProps, ['buttonProps', 'isEditable'])), {}, {
112
+ children: /*#__PURE__*/React.isValidElement(btnConfig.label) ? ( /*#__PURE__*/React.cloneElement(btnConfig.label, _objectSpread(_objectSpread({}, omit(actionBtnProps, ['buttonProps', 'isEditable'])), {}, {
113
113
  record: record,
114
114
  index: index
115
- })) : _jsx(_Button, _objectSpread(_objectSpread({
115
+ }))) : _jsx(_Button, _objectSpread(_objectSpread({
116
116
  className: "action-button"
117
117
  }, omit(actionBtnProps, ['buttonProps', 'isEditable'])), {}, {
118
118
  type: "link",
@@ -30,7 +30,7 @@ import useRules from '../../../ProForm/utils/useRules';
30
30
  import { isSelect } from '../../../ProForm/utils';
31
31
  import locale from '../../../locale';
32
32
  var RenderField = function RenderField(_ref) {
33
- var _type, _type$replace, _fieldProps2, _fieldProps3, _fieldProps4, _names, _formItemChildProps$p, _TargetComponent4, _classNames;
33
+ var _type, _type$replace, _fieldProps2, _fieldProps3, _fieldProps4, _names, _formItemChildProps$p, _TargetComponent4;
34
34
  var value = _ref.text,
35
35
  record = _ref.record,
36
36
  index = _ref.index,
@@ -506,13 +506,13 @@ var RenderField = function RenderField(_ref) {
506
506
  if (!isEditing) {
507
507
  delete _formItemProps.rules;
508
508
  }
509
- var _className = classNames((_classNames = {}, _defineProperty(_classNames, className, className), _defineProperty(_classNames, 'pro-form-item-changed', changed), _classNames));
509
+ var _className = classNames(_defineProperty(_defineProperty({}, className, className), 'pro-form-item-changed', changed));
510
510
  var originalTitle = originalTip ? _jsxs(_Space, {
511
- children: ["\u521D\u59CB\u503C\uFF1A", /*#__PURE__*/React.isValidElement(TargetComponent) ? /*#__PURE__*/React.cloneElement(TargetComponent, _objectSpread(_objectSpread({}, omit(componentProps, ['onFieldChange'])), {}, {
511
+ children: ["\u521D\u59CB\u503C\uFF1A", /*#__PURE__*/React.isValidElement(TargetComponent) ? ( /*#__PURE__*/React.cloneElement(TargetComponent, _objectSpread(_objectSpread({}, omit(componentProps, ['onFieldChange'])), {}, {
512
512
  isView: true,
513
513
  value: originalValue,
514
514
  checked: type === 'Switch' ? originalValue : undefined
515
- })) : _jsx(TargetComponent, _objectSpread(_objectSpread({}, omit(componentProps, ['onFieldChange'])), {}, {
515
+ }))) : _jsx(TargetComponent, _objectSpread(_objectSpread({}, omit(componentProps, ['onFieldChange'])), {}, {
516
516
  isView: true,
517
517
  value: originalValue,
518
518
  checked: type === 'Switch' ? originalValue : undefined
@@ -523,7 +523,7 @@ var RenderField = function RenderField(_ref) {
523
523
  }, omit(_formItemProps, ['render', 'cache', 'key', 'width', 'hiddenNames', 'name'])), {}, {
524
524
  className: _className,
525
525
  name: cellName,
526
- children: /*#__PURE__*/React.isValidElement(TargetComponent) ? /*#__PURE__*/React.cloneElement(TargetComponent, _objectSpread({}, omit(componentProps, ['onFieldChange']))) : _jsx(TargetComponent, _objectSpread({}, omit(componentProps, ['onFieldChange'])))
526
+ children: /*#__PURE__*/React.isValidElement(TargetComponent) ? ( /*#__PURE__*/React.cloneElement(TargetComponent, _objectSpread({}, omit(componentProps, ['onFieldChange'])))) : _jsx(TargetComponent, _objectSpread({}, omit(componentProps, ['onFieldChange'])))
527
527
  })) : _jsx(Container, {
528
528
  viewEmpty: viewEmpty
529
529
  });
@@ -313,7 +313,6 @@
313
313
  }
314
314
 
315
315
  .pro-edit-table-toolbar {
316
- margin-top: var(--zaui-space-size-md, 16px);
317
316
  .@{ant-prefix}-space {
318
317
  gap: var(--zaui-space-size-sm, 8px);
319
318
 
@@ -217,9 +217,9 @@ export var transformColumns = function transformColumns() {
217
217
  children: [columnTitle, _jsx(_Tooltip, _objectSpread(_objectSpread({
218
218
  title: tooltipTitle !== null && tooltipTitle !== void 0 ? tooltipTitle : tooltip
219
219
  }, resetProps), {}, {
220
- children: icon ? /*#__PURE__*/React.cloneElement(icon, {
220
+ children: icon ? ( /*#__PURE__*/React.cloneElement(icon, {
221
221
  className: 'icon-tip'
222
- }) : _jsx(ReactSVG, {
222
+ })) : _jsx(ReactSVG, {
223
223
  className: "icon-tip",
224
224
  src: tipSvg
225
225
  })
@@ -336,7 +336,6 @@ export var transformColumns = function transformColumns() {
336
336
  })
337
337
  });
338
338
  };
339
-
340
339
  item.render = _render;
341
340
  });
342
341
  if (disabled || isView) {
@@ -359,7 +358,6 @@ export var transformColumns = function transformColumns() {
359
358
  var actionColumn = getActionColumn(_objectSpread(_objectSpread({}, config), {}, {
360
359
  validateKeys: validateKeys // 需要校验的单元格的formItem的name
361
360
  }));
362
-
363
361
  actionColumn && _columns.push(actionColumn);
364
362
  }
365
363
  // cacheMap 用来存储缓存值,若有值后不再请求
@@ -0,0 +1,13 @@
1
+ import React from 'react';
2
+ import { FormInstance } from 'antd';
3
+ interface FormGroup {
4
+ [K: string]: FormInstance | undefined;
5
+ }
6
+ type ContextType = [FormGroup, (forms: FormGroup) => void];
7
+ export declare const groupContext: React.Context<ContextType>;
8
+ interface Props {
9
+ formGroup?: FormGroup;
10
+ }
11
+ export declare const useProFormGroup: () => FormGroup;
12
+ export declare const ProFormGroup: React.FC<Props>;
13
+ export {};
@@ -0,0 +1,27 @@
1
+ import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
2
+ import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
3
+ import { jsx as _jsx } from "react/jsx-runtime";
4
+ import React, { useContext, useMemo, useState } from 'react';
5
+ export var groupContext = /*#__PURE__*/React.createContext([{}, function () {
6
+ return undefined;
7
+ }]);
8
+ export var useProFormGroup = function useProFormGroup() {
9
+ var formGroup = useContext(groupContext);
10
+ return formGroup[0];
11
+ };
12
+ export var ProFormGroup = function ProFormGroup(props) {
13
+ var formGroup = props.formGroup,
14
+ children = props.children;
15
+ var Provider = groupContext.Provider;
16
+ var initialFormGroup = useMemo(function () {
17
+ return formGroup ? _objectSpread({}, formGroup) : {};
18
+ }, [formGroup]);
19
+ var _useState = useState(initialFormGroup),
20
+ _useState2 = _slicedToArray(_useState, 2),
21
+ forms = _useState2[0],
22
+ setForms = _useState2[1];
23
+ return _jsx(Provider, {
24
+ value: [forms, setForms],
25
+ children: children
26
+ });
27
+ };
@@ -38,5 +38,4 @@ var Switch = function Switch(props) {
38
38
  id: "switch_only" // 解决点击label联动的问题
39
39
  }));
40
40
  };
41
-
42
41
  export default Switch;
@@ -9,6 +9,7 @@ import classnames from 'classnames';
9
9
  import { useProConfig } from '../../../../ProConfigProvider';
10
10
  import locale from '../../../../locale';
11
11
  import ProForm from '../../../../ProForm';
12
+ import Container from '../../Container';
12
13
  import './index.less';
13
14
  var TextArea = _Input.TextArea;
14
15
  var TextAreaDef = function TextAreaDef(props) {
@@ -18,16 +19,20 @@ var TextAreaDef = function TextAreaDef(props) {
18
19
  rest = _objectWithoutProperties(props, _excluded);
19
20
  var _ref = ProForm.useFieldProps() || {},
20
21
  label = _ref.label,
21
- isViewCon = _ref.isView;
22
+ isViewCon = _ref.isView,
23
+ viewEmpty = _ref.viewEmpty;
22
24
  var isView = typeof props.isView === 'boolean' ? props.isView : isViewCon;
23
25
  var initialConfig = useProConfig('TextArea');
24
- var disabled = (initialConfig === null || initialConfig === void 0 ? void 0 : initialConfig.disabled) || rest.disabled;
25
26
  if (isView) {
26
- disabled = true;
27
+ return _jsx(Container, {
28
+ nowrap: false,
29
+ tooltip: true,
30
+ viewEmpty: viewEmpty,
31
+ children: rest.value
32
+ });
27
33
  }
28
34
  var _className = classnames({
29
35
  'pro-textarea': true,
30
- disabled: disabled,
31
36
  'pro-textarea-view': isView,
32
37
  className: className
33
38
  });
@@ -39,7 +44,6 @@ var TextAreaDef = function TextAreaDef(props) {
39
44
  minRows: 4
40
45
  }
41
46
  }, omit(initialConfig, ['trim'])), rest), {}, {
42
- disabled: disabled,
43
47
  className: _className
44
48
  }));
45
49
  };
@@ -11,11 +11,12 @@ var Container = function Container(props) {
11
11
  var children = props.children,
12
12
  otherProps = props.otherProps,
13
13
  className = props.className,
14
- container = props.container;
14
+ container = props.container,
15
+ show = props.show,
16
+ clearNotShow = props.clearNotShow;
15
17
  var _ref = ProForm.useFieldProps() || {},
16
18
  type = _ref.type,
17
19
  form = _ref.form,
18
- show = _ref.show,
19
20
  required = _ref.required,
20
21
  disabled = _ref.disabled;
21
22
  var _className = classnames(_defineProperty({
@@ -25,6 +26,7 @@ var Container = function Container(props) {
25
26
  var _children = useMemo(function () {
26
27
  var result = children.map(function (item) {
27
28
  return _objectSpread({
29
+ clearNotShow: clearNotShow,
28
30
  show: show,
29
31
  required: required,
30
32
  disabled: disabled
@@ -7,4 +7,6 @@ export interface ContainerProps {
7
7
  rowProps?: RowProps;
8
8
  className?: string;
9
9
  container?: string | React.ReactNode;
10
+ show?: boolean | (() => boolean);
11
+ clearNotShow?: boolean;
10
12
  }
@@ -225,13 +225,13 @@ var ActionButton = function ActionButton(props) {
225
225
  },
226
226
  children: label
227
227
  }))
228
- }), "".concat(item === null || item === void 0 ? void 0 : item.actionType).concat(index)) : /*#__PURE__*/_createElement(_Button, _objectSpread(_objectSpread({}, rest), {}, {
228
+ }), "".concat(item === null || item === void 0 ? void 0 : item.actionType).concat(index)) : ( /*#__PURE__*/_createElement(_Button, _objectSpread(_objectSpread({}, rest), {}, {
229
229
  key: "".concat(item === null || item === void 0 ? void 0 : item.actionType).concat(index),
230
230
  onClick: function onClick(e) {
231
231
  e.stopPropagation();
232
232
  handleClick(_onClick, index);
233
233
  }
234
- }), label);
234
+ }), label));
235
235
  })
236
236
  });
237
237
  };
@@ -83,7 +83,6 @@ export var ProCombination = function ProCombination(props) {
83
83
  _handleChange(_values, rest === null || rest === void 0 ? void 0 : rest[0], form);
84
84
  (_childProps$index = childProps[index]) === null || _childProps$index === void 0 ? void 0 : (_childProps$index$onC = _childProps$index.onChange) === null || _childProps$index$onC === void 0 ? void 0 : _childProps$index$onC.call(_childProps$index, value, rest === null || rest === void 0 ? void 0 : rest[0], form); // 支持子组件分别传入onChange
85
85
  };
86
-
87
86
  var className = classNames({
88
87
  'pro-combination': true,
89
88
  'pro-combination-view': isView
@@ -548,8 +548,7 @@ var ProModalSelect = function ProModalSelect(props, ref) {
548
548
  _value: value
549
549
  });
550
550
  } else if (Object.prototype.toString.call(value) === '[object Object]') {
551
- var _initialValue;
552
- var initialValue = (_initialValue = {}, _defineProperty(_initialValue, valueKey, value[valueKey]), _defineProperty(_initialValue, labelKey, value[labelKey]), _initialValue);
551
+ var initialValue = _defineProperty(_defineProperty({}, valueKey, value[valueKey]), labelKey, value[labelKey]);
553
552
  setState({
554
553
  selectedRowKeys: [value],
555
554
  selectedRows: [initialValue],
@@ -3,6 +3,7 @@ import { Moment } from 'moment';
3
3
  import React from 'react';
4
4
  import { ProFormOtherProps } from '../../../propsType';
5
5
  import { Props as ProRangeLimitProps } from '../ProRangeLimit';
6
+ import { DistributiveOmit } from '../../../../ProForm/propsType';
6
7
  export type DateType = DatePickerProps['value'];
7
8
  export type ProTimeLimitProps = DistributiveOmit<DatePickerProps, 'value' | 'onChange' | 'mode'> & {
8
9
  value?: string;
@@ -12,7 +12,7 @@ var _excluded = ["format", "disabled", "foreverTime", "foreverText", "valueType"
12
12
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
13
13
  import classNames from 'classnames';
14
14
  import { omit } from 'lodash';
15
- import moment, { isMoment } from 'moment';
15
+ import moment from 'moment';
16
16
  import { useMemo } from 'react';
17
17
  import { useProConfig } from '../../../../ProConfigProvider';
18
18
  import Container from '../../Container';
@@ -53,7 +53,7 @@ export var ProTimeLimit = function ProTimeLimit(props) {
53
53
  onChange = _useControlled2[1];
54
54
  var initialConfig = useProConfig('ProTimeLimit');
55
55
  var isForever = useMemo(function () {
56
- if (isMoment(value)) {
56
+ if (moment.isMoment(value)) {
57
57
  return foreverMoment.format(format) === value.format(format);
58
58
  }
59
59
  return false;
@@ -33,7 +33,7 @@ import tipSvg from '../../../assets/tip.svg';
33
33
  import useRules from '../../utils/useRules';
34
34
  // 这个组件只管渲染, 参数的整理在外部处理
35
35
  var Render = function Render(props) {
36
- var _ref2, _classNames, _otherProps$names2;
36
+ var _ref2, _otherProps$names2;
37
37
  var component = props.component,
38
38
  originComponent = props.originComponent,
39
39
  _props$formItemProps = props.formItemProps,
@@ -171,11 +171,11 @@ var Render = function Render(props) {
171
171
  var lastComponentProps = _objectSpread(_objectSpread(_objectSpread({}, componentProps), _fieldProps), {}, {
172
172
  disabled: lastDisabled
173
173
  });
174
- var _className = classNames((_classNames = {}, _defineProperty(_classNames, className, className), _defineProperty(_classNames, 'pro-form-item-changed', changed), _defineProperty(_classNames, 'pro-form-item-width-auto', ['Switch'].includes(type)), _classNames));
174
+ var _className = classNames(_defineProperty(_defineProperty(_defineProperty({}, className, className), 'pro-form-item-changed', changed), 'pro-form-item-width-auto', ['Switch'].includes(type)));
175
175
  if (formItemProps.hidden === true || _show === false) {
176
176
  // 为了监听shouldUpdate 必须存在一个FormItem, 空Input解决 【[antd: Form.Item] `name` is only used for validate React element】
177
177
  return _jsx(_Form.Item, {
178
- name: _otherFormItemProps.name,
178
+ name: _otherFormItemProps.name || 'proFormItemHidden',
179
179
  shouldUpdate: _otherFormItemProps.shouldUpdate,
180
180
  className: _className,
181
181
  noStyle: true,
@@ -344,7 +344,7 @@ var Render = function Render(props) {
344
344
  if (originComponent) {
345
345
  delete childProps.otherProps;
346
346
  }
347
- var child = /*#__PURE__*/React.isValidElement(AutoComponent) ? /*#__PURE__*/React.cloneElement(AutoComponent, childProps) : _jsx(AutoComponent, _objectSpread(_objectSpread({}, omit(lastComponentProps, ['onFieldChange', 'disabledStrictly'])), {}, {
347
+ var child = /*#__PURE__*/React.isValidElement(AutoComponent) ? ( /*#__PURE__*/React.cloneElement(AutoComponent, childProps)) : _jsx(AutoComponent, _objectSpread(_objectSpread({}, omit(lastComponentProps, ['onFieldChange', 'disabledStrictly'])), {}, {
348
348
  otherProps: _objectSpread(_objectSpread({}, otherProps), {}, {
349
349
  show: show,
350
350
  disabled: lastDisabled,
@@ -390,7 +390,6 @@ var Render = function Render(props) {
390
390
  span: 24 // 默认占一行
391
391
  });
392
392
  }
393
-
394
393
  var orgFormItem = _jsx(_Form.Item, _objectSpread(_objectSpread({}, omit(_otherFormItemProps, filterFormItemKey)), {}, {
395
394
  // @ts-ignore
396
395
  _internalItemRender: internalItemRender,
@@ -146,6 +146,11 @@ var RenderFields = function RenderFields(props) {
146
146
  }, _fieldProps), {}, {
147
147
  disabled: _disabled
148
148
  });
149
+ // 容器组件,额外处理show的问题
150
+ if (['ProCollapse', 'Container'].includes(_type)) {
151
+ componentProps.show = show;
152
+ componentProps.clearNotShow = clearNotShow;
153
+ }
149
154
  // switch与SwitchCheckbox单独添加valuePropName
150
155
  if (['Switch', 'SwitchCheckbox'].includes(_type)) {
151
156
  _formItemProps.valuePropName = 'checked';
@@ -32,6 +32,7 @@ import { ProUploadProps } from '../../../ProUpload/propsType';
32
32
  import { ProTreeProps } from '../../../ProTree/propsType';
33
33
  import { GroupProps } from '../combination/Group/propsType';
34
34
  import { ProCollapseProps } from '../../../ProLayout/components/ProCollapse/PropTypes';
35
+ import { DistributiveOmit } from '../../propsType';
35
36
  export type ComponentMap = keyof typeof componentMap;
36
37
  type ValidateKey = keyof typeof validate;
37
38
  type RegExpKey = keyof typeof regExp;
@@ -1 +1,2 @@
1
+ var a = {};
1
2
  export {};
@@ -1,22 +1,22 @@
1
1
  import _toArray from "@babel/runtime/helpers/esm/toArray";
2
2
  import "antd/es/row/style";
3
3
  import _Row from "antd/es/row";
4
- import "antd/es/form/style";
5
- import _Form from "antd/es/form";
6
- import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
7
4
  import "antd/es/col/style";
8
5
  import _Col from "antd/es/col";
9
6
  import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
10
7
  import _toConsumableArray from "@babel/runtime/helpers/esm/toConsumableArray";
11
8
  import "antd/es/space/style";
12
9
  import _Space from "antd/es/space";
10
+ import "antd/es/form/style";
11
+ import _Form from "antd/es/form";
12
+ import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
13
13
  import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
14
14
  import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
15
- var _excluded = ["mode", "span", "disabled", "isView", "columns", "footer", "onOk", "okText", "onCancel", "confirmLoading", "cancelText", "form", "children", "rowProps", "className", "expand", "expandOpen", "expandOpenChange", "viewEmpty", "labelAlign", "labelWidth", "onValuesChange", "onFinish", "originalValues", "submitOnEnter", "clearNotShow", "initialValues", "requiredOnView", "formId", "required", "originalTip"];
15
+ var _excluded = ["mode", "span", "disabled", "isView", "columns", "footer", "onOk", "okText", "onCancel", "confirmLoading", "cancelText", "form", "children", "rowProps", "className", "expand", "expandOpen", "expandOpenChange", "viewEmpty", "labelAlign", "labelWidth", "onValuesChange", "onFinish", "originalValues", "submitOnEnter", "clearNotShow", "initialValues", "requiredOnView", "formId", "required", "originalTip", "groupName"];
16
16
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
17
17
  import { DoubleLeftOutlined } from '@ant-design/icons';
18
18
  import classnames from 'classnames';
19
- import React, { forwardRef, useImperativeHandle, useMemo } from 'react';
19
+ import React, { forwardRef, useContext, useImperativeHandle, useMemo } from 'react';
20
20
  import { isObject, isString, merge } from 'lodash';
21
21
  import { FormFooter, InputRange, ProAddress, ProAddressBar, ProCertNo, ProCertValidity, ProCombination, ProModalSelect, ProNumberRange, ProRangeBox, ProTimeLimit, transferAddressInfoToRegion, ProUpload, ProTreeSelect, ProTreeModal, ProTree, EnumSelect } from './components';
22
22
  import RenderFields from './components/render/RenderFields';
@@ -25,8 +25,9 @@ import { getLayout, splitNameStr, useControlled, initialValuesToNames } from './
25
25
  import { useForm } from './utils/useForm';
26
26
  import { useFieldProps } from './utils/useFieldProps';
27
27
  import locale from '../locale';
28
+ import { groupContext } from './components/ProFormGroup';
28
29
  var ProForm = function ProForm(props, ref) {
29
- var _localStorage;
30
+ var _groupForm$groupName, _localStorage;
30
31
  var _props$mode = props.mode,
31
32
  mode = _props$mode === void 0 ? 'search' : _props$mode,
32
33
  span = props.span,
@@ -65,8 +66,13 @@ var ProForm = function ProForm(props, ref) {
65
66
  required = props.required,
66
67
  _props$originalTip = props.originalTip,
67
68
  originalTip = _props$originalTip === void 0 ? true : _props$originalTip,
69
+ groupName = props.groupName,
68
70
  otherProps = _objectWithoutProperties(props, _excluded);
69
- var _useForm = useForm(originForm),
71
+ var _ref = useContext(groupContext) || [],
72
+ _ref2 = _slicedToArray(_ref, 2),
73
+ groupForm = _ref2[0],
74
+ setGroupForm = _ref2[1];
75
+ var _useForm = useForm((_groupForm$groupName = groupForm[groupName]) !== null && _groupForm$groupName !== void 0 ? _groupForm$groupName : originForm),
70
76
  _useForm2 = _slicedToArray(_useForm, 1),
71
77
  form = _useForm2[0];
72
78
  var _useControlled = useControlled({
@@ -77,6 +83,20 @@ var ProForm = function ProForm(props, ref) {
77
83
  openState = _useControlled2[0],
78
84
  setOpenState = _useControlled2[1];
79
85
  var config = useProConfig('ProForm');
86
+ // 把表单实例存入表单组
87
+ useMemo(function () {
88
+ if (groupName && groupForm[groupName] !== form) {
89
+ groupForm[groupName] = form;
90
+ setGroupForm(_objectSpread({}, groupForm));
91
+ }
92
+ // 销毁
93
+ return function () {
94
+ if (groupName && groupForm[groupName]) {
95
+ delete _Form[groupName];
96
+ setGroupForm(_objectSpread({}, groupForm));
97
+ }
98
+ };
99
+ }, [groupName, form]);
80
100
  var _getLayout = getLayout({
81
101
  span: span,
82
102
  form: form
@@ -43,6 +43,7 @@ export interface ProFormOtherProps {
43
43
  export interface ProFormProps<Values = any> extends FormProps<Values> {
44
44
  disabled?: boolean;
45
45
  mode?: ModeEnum;
46
+ groupName?: string;
46
47
  /** 是否查看 */
47
48
  isView?: boolean;
48
49
  span?: number;
@@ -73,3 +74,4 @@ export interface Transform<T = any> {
73
74
  getValueProps?: (value: StoreValue) => Record<string, unknown>;
74
75
  shouldUpdate?: ShouldUpdate<T>;
75
76
  }
77
+ export type DistributiveOmit<T, K extends keyof any> = T extends any ? Omit<T, K> : never;
@@ -126,11 +126,12 @@
126
126
  }
127
127
  }
128
128
 
129
- // 比较原始值场景下 不同时候的样式
129
+ // 比较原始值场景下 不同时的样式
130
130
  &.pro-form-item-changed {
131
131
  span.@{ant-prefix}-input-affix-wrapper,
132
132
  .@{ant-prefix}-select-selector,
133
- .@{ant-prefix}-picker {
133
+ .@{ant-prefix}-picker,
134
+ .@{ant-prefix}-input-number {
134
135
  background: @zaui-contract-bg !important;
135
136
 
136
137
  input {
@@ -141,7 +142,9 @@
141
142
  }
142
143
  }
143
144
 
144
- .@{ant-prefix}-form-item-control-input-content > .pro-form-view-container {
145
+ // 查看模式 修改容器样式
146
+ .@{ant-prefix}-form-item-control-input-content > span, // 地址组件
147
+ .pro-form-view-container {
145
148
  padding: 4px 8px;
146
149
  background: @zaui-contract-bg;
147
150
  border-radius: 4px;
@@ -134,18 +134,22 @@ export var splitNameStr = function splitNameStr(name) {
134
134
  // 过滤掉字段名中包含 '-' 的字段
135
135
  export var filterInternalFields = function filterInternalFields(values) {
136
136
  var nextValues = values;
137
+ // fix: braft-editor对象不可遍历
138
+ if (values === null || values === void 0 ? void 0 : values._immutable) {
139
+ return nextValues;
140
+ }
137
141
  if (Array.isArray(nextValues)) {
138
- nextValues.forEach(function (item) {
139
- filterInternalFields(item);
142
+ return nextValues.map(function (item) {
143
+ return filterInternalFields(item);
140
144
  });
141
145
  }
142
146
  if (isObject(nextValues)) {
147
+ var result = {};
143
148
  Object.keys(nextValues).forEach(function (key) {
144
- if (key.includes('-')) {
145
- delete nextValues[key];
146
- }
147
- filterInternalFields(nextValues[key]);
149
+ if (key.includes('-')) return;
150
+ result[key] = filterInternalFields(nextValues[key]);
148
151
  });
152
+ return result;
149
153
  }
150
154
  return nextValues;
151
155
  };
@@ -12,7 +12,7 @@ export var useChanged = function useChanged(_ref) {
12
12
  var originalValue = (names === null || names === void 0 ? void 0 : names.length) ? names.map(function (name) {
13
13
  return get(originalValues, name);
14
14
  }) : get(originalValues, name);
15
- var notWatch = !originalValues || originalValue === undefined;
15
+ var notWatch = !equalWith && (!originalValues || originalValue === undefined);
16
16
  if (notWatch) form = [];
17
17
  var value = _Form.useWatch(namesStr || name, form);
18
18
  if (notWatch) return [false];