tntd 2.8.45 → 2.8.46

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 (185) hide show
  1. package/es/alert/alert.js +153 -0
  2. package/es/alert/alert.js.map +1 -0
  3. package/es/alert/alert.less +128 -0
  4. package/es/cascader/cascader.js +84 -0
  5. package/es/cascader/cascader.js.map +1 -0
  6. package/es/cascader/cascader.less +16 -0
  7. package/es/checkbox/check.png +0 -0
  8. package/es/checkbox/checkbox.js +100 -0
  9. package/es/checkbox/checkbox.js.map +1 -0
  10. package/es/checkbox/checkbox.less +69 -0
  11. package/es/date-picker/DatePicker.js +163 -0
  12. package/es/date-picker/DatePicker.js.map +1 -0
  13. package/es/date-picker/index.less +294 -0
  14. package/es/input-number/inputNumber.js +89 -0
  15. package/es/input-number/inputNumber.js.map +1 -0
  16. package/es/input-number/inputNumber.less +12 -0
  17. package/es/modal/index.less +36 -0
  18. package/es/modal/modal.js +5 -3
  19. package/es/modal/modal.js.map +1 -1
  20. package/es/modal/modal.less +16 -0
  21. package/es/popconfirm/index.less +32 -0
  22. package/es/popconfirm/popconfirm.js +96 -0
  23. package/es/popconfirm/popconfirm.js.map +1 -0
  24. package/es/popover/index.less +57 -0
  25. package/es/popover/popover.js +90 -0
  26. package/es/popover/popover.js.map +1 -0
  27. package/es/progress/progress.js +185 -0
  28. package/es/progress/progress.js.map +1 -0
  29. package/es/progress/progress.less +82 -0
  30. package/es/query-form/Field/Composition/FieldPopover.js +466 -0
  31. package/es/query-form/Field/Composition/FieldPopover.js.map +1 -0
  32. package/es/query-form/Field/Composition/FieldPopover.less +41 -0
  33. package/es/query-form/Field/Composition/Select.js +260 -0
  34. package/es/query-form/Field/Composition/Select.js.map +1 -0
  35. package/es/query-form/Field/Composition/SelectInput.js +112 -0
  36. package/es/query-form/Field/Composition/SelectInput.js.map +1 -0
  37. package/es/query-form/Field/Composition/ValueTag.js +241 -0
  38. package/es/query-form/Field/Composition/ValueTag.js.map +1 -0
  39. package/es/query-form/Field/Composition/index.js +448 -0
  40. package/es/query-form/Field/Composition/index.js.map +1 -0
  41. package/es/query-form/Field/Composition/index.less +167 -0
  42. package/es/query-form/Field/Composition/utils.js +173 -0
  43. package/es/query-form/Field/Composition/utils.js.map +1 -0
  44. package/es/query-form-backup/Field/Composition/FieldPopover.less +35 -0
  45. package/es/query-form-backup/Field/Composition/index.less +114 -0
  46. package/es/query-form-backup/index.less +90 -0
  47. package/es/query-form-v2/index.less +133 -0
  48. package/es/radio/radio.js +110 -0
  49. package/es/radio/radio.js.map +1 -0
  50. package/es/radio/radio.less +43 -0
  51. package/es/spin/spin.js +79 -0
  52. package/es/spin/spin.js.map +1 -0
  53. package/es/spin/spin.less +9 -0
  54. package/es/steps/assets/background_left.svg +12 -0
  55. package/es/steps/assets/background_right.svg +12 -0
  56. package/es/steps/assets/horizontal_line.svg +3 -0
  57. package/es/steps/assets/vertical_line.svg +3 -0
  58. package/es/steps/stepStyle/icon.less +51 -0
  59. package/es/steps/stepStyle/progress-dot.less +10 -0
  60. package/es/steps/stepStyle/variables.less +8 -0
  61. package/es/steps/stepStyle/vertical.less +41 -0
  62. package/es/switch/index.less +45 -0
  63. package/es/tabs/tabs.less +125 -0
  64. package/es/time-picker/TimePicker.js +90 -0
  65. package/es/time-picker/TimePicker.js.map +1 -0
  66. package/es/time-picker/index.less +38 -0
  67. package/es/tntd-action/Action.js +219 -0
  68. package/es/tntd-action/Action.js.map +1 -0
  69. package/es/tntd-action/index.less +61 -0
  70. package/es/tntd-select/index.less +7 -0
  71. package/lib/alert/alert.d.ts +12 -0
  72. package/lib/alert/alert.d.ts.map +1 -0
  73. package/lib/alert/alert.js +153 -0
  74. package/lib/alert/alert.js.map +1 -0
  75. package/lib/alert/alert.less +128 -0
  76. package/lib/cascader/cascader.d.ts +10 -0
  77. package/lib/cascader/cascader.d.ts.map +1 -0
  78. package/lib/cascader/cascader.js +84 -0
  79. package/lib/cascader/cascader.js.map +1 -0
  80. package/lib/cascader/cascader.less +16 -0
  81. package/lib/checkbox/check.png +0 -0
  82. package/lib/checkbox/checkbox.d.ts +16 -0
  83. package/lib/checkbox/checkbox.d.ts.map +1 -0
  84. package/lib/checkbox/checkbox.js +100 -0
  85. package/lib/checkbox/checkbox.js.map +1 -0
  86. package/lib/checkbox/checkbox.less +69 -0
  87. package/lib/date-picker/DatePicker.d.ts +21 -0
  88. package/lib/date-picker/DatePicker.d.ts.map +1 -0
  89. package/lib/date-picker/DatePicker.js +163 -0
  90. package/lib/date-picker/DatePicker.js.map +1 -0
  91. package/lib/date-picker/index.less +294 -0
  92. package/lib/input-number/inputNumber.d.ts +10 -0
  93. package/lib/input-number/inputNumber.d.ts.map +1 -0
  94. package/lib/input-number/inputNumber.js +89 -0
  95. package/lib/input-number/inputNumber.js.map +1 -0
  96. package/lib/input-number/inputNumber.less +12 -0
  97. package/lib/modal/index.less +36 -0
  98. package/lib/modal/modal.d.ts +1 -0
  99. package/lib/modal/modal.d.ts.map +1 -1
  100. package/lib/modal/modal.js +5 -3
  101. package/lib/modal/modal.js.map +1 -1
  102. package/lib/modal/modal.less +16 -0
  103. package/lib/popconfirm/index.less +32 -0
  104. package/lib/popconfirm/popconfirm.d.ts +8 -0
  105. package/lib/popconfirm/popconfirm.d.ts.map +1 -0
  106. package/lib/popconfirm/popconfirm.js +96 -0
  107. package/lib/popconfirm/popconfirm.js.map +1 -0
  108. package/lib/popover/index.less +57 -0
  109. package/lib/popover/popover.d.ts +14 -0
  110. package/lib/popover/popover.d.ts.map +1 -0
  111. package/lib/popover/popover.js +90 -0
  112. package/lib/popover/popover.js.map +1 -0
  113. package/lib/progress/progress.d.ts +12 -0
  114. package/lib/progress/progress.d.ts.map +1 -0
  115. package/lib/progress/progress.js +185 -0
  116. package/lib/progress/progress.js.map +1 -0
  117. package/lib/progress/progress.less +82 -0
  118. package/lib/query-form/Field/Composition/FieldPopover.d.ts +19 -0
  119. package/lib/query-form/Field/Composition/FieldPopover.d.ts.map +1 -0
  120. package/lib/query-form/Field/Composition/FieldPopover.js +466 -0
  121. package/lib/query-form/Field/Composition/FieldPopover.js.map +1 -0
  122. package/lib/query-form/Field/Composition/FieldPopover.less +41 -0
  123. package/lib/query-form/Field/Composition/Select.d.ts +4 -0
  124. package/lib/query-form/Field/Composition/Select.d.ts.map +1 -0
  125. package/lib/query-form/Field/Composition/Select.js +260 -0
  126. package/lib/query-form/Field/Composition/Select.js.map +1 -0
  127. package/lib/query-form/Field/Composition/SelectInput.d.ts +3 -0
  128. package/lib/query-form/Field/Composition/SelectInput.d.ts.map +1 -0
  129. package/lib/query-form/Field/Composition/SelectInput.js +112 -0
  130. package/lib/query-form/Field/Composition/SelectInput.js.map +1 -0
  131. package/lib/query-form/Field/Composition/ValueTag.d.ts +13 -0
  132. package/lib/query-form/Field/Composition/ValueTag.d.ts.map +1 -0
  133. package/lib/query-form/Field/Composition/ValueTag.js +241 -0
  134. package/lib/query-form/Field/Composition/ValueTag.js.map +1 -0
  135. package/lib/query-form/Field/Composition/index.d.ts +15 -0
  136. package/lib/query-form/Field/Composition/index.d.ts.map +1 -0
  137. package/lib/query-form/Field/Composition/index.js +448 -0
  138. package/lib/query-form/Field/Composition/index.js.map +1 -0
  139. package/lib/query-form/Field/Composition/index.less +167 -0
  140. package/lib/query-form/Field/Composition/utils.d.ts +21 -0
  141. package/lib/query-form/Field/Composition/utils.d.ts.map +1 -0
  142. package/lib/query-form/Field/Composition/utils.js +173 -0
  143. package/lib/query-form/Field/Composition/utils.js.map +1 -0
  144. package/lib/query-form-backup/Field/Composition/FieldPopover.less +35 -0
  145. package/lib/query-form-backup/Field/Composition/index.less +114 -0
  146. package/lib/query-form-backup/index.less +90 -0
  147. package/lib/query-form-v2/index.less +133 -0
  148. package/lib/radio/radio.d.ts +17 -0
  149. package/lib/radio/radio.d.ts.map +1 -0
  150. package/lib/radio/radio.js +110 -0
  151. package/lib/radio/radio.js.map +1 -0
  152. package/lib/radio/radio.less +43 -0
  153. package/lib/spin/spin.d.ts +9 -0
  154. package/lib/spin/spin.d.ts.map +1 -0
  155. package/lib/spin/spin.js +79 -0
  156. package/lib/spin/spin.js.map +1 -0
  157. package/lib/spin/spin.less +9 -0
  158. package/lib/steps/assets/background_left.svg +12 -0
  159. package/lib/steps/assets/background_right.svg +12 -0
  160. package/lib/steps/assets/horizontal_line.svg +3 -0
  161. package/lib/steps/assets/vertical_line.svg +3 -0
  162. package/lib/steps/stepStyle/icon.less +51 -0
  163. package/lib/steps/stepStyle/progress-dot.less +10 -0
  164. package/lib/steps/stepStyle/variables.less +8 -0
  165. package/lib/steps/stepStyle/vertical.less +41 -0
  166. package/lib/switch/index.less +45 -0
  167. package/lib/tabs/tabs.less +125 -0
  168. package/lib/time-picker/TimePicker.d.ts +9 -0
  169. package/lib/time-picker/TimePicker.d.ts.map +1 -0
  170. package/lib/time-picker/TimePicker.js +90 -0
  171. package/lib/time-picker/TimePicker.js.map +1 -0
  172. package/lib/time-picker/index.less +38 -0
  173. package/lib/tntd-action/Action.d.ts +6 -0
  174. package/lib/tntd-action/Action.d.ts.map +1 -0
  175. package/lib/tntd-action/Action.js +219 -0
  176. package/lib/tntd-action/Action.js.map +1 -0
  177. package/lib/tntd-action/index.less +61 -0
  178. package/lib/tntd-select/index.less +7 -0
  179. package/package.json +2 -2
  180. package/es/array-input/utils.js +0 -414
  181. package/es/array-input/utils.js.map +0 -1
  182. package/lib/array-input/utils.d.ts +0 -2
  183. package/lib/array-input/utils.d.ts.map +0 -1
  184. package/lib/array-input/utils.js +0 -414
  185. package/lib/array-input/utils.js.map +0 -1
@@ -0,0 +1,448 @@
1
+ "use strict";
2
+
3
+ function _typeof(o) {
4
+ "@babel/helpers - typeof";
5
+
6
+ return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) {
7
+ return typeof o;
8
+ } : function (o) {
9
+ return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o;
10
+ }, _typeof(o);
11
+ }
12
+ Object.defineProperty(exports, "__esModule", {
13
+ value: true
14
+ });
15
+ exports["default"] = void 0;
16
+ var _isObject2 = _interopRequireDefault(require("lodash/isObject"));
17
+ var _find2 = _interopRequireDefault(require("lodash/find"));
18
+ var _react = _interopRequireWildcard(require("react"));
19
+ var _LocaleReceiver = _interopRequireDefault(require("antd/es/locale-provider/LocaleReceiver"));
20
+ var _icon = _interopRequireDefault(require("../../../icon"));
21
+ var _input = _interopRequireDefault(require("../../../input"));
22
+ var _FieldPopover = _interopRequireDefault(require("./FieldPopover"));
23
+ var _ValueTag = _interopRequireDefault(require("./ValueTag"));
24
+ var _utils = require("./utils");
25
+ require("./index.less");
26
+ function _getRequireWildcardCache(e) {
27
+ if ("function" != typeof WeakMap) return null;
28
+ var r = new WeakMap(),
29
+ t = new WeakMap();
30
+ return (_getRequireWildcardCache = function _getRequireWildcardCache(e) {
31
+ return e ? t : r;
32
+ })(e);
33
+ }
34
+ function _interopRequireWildcard(e, r) {
35
+ if (!r && e && e.__esModule) return e;
36
+ if (null === e || "object" != _typeof(e) && "function" != typeof e) return {
37
+ "default": e
38
+ };
39
+ var t = _getRequireWildcardCache(r);
40
+ if (t && t.has(e)) return t.get(e);
41
+ var n = {
42
+ __proto__: null
43
+ },
44
+ a = Object.defineProperty && Object.getOwnPropertyDescriptor;
45
+ for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) {
46
+ var i = a ? Object.getOwnPropertyDescriptor(e, u) : null;
47
+ i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u];
48
+ }
49
+ return n["default"] = e, t && t.set(e, n), n;
50
+ }
51
+ function _interopRequireDefault(obj) {
52
+ return obj && obj.__esModule ? obj : {
53
+ "default": obj
54
+ };
55
+ }
56
+ function _toConsumableArray(arr) {
57
+ return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread();
58
+ }
59
+ function _nonIterableSpread() {
60
+ throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
61
+ }
62
+ function _iterableToArray(iter) {
63
+ if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter);
64
+ }
65
+ function _arrayWithoutHoles(arr) {
66
+ if (Array.isArray(arr)) return _arrayLikeToArray(arr);
67
+ }
68
+ function _defineProperty(obj, key, value) {
69
+ key = _toPropertyKey(key);
70
+ if (key in obj) {
71
+ Object.defineProperty(obj, key, {
72
+ value: value,
73
+ enumerable: true,
74
+ configurable: true,
75
+ writable: true
76
+ });
77
+ } else {
78
+ obj[key] = value;
79
+ }
80
+ return obj;
81
+ }
82
+ function _toPropertyKey(t) {
83
+ var i = _toPrimitive(t, "string");
84
+ return "symbol" == _typeof(i) ? i : i + "";
85
+ }
86
+ function _toPrimitive(t, r) {
87
+ if ("object" != _typeof(t) || !t) return t;
88
+ var e = t[Symbol.toPrimitive];
89
+ if (void 0 !== e) {
90
+ var i = e.call(t, r || "default");
91
+ if ("object" != _typeof(i)) return i;
92
+ throw new TypeError("@@toPrimitive must return a primitive value.");
93
+ }
94
+ return ("string" === r ? String : Number)(t);
95
+ }
96
+ function _slicedToArray(arr, i) {
97
+ return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest();
98
+ }
99
+ function _nonIterableRest() {
100
+ throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
101
+ }
102
+ function _unsupportedIterableToArray(o, minLen) {
103
+ if (!o) return;
104
+ if (typeof o === "string") return _arrayLikeToArray(o, minLen);
105
+ var n = Object.prototype.toString.call(o).slice(8, -1);
106
+ if (n === "Object" && o.constructor) n = o.constructor.name;
107
+ if (n === "Map" || n === "Set") return Array.from(o);
108
+ if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);
109
+ }
110
+ function _arrayLikeToArray(arr, len) {
111
+ if (len == null || len > arr.length) len = arr.length;
112
+ for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i];
113
+ return arr2;
114
+ }
115
+ function _iterableToArrayLimit(r, l) {
116
+ var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"];
117
+ if (null != t) {
118
+ var e,
119
+ n,
120
+ i,
121
+ u,
122
+ a = [],
123
+ f = !0,
124
+ o = !1;
125
+ try {
126
+ if (i = (t = t.call(r)).next, 0 === l) {
127
+ if (Object(t) !== t) return;
128
+ f = !1;
129
+ } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0);
130
+ } catch (r) {
131
+ o = !0, n = r;
132
+ } finally {
133
+ try {
134
+ if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return;
135
+ } finally {
136
+ if (o) throw n;
137
+ }
138
+ }
139
+ return a;
140
+ }
141
+ }
142
+ function _arrayWithHoles(arr) {
143
+ if (Array.isArray(arr)) return arr;
144
+ }
145
+ /**
146
+ * @param value: [{
147
+ key: 'key1',
148
+ value: 'value1',
149
+ }, {
150
+ key: 'key2',
151
+ value: ['value2', 'value3']
152
+ }]
153
+ * @param {*} ref
154
+ * @returns
155
+ */
156
+ var regex = /^.+:.*$/;
157
+ var CompositionInput = function CompositionInput(_ref, ref) {
158
+ var fieldItems = _ref.fieldItems,
159
+ initialValues = _ref.initialValues,
160
+ onChange = _ref.onChange,
161
+ form = _ref.form,
162
+ compositionShowReset = _ref.compositionShowReset,
163
+ defaultSearchField = _ref.defaultSearchField,
164
+ defaultSearchPlaceholder = _ref.defaultSearchPlaceholder,
165
+ clsPrefix = _ref.clsPrefix,
166
+ _onReset = _ref._onReset,
167
+ _onSearch = _ref._onSearch;
168
+ var _a;
169
+ var prefix = "".concat(clsPrefix, "-composition-input");
170
+ var _useState = (0, _react.useState)((0, _utils.parseObjectToArray)(initialValues, fieldItems)),
171
+ _useState2 = _slicedToArray(_useState, 2),
172
+ value = _useState2[0],
173
+ setValue = _useState2[1];
174
+ var _useState3 = (0, _react.useState)(),
175
+ _useState4 = _slicedToArray(_useState3, 2),
176
+ tempItem = _useState4[0],
177
+ setTempItem = _useState4[1];
178
+ var _useState5 = (0, _react.useState)(''),
179
+ _useState6 = _slicedToArray(_useState5, 2),
180
+ searchText = _useState6[0],
181
+ setSearchText = _useState6[1];
182
+ var _useState7 = (0, _react.useState)(false),
183
+ _useState8 = _slicedToArray(_useState7, 2),
184
+ visible = _useState8[0],
185
+ setVisible = _useState8[1];
186
+ var _useState9 = (0, _react.useState)(undefined),
187
+ _useState10 = _slicedToArray(_useState9, 2),
188
+ fieldItem = _useState10[0],
189
+ setFieldItem = _useState10[1];
190
+ var fieldItemsRef = (0, _react.useRef)(fieldItems);
191
+ var _fieldItem = fieldItem ? ((_a = (0, _find2["default"])(fieldItems, function (f) {
192
+ var _a;
193
+ return ((_a = f.props) === null || _a === void 0 ? void 0 : _a.name) === fieldItem.name;
194
+ })) === null || _a === void 0 ? void 0 : _a.props) || fieldItem : {};
195
+ var _ref2 = fieldItem || {},
196
+ props = _ref2.props;
197
+ var inputRef = (0, _react.useRef)(null);
198
+ var widthRef = (0, _react.useRef)(null);
199
+ var fieldRef = (0, _react.useRef)(null);
200
+ var eventRef = (0, _react.useRef)(false);
201
+ fieldItemsRef.current = fieldItems;
202
+ var updateValues = (0, _react.useCallback)(function (obj) {
203
+ var newValueArr = (0, _utils.parseObjectToArray)(obj, fieldItemsRef.current);
204
+ setValue(newValueArr);
205
+ }, []);
206
+ var updateValue = (0, _react.useCallback)(function (name, value) {
207
+ updateValues(_defineProperty({}, name, value));
208
+ }, []);
209
+ if (!eventRef.current) {
210
+ eventRef.current = true;
211
+ form.on('setValue', updateValue);
212
+ form.on('setValues', updateValues);
213
+ }
214
+ (0, _react.useEffect)(function () {
215
+ return function () {
216
+ form.off('setValue', updateValue);
217
+ form.off('setValues', updateValues);
218
+ };
219
+ }, []);
220
+ var handleFocus = function handleFocus(e) {
221
+ e.preventDefault();
222
+ setTimeout(function () {
223
+ var _a;
224
+ (_a = inputRef === null || inputRef === void 0 ? void 0 : inputRef.current) === null || _a === void 0 ? void 0 : _a.focus();
225
+ }, 10);
226
+ if (!visible && !regex.test(searchText)) {
227
+ setVisible(true);
228
+ }
229
+ };
230
+ (0, _react.useImperativeHandle)(ref, function () {
231
+ return {
232
+ changeVal: function changeVal() {
233
+ return value;
234
+ }
235
+ };
236
+ });
237
+ var onClear = function onClear(e) {
238
+ e.stopPropagation();
239
+ var initKeys = Object.keys(initialValues || {});
240
+ var deleteKeys = value === null || value === void 0 ? void 0 : value.filter(function (_ref3) {
241
+ var key = _ref3.key;
242
+ return !initKeys.includes(key);
243
+ }).map(function (_ref4) {
244
+ var key = _ref4.key;
245
+ return key;
246
+ });
247
+ setValue((0, _utils.parseObjectToArray)(initialValues || {}, fieldItems));
248
+ onChange(Object.assign({}, initialValues || {}), deleteKeys, false, true);
249
+ // 清除其他数据
250
+ setSearchText('');
251
+ setTempItem();
252
+ _onReset();
253
+ };
254
+ var doSearch = function doSearch(e) {
255
+ var _a;
256
+ e.stopPropagation();
257
+ var inputValue = ((_a = searchText === null || searchText === void 0 ? void 0 : searchText.match(/[^:]+:(.*)/)) === null || _a === void 0 ? void 0 : _a[1]) || null;
258
+ if (tempItem && inputValue) {
259
+ if ((0, _isObject2["default"])(tempItem.value)) {
260
+ tempItem.value = _defineProperty({}, Object.keys(tempItem.value)[0], inputValue);
261
+ } else {
262
+ tempItem.value = inputValue; // 得到输入值
263
+ }
264
+ if (!(value === null || value === void 0 ? void 0 : value.find(function (v) {
265
+ return v.key === tempItem.key;
266
+ }))) {
267
+ var newValue = [].concat(_toConsumableArray(value), [tempItem]);
268
+ setValue(newValue);
269
+ onChange((0, _utils.parseArrayToObject)(newValue));
270
+ } else {
271
+ var _newValue = value.map(function (v) {
272
+ return v.key === tempItem.key ? tempItem : v;
273
+ });
274
+ setValue(_newValue);
275
+ onChange((0, _utils.parseArrayToObject)(_newValue));
276
+ }
277
+ e.target.value = tempItem.value;
278
+ form.emit('search', _defineProperty(_defineProperty({}, tempItem.key, tempItem.value), "current", 1));
279
+ setTempItem();
280
+ setSearchText('');
281
+ } else {
282
+ _onSearch();
283
+ }
284
+ };
285
+ var onDelete = function onDelete(key, e) {
286
+ var _a, _b;
287
+ e.preventDefault();
288
+ if (value.length > 0) {
289
+ var newValue = value.filter(function (v) {
290
+ return v.key !== key;
291
+ });
292
+ setValue(newValue);
293
+ var deleteKeys = [key];
294
+ onChange((0, _utils.parseArrayToObject)(newValue), deleteKeys, true);
295
+ // 删除的时候也触发Field的onChange -- 泳建提的需求
296
+ var fieldProps = (_a = (0, _find2["default"])(fieldItems, function (it) {
297
+ var _a;
298
+ return ((_a = it.props) === null || _a === void 0 ? void 0 : _a.name) === key;
299
+ })) === null || _a === void 0 ? void 0 : _a.props;
300
+ ((_b = fieldProps === null || fieldProps === void 0 ? void 0 : fieldProps.props) === null || _b === void 0 ? void 0 : _b.onChange) && fieldProps.props.onChange(undefined);
301
+ }
302
+ };
303
+ var focusInput = function focusInput(value) {
304
+ var _a;
305
+ (_a = inputRef === null || inputRef === void 0 ? void 0 : inputRef.current) === null || _a === void 0 ? void 0 : _a.focus();
306
+ setSearchText((0, _utils.getLabel)(value, fieldItems));
307
+ setTempItem(value);
308
+ setTimeout(function () {
309
+ var _a;
310
+ (_a = inputRef === null || inputRef === void 0 ? void 0 : inputRef.current) === null || _a === void 0 ? void 0 : _a.focus();
311
+ }, 10);
312
+ };
313
+ var handleFieldChange = function handleFieldChange(value, isInput, hasValue) {
314
+ var needSearch = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : true;
315
+ if (isInput) {
316
+ focusInput(value);
317
+ return;
318
+ }
319
+ setValue(value);
320
+ setSearchText('');
321
+ setTempItem();
322
+ if (hasValue) onChange((0, _utils.parseArrayToObject)(value), undefined, needSearch);
323
+ };
324
+ // 输入框事件方法
325
+ var onInputChange = function onInputChange(e) {
326
+ var value = e.target.value;
327
+ if (tempItem) {
328
+ if (regex.test(value)) {
329
+ // 有输入值
330
+ setSearchText(value);
331
+ } else {
332
+ // 没有输入值, 清空选择的属性类型重新显示属性列表
333
+ setSearchText('');
334
+ setTempItem();
335
+ }
336
+ } else {
337
+ setSearchText(value);
338
+ }
339
+ };
340
+ var onPressEnter = function onPressEnter(e) {
341
+ var _a;
342
+ var inputValue = ((_a = searchText === null || searchText === void 0 ? void 0 : searchText.match(/[^:]+:(.*)/)) === null || _a === void 0 ? void 0 : _a[1]) || null;
343
+ var fieldValue;
344
+ if (tempItem && inputValue) {
345
+ setVisible(false);
346
+ if ((0, _isObject2["default"])(tempItem.value)) {
347
+ tempItem.value = _defineProperty({}, Object.keys(tempItem.value)[0], inputValue);
348
+ } else {
349
+ tempItem.value = inputValue; // 得到输入值
350
+ }
351
+ fieldValue = tempItem;
352
+ } else if (defaultSearchField) {
353
+ fieldValue = {
354
+ key: defaultSearchField,
355
+ value: searchText
356
+ };
357
+ }
358
+ if (fieldValue) {
359
+ if (!(value === null || value === void 0 ? void 0 : value.find(function (v) {
360
+ return v.key === fieldValue.key;
361
+ }))) {
362
+ var newValue = [].concat(_toConsumableArray(value), [fieldValue]);
363
+ setValue(newValue);
364
+ onChange((0, _utils.parseArrayToObject)(newValue));
365
+ } else {
366
+ var _newValue2 = value.map(function (v) {
367
+ return v.key === fieldValue.key ? fieldValue : v;
368
+ });
369
+ setValue(_newValue2);
370
+ onChange((0, _utils.parseArrayToObject)(_newValue2));
371
+ }
372
+ e.target.value = fieldValue.value;
373
+ form.emit('search', _defineProperty(_defineProperty({}, fieldValue.key, fieldValue.value), "current", 1));
374
+ (props === null || props === void 0 ? void 0 : props.onPressEnter) && props.onPressEnter(e);
375
+ }
376
+ setTempItem();
377
+ setSearchText('');
378
+ };
379
+ return _react["default"].createElement(_LocaleReceiver["default"], {
380
+ componentName: "QueryForm"
381
+ }, function (locale) {
382
+ return _react["default"].createElement("div", {
383
+ className: prefix,
384
+ onClick: handleFocus
385
+ }, _react["default"].createElement("span", {
386
+ className: "".concat(prefix, "-width"),
387
+ ref: widthRef
388
+ }, searchText), _react["default"].createElement("ul", {
389
+ className: "".concat(prefix, "-items")
390
+ }, value && value.map(function (item, index) {
391
+ return _react["default"].createElement("li", {
392
+ key: item.key,
393
+ className: "".concat(prefix, "-items-item")
394
+ }, _react["default"].createElement(_ValueTag["default"], {
395
+ onChange: handleFieldChange,
396
+ value: value,
397
+ item: item,
398
+ fieldItems: fieldItems,
399
+ locale: locale,
400
+ onDelete: onDelete,
401
+ handleTag: focusInput,
402
+ clsPrefix: clsPrefix,
403
+ form: form
404
+ }));
405
+ }), _react["default"].createElement("li", {
406
+ className: "".concat(prefix, "-items-input")
407
+ }, _react["default"].createElement(_FieldPopover["default"], {
408
+ ref: fieldRef,
409
+ onChange: handleFieldChange,
410
+ clsPrefix: clsPrefix,
411
+ fieldItems: fieldItems,
412
+ propItem: _fieldItem,
413
+ setFieldItem: setFieldItem,
414
+ form: form,
415
+ regex: regex,
416
+ visible: visible,
417
+ value: value,
418
+ setVisible: setVisible,
419
+ searchText: searchText,
420
+ locale: locale,
421
+ placement: "bottomLeft"
422
+ }, _react["default"].createElement(_input["default"], Object.assign({
423
+ ref: inputRef,
424
+ value: searchText,
425
+ className: "inputClass",
426
+ placeholder: defaultSearchPlaceholder || (!(value === null || value === void 0 ? void 0 : value.length) ? locale.placeholder : undefined)
427
+ }, props, {
428
+ onPressEnter: onPressEnter,
429
+ onChange: onInputChange
430
+ }))))), _react["default"].createElement("div", {
431
+ className: "".concat(prefix, "-prefix")
432
+ }, _react["default"].createElement(_icon["default"], {
433
+ type: "filter"
434
+ })), compositionShowReset && _react["default"].createElement("div", {
435
+ className: "".concat(prefix, "-clear")
436
+ }, _react["default"].createElement(_icon["default"], {
437
+ onClick: onClear,
438
+ type: "close-circle",
439
+ theme: "filled"
440
+ })), _react["default"].createElement("div", {
441
+ className: "".concat(prefix, "-search"),
442
+ onClick: doSearch
443
+ }, _react["default"].createElement(_icon["default"], {
444
+ type: "search"
445
+ })));
446
+ });
447
+ };
448
+ var _default = exports["default"] = (0, _react.forwardRef)(CompositionInput);
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/query-form/Field/Composition/index.js"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EACZ,SAAS,EACT,QAAQ,EACR,MAAM,EACN,mBAAmB,EACnB,UAAU,EACV,WAAW,GACZ,MAAM,OAAO,CAAA;AACd,OAAO,cAAc,MAAM,wCAAwC,CAAA;AACnE,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAA;AACvC,OAAO,IAAI,MAAM,eAAe,CAAA;AAChC,OAAO,KAAK,MAAM,gBAAgB,CAAA;AAClC,OAAO,YAAY,MAAM,gBAAgB,CAAA;AACzC,OAAO,QAAQ,MAAM,YAAY,CAAA;AACjC,OAAO,EAAE,kBAAkB,EAAE,kBAAkB,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAA;AAC1E,OAAO,cAAc,CAAA;AAErB;;;;;;;;;;GAUG;AACH,MAAM,KAAK,GAAG,SAAS,CAAA;AACvB,MAAM,gBAAgB,GAAG,CACvB,EACE,UAAU,EACV,aAAa,EACb,QAAQ,EACR,IAAI,EACJ,oBAAoB,EACpB,kBAAkB,EAClB,wBAAwB,EACxB,SAAS,EACT,QAAQ,EACR,SAAS,GACV,EACD,GAAG,EACH,EAAE;;IACF,MAAM,MAAM,GAAG,GAAG,SAAS,oBAAoB,CAAA;IAC/C,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAC,kBAAkB,CAAC,aAAa,EAAE,UAAU,CAAC,CAAC,CAAA;IACjF,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAG,QAAQ,EAAE,CAAA;IAC1C,MAAM,CAAC,UAAU,EAAE,aAAa,CAAC,GAAG,QAAQ,CAAC,EAAE,CAAC,CAAA;IAChD,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAA;IAC7C,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAC,SAAS,CAAC,CAAA;IACrD,MAAM,aAAa,GAAG,MAAM,CAAC,UAAU,CAAC,CAAA;IACxC,MAAM,UAAU,GAAG,SAAS;QAC1B,CAAC,CAAC,CAAA,MAAA,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,EAAE,EAAE,WAAC,OAAA,CAAA,MAAA,CAAC,CAAC,KAAK,0CAAE,IAAI,MAAK,SAAS,CAAC,IAAI,CAAA,EAAA,CAAC,0CAAE,KAAK,KAAI,SAAS;QAC/E,CAAC,CAAC,EAAE,CAAA;IACN,MAAM,EAAE,KAAK,EAAE,GAAG,SAAS,IAAI,EAAE,CAAA;IAEjC,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,CAAC,CAAA;IAC7B,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,CAAC,CAAA;IAC7B,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,CAAC,CAAA;IAC7B,MAAM,QAAQ,GAAG,MAAM,CAAC,KAAK,CAAC,CAAA;IAE9B,aAAa,CAAC,OAAO,GAAG,UAAU,CAAA;IAElC,MAAM,YAAY,GAAG,WAAW,CAAC,CAAC,GAAG,EAAE,EAAE;QACvC,MAAM,WAAW,GAAG,kBAAkB,CAAC,GAAG,EAAE,aAAa,CAAC,OAAO,CAAC,CAAA;QAClE,QAAQ,CAAC,WAAW,CAAC,CAAA;IACvB,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,MAAM,WAAW,GAAG,WAAW,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;QAC9C,YAAY,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,CAAC,CAAA;IACjC,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE;QACrB,QAAQ,CAAC,OAAO,GAAG,IAAI,CAAA;QACvB,IAAI,CAAC,EAAE,CAAC,UAAU,EAAE,WAAW,CAAC,CAAA;QAChC,IAAI,CAAC,EAAE,CAAC,WAAW,EAAE,YAAY,CAAC,CAAA;KACnC;IAED,SAAS,CAAC,GAAG,EAAE;QACb,OAAO,GAAG,EAAE;YACV,IAAI,CAAC,GAAG,CAAC,UAAU,EAAE,WAAW,CAAC,CAAA;YACjC,IAAI,CAAC,GAAG,CAAC,WAAW,EAAE,YAAY,CAAC,CAAA;QACrC,CAAC,CAAA;IACH,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,MAAM,WAAW,GAAG,CAAC,CAAC,EAAE,EAAE;QACxB,CAAC,CAAC,cAAc,EAAE,CAAA;QAClB,UAAU,CAAC,GAAG,EAAE;;YACd,MAAA,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,OAAO,0CAAE,KAAK,EAAE,CAAA;QAC5B,CAAC,EAAE,EAAE,CAAC,CAAA;QACN,IAAI,CAAC,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE;YACvC,UAAU,CAAC,IAAI,CAAC,CAAA;SACjB;IACH,CAAC,CAAA;IAED,mBAAmB,CAAC,GAAG,EAAE,GAAG,EAAE,CAAC,CAAC;QAC9B,SAAS,EAAE,GAAG,EAAE;YACd,OAAO,KAAK,CAAA;QACd,CAAC;KACF,CAAC,CAAC,CAAA;IAEH,MAAM,OAAO,GAAG,CAAC,CAAC,EAAE,EAAE;QACpB,CAAC,CAAC,eAAe,EAAE,CAAA;QACnB,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,CAAC,aAAa,IAAI,EAAE,CAAC,CAAA;QACjD,MAAM,UAAU,GAAG,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,MAAM,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC,GAAG,CAAC,CAAA;QAC5F,QAAQ,CAAC,kBAAkB,CAAC,aAAa,IAAI,EAAE,EAAE,UAAU,CAAC,CAAC,CAAA;QAC7D,QAAQ,mBAAM,CAAC,aAAa,IAAI,EAAE,CAAC,GAAI,UAAU,EAAE,KAAK,EAAE,IAAI,CAAC,CAAA;QAC/D,SAAS;QACT,aAAa,CAAC,EAAE,CAAC,CAAA;QACjB,WAAW,EAAE,CAAA;QACb,QAAQ,EAAE,CAAA;IACZ,CAAC,CAAA;IAED,MAAM,QAAQ,GAAG,CAAC,CAAC,EAAE,EAAE;;QACrB,CAAC,CAAC,eAAe,EAAE,CAAA;QACnB,MAAM,UAAU,GAAG,CAAA,MAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,KAAK,CAAC,YAAY,CAAC,0CAAG,CAAC,CAAC,KAAI,IAAI,CAAA;QAC/D,IAAI,QAAQ,IAAI,UAAU,EAAE;YAC1B,IAAI,QAAQ,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE;gBAC5B,QAAQ,CAAC,KAAK,GAAG;oBACf,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,UAAU;iBAC7C,CAAA;aACF;iBAAM;gBACL,QAAQ,CAAC,KAAK,GAAG,UAAU,CAAA,CAAC,QAAQ;aACrC;YACD,IAAI,CAAC,CAAA,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,KAAK,QAAQ,CAAC,GAAG,CAAC,CAAA,EAAE;gBAC/C,MAAM,QAAQ,GAAG,CAAC,GAAG,KAAK,EAAE,QAAQ,CAAC,CAAA;gBACrC,QAAQ,CAAC,QAAQ,CAAC,CAAA;gBAClB,QAAQ,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAC,CAAA;aACvC;iBAAM;gBACL,MAAM,QAAQ,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,KAAK,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;gBAC1E,QAAQ,CAAC,QAAQ,CAAC,CAAA;gBAClB,QAAQ,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAC,CAAA;aACvC;YACD,CAAC,CAAC,MAAM,CAAC,KAAK,GAAG,QAAQ,CAAC,KAAK,CAAA;YAC/B,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,QAAQ,CAAC,KAAK,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAA;YACnE,WAAW,EAAE,CAAA;YACb,aAAa,CAAC,EAAE,CAAC,CAAA;SAClB;aAAM;YACL,SAAS,EAAE,CAAA;SACZ;IACH,CAAC,CAAA;IAED,MAAM,QAAQ,GAAG,CAAC,GAAG,EAAE,CAAC,EAAE,EAAE;;QAC1B,CAAC,CAAC,cAAc,EAAE,CAAA;QAClB,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;YACpB,MAAM,QAAQ,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,KAAK,GAAG,CAAC,CAAA;YACnD,QAAQ,CAAC,QAAQ,CAAC,CAAA;YAClB,MAAM,UAAU,GAAG,CAAC,GAAG,CAAC,CAAA;YACxB,QAAQ,CAAC,kBAAkB,CAAC,QAAQ,CAAC,EAAE,UAAU,EAAE,IAAI,CAAC,CAAA;YACxD,oCAAoC;YACpC,MAAM,UAAU,GAAG,MAAA,IAAI,CAAC,UAAU,EAAE,CAAC,EAAE,EAAE,EAAE,WAAC,OAAA,CAAA,MAAA,EAAE,CAAC,KAAK,0CAAE,IAAI,MAAK,GAAG,CAAA,EAAA,CAAC,0CAAE,KAAK,CAAA;YAC1E,CAAA,MAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,KAAK,0CAAE,QAAQ,KAAI,UAAU,CAAC,KAAK,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAA;SACpE;IACH,CAAC,CAAA;IAED,MAAM,UAAU,GAAG,CAAC,KAAK,EAAE,EAAE;;QAC3B,MAAA,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,OAAO,0CAAE,KAAK,EAAE,CAAA;QAC1B,aAAa,CAAC,QAAQ,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC,CAAA;QAC1C,WAAW,CAAC,KAAK,CAAC,CAAA;QAClB,UAAU,CAAC,GAAG,EAAE;;YACd,MAAA,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,OAAO,0CAAE,KAAK,EAAE,CAAA;QAC5B,CAAC,EAAE,EAAE,CAAC,CAAA;IACR,CAAC,CAAA;IAED,MAAM,iBAAiB,GAAG,CAAC,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,UAAU,GAAG,IAAI,EAAE,EAAE;QACxE,IAAI,OAAO,EAAE;YACX,UAAU,CAAC,KAAK,CAAC,CAAA;YACjB,OAAM;SACP;QACD,QAAQ,CAAC,KAAK,CAAC,CAAA;QACf,aAAa,CAAC,EAAE,CAAC,CAAA;QACjB,WAAW,EAAE,CAAA;QACb,IAAI,QAAQ;YAAE,QAAQ,CAAC,kBAAkB,CAAC,KAAK,CAAC,EAAE,SAAS,EAAE,UAAU,CAAC,CAAA;IAC1E,CAAC,CAAA;IAED,UAAU;IACV,MAAM,aAAa,GAAG,CAAC,CAAC,EAAE,EAAE;QAC1B,MAAM,KAAK,GAAG,CAAC,CAAC,MAAM,CAAC,KAAK,CAAA;QAC5B,IAAI,QAAQ,EAAE;YACZ,IAAI,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;gBACrB,OAAO;gBACP,aAAa,CAAC,KAAK,CAAC,CAAA;aACrB;iBAAM;gBACL,2BAA2B;gBAC3B,aAAa,CAAC,EAAE,CAAC,CAAA;gBACjB,WAAW,EAAE,CAAA;aACd;SACF;aAAM;YACL,aAAa,CAAC,KAAK,CAAC,CAAA;SACrB;IACH,CAAC,CAAA;IAED,MAAM,YAAY,GAAG,CAAC,CAAC,EAAE,EAAE;;QACzB,MAAM,UAAU,GAAG,CAAA,MAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,KAAK,CAAC,YAAY,CAAC,0CAAG,CAAC,CAAC,KAAI,IAAI,CAAA;QAC/D,IAAI,UAAU,CAAA;QACd,IAAI,QAAQ,IAAI,UAAU,EAAE;YAC1B,UAAU,CAAC,KAAK,CAAC,CAAA;YACjB,IAAI,QAAQ,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE;gBAC5B,QAAQ,CAAC,KAAK,GAAG;oBACf,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,UAAU;iBAC7C,CAAA;aACF;iBAAM;gBACL,QAAQ,CAAC,KAAK,GAAG,UAAU,CAAA,CAAC,QAAQ;aACrC;YACD,UAAU,GAAG,QAAQ,CAAA;SACtB;aAAM,IAAI,kBAAkB,EAAE;YAC7B,UAAU,GAAG,EAAE,GAAG,EAAE,kBAAkB,EAAE,KAAK,EAAE,UAAU,EAAE,CAAA;SAC5D;QACD,IAAI,UAAU,EAAE;YACd,IAAI,CAAC,CAAA,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,KAAK,UAAU,CAAC,GAAG,CAAC,CAAA,EAAE;gBACjD,MAAM,QAAQ,GAAG,CAAC,GAAG,KAAK,EAAE,UAAU,CAAC,CAAA;gBACvC,QAAQ,CAAC,QAAQ,CAAC,CAAA;gBAClB,QAAQ,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAC,CAAA;aACvC;iBAAM;gBACL,MAAM,QAAQ,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,KAAK,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;gBAC9E,QAAQ,CAAC,QAAQ,CAAC,CAAA;gBAClB,QAAQ,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAC,CAAA;aACvC;YACD,CAAC,CAAC,MAAM,CAAC,KAAK,GAAG,UAAU,CAAC,KAAK,CAAA;YACjC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,UAAU,CAAC,KAAK,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAA;YACvE,CAAA,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,YAAY,KAAI,KAAK,CAAC,YAAY,CAAC,CAAC,CAAC,CAAA;SAC7C;QACD,WAAW,EAAE,CAAA;QACb,aAAa,CAAC,EAAE,CAAC,CAAA;IACnB,CAAC,CAAA;IACD,OAAO,CACL,oBAAC,cAAc,IAAC,aAAa,EAAC,WAAW,IACtC,CAAC,MAAM,EAAE,EAAE;QACV,OAAO,CACL,6BAAK,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,WAAW;YAC1C,8BAAM,SAAS,EAAE,GAAG,MAAM,QAAQ,EAAE,GAAG,EAAE,QAAQ,IAC9C,UAAU,CACN;YACP,4BAAI,SAAS,EAAE,GAAG,MAAM,QAAQ;gBAC7B,KAAK;oBACJ,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,CACzB,4BAAI,GAAG,EAAE,IAAI,CAAC,GAAG,EAAE,SAAS,EAAE,GAAG,MAAM,aAAa;wBAClD,oBAAC,QAAQ,IACP,QAAQ,EAAE,iBAAiB,EAC3B,KAAK,EAAE,KAAK,EACZ,IAAI,EAAE,IAAI,EACV,UAAU,EAAE,UAAU,EACtB,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,QAAQ,EAClB,SAAS,EAAE,UAAU,EACrB,SAAS,EAAE,SAAS,EACpB,IAAI,EAAE,IAAI,GACV,CACC,CACN,CAAC;gBACJ,4BAAI,SAAS,EAAE,GAAG,MAAM,cAAc;oBACpC,oBAAC,YAAY,IACX,GAAG,EAAE,QAAQ,EACb,QAAQ,EAAE,iBAAiB,EAC3B,SAAS,EAAE,SAAS,EACpB,UAAU,EAAE,UAAU,EACtB,QAAQ,EAAE,UAAU,EACpB,YAAY,EAAE,YAAY,EAC1B,IAAI,EAAE,IAAI,EACV,KAAK,EAAE,KAAK,EACZ,OAAO,EAAE,OAAO,EAChB,KAAK,EAAE,KAAK,EACZ,UAAU,EAAE,UAAU,EACtB,UAAU,EAAE,UAAU,EACtB,MAAM,EAAE,MAAM,EACd,SAAS,EAAC,YAAY;wBAEtB,oBAAC,KAAK,kBACJ,GAAG,EAAE,QAAQ,EACb,KAAK,EAAE,UAAU,EACjB,SAAS,EAAC,YAAY,EACtB,WAAW,EACT,wBAAwB,IAAI,CAAC,CAAC,CAAA,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,MAAM,CAAA,CAAC,CAAC,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,SAAS,CAAC,IAE3E,KAAK,IACT,YAAY,EAAE,YAAY,EAC1B,QAAQ,EAAE,aAAa,IACvB,CACW,CACZ,CACF;YACL,6BAAK,SAAS,EAAE,GAAG,MAAM,SAAS;gBAChC,oBAAC,IAAI,IAAC,IAAI,EAAC,QAAQ,GAAG,CAClB;YACL,oBAAoB,IAAI,CACvB,6BAAK,SAAS,EAAE,GAAG,MAAM,QAAQ;gBAC/B,oBAAC,IAAI,IAAC,OAAO,EAAE,OAAO,EAAE,IAAI,EAAC,cAAc,EAAC,KAAK,EAAC,QAAQ,GAAG,CACzD,CACP;YACD,6BAAK,SAAS,EAAE,GAAG,MAAM,SAAS,EAAE,OAAO,EAAE,QAAQ;gBACnD,oBAAC,IAAI,IAAC,IAAI,EAAC,QAAQ,GAAG,CAClB,CACF,CACP,CAAA;IACH,CAAC,CACc,CAClB,CAAA;AACH,CAAC,CAAA;AACD,eAAe,UAAU,CAAC,gBAAgB,CAAC,CAAA","sourcesContent":["import React, {\n useEffect,\n useState,\n useRef,\n useImperativeHandle,\n forwardRef,\n useCallback,\n} from 'react'\nimport LocaleReceiver from 'antd/es/locale-provider/LocaleReceiver'\nimport { find, isObject } from 'lodash'\nimport Icon from '../../../icon'\nimport Input from '../../../input'\nimport FieldPopover from './FieldPopover'\nimport ValueTag from './ValueTag'\nimport { parseArrayToObject, parseObjectToArray, getLabel } from './utils'\nimport './index.less'\n\n/**\n * @param value: [{\n key: 'key1',\n value: 'value1',\n }, {\n key: 'key2',\n value: ['value2', 'value3']\n }]\n * @param {*} ref \n * @returns \n */\nconst regex = /^.+:.*$/\nconst CompositionInput = (\n {\n fieldItems,\n initialValues,\n onChange,\n form,\n compositionShowReset,\n defaultSearchField,\n defaultSearchPlaceholder,\n clsPrefix,\n _onReset,\n _onSearch,\n },\n ref\n) => {\n const prefix = `${clsPrefix}-composition-input`\n const [value, setValue] = useState(parseObjectToArray(initialValues, fieldItems))\n const [tempItem, setTempItem] = useState()\n const [searchText, setSearchText] = useState('')\n const [visible, setVisible] = useState(false)\n const [fieldItem, setFieldItem] = useState(undefined)\n const fieldItemsRef = useRef(fieldItems)\n const _fieldItem = fieldItem\n ? find(fieldItems, (f) => f.props?.name === fieldItem.name)?.props || fieldItem\n : {}\n const { props } = fieldItem || {}\n\n const inputRef = useRef(null)\n const widthRef = useRef(null)\n const fieldRef = useRef(null)\n const eventRef = useRef(false)\n\n fieldItemsRef.current = fieldItems\n\n const updateValues = useCallback((obj) => {\n const newValueArr = parseObjectToArray(obj, fieldItemsRef.current)\n setValue(newValueArr)\n }, [])\n\n const updateValue = useCallback((name, value) => {\n updateValues({ [name]: value })\n }, [])\n\n if (!eventRef.current) {\n eventRef.current = true\n form.on('setValue', updateValue)\n form.on('setValues', updateValues)\n }\n\n useEffect(() => {\n return () => {\n form.off('setValue', updateValue)\n form.off('setValues', updateValues)\n }\n }, [])\n\n const handleFocus = (e) => {\n e.preventDefault()\n setTimeout(() => {\n inputRef?.current?.focus()\n }, 10)\n if (!visible && !regex.test(searchText)) {\n setVisible(true)\n }\n }\n\n useImperativeHandle(ref, () => ({\n changeVal: () => {\n return value\n },\n }))\n\n const onClear = (e) => {\n e.stopPropagation()\n const initKeys = Object.keys(initialValues || {})\n const deleteKeys = value?.filter(({ key }) => !initKeys.includes(key)).map(({ key }) => key)\n setValue(parseObjectToArray(initialValues || {}, fieldItems))\n onChange({ ...(initialValues || {}) }, deleteKeys, false, true)\n // 清除其他数据\n setSearchText('')\n setTempItem()\n _onReset()\n }\n\n const doSearch = (e) => {\n e.stopPropagation()\n const inputValue = searchText?.match(/[^:]+:(.*)/)?.[1] || null\n if (tempItem && inputValue) {\n if (isObject(tempItem.value)) {\n tempItem.value = {\n [Object.keys(tempItem.value)[0]]: inputValue,\n }\n } else {\n tempItem.value = inputValue // 得到输入值\n }\n if (!value?.find((v) => v.key === tempItem.key)) {\n const newValue = [...value, tempItem]\n setValue(newValue)\n onChange(parseArrayToObject(newValue))\n } else {\n const newValue = value.map((v) => (v.key === tempItem.key ? tempItem : v))\n setValue(newValue)\n onChange(parseArrayToObject(newValue))\n }\n e.target.value = tempItem.value\n form.emit('search', { [tempItem.key]: tempItem.value, current: 1 })\n setTempItem()\n setSearchText('')\n } else {\n _onSearch()\n }\n }\n\n const onDelete = (key, e) => {\n e.preventDefault()\n if (value.length > 0) {\n const newValue = value.filter((v) => v.key !== key)\n setValue(newValue)\n const deleteKeys = [key]\n onChange(parseArrayToObject(newValue), deleteKeys, true)\n // 删除的时候也触发Field的onChange -- 泳建提的需求\n const fieldProps = find(fieldItems, (it) => it.props?.name === key)?.props\n fieldProps?.props?.onChange && fieldProps.props.onChange(undefined)\n }\n }\n\n const focusInput = (value) => {\n inputRef?.current?.focus()\n setSearchText(getLabel(value, fieldItems))\n setTempItem(value)\n setTimeout(() => {\n inputRef?.current?.focus()\n }, 10)\n }\n\n const handleFieldChange = (value, isInput, hasValue, needSearch = true) => {\n if (isInput) {\n focusInput(value)\n return\n }\n setValue(value)\n setSearchText('')\n setTempItem()\n if (hasValue) onChange(parseArrayToObject(value), undefined, needSearch)\n }\n\n // 输入框事件方法\n const onInputChange = (e) => {\n const value = e.target.value\n if (tempItem) {\n if (regex.test(value)) {\n // 有输入值\n setSearchText(value)\n } else {\n // 没有输入值, 清空选择的属性类型重新显示属性列表\n setSearchText('')\n setTempItem()\n }\n } else {\n setSearchText(value)\n }\n }\n\n const onPressEnter = (e) => {\n const inputValue = searchText?.match(/[^:]+:(.*)/)?.[1] || null\n let fieldValue\n if (tempItem && inputValue) {\n setVisible(false)\n if (isObject(tempItem.value)) {\n tempItem.value = {\n [Object.keys(tempItem.value)[0]]: inputValue,\n }\n } else {\n tempItem.value = inputValue // 得到输入值\n }\n fieldValue = tempItem\n } else if (defaultSearchField) {\n fieldValue = { key: defaultSearchField, value: searchText }\n }\n if (fieldValue) {\n if (!value?.find((v) => v.key === fieldValue.key)) {\n const newValue = [...value, fieldValue]\n setValue(newValue)\n onChange(parseArrayToObject(newValue))\n } else {\n const newValue = value.map((v) => (v.key === fieldValue.key ? fieldValue : v))\n setValue(newValue)\n onChange(parseArrayToObject(newValue))\n }\n e.target.value = fieldValue.value\n form.emit('search', { [fieldValue.key]: fieldValue.value, current: 1 })\n props?.onPressEnter && props.onPressEnter(e)\n }\n setTempItem()\n setSearchText('')\n }\n return (\n <LocaleReceiver componentName=\"QueryForm\">\n {(locale) => {\n return (\n <div className={prefix} onClick={handleFocus}>\n <span className={`${prefix}-width`} ref={widthRef}>\n {searchText}\n </span>\n <ul className={`${prefix}-items`}>\n {value &&\n value.map((item, index) => (\n <li key={item.key} className={`${prefix}-items-item`}>\n <ValueTag\n onChange={handleFieldChange}\n value={value}\n item={item}\n fieldItems={fieldItems}\n locale={locale}\n onDelete={onDelete}\n handleTag={focusInput}\n clsPrefix={clsPrefix}\n form={form}\n />\n </li>\n ))}\n <li className={`${prefix}-items-input`}>\n <FieldPopover\n ref={fieldRef}\n onChange={handleFieldChange}\n clsPrefix={clsPrefix}\n fieldItems={fieldItems}\n propItem={_fieldItem}\n setFieldItem={setFieldItem}\n form={form}\n regex={regex}\n visible={visible}\n value={value}\n setVisible={setVisible}\n searchText={searchText}\n locale={locale}\n placement=\"bottomLeft\"\n >\n <Input\n ref={inputRef}\n value={searchText}\n className=\"inputClass\"\n placeholder={\n defaultSearchPlaceholder || (!value?.length ? locale.placeholder : undefined)\n }\n {...props}\n onPressEnter={onPressEnter}\n onChange={onInputChange}\n />\n </FieldPopover>\n </li>\n </ul>\n <div className={`${prefix}-prefix`}>\n <Icon type=\"filter\" />\n </div>\n {compositionShowReset && (\n <div className={`${prefix}-clear`}>\n <Icon onClick={onClear} type=\"close-circle\" theme=\"filled\" />\n </div>\n )}\n <div className={`${prefix}-search`} onClick={doSearch}>\n <Icon type=\"search\" />\n </div>\n </div>\n )\n }}\n </LocaleReceiver>\n )\n}\nexport default forwardRef(CompositionInput)\n"]}
@@ -0,0 +1,167 @@
1
+ @import '../../../style/themes/index';
2
+ @import '../../../style/mixins/index';
3
+ @import '../../../input/style/mixin';
4
+
5
+ .tnt-queryform-composition-input {
6
+ // width: 100%;
7
+ max-height: 162px;
8
+ overflow-x: hidden;
9
+ cursor: text;
10
+ padding: 1px @padding-xl;
11
+ position: relative;
12
+ box-sizing: border-box;
13
+ background-color: @select-background;
14
+ border: @border-width-base @border-style-base @select-border-color;
15
+ border-top-width: calc(@border-width-base + 0.02px);
16
+ border-radius: @border-radius-base;
17
+ outline: none;
18
+ transition: all 0.3s @ease-in-out;
19
+ user-select: none;
20
+ margin-bottom: @margin-base;
21
+
22
+ &-prefix {
23
+ position: absolute;
24
+ left: @padding-sm;
25
+ top: 50%;
26
+ transform: translateY(-50%);
27
+
28
+ i.anticon {
29
+ color: #8b919e;
30
+ }
31
+ }
32
+
33
+ &-width {
34
+ height: 0;
35
+ opacity: 0;
36
+ width: auto;
37
+ position: absolute;
38
+ max-width: 100%;
39
+ }
40
+
41
+ &-items {
42
+ display: flex;
43
+ flex-wrap: wrap;
44
+ padding: 0;
45
+ list-style: none;
46
+ margin: 0;
47
+ width: 100%;
48
+
49
+ &-item {
50
+ // padding: 3px 0;
51
+ margin: 2px 0 !important;
52
+ }
53
+
54
+ li {
55
+ line-height: 1;
56
+ }
57
+
58
+ &-input {
59
+ flex: 1;
60
+ min-width: 160px;
61
+
62
+ .inputClass {
63
+ background: none;
64
+ border: none !important;
65
+ outline: none;
66
+ box-shadow: none !important;
67
+ width: 100% !important;
68
+ height: 28px;
69
+ line-height: 28px;
70
+ padding: 0;
71
+
72
+ input {
73
+ border: none !important;
74
+ outline: none !important;
75
+ box-shadow: none !important;
76
+ height: 26px;
77
+ line-height: 26px;
78
+ padding: 0;
79
+ }
80
+
81
+ textarea {
82
+ padding: 0;
83
+ }
84
+ }
85
+
86
+ .inputClass-with-placeholder {
87
+ min-width: 398px !important;
88
+ }
89
+ }
90
+ }
91
+
92
+ &-clear {
93
+ position: absolute;
94
+ // right: @margin-sm;
95
+ right: calc(@margin-sm + 30px);
96
+ top: 50%;
97
+ transform: translateY(-50%);
98
+ display: none;
99
+
100
+ i.anticon {
101
+ color: tint(@bg-color-spotilight, 50%);
102
+ }
103
+
104
+ &:hover {
105
+ .anticon {
106
+ color: @text-color-secondary !important;
107
+ }
108
+ }
109
+ }
110
+
111
+ &-search {
112
+ position: absolute;
113
+ right: 0;
114
+ top: 0;
115
+ height: 100%;
116
+ border-left: @border-width-base @border-style-base @select-border-color;
117
+ background-color: @fill-color-quaternary;
118
+ display: flex;
119
+ width: 30px;
120
+ justify-content: center;
121
+ align-items: center;
122
+ transition: border-color 0.3s @ease-in-out;
123
+ cursor: pointer;
124
+
125
+ &:hover {
126
+ background-color: #e6f4ff;
127
+
128
+ i.anticon {
129
+ color: @primary-color;
130
+ }
131
+ }
132
+ }
133
+
134
+ &:hover,
135
+ &:focus,
136
+ &:active {
137
+ border-color: @primary-color;
138
+ box-shadow: 0px 0px 4px 0px rgba(18, 107, 251, 0.1), 0px 0px 5px 0px rgba(18, 107, 251, 0.3);
139
+ outline: 0;
140
+
141
+ .tnt-queryform-composition-input-prefix {
142
+ i.anticon {
143
+ color: @text-color;
144
+ }
145
+ }
146
+
147
+ .tnt-queryform-composition-input-clear {
148
+ display: block;
149
+ }
150
+
151
+ .tnt-queryform-composition-input-search {
152
+ border-color: @primary-color;
153
+ }
154
+ }
155
+
156
+ .ant-tag {
157
+
158
+ // padding: 0 @padding-xs;
159
+ // border: none;
160
+ // background: @fill-color-tertiary;
161
+ // height: 20px;
162
+ .ant-tag-addon-wrap {
163
+ margin-top: 0px;
164
+ vertical-align: top;
165
+ }
166
+ }
167
+ }