@zat-design/sisyphus-react 3.4.3 → 3.4.4

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 (97) hide show
  1. package/dist/index.esm.css +35 -31
  2. package/dist/less.esm.css +20 -4
  3. package/es/ProConfigProvider/index.d.ts +1 -1
  4. package/es/ProConfigProvider/index.js +22 -1
  5. package/es/ProEditLabel/style/index.less +0 -1
  6. package/es/ProEditTable/components/DndWrapper/index.js +1 -1
  7. package/es/ProEditTable/components/RenderField/index.js +20 -14
  8. package/es/ProEditTable/index.js +17 -10
  9. package/es/ProEnum/components/Group.js +2 -19
  10. package/es/ProForm/components/base/DatePicker/index.js +3 -1
  11. package/es/ProForm/components/base/TextArea/index.js +4 -4
  12. package/es/ProForm/components/combination/FormList/components/ActionButton.d.ts +1 -0
  13. package/es/ProForm/components/combination/FormList/components/ActionButton.js +12 -10
  14. package/es/ProForm/components/combination/FormList/components/BlockFields.js +6 -1
  15. package/es/ProForm/components/combination/FormList/components/ToolbarButton.js +2 -5
  16. package/es/ProForm/components/combination/Group/index.js +3 -2
  17. package/es/ProForm/components/combination/ProModalSelect/hooks/useRequestList.js +2 -1
  18. package/es/ProForm/components/combination/ProModalSelect/index.js +116 -63
  19. package/es/ProForm/components/combination/ProModalSelect/propsType.d.ts +2 -2
  20. package/es/ProForm/components/combination/ProModalSelect/style/index.less +1 -1
  21. package/es/ProForm/components/combination/ProNumberRange/style/index.less +1 -1
  22. package/es/ProForm/components/render/ConfirmWrapper.js +8 -2
  23. package/es/ProForm/components/render/Render.js +12 -9
  24. package/es/ProForm/components/render/RenderFields.d.ts +1 -1
  25. package/es/ProForm/components/render/propsType.d.ts +4 -4
  26. package/es/ProForm/index.js +4 -5
  27. package/es/ProForm/propsType.d.ts +2 -2
  28. package/es/ProForm/style/index.less +23 -5
  29. package/es/ProForm/utils/diffOriginal.js +17 -32
  30. package/es/ProForm/utils/index.d.ts +1 -1
  31. package/es/ProForm/utils/index.js +14 -4
  32. package/es/ProForm/utils/rulesCreator.d.ts +7 -1
  33. package/es/ProForm/utils/rulesCreator.js +45 -3
  34. package/es/ProForm/utils/useRules.js +36 -11
  35. package/es/ProForm/utils/useShouldUpdate.js +4 -4
  36. package/es/ProLayout/components/ProCollapse/index.js +23 -1
  37. package/es/ProLayout/components/ProCollapse/style/index.less +1 -1
  38. package/es/ProThemeTools/component/PrdTools/index.js +12 -50
  39. package/es/ProThemeTools/index.js +0 -1
  40. package/es/ProTree/components/ProTreeSelect/style/index.less +1 -1
  41. package/es/ProTree/style/index.less +5 -0
  42. package/es/ProUpload/style/index.less +1 -1
  43. package/es/assets/view.svg +20 -1
  44. package/es/locale/en_US.d.ts +4 -2
  45. package/es/locale/en_US.js +4 -2
  46. package/es/locale/zh_CN.d.ts +4 -2
  47. package/es/locale/zh_CN.js +4 -2
  48. package/es/style/components.less +0 -3
  49. package/es/style/theme/antd.less +14 -28
  50. package/lib/ProConfigProvider/index.d.ts +1 -1
  51. package/lib/ProConfigProvider/index.js +21 -0
  52. package/lib/ProEditLabel/style/index.less +0 -1
  53. package/lib/ProEditTable/components/DndWrapper/index.js +1 -1
  54. package/lib/ProEditTable/components/RenderField/index.js +18 -12
  55. package/lib/ProEditTable/index.js +17 -10
  56. package/lib/ProEnum/components/Group.js +2 -19
  57. package/lib/ProForm/components/base/DatePicker/index.js +3 -1
  58. package/lib/ProForm/components/base/TextArea/index.js +5 -5
  59. package/lib/ProForm/components/combination/FormList/components/ActionButton.d.ts +1 -0
  60. package/lib/ProForm/components/combination/FormList/components/ActionButton.js +12 -10
  61. package/lib/ProForm/components/combination/FormList/components/BlockFields.js +6 -1
  62. package/lib/ProForm/components/combination/FormList/components/ToolbarButton.js +2 -5
  63. package/lib/ProForm/components/combination/Group/index.js +3 -2
  64. package/lib/ProForm/components/combination/ProModalSelect/hooks/useRequestList.js +2 -1
  65. package/lib/ProForm/components/combination/ProModalSelect/index.js +123 -74
  66. package/lib/ProForm/components/combination/ProModalSelect/propsType.d.ts +2 -2
  67. package/lib/ProForm/components/combination/ProModalSelect/style/index.less +1 -1
  68. package/lib/ProForm/components/combination/ProNumberRange/style/index.less +1 -1
  69. package/lib/ProForm/components/render/ConfirmWrapper.js +8 -2
  70. package/lib/ProForm/components/render/Render.js +12 -9
  71. package/lib/ProForm/components/render/RenderFields.d.ts +1 -1
  72. package/lib/ProForm/components/render/propsType.d.ts +4 -4
  73. package/lib/ProForm/index.js +4 -5
  74. package/lib/ProForm/propsType.d.ts +2 -2
  75. package/lib/ProForm/style/index.less +23 -5
  76. package/lib/ProForm/utils/diffOriginal.js +16 -31
  77. package/lib/ProForm/utils/index.d.ts +1 -1
  78. package/lib/ProForm/utils/index.js +14 -4
  79. package/lib/ProForm/utils/rulesCreator.d.ts +7 -1
  80. package/lib/ProForm/utils/rulesCreator.js +45 -2
  81. package/lib/ProForm/utils/useRules.js +36 -11
  82. package/lib/ProForm/utils/useShouldUpdate.js +4 -4
  83. package/lib/ProLayout/components/ProCollapse/index.js +23 -1
  84. package/lib/ProLayout/components/ProCollapse/style/index.less +1 -1
  85. package/lib/ProThemeTools/component/PrdTools/index.js +12 -50
  86. package/lib/ProThemeTools/index.js +0 -1
  87. package/lib/ProTree/components/ProTreeSelect/style/index.less +1 -1
  88. package/lib/ProTree/style/index.less +5 -0
  89. package/lib/ProUpload/style/index.less +1 -1
  90. package/lib/assets/view.svg +20 -1
  91. package/lib/locale/en_US.d.ts +4 -2
  92. package/lib/locale/en_US.js +4 -2
  93. package/lib/locale/zh_CN.d.ts +4 -2
  94. package/lib/locale/zh_CN.js +4 -2
  95. package/lib/style/components.less +0 -3
  96. package/lib/style/theme/antd.less +14 -28
  97. package/package.json +2 -2
@@ -689,7 +689,7 @@
689
689
  display: block !important;
690
690
  }
691
691
  .pro-collapse.ant-collapse .pro-collapse-panel {
692
- margin-bottom: calc(var(--zaui-space-size-md, 16px) * var(--zaui-size, 1));
692
+ margin-bottom: 16px;
693
693
  }
694
694
  .pro-collapse .ant-collapse-header {
695
695
  -webkit-box-align: center !important;
@@ -2322,7 +2322,7 @@ span.ant-input-group-compact.pro-range-limit .forever-checkbox {
2322
2322
  }
2323
2323
  .pro-modal-select .viewSvg,
2324
2324
  .pro-tree-modal .viewSvg {
2325
- height: 24px;
2325
+ height: 20px;
2326
2326
  cursor: pointer;
2327
2327
  fill: #c5c7cd;
2328
2328
  }
@@ -2696,7 +2696,8 @@ span.ant-input-group-compact.pro-range-limit .forever-checkbox {
2696
2696
  .pro-form .ant-form-item.pro-form-item-changed .ant-input-number .ant-select-selection-placeholder {
2697
2697
  z-index: 9;
2698
2698
  }
2699
- .pro-form .ant-form-item.pro-form-item-changed .ant-form-item-control:has(.ant-switch-handle, .ant-checkbox-wrapper-in-form-item) {
2699
+ .pro-form .ant-form-item.pro-form-item-changed .ant-form-item-control:has(.ant-switch-handle),
2700
+ .pro-form .ant-form-item.pro-form-item-changed .ant-form-item-control:has(.ant-checkbox-wrapper-in-form-item) {
2700
2701
  background: var(--zaui-contract-bg, #fffaa1);
2701
2702
  border-radius: 4px;
2702
2703
  }
@@ -2850,6 +2851,19 @@ span.ant-input-group-compact.pro-range-limit .forever-checkbox {
2850
2851
  .pro-form .delete-icon {
2851
2852
  width: 18px;
2852
2853
  }
2854
+ .pro-form .pro-form-list-tool-btn {
2855
+ margin-left: 8px;
2856
+ padding: 0;
2857
+ cursor: pointer;
2858
+ }
2859
+ .pro-form .pro-form-list-tool-btn .anticon {
2860
+ color: var(--zaui-text-weak, #a0a0a0);
2861
+ font-size: 16px;
2862
+ vertical-align: middle;
2863
+ }
2864
+ .pro-form .pro-form-list-mode-block .pro-collapse-content .ant-row {
2865
+ width: auto;
2866
+ }
2853
2867
  .pro-upload .pro-upload-dragger .pro-upload-handle-box {
2854
2868
  background: #F8F9FA;
2855
2869
  border-radius: var(--zaui-border-radius, 8px);
@@ -3864,6 +3878,9 @@ span.ant-input-group-compact.pro-range-limit .forever-checkbox {
3864
3878
  .pro-form.pro-form-view .ant-form-item .pro-tree .ant-tree-checkbox * {
3865
3879
  height: 16px !important;
3866
3880
  }
3881
+ .ant-select-dropdown.pro-tree-select-drop-down-container.checkable-tree {
3882
+ overflow: hidden!important;
3883
+ }
3867
3884
  .pro-drawer .pro-drawer-close {
3868
3885
  position: absolute;
3869
3886
  top: 6px;
@@ -4349,7 +4366,6 @@ span.ant-input-group-compact.pro-range-limit .forever-checkbox {
4349
4366
  -webkit-flex: 0 0 var(--zaui-form-label-width, 130px);
4350
4367
  -ms-flex: 0 0 var(--zaui-form-label-width, 130px);
4351
4368
  flex: 0 0 var(--zaui-form-label-width, 130px);
4352
- text-align: var(--zaui-form-align, left);
4353
4369
  white-space: pre-wrap;
4354
4370
  line-height: 1;
4355
4371
  overflow: initial;
@@ -5039,16 +5055,23 @@ input[type='button'] {
5039
5055
  -webkit-flex: 0 0 var(--zaui-form-label-width, 130px);
5040
5056
  -ms-flex: 0 0 var(--zaui-form-label-width, 130px);
5041
5057
  flex: 0 0 var(--zaui-form-label-width, 130px);
5042
- padding-right: calc(var(--zaui-space-size-md, 16px) * var(--zaui-size, 1));
5058
+ padding-right: 16px;
5043
5059
  overflow: initial;
5044
5060
  line-height: 1;
5045
5061
  white-space: pre-wrap;
5046
- text-align: var(--zaui-form-align, left);
5047
5062
  }
5048
- .ant-form .ant-form-item .ant-form-item-label .ant-form-item-required::after,
5049
- .ant-drawer .ant-form-item .ant-form-item-label .ant-form-item-required::after,
5050
- .ant-modal .ant-form-item .ant-form-item-label .ant-form-item-required::after {
5051
- display: block;
5063
+ .ant-form .ant-form-item .ant-form-item-label .ant-form-item-required,
5064
+ .ant-drawer .ant-form-item .ant-form-item-label .ant-form-item-required,
5065
+ .ant-modal .ant-form-item .ant-form-item-label .ant-form-item-required {
5066
+ position: relative;
5067
+ }
5068
+ .ant-form .ant-form-item .ant-form-item-label .ant-form-item-required::before,
5069
+ .ant-drawer .ant-form-item .ant-form-item-label .ant-form-item-required::before,
5070
+ .ant-modal .ant-form-item .ant-form-item-label .ant-form-item-required::before {
5071
+ position: absolute;
5072
+ top: calc(50% - 7px);
5073
+ left: -8px;
5074
+ margin: 0;
5052
5075
  }
5053
5076
  .ant-form .ant-form-item .ant-form-item-label > label,
5054
5077
  .ant-drawer .ant-form-item .ant-form-item-label > label,
@@ -5059,31 +5082,12 @@ input[type='button'] {
5059
5082
  .ant-drawer .ant-form-item .ant-form-item-label > label::after,
5060
5083
  .ant-modal .ant-form-item .ant-form-item-label > label::after {
5061
5084
  display: none;
5062
- margin: 0;
5063
- }
5064
- .ant-form .ant-form-item .ant-form-item-label .ant-form-item-required::before,
5065
- .ant-drawer .ant-form-item .ant-form-item-label .ant-form-item-required::before,
5066
- .ant-modal .ant-form-item .ant-form-item-label .ant-form-item-required::before {
5067
- display: inline-block;
5068
5085
  }
5069
5086
  .ant-form .ant-form-item .ant-form-item-label.ant-form-item-label-left > .ant-form-item-required::before,
5070
5087
  .ant-drawer .ant-form-item .ant-form-item-label.ant-form-item-label-left > .ant-form-item-required::before,
5071
5088
  .ant-modal .ant-form-item .ant-form-item-label.ant-form-item-label-left > .ant-form-item-required::before {
5072
- display: none;
5073
- }
5074
- .ant-form .ant-form-item .ant-form-item-label.ant-form-item-label-left > .ant-form-item-required::after,
5075
- .ant-drawer .ant-form-item .ant-form-item-label.ant-form-item-label-left > .ant-form-item-required::after,
5076
- .ant-modal .ant-form-item .ant-form-item-label.ant-form-item-label-left > .ant-form-item-required::after {
5077
- margin-top: 1px;
5078
- color: #ff4d4f;
5079
- font-size: var(--zaui-font-size, 14px);
5080
- line-height: 1;
5081
- content: '*';
5082
- }
5083
- .ant-form .ant-form-item .ant-form-item-label:not(.ant-form-item-label-left) > .ant-form-item-required::after,
5084
- .ant-drawer .ant-form-item .ant-form-item-label:not(.ant-form-item-label-left) > .ant-form-item-required::after,
5085
- .ant-modal .ant-form-item .ant-form-item-label:not(.ant-form-item-label-left) > .ant-form-item-required::after {
5086
- display: none;
5089
+ right: -10px;
5090
+ left: unset;
5087
5091
  }
5088
5092
  .ant-form .ant-form-item .ant-form-item-explain-error,
5089
5093
  .ant-drawer .ant-form-item .ant-form-item-explain-error,
package/dist/less.esm.css CHANGED
@@ -689,7 +689,7 @@
689
689
  display: block !important;
690
690
  }
691
691
  .pro-collapse.ant-collapse .pro-collapse-panel {
692
- margin-bottom: calc(var(--zaui-space-size-md, 16px) * var(--zaui-size, 1));
692
+ margin-bottom: 16px;
693
693
  }
694
694
  .pro-collapse .ant-collapse-header {
695
695
  -webkit-box-align: center !important;
@@ -2322,7 +2322,7 @@ span.ant-input-group-compact.pro-range-limit .forever-checkbox {
2322
2322
  }
2323
2323
  .pro-modal-select .viewSvg,
2324
2324
  .pro-tree-modal .viewSvg {
2325
- height: 24px;
2325
+ height: 20px;
2326
2326
  cursor: pointer;
2327
2327
  fill: #c5c7cd;
2328
2328
  }
@@ -2696,7 +2696,8 @@ span.ant-input-group-compact.pro-range-limit .forever-checkbox {
2696
2696
  .pro-form .ant-form-item.pro-form-item-changed .ant-input-number .ant-select-selection-placeholder {
2697
2697
  z-index: 9;
2698
2698
  }
2699
- .pro-form .ant-form-item.pro-form-item-changed .ant-form-item-control:has(.ant-switch-handle, .ant-checkbox-wrapper-in-form-item) {
2699
+ .pro-form .ant-form-item.pro-form-item-changed .ant-form-item-control:has(.ant-switch-handle),
2700
+ .pro-form .ant-form-item.pro-form-item-changed .ant-form-item-control:has(.ant-checkbox-wrapper-in-form-item) {
2700
2701
  background: var(--zaui-contract-bg, #fffaa1);
2701
2702
  border-radius: 4px;
2702
2703
  }
@@ -2850,6 +2851,19 @@ span.ant-input-group-compact.pro-range-limit .forever-checkbox {
2850
2851
  .pro-form .delete-icon {
2851
2852
  width: 18px;
2852
2853
  }
2854
+ .pro-form .pro-form-list-tool-btn {
2855
+ margin-left: 8px;
2856
+ padding: 0;
2857
+ cursor: pointer;
2858
+ }
2859
+ .pro-form .pro-form-list-tool-btn .anticon {
2860
+ color: var(--zaui-text-weak, #a0a0a0);
2861
+ font-size: 16px;
2862
+ vertical-align: middle;
2863
+ }
2864
+ .pro-form .pro-form-list-mode-block .pro-collapse-content .ant-row {
2865
+ width: auto;
2866
+ }
2853
2867
  .pro-upload .pro-upload-dragger .pro-upload-handle-box {
2854
2868
  background: #F8F9FA;
2855
2869
  border-radius: var(--zaui-border-radius, 8px);
@@ -3864,6 +3878,9 @@ span.ant-input-group-compact.pro-range-limit .forever-checkbox {
3864
3878
  .pro-form.pro-form-view .ant-form-item .pro-tree .ant-tree-checkbox * {
3865
3879
  height: 16px !important;
3866
3880
  }
3881
+ .ant-select-dropdown.pro-tree-select-drop-down-container.checkable-tree {
3882
+ overflow: hidden!important;
3883
+ }
3867
3884
  .pro-drawer .pro-drawer-close {
3868
3885
  position: absolute;
3869
3886
  top: 6px;
@@ -4349,7 +4366,6 @@ span.ant-input-group-compact.pro-range-limit .forever-checkbox {
4349
4366
  -webkit-flex: 0 0 var(--zaui-form-label-width, 130px);
4350
4367
  -ms-flex: 0 0 var(--zaui-form-label-width, 130px);
4351
4368
  flex: 0 0 var(--zaui-form-label-width, 130px);
4352
- text-align: var(--zaui-form-align, left);
4353
4369
  white-space: pre-wrap;
4354
4370
  line-height: 1;
4355
4371
  overflow: initial;
@@ -21,7 +21,7 @@ export declare const ProConfigContext: React.Context<ConfigContext>;
21
21
  export declare function useProConfig(): ConfigContext;
22
22
  export declare function useProConfig(name: keyof ConfigContext['state']): ConfigContext['state'][keyof ConfigContext['state']];
23
23
  export declare function useContextForms(): Record<string, FormInstance<any>>;
24
- type ActionsType = 'set' | 'setProEnum' | 'setProEnumDic';
24
+ type ActionsType = 'set' | 'setProEnum' | 'setProEnumDic' | 'setWithLocal';
25
25
  interface Actions {
26
26
  type: ActionsType;
27
27
  payload: any;
@@ -3,7 +3,7 @@ import _ConfigProvider from "antd/es/config-provider";
3
3
  import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
4
4
  import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
5
5
  import { jsxs as _jsxs, jsx as _jsx } from "react/jsx-runtime";
6
- import React, { useContext, useReducer } from 'react';
6
+ import React, { useContext, useEffect, useReducer } from 'react';
7
7
  import zhCN from 'antd/es/locale/zh_CN';
8
8
  import enUS from 'antd/es/locale/en_US';
9
9
  import merge from 'lodash/merge';
@@ -13,6 +13,9 @@ var initialState = {
13
13
  ProEnum: {
14
14
  dics: {}
15
15
  },
16
+ ProForm: {
17
+ labelAlign: 'left'
18
+ },
16
19
  forms: {},
17
20
  ProIcon: {
18
21
  mode: 'icon',
@@ -46,6 +49,15 @@ var reducer = function reducer(state, action) {
46
49
  switch (action.type) {
47
50
  case 'set':
48
51
  return _objectSpread(_objectSpread({}, state), action.payload);
52
+ // 设置的值会被存入localStorage
53
+ case 'setWithLocal':
54
+ {
55
+ var _state = merge({}, state, action.payload);
56
+ var localConfigStr = localStorage.getItem('localConfig');
57
+ var localConfig = JSON.parse(localConfigStr || '{}');
58
+ localStorage.setItem('localConfig', JSON.stringify(merge(localConfig, action.payload)));
59
+ return _state;
60
+ }
49
61
  case 'setProEnum':
50
62
  return _objectSpread(_objectSpread({}, state), {}, {
51
63
  ProEnum: _objectSpread(_objectSpread({}, state.ProEnum), action.payload)
@@ -67,6 +79,15 @@ export var ProConfigProvider = function ProConfigProvider(props) {
67
79
  state = _useReducer2[0],
68
80
  dispatch = _useReducer2[1];
69
81
  useEnumRequest(_objectSpread(_objectSpread(_objectSpread({}, state.ProEnum), props === null || props === void 0 ? void 0 : (_props$value = props.value) === null || _props$value === void 0 ? void 0 : _props$value.ProEnum), props === null || props === void 0 ? void 0 : (_props$value2 = props.value) === null || _props$value2 === void 0 ? void 0 : _props$value2.globalConfig), dispatch);
82
+ useEffect(function () {
83
+ // 本地配置取出
84
+ var localConfigStr = localStorage.getItem('localConfig');
85
+ var localConfig = JSON.parse(localConfigStr || '{}');
86
+ dispatch({
87
+ type: 'set',
88
+ payload: merge(state, localConfig)
89
+ });
90
+ }, []);
70
91
  var cacheLang = localStorage.getItem('locale');
71
92
  // 如果是用户切换了语言那么优先使用用户切换的,否则从缓存中取用户语言,在取默认值
72
93
  var lang = (state === null || state === void 0 ? void 0 : state.locale) || cacheLang || (props === null || props === void 0 ? void 0 : props.locale);
@@ -120,7 +120,6 @@
120
120
 
121
121
  .@{ant-prefix}-col-10 {
122
122
  flex : 0 0 var(--zaui-form-label-width, 130px);
123
- text-align : var(--zaui-form-align, left);
124
123
  white-space : pre-wrap;
125
124
  line-height : 1;
126
125
  overflow : initial;
@@ -28,7 +28,7 @@ export var Row = function Row(props) {
28
28
  transition: transition
29
29
  }, isDragging ? {
30
30
  position: 'relative',
31
- zIndex: 9999
31
+ zIndex: 2
32
32
  } : {});
33
33
  return _jsx("tr", _objectSpread(_objectSpread(_objectSpread({}, restProps), {}, {
34
34
  ref: setNodeRef,
@@ -1,9 +1,9 @@
1
1
  import "antd/es/tooltip/style";
2
2
  import _Tooltip from "antd/es/tooltip";
3
- import "antd/es/form/style";
4
- import _Form from "antd/es/form";
5
3
  import "antd/es/space/style";
6
4
  import _Space from "antd/es/space";
5
+ import "antd/es/form/style";
6
+ import _Form from "antd/es/form";
7
7
  import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
8
8
  import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
9
9
  import _regeneratorRuntime from "@babel/runtime/helpers/esm/regeneratorRuntime";
@@ -72,7 +72,9 @@ var RenderField = function RenderField(_ref) {
72
72
  virtualKey = config.virtualKey,
73
73
  viewEmpty = config.viewEmpty,
74
74
  originalValues = config.originalValues,
75
- originalDiffTip = config.originalDiffTip;
75
+ formNamePath = config.namePath,
76
+ _config$originalDiffT = config.originalDiffTip,
77
+ originalDiffTip = _config$originalDiffT === void 0 ? true : _config$originalDiffT;
76
78
  var _fieldProps = fieldProps || formItemProps || {};
77
79
  var _rules = rules || [];
78
80
  var _required = required;
@@ -166,6 +168,7 @@ var RenderField = function RenderField(_ref) {
166
168
  * @returns {}
167
169
  */
168
170
  var valueTypeTransform = useCallback(function () {
171
+ var _fieldProps5;
169
172
  // 不存在valueType返回空
170
173
  if (!valueType) {
171
174
  return {};
@@ -174,7 +177,9 @@ var RenderField = function RenderField(_ref) {
174
177
  if (type === 'SwitchCheckbox') {
175
178
  valueType = 'switch';
176
179
  }
177
- var params = _objectSpread({}, column);
180
+ var params = _objectSpread(_objectSpread({}, column), {}, {
181
+ mode: (_fieldProps5 = _fieldProps) === null || _fieldProps5 === void 0 ? void 0 : _fieldProps5.mode
182
+ });
178
183
  return isFunction(valueTypeMap[valueType]) ? valueTypeMap[valueType](params) : {};
179
184
  }, [valueType]);
180
185
  if ((_names = names) === null || _names === void 0 ? void 0 : _names.length) {
@@ -512,7 +517,16 @@ var RenderField = function RenderField(_ref) {
512
517
  delete _formItemProps.rules;
513
518
  }
514
519
  var _className = classNames(_defineProperty(_defineProperty({}, className, className), 'pro-form-item-changed', changed));
515
- var originalTitle = originalDiffTip ? _jsxs(_Space, {
520
+ var FormItem = TargetComponent ? _jsx(_Form.Item, _objectSpread(_objectSpread({
521
+ validateFirst: true
522
+ }, omit(_formItemProps, ['render', 'cache', 'key', 'width', 'hiddenNames', 'name'])), {}, {
523
+ className: _className,
524
+ name: formNamePath ? cellName.slice((formNamePath === null || formNamePath === void 0 ? void 0 : formNamePath.length) - 1) : cellName,
525
+ children: /*#__PURE__*/React.isValidElement(TargetComponent) ? ( /*#__PURE__*/React.cloneElement(TargetComponent, componentProps)) : _jsx(TargetComponent, _objectSpread({}, componentProps))
526
+ })) : _jsx(Container, {
527
+ viewEmpty: viewEmpty
528
+ });
529
+ var originalTitle = originalDiffTip && originalValues ? _jsxs(_Space, {
516
530
  children: ["\u521D\u59CB\u503C\uFF1A", /*#__PURE__*/React.isValidElement(TargetComponent) ? ( /*#__PURE__*/React.cloneElement(TargetComponent, _objectSpread(_objectSpread({}, componentProps), {}, {
517
531
  isView: true,
518
532
  value: originalValue,
@@ -523,19 +537,11 @@ var RenderField = function RenderField(_ref) {
523
537
  checked: type === 'Switch' ? originalValue : undefined
524
538
  }))]
525
539
  }) : null;
526
- var FormItem = TargetComponent ? _jsx(_Form.Item, _objectSpread(_objectSpread({
527
- validateFirst: true
528
- }, omit(_formItemProps, ['render', 'cache', 'key', 'width', 'hiddenNames', 'name'])), {}, {
529
- className: _className,
530
- name: cellName,
531
- children: /*#__PURE__*/React.isValidElement(TargetComponent) ? ( /*#__PURE__*/React.cloneElement(TargetComponent, componentProps)) : _jsx(TargetComponent, _objectSpread({}, componentProps))
532
- })) : _jsx(Container, {
533
- viewEmpty: viewEmpty
534
- });
535
540
  return _jsx(FieldProvider, {
536
541
  value: (_componentProps = componentProps) === null || _componentProps === void 0 ? void 0 : _componentProps.otherProps,
537
542
  children: !originalDiffTip || ['FormList', 'ProEditTable'].includes(type) ? FormItem : _jsx(_Tooltip, {
538
543
  title: originalTitle,
544
+ placement: "topLeft",
539
545
  open: changed ? undefined : false,
540
546
  getPopupContainer: function getPopupContainer(target) {
541
547
  return target.parentElement;
@@ -7,10 +7,11 @@ import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
7
7
  import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
8
8
  import "antd/es/config-provider/style";
9
9
  import _ConfigProvider from "antd/es/config-provider";
10
+ import _toConsumableArray from "@babel/runtime/helpers/esm/toConsumableArray";
10
11
  import "antd/es/form/style";
11
12
  import _Form from "antd/es/form";
12
13
  import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
13
- var _excluded = ["value", "onChange", "className", "columns", "type", "mode", "stripe", "draggable", "disabled", "insertType", "emptyBtnText", "actionWidth", "actionProps", "toolbarProps", "rowSelection", "onlyOneLineMsg", "deletePoConfirmMsg", "mulDeletePoConfirmMsg", "otherProps", "requiredAlign", "summary", "max", "headerRender", "pagination", "originalValues", "originalDiffTip", "rowKey"];
14
+ var _excluded = ["value", "onChange", "className", "columns", "type", "mode", "stripe", "draggable", "disabled", "insertType", "emptyBtnText", "actionWidth", "actionProps", "toolbarProps", "rowSelection", "onlyOneLineMsg", "deletePoConfirmMsg", "mulDeletePoConfirmMsg", "requiredAlign", "summary", "max", "headerRender", "pagination", "originalValues", "originalDiffTip", "rowKey"];
14
15
  import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
15
16
  import React, { forwardRef, useCallback, useEffect, useImperativeHandle, useMemo, useRef } from 'react';
16
17
  import { get, isArray } from 'lodash';
@@ -19,6 +20,7 @@ import classnames from 'classnames';
19
20
  import { transformColumns } from './utils';
20
21
  import { getRandom, getNamePath } from './utils/tools';
21
22
  import { DndWrapper, Row, Validator, Summary, RenderToolbar } from './components';
23
+ import ProForm from '../ProForm';
22
24
  import Empty from '../assets/empty.png';
23
25
  import locale, { formatMessage } from '../locale';
24
26
  var ProEditTable = function ProEditTable(_ref, ref) {
@@ -41,8 +43,6 @@ var ProEditTable = function ProEditTable(_ref, ref) {
41
43
  onlyOneLineMsg = _ref.onlyOneLineMsg,
42
44
  deletePoConfirmMsg = _ref.deletePoConfirmMsg,
43
45
  mulDeletePoConfirmMsg = _ref.mulDeletePoConfirmMsg,
44
- _ref$otherProps = _ref.otherProps,
45
- otherProps = _ref$otherProps === void 0 ? {} : _ref$otherProps,
46
46
  configRequiredAlign = _ref.requiredAlign,
47
47
  summary = _ref.summary,
48
48
  max = _ref.max,
@@ -54,17 +54,23 @@ var ProEditTable = function ProEditTable(_ref, ref) {
54
54
  resetProps = _objectWithoutProperties(_ref, _excluded);
55
55
  // 上下文form
56
56
  var contentForm = _Form.useFormInstance();
57
- var form = contentForm || (otherProps === null || otherProps === void 0 ? void 0 : otherProps.form) || (resetProps === null || resetProps === void 0 ? void 0 : resetProps.form);
58
- var name = (otherProps === null || otherProps === void 0 ? void 0 : otherProps.name) || (resetProps === null || resetProps === void 0 ? void 0 : resetProps.name) || (resetProps === null || resetProps === void 0 ? void 0 : (_resetProps$id = resetProps.id) === null || _resetProps$id === void 0 ? void 0 : (_resetProps$id$split = _resetProps$id.split) === null || _resetProps$id$split === void 0 ? void 0 : _resetProps$id$split.call(_resetProps$id, '_'));
59
- var _otherProps$isView = otherProps.isView,
60
- isView = _otherProps$isView === void 0 ? false : _otherProps$isView,
61
- _otherProps$viewEmpty = otherProps.viewEmpty,
62
- viewEmpty = _otherProps$viewEmpty === void 0 ? '-' : _otherProps$viewEmpty;
57
+ var formFieldProps = ProForm.useFieldProps() || {};
58
+ var form = contentForm || (formFieldProps === null || formFieldProps === void 0 ? void 0 : formFieldProps.form) || (resetProps === null || resetProps === void 0 ? void 0 : resetProps.form);
59
+ var name = (formFieldProps === null || formFieldProps === void 0 ? void 0 : formFieldProps.name) || (resetProps === null || resetProps === void 0 ? void 0 : resetProps.name) || (resetProps === null || resetProps === void 0 ? void 0 : (_resetProps$id = resetProps.id) === null || _resetProps$id === void 0 ? void 0 : (_resetProps$id$split = _resetProps$id.split) === null || _resetProps$id$split === void 0 ? void 0 : _resetProps$id$split.call(_resetProps$id, '_'));
60
+ var _formFieldProps$isVie = formFieldProps.isView,
61
+ isView = _formFieldProps$isVie === void 0 ? false : _formFieldProps$isVie,
62
+ _formFieldProps$viewE = formFieldProps.viewEmpty,
63
+ viewEmpty = _formFieldProps$viewE === void 0 ? '-' : _formFieldProps$viewE,
64
+ namePath = formFieldProps.namePath;
65
+ // 判断是否在formList内
66
+ if (namePath === null || namePath === void 0 ? void 0 : namePath.length) {
67
+ name = [].concat(_toConsumableArray(namePath), _toConsumableArray(name.slice(1)));
68
+ }
63
69
  var tableRef = useRef(null);
64
70
  var _React$useContext = React.useContext(_ConfigProvider.ConfigContext),
65
71
  getPrefixCls = _React$useContext.getPrefixCls;
66
72
  var prefixCls = getPrefixCls();
67
- disabled = (otherProps === null || otherProps === void 0 ? void 0 : otherProps.disabled) || disabled;
73
+ disabled = (formFieldProps === null || formFieldProps === void 0 ? void 0 : formFieldProps.disabled) || disabled;
68
74
  var _useLocalStorageState = useLocalStorageState('themeConfig'),
69
75
  _useLocalStorageState2 = _slicedToArray(_useLocalStorageState, 1),
70
76
  themeConfig = _useLocalStorageState2[0];
@@ -146,6 +152,7 @@ var ProEditTable = function ProEditTable(_ref, ref) {
146
152
  virtualKey: virtualKey,
147
153
  requiredAlign: requiredAlign,
148
154
  name: isArray(name) ? name : [name],
155
+ namePath: namePath,
149
156
  tableRef: tableRef,
150
157
  max: max,
151
158
  tableLength: value === null || value === void 0 ? void 0 : value.length,
@@ -1,7 +1,5 @@
1
- import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
2
1
  import { jsx as _jsx } from "react/jsx-runtime";
3
2
  import classNames from 'classnames';
4
- import { useSetState } from 'ahooks';
5
3
  import { useEffect, useRef } from 'react';
6
4
  var Group = function Group(props) {
7
5
  var value = props.value,
@@ -13,35 +11,20 @@ var Group = function Group(props) {
13
11
  _props$allowClear = props.allowClear,
14
12
  allowClear = _props$allowClear === void 0 ? true : _props$allowClear;
15
13
  var idx = useRef(-1);
16
- var _useSetState = useSetState({
17
- checked: ''
18
- }),
19
- _useSetState2 = _slicedToArray(_useSetState, 2),
20
- state = _useSetState2[0],
21
- setState = _useSetState2[1];
22
14
  useEffect(function () {
23
- setState({
24
- checked: value
25
- });
26
15
  var index = dataSource.findIndex(function (item) {
27
16
  return item[fieldValue] === value;
28
17
  });
29
18
  idx.current = index;
30
19
  }, [value]);
31
20
  var handleClick = function handleClick(val, index) {
32
- if (state.checked === val) {
21
+ if (value === val) {
33
22
  if (!allowClear) {
34
23
  return false;
35
24
  }
36
- setState({
37
- checked: ''
38
- });
39
25
  onChange === null || onChange === void 0 ? void 0 : onChange('');
40
26
  idx.current = -1;
41
27
  } else {
42
- setState({
43
- checked: val
44
- });
45
28
  idx.current = index;
46
29
  onChange === null || onChange === void 0 ? void 0 : onChange(val);
47
30
  }
@@ -60,7 +43,7 @@ var Group = function Group(props) {
60
43
  handleClick(item[fieldValue], index);
61
44
  }
62
45
  },
63
- className: classNames('pro-enum-group-item', state.checked === item[fieldValue] ? 'pro-enum-group-item-selected' : '', index === idx.current || index + 1 === idx.current ? 'pro-enum-group-item-disabled-after' : '', item.disabled ? 'pro-enum-group-item-disabled' : ''),
46
+ className: classNames('pro-enum-group-item', value === item[fieldValue] ? 'pro-enum-group-item-selected' : '', index === idx.current || index + 1 === idx.current ? 'pro-enum-group-item-disabled-after' : '', item.disabled ? 'pro-enum-group-item-disabled' : ''),
64
47
  children: item[fieldLabel]
65
48
  }, item[fieldValue]);
66
49
  })
@@ -56,7 +56,9 @@ var DatePicker = function DatePicker(props) {
56
56
  disabled: true
57
57
  };
58
58
  }
59
- return _jsx(_DatePicker, _objectSpread(_objectSpread(_objectSpread({}, initialConfig), _rest), {}, {
59
+ return _jsx(_DatePicker, _objectSpread(_objectSpread(_objectSpread({}, initialConfig), {}, {
60
+ format: format
61
+ }, _rest), {}, {
60
62
  className: _className
61
63
  }));
62
64
  };
@@ -1,4 +1,5 @@
1
1
  import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
2
+ import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
2
3
  import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
3
4
  import "antd/es/input/style";
4
5
  import _Input from "antd/es/input";
@@ -31,11 +32,10 @@ var TextAreaDef = function TextAreaDef(props) {
31
32
  children: rest.value
32
33
  });
33
34
  }
34
- var _className = classnames({
35
+ var _className = classnames(_defineProperty({
35
36
  'pro-textarea': true,
36
- 'pro-textarea-view': isView,
37
- className: className
38
- });
37
+ 'pro-textarea-view': isView
38
+ }, className, true));
39
39
  return _jsx(TextArea, _objectSpread(_objectSpread(_objectSpread({
40
40
  showCount: true,
41
41
  autoComplete: "off",
@@ -17,6 +17,7 @@ export interface Props {
17
17
  fields: FormListFieldData[];
18
18
  mode: FormListMode;
19
19
  disabled?: boolean;
20
+ isView?: boolean;
20
21
  }
21
22
  declare const ActionButton: React.FC<Props>;
22
23
  export default ActionButton;
@@ -27,7 +27,7 @@ var getDefaultActions = function getDefaultActions(mode) {
27
27
  add(undefined, index + 1);
28
28
  },
29
29
  type: 'text',
30
- label: "".concat(locale.ProForm.formList_actions[0]),
30
+ label: "".concat(locale.ProForm.formListActions[0]),
31
31
  icon: _jsx(PlusSquareOutlined, {})
32
32
  },
33
33
  delete: {
@@ -39,7 +39,7 @@ var getDefaultActions = function getDefaultActions(mode) {
39
39
  remove(index);
40
40
  },
41
41
  type: 'text',
42
- label: "".concat(locale.ProForm.formList_actions[1]),
42
+ label: "".concat(locale.ProForm.formListActions[1]),
43
43
  icon: mode === 'less' ? _jsx(ProIcon, {
44
44
  type: "solid-close",
45
45
  className: "single-delete"
@@ -56,7 +56,7 @@ var getDefaultActions = function getDefaultActions(mode) {
56
56
  add(record, index + 1);
57
57
  },
58
58
  type: 'text',
59
- label: "".concat(locale.ProForm.formList_actions[2]),
59
+ label: "".concat(locale.ProForm.formListActions[2]),
60
60
  icon: _jsx(CopyOutlined, {})
61
61
  },
62
62
  moveUp: {
@@ -68,7 +68,7 @@ var getDefaultActions = function getDefaultActions(mode) {
68
68
  move(index, index - 1);
69
69
  },
70
70
  type: 'text',
71
- label: "".concat(locale.ProForm.formList_actions[3]),
71
+ label: "".concat(locale.ProForm.formListActions[3]),
72
72
  icon: _jsx(UpSquareOutlined, {})
73
73
  },
74
74
  moveDown: {
@@ -80,13 +80,14 @@ var getDefaultActions = function getDefaultActions(mode) {
80
80
  move(index, index + 1);
81
81
  },
82
82
  type: 'text',
83
- label: "".concat(locale.ProForm.formList_actions[4]),
83
+ label: "".concat(locale.ProForm.formListActions[4]),
84
84
  icon: _jsx(DownSquareOutlined, {})
85
85
  }
86
86
  };
87
87
  if (mode === 'block') {
88
88
  Object.keys(originActions).forEach(function (key) {
89
- originActions[key].type = 'default';
89
+ originActions[key].type = 'text';
90
+ originActions[key].className = 'pro-form-list-tool-btn';
90
91
  });
91
92
  }
92
93
  if (mode === 'line') {
@@ -115,7 +116,8 @@ var ActionButton = function ActionButton(props) {
115
116
  fields = props.fields,
116
117
  min = props.min,
117
118
  max = props.max,
118
- mode = props.mode;
119
+ mode = props.mode,
120
+ isView = props.isView;
119
121
  // 默认显示一个delete
120
122
  var actionProps = useMemo(function () {
121
123
  var _props$actionProps;
@@ -166,7 +168,7 @@ var ActionButton = function ActionButton(props) {
166
168
  var _onClick = onClick || onHandle;
167
169
  if (['add', 'delete', 'copy', 'moveUp', 'moveDown'].includes(actionType)) {
168
170
  // 禁用状态默认隐藏内置操作按钮
169
- if (disabled) return _jsx(_Fragment, {});
171
+ if (disabled || isView) return _jsx(_Fragment, {});
170
172
  var _defaultActions$actio = defaultActions[actionType],
171
173
  internalOnClick = _defaultActions$actio.onClick,
172
174
  defaultLabel = _defaultActions$actio.label,
@@ -188,7 +190,7 @@ var ActionButton = function ActionButton(props) {
188
190
  return false;
189
191
  }
190
192
  return _needConfirm ? _jsx(_Popconfirm, _objectSpread(_objectSpread({
191
- title: title !== null && title !== void 0 ? title : "".concat(locale.ProForm.formList_confirmMessage),
193
+ title: title !== null && title !== void 0 ? title : "".concat(locale.ProForm.formListConfirmMessage),
192
194
  onCancel: function onCancel(e) {
193
195
  return e.stopPropagation();
194
196
  },
@@ -211,7 +213,7 @@ var ActionButton = function ActionButton(props) {
211
213
  }), "".concat(item === null || item === void 0 ? void 0 : item.actionType).concat(index));
212
214
  }
213
215
  return needConfirm ? _jsx(_Popconfirm, _objectSpread(_objectSpread({
214
- title: title !== null && title !== void 0 ? title : "".concat(locale.ProForm.formList_confirmMessage),
216
+ title: title !== null && title !== void 0 ? title : "".concat(locale.ProForm.formListConfirmMessage),
215
217
  onCancel: function onCancel(e) {
216
218
  return e.stopPropagation();
217
219
  },
@@ -2,9 +2,11 @@ import "antd/es/row/style";
2
2
  import _Row from "antd/es/row";
3
3
  import "antd/es/space/style";
4
4
  import _Space from "antd/es/space";
5
+ import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
5
6
  import { jsx as _jsx } from "react/jsx-runtime";
6
7
  import { useMemo } from 'react';
7
8
  import { isFunction } from 'lodash';
9
+ import classNames from 'classnames';
8
10
  import ActionButton from './ActionButton';
9
11
  import RenderFields from '../../../render/RenderFields';
10
12
  import ProCollapse from '../../../../../ProLayout/components/ProCollapse';
@@ -34,8 +36,10 @@ var BlockFields = function BlockFields(props) {
34
36
  }
35
37
  return title;
36
38
  }, [title, index]);
39
+ var cls = classNames(_defineProperty({}, "pro-form-list-mode-".concat(mode), mode === 'block' || mode === 'line' || mode === 'less'));
37
40
  return _jsx(_Space, {
38
41
  direction: "vertical",
42
+ className: cls,
39
43
  children: _jsx(ProCollapse, {
40
44
  title: _title,
41
45
  index: index,
@@ -55,7 +59,8 @@ var BlockFields = function BlockFields(props) {
55
59
  fields: fields,
56
60
  actionProps: actionProps,
57
61
  mode: mode,
58
- disabled: disabled
62
+ disabled: disabled,
63
+ isView: isView
59
64
  }),
60
65
  children: _jsx(_Row, {
61
66
  gutter: 24,