@teamix/pro 1.6.0-beta.5 → 1.6.0-beta.6

Sign up to get free protection for your applications and to get access to all the features.
Files changed (108) hide show
  1. package/dist/pro.all.min.css +1 -1
  2. package/dist/pro.css +1 -1
  3. package/dist/pro.js +15860 -11211
  4. package/dist/pro.min.css +1 -1
  5. package/dist/pro.min.js +1 -1
  6. package/dist/pro.min.js.LICENSE.txt +9 -0
  7. package/dist/pro.xconsole.min.css +1 -1
  8. package/es/actions/index.d.ts +6 -6
  9. package/es/actions/index.js +18 -16
  10. package/es/actions/index.scss +4 -0
  11. package/es/form/Components/FormItem2/animation.scss +72 -0
  12. package/es/form/Components/FormItem2/grid.scss +173 -0
  13. package/es/form/Components/FormItem2/index.d.ts +41 -0
  14. package/es/form/Components/FormItem2/index.js +286 -0
  15. package/es/form/Components/FormItem2/main.scss +413 -0
  16. package/es/form/Components/FormItem2/scss/variable.scss +118 -0
  17. package/es/form/Components/FormItem2/style.d.ts +1 -0
  18. package/es/form/Components/FormItem2/style.js +1 -0
  19. package/es/form/Components/LightFilter/index.scss +4 -0
  20. package/es/form/Components/__builtins__/empty.d.ts +1 -0
  21. package/es/form/Components/__builtins__/empty.js +51 -0
  22. package/es/form/Components/__builtins__/hooks/index.d.ts +2 -0
  23. package/es/form/Components/__builtins__/hooks/index.js +2 -0
  24. package/es/form/Components/__builtins__/hooks/useClickAway.d.ts +5 -0
  25. package/es/form/Components/__builtins__/hooks/useClickAway.js +37 -0
  26. package/es/form/Components/__builtins__/hooks/usePrefixCls.d.ts +3 -0
  27. package/es/form/Components/__builtins__/hooks/usePrefixCls.js +8 -0
  28. package/es/form/Components/__builtins__/icons.d.ts +20 -0
  29. package/es/form/Components/__builtins__/icons.js +153 -0
  30. package/es/form/Components/__builtins__/index.d.ts +8 -0
  31. package/es/form/Components/__builtins__/index.js +8 -0
  32. package/es/form/Components/__builtins__/loading.d.ts +1 -0
  33. package/es/form/Components/__builtins__/loading.js +41 -0
  34. package/es/form/Components/__builtins__/mapSize.d.ts +1 -0
  35. package/es/form/Components/__builtins__/mapSize.js +13 -0
  36. package/es/form/Components/__builtins__/mapStatus.d.ts +2 -0
  37. package/es/form/Components/__builtins__/mapStatus.js +20 -0
  38. package/es/form/Components/__builtins__/moment.d.ts +2 -0
  39. package/es/form/Components/__builtins__/moment.js +47 -0
  40. package/es/form/Components/__builtins__/pickDataProps.d.ts +1 -0
  41. package/es/form/Components/__builtins__/pickDataProps.js +9 -0
  42. package/es/form/Components/form-layout/index.d.ts +74 -0
  43. package/es/form/Components/form-layout/index.js +71 -0
  44. package/es/form/Components/form-layout/main.scss +0 -0
  45. package/es/form/Components/form-layout/style.d.ts +1 -0
  46. package/es/form/Components/form-layout/style.js +3 -0
  47. package/es/form/Components/form-layout/useResponsiveFormLayout.d.ts +18 -0
  48. package/es/form/Components/form-layout/useResponsiveFormLayout.js +87 -0
  49. package/es/form/Filter/AdvancedFilter.js +2 -2
  50. package/es/form/Filter/index2.js +3 -3
  51. package/es/form/ProForm/index.js +14 -12
  52. package/es/info/utils/utils.d.ts +1 -1
  53. package/es/sidebar/utils/index.d.ts +2 -2
  54. package/es/table/index.d.ts +1 -1
  55. package/es/table/index.js +17 -17
  56. package/es/utils/aspect.js +5 -2
  57. package/es/xconsole.scss +1 -0
  58. package/lib/actions/index.d.ts +6 -6
  59. package/lib/actions/index.js +16 -14
  60. package/lib/actions/index.scss +4 -0
  61. package/lib/form/Components/FormItem2/animation.scss +72 -0
  62. package/lib/form/Components/FormItem2/grid.scss +173 -0
  63. package/lib/form/Components/FormItem2/index.d.ts +41 -0
  64. package/lib/form/Components/FormItem2/index.js +299 -0
  65. package/lib/form/Components/FormItem2/main.scss +413 -0
  66. package/lib/form/Components/FormItem2/scss/variable.scss +118 -0
  67. package/lib/form/Components/FormItem2/style.d.ts +1 -0
  68. package/lib/form/Components/FormItem2/style.js +3 -0
  69. package/lib/form/Components/LightFilter/index.scss +4 -0
  70. package/lib/form/Components/__builtins__/empty.d.ts +1 -0
  71. package/lib/form/Components/__builtins__/empty.js +59 -0
  72. package/lib/form/Components/__builtins__/hooks/index.d.ts +2 -0
  73. package/lib/form/Components/__builtins__/hooks/index.js +27 -0
  74. package/lib/form/Components/__builtins__/hooks/useClickAway.d.ts +5 -0
  75. package/lib/form/Components/__builtins__/hooks/useClickAway.js +44 -0
  76. package/lib/form/Components/__builtins__/hooks/usePrefixCls.d.ts +3 -0
  77. package/lib/form/Components/__builtins__/hooks/usePrefixCls.js +15 -0
  78. package/lib/form/Components/__builtins__/icons.d.ts +20 -0
  79. package/lib/form/Components/__builtins__/icons.js +174 -0
  80. package/lib/form/Components/__builtins__/index.d.ts +8 -0
  81. package/lib/form/Components/__builtins__/index.js +93 -0
  82. package/lib/form/Components/__builtins__/loading.d.ts +1 -0
  83. package/lib/form/Components/__builtins__/loading.js +48 -0
  84. package/lib/form/Components/__builtins__/mapSize.d.ts +1 -0
  85. package/lib/form/Components/__builtins__/mapSize.js +20 -0
  86. package/lib/form/Components/__builtins__/mapStatus.d.ts +2 -0
  87. package/lib/form/Components/__builtins__/mapStatus.js +27 -0
  88. package/lib/form/Components/__builtins__/moment.d.ts +2 -0
  89. package/lib/form/Components/__builtins__/moment.js +56 -0
  90. package/lib/form/Components/__builtins__/pickDataProps.d.ts +1 -0
  91. package/lib/form/Components/__builtins__/pickDataProps.js +16 -0
  92. package/lib/form/Components/form-layout/index.d.ts +74 -0
  93. package/lib/form/Components/form-layout/index.js +88 -0
  94. package/lib/form/Components/form-layout/main.scss +0 -0
  95. package/lib/form/Components/form-layout/style.d.ts +1 -0
  96. package/lib/form/Components/form-layout/style.js +3 -0
  97. package/lib/form/Components/form-layout/useResponsiveFormLayout.d.ts +18 -0
  98. package/lib/form/Components/form-layout/useResponsiveFormLayout.js +94 -0
  99. package/lib/form/Filter/AdvancedFilter.js +2 -2
  100. package/lib/form/Filter/index2.js +3 -3
  101. package/lib/form/ProForm/index.js +13 -11
  102. package/lib/info/utils/utils.d.ts +1 -1
  103. package/lib/sidebar/utils/index.d.ts +2 -2
  104. package/lib/table/index.d.ts +1 -1
  105. package/lib/table/index.js +16 -16
  106. package/lib/utils/aspect.js +5 -2
  107. package/lib/xconsole.scss +1 -0
  108. package/package.json +1 -1
@@ -0,0 +1,286 @@
1
+ var _excluded = ["children"];
2
+ function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
3
+ function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
4
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
5
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
6
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
7
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
8
+ function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
9
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
10
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
11
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
12
+ function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
13
+ import { Balloon } from '@alicloudfe/components';
14
+ import { isVoidField } from '@formily/core';
15
+ import { connect, mapProps } from '@formily/react';
16
+ import cls from 'classnames';
17
+ import React, { useEffect, useRef, useState } from 'react';
18
+ import { FormLayoutShallowContext, useFormLayout } from '../form-layout';
19
+ import { CheckCircleOutlinedIcon, CloseCircleOutlinedIcon, ExclamationCircleOutlinedIcon, pickDataProps, QuestionCircleOutlinedIcon, usePrefixCls } from '../__builtins__';
20
+ var useFormItemLayout = function useFormItemLayout(props) {
21
+ var _ref, _props$layout, _props$colon, _props$labelAlign, _ref2, _props$labelAlign2, _props$labelWrap, _props$labelWidth, _props$wrapperWidth, _props$labelCol, _props$wrapperCol, _props$wrapperAlign, _props$wrapperWrap, _props$fullness, _props$size, _props$inset, _props$bordered, _ref3, _props$feedbackLayout, _ref4, _props$tooltipLayout, _ref5, _props$tooltipIcon;
22
+ var layout = useFormLayout();
23
+ var layoutType = (_ref = (_props$layout = props.layout) !== null && _props$layout !== void 0 ? _props$layout : layout.layout) !== null && _ref !== void 0 ? _ref : 'horizontal';
24
+ return _objectSpread(_objectSpread({}, props), {}, {
25
+ layout: layoutType,
26
+ colon: (_props$colon = props.colon) !== null && _props$colon !== void 0 ? _props$colon : layout.colon,
27
+ labelAlign: layoutType === 'vertical' ? (_props$labelAlign = props.labelAlign) !== null && _props$labelAlign !== void 0 ? _props$labelAlign : 'left' : (_ref2 = (_props$labelAlign2 = props.labelAlign) !== null && _props$labelAlign2 !== void 0 ? _props$labelAlign2 : layout.labelAlign) !== null && _ref2 !== void 0 ? _ref2 : 'right',
28
+ labelWrap: (_props$labelWrap = props.labelWrap) !== null && _props$labelWrap !== void 0 ? _props$labelWrap : layout.labelWrap,
29
+ labelWidth: (_props$labelWidth = props.labelWidth) !== null && _props$labelWidth !== void 0 ? _props$labelWidth : layout.labelWidth,
30
+ wrapperWidth: (_props$wrapperWidth = props.wrapperWidth) !== null && _props$wrapperWidth !== void 0 ? _props$wrapperWidth : layout.wrapperWidth,
31
+ labelCol: (_props$labelCol = props.labelCol) !== null && _props$labelCol !== void 0 ? _props$labelCol : layout.labelCol,
32
+ wrapperCol: (_props$wrapperCol = props.wrapperCol) !== null && _props$wrapperCol !== void 0 ? _props$wrapperCol : layout.wrapperCol,
33
+ wrapperAlign: (_props$wrapperAlign = props.wrapperAlign) !== null && _props$wrapperAlign !== void 0 ? _props$wrapperAlign : layout.wrapperAlign,
34
+ wrapperWrap: (_props$wrapperWrap = props.wrapperWrap) !== null && _props$wrapperWrap !== void 0 ? _props$wrapperWrap : layout.wrapperWrap,
35
+ fullness: (_props$fullness = props.fullness) !== null && _props$fullness !== void 0 ? _props$fullness : layout.fullness,
36
+ size: (_props$size = props.size) !== null && _props$size !== void 0 ? _props$size : layout.size,
37
+ inset: (_props$inset = props.inset) !== null && _props$inset !== void 0 ? _props$inset : layout.inset,
38
+ asterisk: props.asterisk,
39
+ bordered: (_props$bordered = props.bordered) !== null && _props$bordered !== void 0 ? _props$bordered : layout.bordered,
40
+ feedbackIcon: props.feedbackIcon,
41
+ feedbackLayout: (_ref3 = (_props$feedbackLayout = props.feedbackLayout) !== null && _props$feedbackLayout !== void 0 ? _props$feedbackLayout : layout.feedbackLayout) !== null && _ref3 !== void 0 ? _ref3 : 'loose',
42
+ tooltipLayout: (_ref4 = (_props$tooltipLayout = props.tooltipLayout) !== null && _props$tooltipLayout !== void 0 ? _props$tooltipLayout : layout.tooltipLayout) !== null && _ref4 !== void 0 ? _ref4 : 'icon',
43
+ tooltipIcon: (_ref5 = (_props$tooltipIcon = props.tooltipIcon) !== null && _props$tooltipIcon !== void 0 ? _props$tooltipIcon : layout.tooltipIcon) !== null && _ref5 !== void 0 ? _ref5 : /*#__PURE__*/React.createElement(QuestionCircleOutlinedIcon, null)
44
+ });
45
+ };
46
+ function useOverflow() {
47
+ var _useState = useState(false),
48
+ _useState2 = _slicedToArray(_useState, 2),
49
+ overflow = _useState2[0],
50
+ setOverflow = _useState2[1];
51
+ var containerRef = useRef();
52
+ var contentRef = useRef();
53
+ var layout = useFormLayout();
54
+ var labelCol = JSON.stringify(layout.labelCol);
55
+ useEffect(function () {
56
+ requestAnimationFrame(function () {
57
+ if (containerRef.current && contentRef.current) {
58
+ var contentWidth = contentRef.current.getBoundingClientRect().width;
59
+ var containerWidth = containerRef.current.getBoundingClientRect().width;
60
+ if (contentWidth && containerWidth && containerWidth < contentWidth) {
61
+ if (!overflow) setOverflow(true);
62
+ } else {
63
+ if (overflow) setOverflow(false);
64
+ }
65
+ }
66
+ });
67
+ }, [labelCol]);
68
+ return {
69
+ overflow: overflow,
70
+ containerRef: containerRef,
71
+ contentRef: contentRef
72
+ };
73
+ }
74
+ var ICON_MAP = {
75
+ error: /*#__PURE__*/React.createElement(CloseCircleOutlinedIcon, null),
76
+ success: /*#__PURE__*/React.createElement(CheckCircleOutlinedIcon, null),
77
+ warning: /*#__PURE__*/React.createElement(ExclamationCircleOutlinedIcon, null)
78
+ };
79
+ export var BaseItem = function BaseItem(props) {
80
+ var _cls, _cls3, _cls4, _cls5, _cls6;
81
+ console.log('FormItem2');
82
+ var children = props.children,
83
+ others = _objectWithoutProperties(props, _excluded);
84
+ var _useState3 = useState(false),
85
+ _useState4 = _slicedToArray(_useState3, 2),
86
+ active = _useState4[0],
87
+ setActive = _useState4[1];
88
+ var formLayout = useFormItemLayout(others);
89
+ var _useOverflow = useOverflow(),
90
+ containerRef = _useOverflow.containerRef,
91
+ contentRef = _useOverflow.contentRef,
92
+ overflow = _useOverflow.overflow;
93
+ var label = formLayout.label,
94
+ style = formLayout.style,
95
+ layout = formLayout.layout,
96
+ _formLayout$colon = formLayout.colon,
97
+ colon = _formLayout$colon === void 0 ? true : _formLayout$colon,
98
+ addonBefore = formLayout.addonBefore,
99
+ addonAfter = formLayout.addonAfter,
100
+ asterisk = formLayout.asterisk,
101
+ feedbackStatus = formLayout.feedbackStatus,
102
+ extra = formLayout.extra,
103
+ feedbackText = formLayout.feedbackText,
104
+ fullness = formLayout.fullness,
105
+ feedbackLayout = formLayout.feedbackLayout,
106
+ feedbackIcon = formLayout.feedbackIcon,
107
+ inset = formLayout.inset,
108
+ _formLayout$bordered = formLayout.bordered,
109
+ bordered = _formLayout$bordered === void 0 ? true : _formLayout$bordered,
110
+ labelWidth = formLayout.labelWidth,
111
+ wrapperWidth = formLayout.wrapperWidth,
112
+ labelCol = formLayout.labelCol,
113
+ wrapperCol = formLayout.wrapperCol,
114
+ labelAlign = formLayout.labelAlign,
115
+ _formLayout$wrapperAl = formLayout.wrapperAlign,
116
+ wrapperAlign = _formLayout$wrapperAl === void 0 ? 'left' : _formLayout$wrapperAl,
117
+ size = formLayout.size,
118
+ labelWrap = formLayout.labelWrap,
119
+ wrapperWrap = formLayout.wrapperWrap,
120
+ tooltip = formLayout.tooltip,
121
+ tooltipLayout = formLayout.tooltipLayout,
122
+ tooltipIcon = formLayout.tooltipIcon;
123
+ var labelStyle = _objectSpread({}, formLayout.labelStyle);
124
+ var wrapperStyle = _objectSpread({}, formLayout.wrapperStyle);
125
+ // 固定宽度
126
+ var enableCol = false;
127
+ if (labelWidth || wrapperWidth) {
128
+ if (labelWidth) {
129
+ labelStyle.width = labelWidth === 'auto' ? undefined : labelWidth;
130
+ labelStyle.maxWidth = labelWidth === 'auto' ? undefined : labelWidth;
131
+ }
132
+ if (wrapperWidth) {
133
+ wrapperStyle.width = wrapperWidth === 'auto' ? undefined : wrapperWidth;
134
+ wrapperStyle.maxWidth = wrapperWidth === 'auto' ? undefined : wrapperWidth;
135
+ }
136
+ // 栅格模式
137
+ }
138
+
139
+ if (labelCol || wrapperCol) {
140
+ if (!labelStyle.width && !wrapperStyle.width && layout !== 'vertical') {
141
+ enableCol = true;
142
+ }
143
+ }
144
+ var prefixCls = usePrefixCls('formily-item', props);
145
+ var prefix = usePrefixCls();
146
+ console.log('feedbackLayout', feedbackLayout);
147
+ var formatChildren = feedbackLayout === 'popover' || feedbackLayout === 'hover-popover' ? /*#__PURE__*/React.createElement(Balloon, _objectSpread({
148
+ needAdjust: true,
149
+ align: "t",
150
+ closable: false,
151
+ trigger: children
152
+ }, feedbackLayout === 'popover' ? {
153
+ visible: !!feedbackText
154
+ } : {}), /*#__PURE__*/React.createElement("div", {
155
+ className: cls((_cls = {}, _defineProperty(_cls, "".concat(prefixCls, "-").concat(feedbackStatus, "-help"), !!feedbackStatus), _defineProperty(_cls, "".concat(prefixCls, "-help"), true), _cls))
156
+ }, ICON_MAP[feedbackStatus !== null && feedbackStatus !== void 0 ? feedbackStatus : ''], " ", feedbackText)) : children;
157
+ var gridStyles = {};
158
+ var getOverflowTooltip = function getOverflowTooltip() {
159
+ if (overflow) {
160
+ return /*#__PURE__*/React.createElement("div", null, /*#__PURE__*/React.createElement("div", null, label), /*#__PURE__*/React.createElement("div", null, tooltip));
161
+ }
162
+ return tooltip;
163
+ };
164
+ var renderLabelText = function renderLabelText() {
165
+ var labelChildren = /*#__PURE__*/React.createElement("div", {
166
+ className: cls("".concat(prefixCls, "-label-content")),
167
+ ref: containerRef
168
+ }, /*#__PURE__*/React.createElement("span", {
169
+ ref: contentRef
170
+ }, asterisk && /*#__PURE__*/React.createElement("span", {
171
+ className: cls("".concat(prefixCls, "-asterisk"))
172
+ }, '*'), /*#__PURE__*/React.createElement("label", null, label)));
173
+ if (tooltipLayout === 'text' && tooltip || overflow) {
174
+ return /*#__PURE__*/React.createElement(Balloon.Tooltip, {
175
+ align: "t",
176
+ trigger: labelChildren
177
+ }, getOverflowTooltip());
178
+ }
179
+ return labelChildren;
180
+ };
181
+ var renderTooltipIcon = function renderTooltipIcon() {
182
+ if (tooltip && tooltipLayout === 'icon' && !overflow) {
183
+ return /*#__PURE__*/React.createElement("span", {
184
+ className: cls("".concat(prefixCls, "-label-tooltip-icon"))
185
+ }, /*#__PURE__*/React.createElement(Balloon.Tooltip, {
186
+ align: "t",
187
+ trigger: tooltipIcon
188
+ }, tooltip));
189
+ }
190
+ };
191
+ var renderLabel = function renderLabel() {
192
+ var _cls2;
193
+ if (!label) return null;
194
+ return /*#__PURE__*/React.createElement("div", {
195
+ className: cls((_cls2 = {}, _defineProperty(_cls2, "".concat(prefixCls, "-label"), true), _defineProperty(_cls2, "".concat(prefixCls, "-label-tooltip"), tooltip && tooltipLayout === 'text' || overflow), _defineProperty(_cls2, "".concat(prefixCls, "-item-col-").concat(labelCol), enableCol && !!labelCol), _cls2)),
196
+ style: labelStyle
197
+ }, renderLabelText(), renderTooltipIcon(), asterisk && /*#__PURE__*/React.createElement("span", {
198
+ className: cls("".concat(prefixCls, "-asterisk-pro"))
199
+ }), label !== ' ' && /*#__PURE__*/React.createElement("span", {
200
+ className: cls("".concat(prefixCls, "-colon"))
201
+ }, colon ? ':' : ''));
202
+ };
203
+ return /*#__PURE__*/React.createElement("div", _objectSpread(_objectSpread({}, pickDataProps(props)), {}, {
204
+ style: _objectSpread(_objectSpread({}, style), gridStyles),
205
+ "data-grid-span": props.gridSpan,
206
+ className: cls((_cls3 = {}, _defineProperty(_cls3, "".concat(prefixCls), true), _defineProperty(_cls3, "".concat(prefixCls, "-layout-").concat(layout), true), _defineProperty(_cls3, "".concat(prefixCls, "-").concat(feedbackStatus), !!feedbackStatus), _defineProperty(_cls3, "".concat(prefixCls, "-feedback-has-text"), !!feedbackText), _defineProperty(_cls3, "".concat(prefixCls, "-size-").concat(size), !!size), _defineProperty(_cls3, "".concat(prefixCls, "-feedback-layout-").concat(feedbackLayout), !!feedbackLayout), _defineProperty(_cls3, "".concat(prefixCls, "-fullness"), !!fullness || !!inset || !!feedbackIcon), _defineProperty(_cls3, "".concat(prefixCls, "-inset"), !!inset), _defineProperty(_cls3, "".concat(prefix, "input"), !!inset), _defineProperty(_cls3, "".concat(prefixCls, "-active"), active), _defineProperty(_cls3, "".concat(prefix, "focus"), active), _defineProperty(_cls3, "".concat(prefixCls, "-extra-wrap"), extra), _defineProperty(_cls3, "".concat(prefixCls, "-inset-active"), !!inset && active), _defineProperty(_cls3, "".concat(prefixCls, "-label-align-").concat(labelAlign), true), _defineProperty(_cls3, "".concat(prefixCls, "-control-align-").concat(wrapperAlign), true), _defineProperty(_cls3, "".concat(prefixCls, "-label-wrap"), !!labelWrap), _defineProperty(_cls3, "".concat(prefixCls, "-control-wrap"), !!wrapperWrap), _defineProperty(_cls3, "".concat(prefixCls, "-bordered-none"), bordered === false), _defineProperty(_cls3, props === null || props === void 0 ? void 0 : props.className, !!props.className), _cls3)),
207
+ onFocus: function onFocus() {
208
+ if (feedbackIcon || inset) {
209
+ setActive(true);
210
+ }
211
+ },
212
+ onBlur: function onBlur() {
213
+ if (feedbackIcon || inset) {
214
+ setActive(false);
215
+ }
216
+ }
217
+ }), renderLabel(), /*#__PURE__*/React.createElement("div", {
218
+ className: cls((_cls4 = {}, _defineProperty(_cls4, "".concat(prefixCls, "-control"), true), _defineProperty(_cls4, "".concat(prefixCls, "-item-col-").concat(wrapperCol), enableCol && !!wrapperCol && label), _cls4))
219
+ }, /*#__PURE__*/React.createElement("div", {
220
+ className: cls("".concat(prefixCls, "-control-content"))
221
+ }, addonBefore && /*#__PURE__*/React.createElement("div", {
222
+ className: cls("".concat(prefixCls, "-addon-before"))
223
+ }, addonBefore), /*#__PURE__*/React.createElement("div", {
224
+ style: wrapperStyle,
225
+ className: cls((_cls5 = {}, _defineProperty(_cls5, "".concat(prefixCls, "-control-content-component"), true), _defineProperty(_cls5, "".concat(prefixCls, "-control-content-component-has-feedback-icon"), !!feedbackIcon), _defineProperty(_cls5, "".concat(prefix, "input"), !!feedbackIcon), _defineProperty(_cls5, "".concat(prefixCls, "-active"), active), _defineProperty(_cls5, "".concat(prefix, "focus"), active), _cls5))
226
+ }, /*#__PURE__*/React.createElement(FormLayoutShallowContext.Provider, {
227
+ value: {
228
+ size: size
229
+ }
230
+ }, formatChildren), feedbackIcon && /*#__PURE__*/React.createElement("div", {
231
+ className: cls("".concat(prefixCls, "-feedback-icon"))
232
+ }, feedbackIcon)), addonAfter && /*#__PURE__*/React.createElement("div", {
233
+ className: cls("".concat(prefixCls, "-addon-after"))
234
+ }, addonAfter)), !!feedbackText && feedbackLayout !== 'popover' && feedbackLayout !== 'hover-popover' && feedbackLayout !== 'none' && /*#__PURE__*/React.createElement("div", {
235
+ className: cls((_cls6 = {}, _defineProperty(_cls6, "".concat(prefixCls, "-").concat(feedbackStatus, "-help"), !!feedbackStatus), _defineProperty(_cls6, "".concat(prefixCls, "-help"), true), _defineProperty(_cls6, "".concat(prefixCls, "-help-enter"), true), _defineProperty(_cls6, "".concat(prefixCls, "-help-enter-active"), true), _cls6))
236
+ }, feedbackText), extra && /*#__PURE__*/React.createElement("div", {
237
+ className: cls("".concat(prefixCls, "-extra"))
238
+ }, extra)));
239
+ };
240
+ // 适配
241
+ export var FormItem2 = connect(BaseItem, mapProps(function (props, field) {
242
+ if (isVoidField(field)) return {
243
+ label: field.title || props.label,
244
+ asterisk: props.asterisk,
245
+ extra: props.extra || field.description
246
+ };
247
+ if (!field) return props;
248
+ var takeFeedbackStatus = function takeFeedbackStatus() {
249
+ if (field.validating) return 'pending';
250
+ return field.decoratorProps.feedbackStatus || field.validateStatus;
251
+ };
252
+ var takeMessage = function takeMessage() {
253
+ var split = function split(messages) {
254
+ return messages.reduce(function (buf, text, index) {
255
+ if (!text) return buf;
256
+ return index < messages.length - 1 ? buf.concat([text, ', ']) : buf.concat([text]);
257
+ }, []);
258
+ };
259
+ if (field.validating) return;
260
+ if (props.feedbackText) return props.feedbackText;
261
+ if (field.selfErrors.length) return split(field.selfErrors);
262
+ if (field.selfWarnings.length) return split(field.selfWarnings);
263
+ if (field.selfSuccesses.length) return split(field.selfSuccesses);
264
+ };
265
+ var takeAsterisk = function takeAsterisk() {
266
+ if (field.required && field.pattern !== 'readPretty') {
267
+ return true;
268
+ }
269
+ if ('asterisk' in props) {
270
+ return props.asterisk;
271
+ }
272
+ return false;
273
+ };
274
+ return {
275
+ label: props.label || field.title,
276
+ feedbackStatus: takeFeedbackStatus(),
277
+ feedbackText: takeMessage(),
278
+ asterisk: takeAsterisk(),
279
+ extra: props.extra || field.description
280
+ };
281
+ }));
282
+ FormItem2.defaultProps = {
283
+ fullness: true
284
+ };
285
+ FormItem2.BaseItem = BaseItem;
286
+ export default FormItem2;
@@ -0,0 +1,413 @@
1
+ @import '../global.scss';
2
+ @import './scss/variable.scss';
3
+ @import './grid.scss';
4
+ @import './animation.scss';
5
+
6
+ .#{$form-item-cls} {
7
+ display: flex;
8
+ margin-bottom: $form-item-m-margin-b + 2;
9
+ position: relative;
10
+ line-height: $form-element-medium-height;
11
+ font-size: $form-element-medium-font-size;
12
+
13
+ &-layout-vertical {
14
+ display: block;
15
+ }
16
+
17
+ &-label-content {
18
+ min-height: $form-element-medium-height;
19
+ }
20
+
21
+ &-control-content-component {
22
+ line-height: $form-element-medium-height;
23
+ }
24
+
25
+ &-inset {
26
+ padding: 0 8px;
27
+ border: 1px solid $input-border-color;
28
+ border-radius: $form-element-medium-corner;
29
+ width: 100%;
30
+
31
+ .#{$css-prefix}input {
32
+ border: none !important;
33
+ box-shadow: none !important;
34
+ outline: none;
35
+ }
36
+ }
37
+
38
+ &-bordered-none:not(.#{$form-item-cls}-inset) {
39
+ .#{$css-prefix}input {
40
+ border: none !important;
41
+ box-shadow: none !important;
42
+ outline: none;
43
+ }
44
+ }
45
+ }
46
+
47
+ .#{$form-item-cls}-label {
48
+ position: relative;
49
+ display: flex;
50
+ &-content {
51
+ overflow: hidden;
52
+ text-overflow: ellipsis;
53
+ white-space: nowrap;
54
+ }
55
+
56
+ &-tooltip {
57
+ cursor: help;
58
+
59
+ .#{$form-item-cls}-colon {
60
+ display: flex;
61
+ }
62
+
63
+ * {
64
+ cursor: help;
65
+ }
66
+
67
+ &-colon {
68
+ cursor: help;
69
+ }
70
+
71
+ label {
72
+ border-bottom: 1px dashed currentColor;
73
+ }
74
+ }
75
+ }
76
+
77
+ .#{$form-item-cls}-label label {
78
+ cursor: text;
79
+ color: rgba(0, 0, 0, 0.85);
80
+ }
81
+
82
+ .#{$form-item-cls}-label-align-left {
83
+ > .#{$form-item-cls}-label {
84
+ justify-content: flex-start;
85
+ }
86
+ }
87
+
88
+ .#{$form-item-cls}-label-align-right {
89
+ > .#{$form-item-cls}-label {
90
+ justify-content: flex-end;
91
+ }
92
+ }
93
+
94
+ .#{$form-item-cls}-label-wrap {
95
+ .#{$form-item-cls}-label {
96
+ label {
97
+ white-space: pre-line;
98
+ word-break: break-all;
99
+ }
100
+ }
101
+ }
102
+
103
+ .#{$form-item-cls}-feedback-layout-terse {
104
+ margin-bottom: 8px;
105
+
106
+ &.#{$form-item-cls}-feedback-has-text:not(.#{$form-item-cls}-inset) {
107
+ margin-bottom: 0;
108
+ }
109
+ }
110
+
111
+ .#{$form-item-cls}-feedback-layout-loose {
112
+ margin-bottom: $form-item-m-margin-b + 4;
113
+
114
+ &.#{$form-item-cls}-feedback-has-text:not(.#{$form-item-cls}-inset) {
115
+ margin-bottom: 0;
116
+ }
117
+ }
118
+
119
+ .#{$form-item-cls}-feedback-layout-none {
120
+ margin-bottom: 0px;
121
+
122
+ &.#{$form-item-cls}-feedback-has-text:not(.#{$form-item-cls}-inset) {
123
+ margin-bottom: 0;
124
+ }
125
+ }
126
+
127
+ .#{$form-item-cls}-control {
128
+ flex: 1;
129
+ max-width: 100%;
130
+
131
+ .#{$form-item-cls}-control-content {
132
+ display: flex;
133
+
134
+ .#{$form-item-cls}-control-content-component {
135
+ width: 100%;
136
+ min-height: $form-element-medium-height;
137
+ line-height: $form-element-medium-height;
138
+
139
+ &-has-feedback-icon {
140
+ flex: 1;
141
+ position: relative;
142
+ display: flex;
143
+ align-items: center;
144
+
145
+ .#{$css-prefix}input {
146
+ height: 100%;
147
+ border: none !important;
148
+ box-shadow: none !important;
149
+ outline: none;
150
+
151
+ .#{$css-prefix}input-control {
152
+ margin-right: 0;
153
+ padding-right: 0;
154
+
155
+ .#{$css-prefix}icon {
156
+ display: none;
157
+ }
158
+
159
+ .#{$css-prefix}input-hint-wrap {
160
+ .#{$css-prefix}icon {
161
+ display: block;
162
+ }
163
+ }
164
+ }
165
+ }
166
+ }
167
+
168
+ .#{$css-prefix}range {
169
+ height: 100%;
170
+ padding-left: 2px;
171
+ }
172
+
173
+ .#{$css-prefix}transfer {
174
+ display: flex;
175
+ align-items: center;
176
+ }
177
+ }
178
+
179
+ .#{$form-item-cls}-addon-before {
180
+ margin-right: 8px;
181
+ display: inline-flex;
182
+ align-items: center;
183
+ min-height: $form-element-medium-height;
184
+ flex-shrink: 0;
185
+ }
186
+
187
+ .#{$form-item-cls}-addon-after {
188
+ margin-left: 8px;
189
+ display: inline-flex;
190
+ align-items: center;
191
+ min-height: $form-element-medium-height;
192
+ flex-shrink: 0;
193
+ }
194
+ }
195
+ }
196
+
197
+ .#{$form-item-cls}-size-small {
198
+ font-size: $form-element-small-font-size;
199
+ line-height: $form-element-small-height;
200
+
201
+ .#{$form-item-cls}-label-content {
202
+ min-height: $form-element-small-height;
203
+ }
204
+
205
+ .#{$form-item-cls}-control-content {
206
+ .#{$form-item-cls}-control-content-component {
207
+ line-height: $form-element-small-height;
208
+ min-height: $form-element-small-height;
209
+ }
210
+
211
+ .#{$form-item-cls}-addon-before {
212
+ min-height: $form-element-small-height;
213
+ }
214
+
215
+ .#{$form-item-cls}-addon-after {
216
+ min-height: $form-element-small-height;
217
+ }
218
+ }
219
+
220
+ &-inset {
221
+ border-radius: $form-element-small-corner;
222
+ }
223
+
224
+ &.#{$form-item-cls}-feedback-layout-terse {
225
+ margin-bottom: 8px;
226
+
227
+ &.#{$form-item-cls}-feedback-has-text:not(.#{$form-item-cls}-inset) {
228
+ margin-bottom: 0;
229
+ }
230
+ }
231
+
232
+ &.#{$form-item-cls}-feedback-layout-loose {
233
+ margin-bottom: $form-item-s-margin-b + 8;
234
+
235
+ &.#{$form-item-cls}-feedback-has-text:not(.#{$form-item-cls}-inset) {
236
+ margin-bottom: 0;
237
+ }
238
+ }
239
+
240
+ .#{$form-item-cls}-help,
241
+ .#{$form-item-cls}-extra {
242
+ min-height: $form-element-small-font-size + 2;
243
+ }
244
+
245
+ .#{$form-item-cls}-control-content {
246
+ min-height: $form-element-small-height;
247
+ }
248
+
249
+ .#{$form-item-cls}-label > label {
250
+ height: $form-element-small-height;
251
+ }
252
+ }
253
+
254
+ .#{$form-item-cls}-size-large {
255
+ font-size: $form-element-large-font-size;
256
+ line-height: $form-element-large-height;
257
+
258
+ .#{$form-item-cls}-label-content {
259
+ min-height: $form-element-large-height;
260
+ }
261
+
262
+ .#{$form-item-cls}-control-content {
263
+ .#{$form-item-cls}-control-content-component {
264
+ line-height: $form-element-large-height;
265
+ min-height: $form-element-large-height;
266
+ }
267
+
268
+ .#{$form-item-cls}-addon-before {
269
+ min-height: $form-element-large-height;
270
+ }
271
+
272
+ .#{$form-item-cls}-addon-after {
273
+ min-height: $form-element-large-height;
274
+ }
275
+ }
276
+
277
+ &-inset {
278
+ border-radius: $form-element-large-corner;
279
+ }
280
+
281
+ .#{$form-item-cls}-help,
282
+ .#{$form-item-cls}-extra {
283
+ min-height: $form-element-large-font-size + 2;
284
+ }
285
+
286
+ &.#{$form-item-cls}-feedback-layout-loose {
287
+ margin-bottom: $form-item-l-margin-b;
288
+
289
+ &.#{$form-item-cls}-feedback-has-text:not(.#{$form-item-cls}-inset) {
290
+ margin-bottom: 0;
291
+ }
292
+ }
293
+
294
+ .#{$form-item-cls}-control-content {
295
+ min-height: $form-element-large-height;
296
+ }
297
+
298
+ .#{$form-item-cls}-label > label {
299
+ height: $form-element-large-height;
300
+ }
301
+ }
302
+
303
+ .#{$form-item-cls}-feedback-layout-popover {
304
+ margin-bottom: 8px;
305
+ }
306
+
307
+ .#{$form-item-cls}-label-tooltip-icon {
308
+ margin-left: 4px;
309
+ color: #00000073;
310
+ cursor: pointer;
311
+ max-height: $form-element-medium-height;
312
+ }
313
+
314
+ .#{$form-item-cls}-control-align-left {
315
+ .#{$form-item-cls}-control-content {
316
+ justify-content: flex-start;
317
+ }
318
+ }
319
+
320
+ .#{$form-item-cls}-control-align-right {
321
+ .#{$form-item-cls}-control-content {
322
+ justify-content: flex-end;
323
+ }
324
+ }
325
+
326
+ .#{$form-item-cls}-control-wrap {
327
+ .#{$form-item-cls}-control {
328
+ white-space: pre-line;
329
+ }
330
+ }
331
+
332
+ .#{$form-item-cls}-asterisk {
333
+ color: $form-error-color;
334
+ margin-right: 4px;
335
+ display: inline-block;
336
+ font-family: SimSun, sans-serif;
337
+ }
338
+
339
+ .#{$form-item-cls}-colon {
340
+ margin-left: 2px;
341
+ margin-right: 8px;
342
+ }
343
+
344
+ .#{$form-item-cls}-help,
345
+ .#{$form-item-cls}-extra {
346
+ clear: both;
347
+ line-height: $form-item-m-margin-b + 4;
348
+ min-height: $form-item-m-margin-b;
349
+ color: rgba(0, 0, 0, 0.45);
350
+ transition: color 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
351
+ padding-top: 0px;
352
+ }
353
+
354
+ .#{$form-item-cls}-fullness {
355
+ > .#{$form-item-cls}-control {
356
+ > .#{$form-item-cls}-control-content {
357
+ > .#{$form-item-cls}-control-content-component {
358
+ > *:first-child:not(.#{$css-prefix}switch):not(.#{$css-prefix}icon):not(.#{$css-prefix}formily-icon):not(.anticon) {
359
+ width: 100%;
360
+ }
361
+ }
362
+ }
363
+ }
364
+ }
365
+
366
+ .#{$form-item-cls}-control-content-component-has-feedback-icon {
367
+ border-radius: 2px;
368
+ border: 1px solid $input-border-color;
369
+ transition: all 0.3s;
370
+ touch-action: manipulation;
371
+ outline: none;
372
+ padding-right: 8px;
373
+
374
+ .#{$css-prefix}input {
375
+ border: none !important;
376
+ }
377
+
378
+ .#{$css-prefix}range-picker-trigger {
379
+ border: none !important;
380
+ }
381
+
382
+ .#{$form-item-cls}-feedback-icon {
383
+ display: flex;
384
+ justify-content: center;
385
+ align-items: center;
386
+ margin-right: -2px;
387
+ padding-left: 2px;
388
+
389
+ .anticon {
390
+ display: inline-block;
391
+ color: inherit;
392
+ font-style: normal;
393
+ font-size: $form-element-medium-font-size;
394
+ line-height: 0;
395
+ text-align: center;
396
+ text-transform: none;
397
+ vertical-align: -0.125em;
398
+ text-rendering: optimizeLegibility;
399
+ }
400
+ }
401
+ }
402
+
403
+ .#{$form-item-cls}-error-help {
404
+ color: $form-error-color;
405
+ }
406
+
407
+ .#{$form-item-cls}-warning-help {
408
+ color: $form-warning-color;
409
+ }
410
+
411
+ .#{$form-item-cls}-success-help {
412
+ color: $form-success-color;
413
+ }