tntd 3.0.66 → 3.0.67-beta.1

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 (148) hide show
  1. package/es/color-picker/ColorPicker.js +3 -2
  2. package/es/color-picker/ColorPicker.js.map +1 -1
  3. package/es/form/style/index.less +5 -5
  4. package/es/index.less +0 -1
  5. package/es/modal/modal.js.map +1 -1
  6. package/es/query-form/Field/Checkbox.js +1 -1
  7. package/es/query-form/Field/Checkbox.js.map +1 -1
  8. package/es/query-form/Field/Composition/FieldPopover.js +363 -0
  9. package/es/query-form/Field/Composition/FieldPopover.js.map +1 -0
  10. package/es/query-form/Field/Composition/FieldPopover.less +41 -0
  11. package/es/query-form/Field/Composition/Select.js +157 -0
  12. package/es/query-form/Field/Composition/Select.js.map +1 -0
  13. package/es/query-form/Field/Composition/SelectInput.js +34 -0
  14. package/es/query-form/Field/Composition/SelectInput.js.map +1 -0
  15. package/es/query-form/Field/Composition/ValueTag.js +163 -0
  16. package/es/query-form/Field/Composition/ValueTag.js.map +1 -0
  17. package/es/query-form/Field/Composition/index.js +337 -0
  18. package/es/query-form/Field/Composition/index.js.map +1 -0
  19. package/es/query-form/Field/Composition/index.less +167 -0
  20. package/es/query-form/Field/Composition/utils.js +169 -0
  21. package/es/query-form/Field/Composition/utils.js.map +1 -0
  22. package/es/query-form/Field/SelectInput.js +16 -12
  23. package/es/query-form/Field/SelectInput.js.map +1 -1
  24. package/es/query-form/Field/fieldsMap.js +2 -2
  25. package/es/query-form/Field/fieldsMap.js.map +1 -1
  26. package/es/query-form/Field/index.js +2 -1
  27. package/es/query-form/Field/index.js.map +1 -1
  28. package/es/query-form/index.js +226 -357
  29. package/es/query-form/index.js.map +1 -1
  30. package/es/query-form/index.less +26 -77
  31. package/es/query-form-v2/index.less +133 -0
  32. package/es/query-list-scene/List.js +16 -3
  33. package/es/query-list-scene/List.js.map +1 -1
  34. package/es/query-list-scene/QueryForm.js +35 -13
  35. package/es/query-list-scene/QueryForm.js.map +1 -1
  36. package/es/query-list-scene/index.js +2 -1
  37. package/es/query-list-scene/index.js.map +1 -1
  38. package/es/scroll-bar/ScrollBar.js +8 -5
  39. package/es/scroll-bar/ScrollBar.js.map +1 -1
  40. package/es/table/hooks/use-column-setting.js.map +1 -1
  41. package/es/table/resizableTable/index.less +1 -1
  42. package/es/table/table.js +8 -2
  43. package/es/table/table.js.map +1 -1
  44. package/es/tntd-select/index.js.map +1 -1
  45. package/es/tntd-virtual-tree/index.js +0 -3
  46. package/es/tntd-virtual-tree/index.js.map +1 -1
  47. package/lib/color-picker/ColorPicker.d.ts +2 -1
  48. package/lib/color-picker/ColorPicker.d.ts.map +1 -1
  49. package/lib/color-picker/ColorPicker.js +3 -2
  50. package/lib/color-picker/ColorPicker.js.map +1 -1
  51. package/lib/form/style/index.less +5 -5
  52. package/lib/index.less +0 -1
  53. package/lib/modal/modal.d.ts.map +1 -1
  54. package/lib/modal/modal.js.map +1 -1
  55. package/lib/query-form/Field/Checkbox.js +1 -1
  56. package/lib/query-form/Field/Checkbox.js.map +1 -1
  57. package/lib/query-form/Field/Composition/FieldPopover.d.ts +19 -0
  58. package/lib/query-form/Field/Composition/FieldPopover.d.ts.map +1 -0
  59. package/lib/query-form/Field/Composition/FieldPopover.js +459 -0
  60. package/lib/query-form/Field/Composition/FieldPopover.js.map +1 -0
  61. package/lib/query-form/Field/Composition/FieldPopover.less +41 -0
  62. package/lib/query-form/Field/Composition/Select.d.ts +4 -0
  63. package/lib/query-form/Field/Composition/Select.d.ts.map +1 -0
  64. package/lib/query-form/Field/Composition/Select.js +253 -0
  65. package/lib/query-form/Field/Composition/Select.js.map +1 -0
  66. package/lib/query-form/Field/Composition/SelectInput.d.ts +3 -0
  67. package/lib/query-form/Field/Composition/SelectInput.d.ts.map +1 -0
  68. package/lib/query-form/Field/Composition/SelectInput.js +111 -0
  69. package/lib/query-form/Field/Composition/SelectInput.js.map +1 -0
  70. package/lib/query-form/Field/Composition/ValueTag.d.ts +13 -0
  71. package/lib/query-form/Field/Composition/ValueTag.d.ts.map +1 -0
  72. package/lib/query-form/Field/Composition/ValueTag.js +240 -0
  73. package/lib/query-form/Field/Composition/ValueTag.js.map +1 -0
  74. package/lib/query-form/Field/Composition/index.d.ts +15 -0
  75. package/lib/query-form/Field/Composition/index.d.ts.map +1 -0
  76. package/lib/query-form/Field/Composition/index.js +441 -0
  77. package/lib/query-form/Field/Composition/index.js.map +1 -0
  78. package/lib/query-form/Field/Composition/index.less +167 -0
  79. package/lib/query-form/Field/Composition/utils.d.ts +21 -0
  80. package/lib/query-form/Field/Composition/utils.d.ts.map +1 -0
  81. package/lib/query-form/Field/Composition/utils.js +173 -0
  82. package/lib/query-form/Field/Composition/utils.js.map +1 -0
  83. package/lib/query-form/Field/SelectInput.d.ts.map +1 -1
  84. package/lib/query-form/Field/SelectInput.js +16 -12
  85. package/lib/query-form/Field/SelectInput.js.map +1 -1
  86. package/lib/query-form/Field/fieldsMap.d.ts +6 -3
  87. package/lib/query-form/Field/fieldsMap.d.ts.map +1 -1
  88. package/lib/query-form/Field/fieldsMap.js +2 -2
  89. package/lib/query-form/Field/fieldsMap.js.map +1 -1
  90. package/lib/query-form/Field/index.d.ts.map +1 -1
  91. package/lib/query-form/Field/index.js +2 -1
  92. package/lib/query-form/Field/index.js.map +1 -1
  93. package/lib/query-form/index.d.ts +1 -36
  94. package/lib/query-form/index.d.ts.map +1 -1
  95. package/lib/query-form/index.js +262 -397
  96. package/lib/query-form/index.js.map +1 -1
  97. package/lib/query-form/index.less +26 -77
  98. package/lib/query-form-v2/index.less +133 -0
  99. package/lib/query-list-scene/List.d.ts.map +1 -1
  100. package/lib/query-list-scene/List.js +16 -3
  101. package/lib/query-list-scene/List.js.map +1 -1
  102. package/lib/query-list-scene/QueryForm.d.ts +5 -4
  103. package/lib/query-list-scene/QueryForm.d.ts.map +1 -1
  104. package/lib/query-list-scene/QueryForm.js +35 -13
  105. package/lib/query-list-scene/QueryForm.js.map +1 -1
  106. package/lib/query-list-scene/index.d.ts.map +1 -1
  107. package/lib/query-list-scene/index.js +2 -1
  108. package/lib/query-list-scene/index.js.map +1 -1
  109. package/lib/scroll-bar/ScrollBar.js +8 -5
  110. package/lib/scroll-bar/ScrollBar.js.map +1 -1
  111. package/lib/table/hooks/use-column-setting.d.ts +1 -0
  112. package/lib/table/hooks/use-column-setting.d.ts.map +1 -1
  113. package/lib/table/hooks/use-column-setting.js.map +1 -1
  114. package/lib/table/resizableTable/index.less +1 -1
  115. package/lib/table/table.d.ts.map +1 -1
  116. package/lib/table/table.js +8 -2
  117. package/lib/table/table.js.map +1 -1
  118. package/lib/tntd-select/index.d.ts.map +1 -1
  119. package/lib/tntd-select/index.js.map +1 -1
  120. package/lib/tntd-virtual-tree/index.js +0 -3
  121. package/lib/tntd-virtual-tree/index.js.map +1 -1
  122. package/package.json +3 -2
  123. package/es/checkbox/checkbox-group.js +0 -16
  124. package/es/checkbox/checkbox-group.js.map +0 -1
  125. package/es/radio/radio-group.js +0 -16
  126. package/es/radio/radio-group.js.map +0 -1
  127. package/es/steps/stepStyle/small.less +0 -5
  128. package/es/table/total-shower.js +0 -20
  129. package/es/table/total-shower.js.map +0 -1
  130. package/es/utils/simple-template.js +0 -19
  131. package/es/utils/simple-template.js.map +0 -1
  132. package/lib/checkbox/checkbox-group.d.ts +0 -8
  133. package/lib/checkbox/checkbox-group.d.ts.map +0 -1
  134. package/lib/checkbox/checkbox-group.js +0 -16
  135. package/lib/checkbox/checkbox-group.js.map +0 -1
  136. package/lib/radio/radio-group.d.ts +0 -8
  137. package/lib/radio/radio-group.d.ts.map +0 -1
  138. package/lib/radio/radio-group.js +0 -16
  139. package/lib/radio/radio-group.js.map +0 -1
  140. package/lib/steps/stepStyle/small.less +0 -5
  141. package/lib/table/total-shower.d.ts +0 -9
  142. package/lib/table/total-shower.d.ts.map +0 -1
  143. package/lib/table/total-shower.js +0 -20
  144. package/lib/table/total-shower.js.map +0 -1
  145. package/lib/utils/simple-template.d.ts +0 -9
  146. package/lib/utils/simple-template.d.ts.map +0 -1
  147. package/lib/utils/simple-template.js +0 -19
  148. package/lib/utils/simple-template.js.map +0 -1
@@ -0,0 +1,337 @@
1
+ "use strict";
2
+
3
+ function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports["default"] = void 0;
8
+ var _isObject2 = _interopRequireDefault(require("lodash/isObject"));
9
+ var _find2 = _interopRequireDefault(require("lodash/find"));
10
+ var _react = _interopRequireWildcard(require("react"));
11
+ var _LocaleReceiver = _interopRequireDefault(require("antd/es/locale-provider/LocaleReceiver"));
12
+ var _icon = _interopRequireDefault(require("../../../icon"));
13
+ var _input = _interopRequireDefault(require("../../../input"));
14
+ var _FieldPopover = _interopRequireDefault(require("./FieldPopover"));
15
+ var _ValueTag = _interopRequireDefault(require("./ValueTag"));
16
+ var _utils = require("./utils");
17
+ require("./index.less");
18
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
19
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
20
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { "default": e }; }
21
+ function _toConsumableArray(r) { return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread(); }
22
+ function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
23
+ function _iterableToArray(r) { if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); }
24
+ function _arrayWithoutHoles(r) { if (Array.isArray(r)) return _arrayLikeToArray(r); }
25
+ function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
26
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
27
+ function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
28
+ function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
29
+ 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."); }
30
+ function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); 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; } }
31
+ function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
32
+ function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
33
+ function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
34
+ /**
35
+ * @param value: [{
36
+ key: 'key1',
37
+ value: 'value1',
38
+ }, {
39
+ key: 'key2',
40
+ value: ['value2', 'value3']
41
+ }]
42
+ * @param {*} ref
43
+ * @returns
44
+ */
45
+ var regex = /^.+:.*$/;
46
+ var CompositionInput = function CompositionInput(_ref, ref) {
47
+ var fieldItems = _ref.fieldItems,
48
+ initialValues = _ref.initialValues,
49
+ onChange = _ref.onChange,
50
+ form = _ref.form,
51
+ compositionShowReset = _ref.compositionShowReset,
52
+ defaultSearchField = _ref.defaultSearchField,
53
+ defaultSearchPlaceholder = _ref.defaultSearchPlaceholder,
54
+ clsPrefix = _ref.clsPrefix,
55
+ _onReset = _ref._onReset,
56
+ _onSearch = _ref._onSearch;
57
+ var _a;
58
+ var prefix = "".concat(clsPrefix, "-composition-input");
59
+ var _useState = (0, _react.useState)((0, _utils.parseObjectToArray)(initialValues, fieldItems)),
60
+ _useState2 = _slicedToArray(_useState, 2),
61
+ value = _useState2[0],
62
+ setValue = _useState2[1];
63
+ var _useState3 = (0, _react.useState)(),
64
+ _useState4 = _slicedToArray(_useState3, 2),
65
+ tempItem = _useState4[0],
66
+ setTempItem = _useState4[1];
67
+ var _useState5 = (0, _react.useState)(''),
68
+ _useState6 = _slicedToArray(_useState5, 2),
69
+ searchText = _useState6[0],
70
+ setSearchText = _useState6[1];
71
+ var _useState7 = (0, _react.useState)(false),
72
+ _useState8 = _slicedToArray(_useState7, 2),
73
+ visible = _useState8[0],
74
+ setVisible = _useState8[1];
75
+ var _useState9 = (0, _react.useState)(undefined),
76
+ _useState10 = _slicedToArray(_useState9, 2),
77
+ fieldItem = _useState10[0],
78
+ setFieldItem = _useState10[1];
79
+ var fieldItemsRef = (0, _react.useRef)(fieldItems);
80
+ var _fieldItem = fieldItem ? ((_a = (0, _find2["default"])(fieldItems, function (f) {
81
+ var _a;
82
+ return ((_a = f.props) === null || _a === void 0 ? void 0 : _a.name) === fieldItem.name;
83
+ })) === null || _a === void 0 ? void 0 : _a.props) || fieldItem : {};
84
+ var _ref2 = fieldItem || {},
85
+ props = _ref2.props;
86
+ var inputRef = (0, _react.useRef)(null);
87
+ var widthRef = (0, _react.useRef)(null);
88
+ var fieldRef = (0, _react.useRef)(null);
89
+ var eventRef = (0, _react.useRef)(false);
90
+ fieldItemsRef.current = fieldItems;
91
+ var updateValues = (0, _react.useCallback)(function (obj) {
92
+ var newValueArr = (0, _utils.parseObjectToArray)(obj, fieldItemsRef.current);
93
+ setValue(newValueArr);
94
+ }, []);
95
+ var updateValue = (0, _react.useCallback)(function (name, value) {
96
+ updateValues(_defineProperty({}, name, value));
97
+ }, []);
98
+ if (!eventRef.current) {
99
+ eventRef.current = true;
100
+ form.on('setValue', updateValue);
101
+ form.on('setValues', updateValues);
102
+ }
103
+ (0, _react.useEffect)(function () {
104
+ return function () {
105
+ form.off('setValue', updateValue);
106
+ form.off('setValues', updateValues);
107
+ };
108
+ }, []);
109
+ var handleFocus = function handleFocus(e) {
110
+ e.preventDefault();
111
+ setTimeout(function () {
112
+ var _a;
113
+ (_a = inputRef === null || inputRef === void 0 ? void 0 : inputRef.current) === null || _a === void 0 ? void 0 : _a.focus();
114
+ }, 10);
115
+ if (!visible && !regex.test(searchText)) {
116
+ setVisible(true);
117
+ }
118
+ };
119
+ (0, _react.useImperativeHandle)(ref, function () {
120
+ return {
121
+ changeVal: function changeVal() {
122
+ return value;
123
+ }
124
+ };
125
+ });
126
+ var onClear = function onClear(e) {
127
+ e.stopPropagation();
128
+ var initKeys = Object.keys(initialValues || {});
129
+ var deleteKeys = value === null || value === void 0 ? void 0 : value.filter(function (_ref3) {
130
+ var key = _ref3.key;
131
+ return !initKeys.includes(key);
132
+ }).map(function (_ref4) {
133
+ var key = _ref4.key;
134
+ return key;
135
+ });
136
+ setValue((0, _utils.parseObjectToArray)(initialValues || {}, fieldItems));
137
+ onChange(Object.assign({}, initialValues || {}), deleteKeys, false, true);
138
+ // 清除其他数据
139
+ setSearchText('');
140
+ setTempItem();
141
+ _onReset();
142
+ };
143
+ var doSearch = function doSearch(e) {
144
+ var _a;
145
+ e.stopPropagation();
146
+ var inputValue = ((_a = searchText === null || searchText === void 0 ? void 0 : searchText.match(/[^:]+:(.*)/)) === null || _a === void 0 ? void 0 : _a[1]) || null;
147
+ if (tempItem && inputValue) {
148
+ if ((0, _isObject2["default"])(tempItem.value)) {
149
+ tempItem.value = _defineProperty({}, Object.keys(tempItem.value)[0], inputValue);
150
+ } else {
151
+ tempItem.value = inputValue; // 得到输入值
152
+ }
153
+ if (!(value === null || value === void 0 ? void 0 : value.find(function (v) {
154
+ return v.key === tempItem.key;
155
+ }))) {
156
+ var newValue = [].concat(_toConsumableArray(value), [tempItem]);
157
+ setValue(newValue);
158
+ onChange((0, _utils.parseArrayToObject)(newValue));
159
+ } else {
160
+ var _newValue = value.map(function (v) {
161
+ return v.key === tempItem.key ? tempItem : v;
162
+ });
163
+ setValue(_newValue);
164
+ onChange((0, _utils.parseArrayToObject)(_newValue));
165
+ }
166
+ e.target.value = tempItem.value;
167
+ form.emit('search', _defineProperty(_defineProperty({}, tempItem.key, tempItem.value), "current", 1));
168
+ setTempItem();
169
+ setSearchText('');
170
+ } else {
171
+ _onSearch();
172
+ }
173
+ };
174
+ var onDelete = function onDelete(key, e) {
175
+ var _a, _b;
176
+ e.preventDefault();
177
+ if (value.length > 0) {
178
+ var newValue = value.filter(function (v) {
179
+ return v.key !== key;
180
+ });
181
+ setValue(newValue);
182
+ var deleteKeys = [key];
183
+ onChange((0, _utils.parseArrayToObject)(newValue), deleteKeys, true);
184
+ // 删除的时候也触发Field的onChange -- 泳建提的需求
185
+ var fieldProps = (_a = (0, _find2["default"])(fieldItems, function (it) {
186
+ var _a;
187
+ return ((_a = it.props) === null || _a === void 0 ? void 0 : _a.name) === key;
188
+ })) === null || _a === void 0 ? void 0 : _a.props;
189
+ ((_b = fieldProps === null || fieldProps === void 0 ? void 0 : fieldProps.props) === null || _b === void 0 ? void 0 : _b.onChange) && fieldProps.props.onChange(undefined);
190
+ }
191
+ };
192
+ var focusInput = function focusInput(value) {
193
+ var _a;
194
+ (_a = inputRef === null || inputRef === void 0 ? void 0 : inputRef.current) === null || _a === void 0 ? void 0 : _a.focus();
195
+ setSearchText((0, _utils.getLabel)(value, fieldItems));
196
+ setTempItem(value);
197
+ setTimeout(function () {
198
+ var _a;
199
+ (_a = inputRef === null || inputRef === void 0 ? void 0 : inputRef.current) === null || _a === void 0 ? void 0 : _a.focus();
200
+ }, 10);
201
+ };
202
+ var handleFieldChange = function handleFieldChange(value, isInput, hasValue) {
203
+ var needSearch = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : true;
204
+ if (isInput) {
205
+ focusInput(value);
206
+ return;
207
+ }
208
+ setValue(value);
209
+ setSearchText('');
210
+ setTempItem();
211
+ if (hasValue) onChange((0, _utils.parseArrayToObject)(value), undefined, needSearch);
212
+ };
213
+ // 输入框事件方法
214
+ var onInputChange = function onInputChange(e) {
215
+ var value = e.target.value;
216
+ if (tempItem) {
217
+ if (regex.test(value)) {
218
+ // 有输入值
219
+ setSearchText(value);
220
+ } else {
221
+ // 没有输入值, 清空选择的属性类型重新显示属性列表
222
+ setSearchText('');
223
+ setTempItem();
224
+ }
225
+ } else {
226
+ setSearchText(value);
227
+ }
228
+ };
229
+ var onPressEnter = function onPressEnter(e) {
230
+ var _a;
231
+ var inputValue = ((_a = searchText === null || searchText === void 0 ? void 0 : searchText.match(/[^:]+:(.*)/)) === null || _a === void 0 ? void 0 : _a[1]) || null;
232
+ var fieldValue;
233
+ if (tempItem && inputValue) {
234
+ setVisible(false);
235
+ if ((0, _isObject2["default"])(tempItem.value)) {
236
+ tempItem.value = _defineProperty({}, Object.keys(tempItem.value)[0], inputValue);
237
+ } else {
238
+ tempItem.value = inputValue; // 得到输入值
239
+ }
240
+ fieldValue = tempItem;
241
+ } else if (defaultSearchField) {
242
+ fieldValue = {
243
+ key: defaultSearchField,
244
+ value: searchText
245
+ };
246
+ }
247
+ if (fieldValue) {
248
+ if (!(value === null || value === void 0 ? void 0 : value.find(function (v) {
249
+ return v.key === fieldValue.key;
250
+ }))) {
251
+ var newValue = [].concat(_toConsumableArray(value), [fieldValue]);
252
+ setValue(newValue);
253
+ onChange((0, _utils.parseArrayToObject)(newValue));
254
+ } else {
255
+ var _newValue2 = value.map(function (v) {
256
+ return v.key === fieldValue.key ? fieldValue : v;
257
+ });
258
+ setValue(_newValue2);
259
+ onChange((0, _utils.parseArrayToObject)(_newValue2));
260
+ }
261
+ e.target.value = fieldValue.value;
262
+ form.emit('search', _defineProperty(_defineProperty({}, fieldValue.key, fieldValue.value), "current", 1));
263
+ (props === null || props === void 0 ? void 0 : props.onPressEnter) && props.onPressEnter(e);
264
+ }
265
+ setTempItem();
266
+ setSearchText('');
267
+ };
268
+ return _react["default"].createElement(_LocaleReceiver["default"], {
269
+ componentName: "QueryForm"
270
+ }, function (locale) {
271
+ return _react["default"].createElement("div", {
272
+ className: prefix,
273
+ onClick: handleFocus
274
+ }, _react["default"].createElement("span", {
275
+ className: "".concat(prefix, "-width"),
276
+ ref: widthRef
277
+ }, searchText), _react["default"].createElement("ul", {
278
+ className: "".concat(prefix, "-items")
279
+ }, value && value.map(function (item, index) {
280
+ return _react["default"].createElement("li", {
281
+ key: item.key,
282
+ className: "".concat(prefix, "-items-item")
283
+ }, _react["default"].createElement(_ValueTag["default"], {
284
+ onChange: handleFieldChange,
285
+ value: value,
286
+ item: item,
287
+ fieldItems: fieldItems,
288
+ locale: locale,
289
+ onDelete: onDelete,
290
+ handleTag: focusInput,
291
+ clsPrefix: clsPrefix,
292
+ form: form
293
+ }));
294
+ }), _react["default"].createElement("li", {
295
+ className: "".concat(prefix, "-items-input")
296
+ }, _react["default"].createElement(_FieldPopover["default"], {
297
+ ref: fieldRef,
298
+ onChange: handleFieldChange,
299
+ clsPrefix: clsPrefix,
300
+ fieldItems: fieldItems,
301
+ propItem: _fieldItem,
302
+ setFieldItem: setFieldItem,
303
+ form: form,
304
+ regex: regex,
305
+ visible: visible,
306
+ value: value,
307
+ setVisible: setVisible,
308
+ searchText: searchText,
309
+ locale: locale,
310
+ placement: "bottomLeft"
311
+ }, _react["default"].createElement(_input["default"], Object.assign({
312
+ ref: inputRef,
313
+ value: searchText,
314
+ className: "inputClass",
315
+ placeholder: defaultSearchPlaceholder || (!(value === null || value === void 0 ? void 0 : value.length) ? locale.placeholder : undefined)
316
+ }, props, {
317
+ onPressEnter: onPressEnter,
318
+ onChange: onInputChange
319
+ }))))), _react["default"].createElement("div", {
320
+ className: "".concat(prefix, "-prefix")
321
+ }, _react["default"].createElement(_icon["default"], {
322
+ type: "filter"
323
+ })), compositionShowReset && _react["default"].createElement("div", {
324
+ className: "".concat(prefix, "-clear")
325
+ }, _react["default"].createElement(_icon["default"], {
326
+ onClick: onClear,
327
+ type: "close-circle",
328
+ theme: "filled"
329
+ })), _react["default"].createElement("div", {
330
+ className: "".concat(prefix, "-search"),
331
+ onClick: doSearch
332
+ }, _react["default"].createElement(_icon["default"], {
333
+ type: "search"
334
+ })));
335
+ });
336
+ };
337
+ 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/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
+ }