tntd 2.8.34 → 2.8.35

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 (127) hide show
  1. package/CHANGELOG.json +1034 -0
  2. package/CHANGELOG.md +605 -0
  3. package/lib/alert/alert.d.ts +12 -0
  4. package/lib/alert/alert.d.ts.map +1 -0
  5. package/lib/alert/alert.js +147 -0
  6. package/lib/alert/alert.js.map +1 -0
  7. package/lib/alert/alert.less +128 -0
  8. package/lib/cascader/cascader.d.ts +10 -0
  9. package/lib/cascader/cascader.d.ts.map +1 -0
  10. package/lib/cascader/cascader.js +84 -0
  11. package/lib/cascader/cascader.js.map +1 -0
  12. package/lib/cascader/cascader.less +16 -0
  13. package/lib/checkbox/check.png +0 -0
  14. package/lib/checkbox/checkbox.d.ts +16 -0
  15. package/lib/checkbox/checkbox.d.ts.map +1 -0
  16. package/lib/checkbox/checkbox.js +100 -0
  17. package/lib/checkbox/checkbox.js.map +1 -0
  18. package/lib/checkbox/checkbox.less +69 -0
  19. package/lib/date-picker/DatePicker.d.ts +21 -0
  20. package/lib/date-picker/DatePicker.d.ts.map +1 -0
  21. package/lib/date-picker/DatePicker.js +163 -0
  22. package/lib/date-picker/DatePicker.js.map +1 -0
  23. package/lib/date-picker/index.less +294 -0
  24. package/lib/input-number/inputNumber.d.ts +10 -0
  25. package/lib/input-number/inputNumber.d.ts.map +1 -0
  26. package/lib/input-number/inputNumber.js +89 -0
  27. package/lib/input-number/inputNumber.js.map +1 -0
  28. package/lib/input-number/inputNumber.less +12 -0
  29. package/lib/modal/index.less +36 -0
  30. package/lib/popconfirm/index.less +32 -0
  31. package/lib/popconfirm/popconfirm.d.ts +8 -0
  32. package/lib/popconfirm/popconfirm.d.ts.map +1 -0
  33. package/lib/popconfirm/popconfirm.js +96 -0
  34. package/lib/popconfirm/popconfirm.js.map +1 -0
  35. package/lib/popover/index.less +57 -0
  36. package/lib/popover/popover.d.ts +14 -0
  37. package/lib/popover/popover.d.ts.map +1 -0
  38. package/lib/popover/popover.js +90 -0
  39. package/lib/popover/popover.js.map +1 -0
  40. package/lib/progress/progress.d.ts +12 -0
  41. package/lib/progress/progress.d.ts.map +1 -0
  42. package/lib/progress/progress.js +179 -0
  43. package/lib/progress/progress.js.map +1 -0
  44. package/lib/progress/progress.less +82 -0
  45. package/lib/query-form/Field/Composition/FieldPopover.d.ts +19 -0
  46. package/lib/query-form/Field/Composition/FieldPopover.d.ts.map +1 -0
  47. package/lib/query-form/Field/Composition/FieldPopover.js +419 -0
  48. package/lib/query-form/Field/Composition/FieldPopover.js.map +1 -0
  49. package/lib/query-form/Field/Composition/FieldPopover.less +35 -0
  50. package/lib/query-form/Field/Composition/Select.d.ts +4 -0
  51. package/lib/query-form/Field/Composition/Select.d.ts.map +1 -0
  52. package/lib/query-form/Field/Composition/Select.js +253 -0
  53. package/lib/query-form/Field/Composition/Select.js.map +1 -0
  54. package/lib/query-form/Field/Composition/ValueTag.d.ts +13 -0
  55. package/lib/query-form/Field/Composition/ValueTag.d.ts.map +1 -0
  56. package/lib/query-form/Field/Composition/ValueTag.js +236 -0
  57. package/lib/query-form/Field/Composition/ValueTag.js.map +1 -0
  58. package/lib/query-form/Field/Composition/index.d.ts +13 -0
  59. package/lib/query-form/Field/Composition/index.d.ts.map +1 -0
  60. package/lib/query-form/Field/Composition/index.js +425 -0
  61. package/lib/query-form/Field/Composition/index.js.map +1 -0
  62. package/lib/query-form/Field/Composition/index.less +145 -0
  63. package/lib/query-form/Field/Composition/utils.d.ts +21 -0
  64. package/lib/query-form/Field/Composition/utils.d.ts.map +1 -0
  65. package/lib/query-form/Field/Composition/utils.js +172 -0
  66. package/lib/query-form/Field/Composition/utils.js.map +1 -0
  67. package/lib/query-form-backup/Field/Composition/FieldPopover.less +35 -0
  68. package/lib/query-form-backup/Field/Composition/index.less +114 -0
  69. package/lib/query-form-backup/index.less +90 -0
  70. package/lib/query-form-v2/index.less +133 -0
  71. package/lib/radio/radio.d.ts +17 -0
  72. package/lib/radio/radio.d.ts.map +1 -0
  73. package/lib/radio/radio.js +110 -0
  74. package/lib/radio/radio.js.map +1 -0
  75. package/lib/radio/radio.less +43 -0
  76. package/lib/scroll-bar/Bar.d.ts +4 -0
  77. package/lib/scroll-bar/Bar.d.ts.map +1 -0
  78. package/lib/scroll-bar/Bar.js +168 -0
  79. package/lib/scroll-bar/Bar.js.map +1 -0
  80. package/lib/scroll-bar/Context.d.ts +7 -0
  81. package/lib/scroll-bar/Context.d.ts.map +1 -0
  82. package/lib/scroll-bar/Context.js +17 -0
  83. package/lib/scroll-bar/Context.js.map +1 -0
  84. package/lib/scroll-bar/ScrollBar.d.ts +4 -0
  85. package/lib/scroll-bar/ScrollBar.d.ts.map +1 -0
  86. package/lib/scroll-bar/ScrollBar.js +132 -0
  87. package/lib/scroll-bar/ScrollBar.js.map +1 -0
  88. package/lib/scroll-bar/Thumb.d.ts +3 -0
  89. package/lib/scroll-bar/Thumb.d.ts.map +1 -0
  90. package/lib/scroll-bar/Thumb.js +202 -0
  91. package/lib/scroll-bar/Thumb.js.map +1 -0
  92. package/lib/scroll-bar/index.d.ts +3 -0
  93. package/lib/scroll-bar/index.d.ts.map +1 -0
  94. package/lib/scroll-bar/index.js +14 -0
  95. package/lib/scroll-bar/index.js.map +1 -0
  96. package/lib/scroll-bar/scrollBar.less +59 -0
  97. package/lib/scroll-bar/util.d.ts +40 -0
  98. package/lib/scroll-bar/util.d.ts.map +1 -0
  99. package/lib/scroll-bar/util.js +66 -0
  100. package/lib/scroll-bar/util.js.map +1 -0
  101. package/lib/spin/spin.d.ts +9 -0
  102. package/lib/spin/spin.d.ts.map +1 -0
  103. package/lib/spin/spin.js +79 -0
  104. package/lib/spin/spin.js.map +1 -0
  105. package/lib/spin/spin.less +9 -0
  106. package/lib/steps/assets/background_left.svg +12 -0
  107. package/lib/steps/assets/background_right.svg +12 -0
  108. package/lib/steps/assets/horizontal_line.svg +3 -0
  109. package/lib/steps/assets/vertical_line.svg +3 -0
  110. package/lib/steps/stepStyle/icon.less +51 -0
  111. package/lib/steps/stepStyle/progress-dot.less +10 -0
  112. package/lib/steps/stepStyle/variables.less +8 -0
  113. package/lib/steps/stepStyle/vertical.less +41 -0
  114. package/lib/switch/index.less +45 -0
  115. package/lib/tabs/tabs.less +125 -0
  116. package/lib/time-picker/TimePicker.d.ts +9 -0
  117. package/lib/time-picker/TimePicker.d.ts.map +1 -0
  118. package/lib/time-picker/TimePicker.js +90 -0
  119. package/lib/time-picker/TimePicker.js.map +1 -0
  120. package/lib/time-picker/index.less +38 -0
  121. package/lib/tntd-action/Action.d.ts +6 -0
  122. package/lib/tntd-action/Action.d.ts.map +1 -0
  123. package/lib/tntd-action/Action.js +218 -0
  124. package/lib/tntd-action/Action.js.map +1 -0
  125. package/lib/tntd-action/index.less +61 -0
  126. package/lib/tntd-select/index.less +7 -0
  127. package/package.json +2 -2
@@ -0,0 +1,425 @@
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 _find2 = _interopRequireDefault(require("lodash/find"));
17
+ var _react = _interopRequireWildcard(require("react"));
18
+ var _LocaleReceiver = _interopRequireDefault(require("antd/lib/locale-provider/LocaleReceiver"));
19
+ var _icon = _interopRequireDefault(require("../../../icon"));
20
+ var _input = _interopRequireDefault(require("../../../input"));
21
+ var _FieldPopover = _interopRequireDefault(require("./FieldPopover"));
22
+ var _ValueTag = _interopRequireDefault(require("./ValueTag"));
23
+ var _utils = require("./utils");
24
+ require("./index.less");
25
+ function _getRequireWildcardCache(e) {
26
+ if ("function" != typeof WeakMap) return null;
27
+ var r = new WeakMap(),
28
+ t = new WeakMap();
29
+ return (_getRequireWildcardCache = function _getRequireWildcardCache(e) {
30
+ return e ? t : r;
31
+ })(e);
32
+ }
33
+ function _interopRequireWildcard(e, r) {
34
+ if (!r && e && e.__esModule) return e;
35
+ if (null === e || "object" != _typeof(e) && "function" != typeof e) return {
36
+ "default": e
37
+ };
38
+ var t = _getRequireWildcardCache(r);
39
+ if (t && t.has(e)) return t.get(e);
40
+ var n = {
41
+ __proto__: null
42
+ },
43
+ a = Object.defineProperty && Object.getOwnPropertyDescriptor;
44
+ for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) {
45
+ var i = a ? Object.getOwnPropertyDescriptor(e, u) : null;
46
+ i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u];
47
+ }
48
+ return n["default"] = e, t && t.set(e, n), n;
49
+ }
50
+ function _interopRequireDefault(e) {
51
+ return e && e.__esModule ? e : {
52
+ "default": e
53
+ };
54
+ }
55
+ function _toConsumableArray(r) {
56
+ return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread();
57
+ }
58
+ function _nonIterableSpread() {
59
+ throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
60
+ }
61
+ function _iterableToArray(r) {
62
+ if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r);
63
+ }
64
+ function _arrayWithoutHoles(r) {
65
+ if (Array.isArray(r)) return _arrayLikeToArray(r);
66
+ }
67
+ function _defineProperty(e, r, t) {
68
+ return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, {
69
+ value: t,
70
+ enumerable: !0,
71
+ configurable: !0,
72
+ writable: !0
73
+ }) : e[r] = t, e;
74
+ }
75
+ function _toPropertyKey(t) {
76
+ var i = _toPrimitive(t, "string");
77
+ return "symbol" == _typeof(i) ? i : i + "";
78
+ }
79
+ function _toPrimitive(t, r) {
80
+ if ("object" != _typeof(t) || !t) return t;
81
+ var e = t[Symbol.toPrimitive];
82
+ if (void 0 !== e) {
83
+ var i = e.call(t, r || "default");
84
+ if ("object" != _typeof(i)) return i;
85
+ throw new TypeError("@@toPrimitive must return a primitive value.");
86
+ }
87
+ return ("string" === r ? String : Number)(t);
88
+ }
89
+ function _slicedToArray(r, e) {
90
+ return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest();
91
+ }
92
+ function _nonIterableRest() {
93
+ throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
94
+ }
95
+ function _unsupportedIterableToArray(r, a) {
96
+ if (r) {
97
+ if ("string" == typeof r) return _arrayLikeToArray(r, a);
98
+ var t = {}.toString.call(r).slice(8, -1);
99
+ return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0;
100
+ }
101
+ }
102
+ function _arrayLikeToArray(r, a) {
103
+ (null == a || a > r.length) && (a = r.length);
104
+ for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e];
105
+ return n;
106
+ }
107
+ function _iterableToArrayLimit(r, l) {
108
+ var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"];
109
+ if (null != t) {
110
+ var e,
111
+ n,
112
+ i,
113
+ u,
114
+ a = [],
115
+ f = !0,
116
+ o = !1;
117
+ try {
118
+ if (i = (t = t.call(r)).next, 0 === l) {
119
+ if (Object(t) !== t) return;
120
+ f = !1;
121
+ } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0);
122
+ } catch (r) {
123
+ o = !0, n = r;
124
+ } finally {
125
+ try {
126
+ if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return;
127
+ } finally {
128
+ if (o) throw n;
129
+ }
130
+ }
131
+ return a;
132
+ }
133
+ }
134
+ function _arrayWithHoles(r) {
135
+ if (Array.isArray(r)) return r;
136
+ }
137
+ /**
138
+ * @param value: [{
139
+ key: 'key1',
140
+ value: 'value1',
141
+ label: 'key1:value1'
142
+ }, {
143
+ key: 'key2',
144
+ value: ['value2', 'value3'],
145
+ label: 'key1:value2|value3'
146
+ }]
147
+ * @param {*} ref
148
+ * @returns
149
+ */
150
+ var regex = /^.+:.*$/;
151
+ var CompositionInput = function CompositionInput(_ref, ref) {
152
+ var fieldItems = _ref.fieldItems,
153
+ initialValues = _ref.initialValues,
154
+ onChange = _ref.onChange,
155
+ form = _ref.form,
156
+ compositionShowReset = _ref.compositionShowReset,
157
+ clsPrefix = _ref.clsPrefix,
158
+ _onReset = _ref._onReset,
159
+ _onSearch = _ref._onSearch;
160
+ var _a;
161
+ var prefix = "".concat(clsPrefix, "-composition-input");
162
+ var _useState = (0, _react.useState)((0, _utils.parseObjectToArray)(initialValues, fieldItems)),
163
+ _useState2 = _slicedToArray(_useState, 2),
164
+ value = _useState2[0],
165
+ setValue = _useState2[1];
166
+ var _useState3 = (0, _react.useState)(),
167
+ _useState4 = _slicedToArray(_useState3, 2),
168
+ tempItem = _useState4[0],
169
+ setTempItem = _useState4[1];
170
+ var _useState5 = (0, _react.useState)(''),
171
+ _useState6 = _slicedToArray(_useState5, 2),
172
+ searchText = _useState6[0],
173
+ setSearchText = _useState6[1];
174
+ var _useState7 = (0, _react.useState)(false),
175
+ _useState8 = _slicedToArray(_useState7, 2),
176
+ visible = _useState8[0],
177
+ setVisible = _useState8[1];
178
+ var _useState9 = (0, _react.useState)(undefined),
179
+ _useState10 = _slicedToArray(_useState9, 2),
180
+ fieldItem = _useState10[0],
181
+ setFieldItem = _useState10[1];
182
+ var fieldItemsRef = (0, _react.useRef)(fieldItems);
183
+ var _fieldItem = fieldItem ? ((_a = (0, _find2["default"])(fieldItems, function (f) {
184
+ var _a;
185
+ return ((_a = f.props) === null || _a === void 0 ? void 0 : _a.name) === fieldItem.name;
186
+ })) === null || _a === void 0 ? void 0 : _a.props) || fieldItem : {};
187
+ var _ref2 = fieldItem || {},
188
+ props = _ref2.props;
189
+ var inputRef = (0, _react.useRef)(null);
190
+ var widthRef = (0, _react.useRef)(null);
191
+ var fieldRef = (0, _react.useRef)(null);
192
+ var eventRef = (0, _react.useRef)(false);
193
+ fieldItemsRef.current = fieldItems;
194
+ var updateValues = (0, _react.useCallback)(function (obj) {
195
+ var newValueArr = (0, _utils.parseObjectToArray)(obj, fieldItemsRef.current);
196
+ setValue(newValueArr);
197
+ }, []);
198
+ var updateValue = (0, _react.useCallback)(function (name, value) {
199
+ updateValues(_defineProperty({}, name, value));
200
+ }, []);
201
+ if (!eventRef.current) {
202
+ eventRef.current = true;
203
+ form.on('setValue', updateValue);
204
+ form.on('setValues', updateValues);
205
+ }
206
+ (0, _react.useEffect)(function () {
207
+ return function () {
208
+ form.off('setValue', updateValue);
209
+ form.off('setValues', updateValues);
210
+ };
211
+ }, []);
212
+ var handleFocus = function handleFocus(e) {
213
+ e.preventDefault();
214
+ setTimeout(function () {
215
+ var _a;
216
+ (_a = inputRef === null || inputRef === void 0 ? void 0 : inputRef.current) === null || _a === void 0 ? void 0 : _a.focus();
217
+ }, 10);
218
+ if (!visible && !regex.test(searchText)) {
219
+ setVisible(true);
220
+ }
221
+ };
222
+ (0, _react.useImperativeHandle)(ref, function () {
223
+ return {
224
+ changeVal: function changeVal() {
225
+ return value;
226
+ }
227
+ };
228
+ });
229
+ var onClear = function onClear(e) {
230
+ e.stopPropagation();
231
+ var initKeys = Object.keys(initialValues || {});
232
+ var deleteKeys = value === null || value === void 0 ? void 0 : value.filter(function (_ref3) {
233
+ var key = _ref3.key;
234
+ return !initKeys.includes(key);
235
+ }).map(function (_ref4) {
236
+ var key = _ref4.key;
237
+ return key;
238
+ });
239
+ setValue((0, _utils.parseObjectToArray)(initialValues || {}, fieldItems));
240
+ onChange(Object.assign({}, initialValues || {}), deleteKeys, false, true);
241
+ // 清除其他数据
242
+ setSearchText('');
243
+ setTempItem();
244
+ _onReset();
245
+ };
246
+ var doSearch = function doSearch(e) {
247
+ var _a;
248
+ e.stopPropagation();
249
+ var inputValue = ((_a = searchText === null || searchText === void 0 ? void 0 : searchText.match(/[^:]+:(.*)/)) === null || _a === void 0 ? void 0 : _a[1]) || null;
250
+ if (tempItem && inputValue) {
251
+ // tempItem.label = searchText
252
+ tempItem.value = inputValue; // 得到输入值
253
+ if (!(value === null || value === void 0 ? void 0 : value.find(function (v) {
254
+ return v.key === tempItem.key;
255
+ }))) {
256
+ var newValue = [].concat(_toConsumableArray(value), [tempItem]);
257
+ setValue(newValue);
258
+ onChange((0, _utils.parseArrayToObject)(newValue));
259
+ } else {
260
+ var _newValue = value.map(function (v) {
261
+ return v.key === tempItem.key ? tempItem : v;
262
+ });
263
+ setValue(_newValue);
264
+ onChange((0, _utils.parseArrayToObject)(_newValue));
265
+ }
266
+ e.target.value = inputValue;
267
+ form.emit('search', _defineProperty(_defineProperty({}, tempItem.key, inputValue), "current", 1));
268
+ setTempItem();
269
+ setSearchText('');
270
+ } else {
271
+ _onSearch();
272
+ }
273
+ };
274
+ var onDelete = function onDelete(key, e) {
275
+ var _a, _b;
276
+ e.preventDefault();
277
+ if (value.length > 0) {
278
+ var newValue = value.filter(function (v) {
279
+ return v.key !== key;
280
+ });
281
+ setValue(newValue);
282
+ var deleteKeys = [key];
283
+ onChange((0, _utils.parseArrayToObject)(newValue), deleteKeys, true);
284
+ // 删除的时候也触发Field的onChange -- 泳建提的需求
285
+ var fieldProps = (_a = (0, _find2["default"])(fieldItems, function (it) {
286
+ var _a;
287
+ return ((_a = it.props) === null || _a === void 0 ? void 0 : _a.name) === key;
288
+ })) === null || _a === void 0 ? void 0 : _a.props;
289
+ ((_b = fieldProps === null || fieldProps === void 0 ? void 0 : fieldProps.props) === null || _b === void 0 ? void 0 : _b.onChange) && fieldProps.props.onChange(undefined);
290
+ }
291
+ };
292
+ var focusInput = function focusInput(value) {
293
+ var _a;
294
+ (_a = inputRef === null || inputRef === void 0 ? void 0 : inputRef.current) === null || _a === void 0 ? void 0 : _a.focus();
295
+ setSearchText((0, _utils.getLabel)(value, fieldItems));
296
+ setTempItem(value);
297
+ setTimeout(function () {
298
+ var _a;
299
+ (_a = inputRef === null || inputRef === void 0 ? void 0 : inputRef.current) === null || _a === void 0 ? void 0 : _a.focus();
300
+ }, 10);
301
+ };
302
+ var handleFieldChange = function handleFieldChange(value, isInput, hasValue) {
303
+ var needSearch = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : true;
304
+ if (isInput) {
305
+ focusInput(value);
306
+ return;
307
+ }
308
+ setValue(value);
309
+ setSearchText('');
310
+ setTempItem();
311
+ if (hasValue) onChange((0, _utils.parseArrayToObject)(value), undefined, needSearch);
312
+ };
313
+ // 输入框事件方法
314
+ var onInputChange = function onInputChange(e) {
315
+ var value = e.target.value;
316
+ if (tempItem) {
317
+ if (regex.test(value)) {
318
+ // 有输入值
319
+ setSearchText(value);
320
+ } else {
321
+ // 没有输入值, 清空选择的属性类型重新显示属性列表
322
+ setSearchText('');
323
+ setTempItem();
324
+ }
325
+ } else {
326
+ setSearchText(value);
327
+ }
328
+ };
329
+ var onPressEnter = function onPressEnter(e) {
330
+ var _a;
331
+ var inputValue = ((_a = searchText === null || searchText === void 0 ? void 0 : searchText.match(/[^:]+:(.*)/)) === null || _a === void 0 ? void 0 : _a[1]) || null;
332
+ if (tempItem && inputValue) {
333
+ setVisible(false);
334
+ // tempItem.label = searchText
335
+ tempItem.value = inputValue; // 得到输入值
336
+ if (!(value === null || value === void 0 ? void 0 : value.find(function (v) {
337
+ return v.key === tempItem.key;
338
+ }))) {
339
+ var newValue = [].concat(_toConsumableArray(value), [tempItem]);
340
+ setValue(newValue);
341
+ onChange((0, _utils.parseArrayToObject)(newValue));
342
+ } else {
343
+ var _newValue2 = value.map(function (v) {
344
+ return v.key === tempItem.key ? tempItem : v;
345
+ });
346
+ setValue(_newValue2);
347
+ onChange((0, _utils.parseArrayToObject)(_newValue2));
348
+ }
349
+ e.target.value = inputValue;
350
+ form.emit('search', _defineProperty(_defineProperty({}, tempItem.key, inputValue), "current", 1));
351
+ (props === null || props === void 0 ? void 0 : props.onPressEnter) && props.onPressEnter(e);
352
+ }
353
+ setTempItem();
354
+ setSearchText('');
355
+ };
356
+ return _react["default"].createElement(_LocaleReceiver["default"], {
357
+ componentName: "QueryForm"
358
+ }, function (locale) {
359
+ return _react["default"].createElement("div", {
360
+ className: prefix,
361
+ onClick: handleFocus
362
+ }, _react["default"].createElement("span", {
363
+ className: "".concat(prefix, "-width"),
364
+ ref: widthRef
365
+ }, searchText), _react["default"].createElement("ul", {
366
+ className: "".concat(prefix, "-items")
367
+ }, value && value.map(function (item, index) {
368
+ return _react["default"].createElement("li", {
369
+ key: item.key,
370
+ className: "".concat(prefix, "-items-item")
371
+ }, _react["default"].createElement(_ValueTag["default"], {
372
+ onChange: handleFieldChange,
373
+ value: value,
374
+ item: item,
375
+ fieldItems: fieldItems,
376
+ locale: locale,
377
+ onDelete: onDelete,
378
+ handleTag: focusInput,
379
+ clsPrefix: clsPrefix,
380
+ form: form
381
+ }));
382
+ }), _react["default"].createElement("li", {
383
+ className: "".concat(prefix, "-items-input")
384
+ }, _react["default"].createElement(_FieldPopover["default"], {
385
+ ref: fieldRef,
386
+ onChange: handleFieldChange,
387
+ clsPrefix: clsPrefix,
388
+ fieldItems: fieldItems,
389
+ propItem: _fieldItem,
390
+ setFieldItem: setFieldItem,
391
+ form: form,
392
+ regex: regex,
393
+ visible: visible,
394
+ value: value,
395
+ setVisible: setVisible,
396
+ searchText: searchText,
397
+ locale: locale,
398
+ placement: "bottomLeft"
399
+ }, _react["default"].createElement(_input["default"], Object.assign({
400
+ ref: inputRef,
401
+ value: searchText,
402
+ className: "inputClass",
403
+ placeholder: !(value === null || value === void 0 ? void 0 : value.length) ? locale.placeholder : undefined
404
+ }, props, {
405
+ onPressEnter: onPressEnter,
406
+ onChange: onInputChange
407
+ }))))), _react["default"].createElement("div", {
408
+ className: "".concat(prefix, "-prefix")
409
+ }, _react["default"].createElement(_icon["default"], {
410
+ type: "filter"
411
+ })), compositionShowReset && _react["default"].createElement("div", {
412
+ className: "".concat(prefix, "-clear")
413
+ }, _react["default"].createElement(_icon["default"], {
414
+ onClick: onClear,
415
+ type: "close-circle",
416
+ theme: "filled"
417
+ })), _react["default"].createElement("div", {
418
+ className: "".concat(prefix, "-search"),
419
+ onClick: doSearch
420
+ }, _react["default"].createElement(_icon["default"], {
421
+ type: "search"
422
+ })));
423
+ });
424
+ };
425
+ 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":"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","sourcesContent":["import React, {\n useEffect,\n useState,\n useRef,\n useImperativeHandle,\n forwardRef,\n useCallback,\n} from 'react'\nimport LocaleReceiver from 'antd/lib/locale-provider/LocaleReceiver'\nimport { find } 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 label: 'key1:value1'\n }, {\n key: 'key2',\n value: ['value2', 'value3'],\n label: 'key1: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 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 // tempItem.label = searchText\n tempItem.value = inputValue // 得到输入值\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 = inputValue\n form.emit('search', { [tempItem.key]: inputValue, 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 if (tempItem && inputValue) {\n setVisible(false)\n // tempItem.label = searchText\n tempItem.value = inputValue // 得到输入值\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 = inputValue\n form.emit('search', { [tempItem.key]: inputValue, current: 1 })\n props?.onPressEnter && props.onPressEnter(e)\n }\n setTempItem()\n setSearchText('')\n }\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={!value?.length ? locale.placeholder : undefined}\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,145 @@
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: 2px @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-sm;
21
+
22
+ &-prefix {
23
+ position: absolute;
24
+ left: @padding-sm;
25
+ top: 50%;
26
+ transform: translateY(-50%);
27
+ i.anticon {
28
+ color: #8B919E;
29
+ }
30
+ }
31
+
32
+ &-width {
33
+ height: 0;
34
+ opacity: 0;
35
+ width: auto;
36
+ position: absolute;
37
+ max-width: 100%;
38
+ }
39
+
40
+ &-items {
41
+ display: flex;
42
+ flex-wrap: wrap;
43
+ padding: 0;
44
+ list-style: none;
45
+ margin: 0;
46
+ width: 100%;
47
+ &-item {
48
+ padding: 3px 0;
49
+ }
50
+ li {
51
+ line-height: 1;
52
+ }
53
+ &-input {
54
+ flex: 1;
55
+ min-width: 160px;
56
+ .inputClass {
57
+ background: none;
58
+ border: none !important;
59
+ outline: none;
60
+ box-shadow: none !important;
61
+ width: 100% !important;
62
+ height: 26px;
63
+ line-height: 26px;
64
+ padding: 0;
65
+ input {
66
+ border: none !important;
67
+ outline: none !important;
68
+ box-shadow: none !important;
69
+ height: 26px;
70
+ line-height: 26px;
71
+ padding: 0;
72
+ }
73
+ textarea {
74
+ padding: 0;
75
+ }
76
+ }
77
+ .inputClass-with-placeholder {
78
+ min-width: 398px !important;
79
+ }
80
+ }
81
+ }
82
+ &-clear {
83
+ position: absolute;
84
+ // right: @margin-sm;
85
+ right: calc(@margin-sm + 30px);
86
+ top: 50%;
87
+ transform: translateY(-50%);
88
+ display: none;
89
+ i.anticon {
90
+ color: tint(@bg-color-spotilight, 50%);
91
+ }
92
+ &:hover {
93
+ .anticon {
94
+ color: @text-color-secondary !important;
95
+ }
96
+ }
97
+ }
98
+ &-search {
99
+ position: absolute;
100
+ right: 0;
101
+ top: 0;
102
+ height: 100%;
103
+ border-left: @border-width-base @border-style-base @select-border-color;
104
+ background-color: @fill-color-quaternary;
105
+ display: flex;
106
+ width: 30px;
107
+ justify-content: center;
108
+ align-items: center;
109
+ transition: border-color 0.3s @ease-in-out;
110
+ cursor: pointer;
111
+ &:hover {
112
+ background-color: #E6F4FF;
113
+ i.anticon {
114
+ color: @primary-color;
115
+ }
116
+ }
117
+ }
118
+ &:hover,
119
+ &:focus,
120
+ &:active {
121
+ border-color: @primary-color;
122
+ box-shadow: 0px 0px 4px 0px rgba(18, 107, 251, 0.10), 0px 0px 5px 0px rgba(18, 107, 251, 0.30);
123
+ outline: 0;
124
+ .tnt-queryform-composition-input-prefix {
125
+ i.anticon {
126
+ color: @text-color;
127
+ }
128
+ }
129
+ .tnt-queryform-composition-input-clear {
130
+ display: block;
131
+ }
132
+ .tnt-queryform-composition-input-search {
133
+ border-color: @primary-color;
134
+ }
135
+ }
136
+ .ant-tag {
137
+ padding: 0 @padding-xs;
138
+ border: none;
139
+ background: @fill-color-tertiary;
140
+ height: 20px;
141
+ .ant-tag-addon-wrap {
142
+ margin-top: -2px;
143
+ }
144
+ }
145
+ }
@@ -0,0 +1,21 @@
1
+ export function highlightSubstring(str: any, substring: any): any;
2
+ export function getLabelByValue({ value, options, fieldNames, }: {
3
+ value: any;
4
+ options: any;
5
+ fieldNames?: {
6
+ label: string;
7
+ value: string;
8
+ } | undefined;
9
+ }): any;
10
+ export function formatLabel(reactDom: any): any;
11
+ export function parseObjectToArray(value: any, data: any): (false | {
12
+ key: string;
13
+ value: any;
14
+ } | null)[];
15
+ export function parseArrayToObject(value: any): any;
16
+ export function getLabel({ key, value }: {
17
+ key: any;
18
+ value: any;
19
+ }, data: any, locale: any): string | false | null;
20
+ export function isInput(type: any): boolean;
21
+ //# sourceMappingURL=utils.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../../src/query-form/Field/Composition/utils.js"],"names":[],"mappings":"AAIA,kEAGC;AAED;;;;;;;QAyBC;AAED,gDAWC;AAED;;;YAgCC;AAED,oDAKC;AAED;;;kDAwCC;AAEM,4CAC+E"}