tntd 3.0.24 → 3.0.25

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 (183) hide show
  1. package/es/query-form/Field/Composition/FieldPopover.js +310 -0
  2. package/es/query-form/Field/Composition/FieldPopover.js.map +1 -0
  3. package/es/query-form/Field/Composition/FieldPopover.less +35 -0
  4. package/es/query-form/Field/Composition/Select.js +122 -0
  5. package/es/query-form/Field/Composition/Select.js.map +1 -0
  6. package/es/query-form/Field/Composition/index.js +248 -0
  7. package/es/query-form/Field/Composition/index.js.map +1 -0
  8. package/es/query-form/Field/Composition/index.less +118 -0
  9. package/es/query-form/Field/Composition/utils.js +153 -0
  10. package/es/query-form/Field/Composition/utils.js.map +1 -0
  11. package/es/query-form-v2/index.less +133 -0
  12. package/es/scroll-bar/Bar.js +56 -0
  13. package/es/scroll-bar/Bar.js.map +1 -0
  14. package/es/scroll-bar/Context.js +6 -0
  15. package/es/scroll-bar/Context.js.map +1 -0
  16. package/es/scroll-bar/ScrollBar.js +86 -0
  17. package/es/scroll-bar/ScrollBar.js.map +1 -0
  18. package/es/scroll-bar/Thumb.js +105 -0
  19. package/es/scroll-bar/Thumb.js.map +1 -0
  20. package/es/scroll-bar/index.js +3 -0
  21. package/es/scroll-bar/index.js.map +1 -0
  22. package/es/scroll-bar/scrollBar.less +59 -0
  23. package/es/scroll-bar/util.js +31 -0
  24. package/es/scroll-bar/util.js.map +1 -0
  25. package/es/table/table.js +7 -11
  26. package/es/table/table.js.map +1 -1
  27. package/lib/query-form/Field/Composition/FieldPopover.d.ts +19 -0
  28. package/lib/query-form/Field/Composition/FieldPopover.d.ts.map +1 -0
  29. package/lib/query-form/Field/Composition/FieldPopover.js +345 -0
  30. package/lib/query-form/Field/Composition/FieldPopover.js.map +1 -0
  31. package/lib/query-form/Field/Composition/FieldPopover.less +35 -0
  32. package/lib/query-form/Field/Composition/Select.d.ts +4 -0
  33. package/lib/query-form/Field/Composition/Select.d.ts.map +1 -0
  34. package/lib/query-form/Field/Composition/Select.js +146 -0
  35. package/lib/query-form/Field/Composition/Select.js.map +1 -0
  36. package/lib/query-form/Field/Composition/index.d.ts +12 -0
  37. package/lib/query-form/Field/Composition/index.d.ts.map +1 -0
  38. package/lib/query-form/Field/Composition/index.js +294 -0
  39. package/lib/query-form/Field/Composition/index.js.map +1 -0
  40. package/lib/query-form/Field/Composition/index.less +118 -0
  41. package/lib/query-form/Field/Composition/utils.d.ts +21 -0
  42. package/lib/query-form/Field/Composition/utils.d.ts.map +1 -0
  43. package/lib/query-form/Field/Composition/utils.js +164 -0
  44. package/lib/query-form/Field/Composition/utils.js.map +1 -0
  45. package/lib/query-form-v2/Field/Checkbox.d.ts +8 -0
  46. package/lib/query-form-v2/Field/Checkbox.d.ts.map +1 -0
  47. package/lib/query-form-v2/Field/Checkbox.js +28 -0
  48. package/lib/query-form-v2/Field/Checkbox.js.map +1 -0
  49. package/lib/{upload/svg/UploadSVG.d.ts → query-form-v2/Field/Select.d.ts} +1 -1
  50. package/lib/query-form-v2/Field/Select.d.ts.map +1 -0
  51. package/lib/query-form-v2/Field/Select.js +80 -0
  52. package/lib/query-form-v2/Field/Select.js.map +1 -0
  53. package/lib/query-form-v2/Field/SelectInput.d.ts +4 -0
  54. package/lib/query-form-v2/Field/SelectInput.d.ts.map +1 -0
  55. package/lib/query-form-v2/Field/SelectInput.js +88 -0
  56. package/lib/query-form-v2/Field/SelectInput.js.map +1 -0
  57. package/lib/query-form-v2/Field/fieldsMap.d.ts +24 -0
  58. package/lib/query-form-v2/Field/fieldsMap.d.ts.map +1 -0
  59. package/lib/query-form-v2/Field/fieldsMap.js +35 -0
  60. package/lib/query-form-v2/Field/fieldsMap.js.map +1 -0
  61. package/lib/query-form-v2/Field/index.d.ts +14 -0
  62. package/lib/query-form-v2/Field/index.d.ts.map +1 -0
  63. package/lib/query-form-v2/Field/index.js +146 -0
  64. package/lib/query-form-v2/Field/index.js.map +1 -0
  65. package/lib/query-form-v2/createActions.d.ts +14 -0
  66. package/lib/query-form-v2/createActions.d.ts.map +1 -0
  67. package/lib/query-form-v2/createActions.js +54 -0
  68. package/lib/query-form-v2/createActions.js.map +1 -0
  69. package/lib/query-form-v2/index.d.ts +39 -0
  70. package/lib/query-form-v2/index.d.ts.map +1 -0
  71. package/lib/query-form-v2/index.js +391 -0
  72. package/lib/query-form-v2/index.js.map +1 -0
  73. package/lib/query-form-v2/index.less +133 -0
  74. package/lib/query-form-v2/useForm.d.ts +13 -0
  75. package/lib/query-form-v2/useForm.d.ts.map +1 -0
  76. package/lib/query-form-v2/useForm.js +13 -0
  77. package/lib/query-form-v2/useForm.js.map +1 -0
  78. package/lib/query-form-v3/Field/Checkbox.d.ts +8 -0
  79. package/lib/query-form-v3/Field/Checkbox.d.ts.map +1 -0
  80. package/lib/query-form-v3/Field/Checkbox.js +28 -0
  81. package/lib/query-form-v3/Field/Checkbox.js.map +1 -0
  82. package/lib/query-form-v3/Field/Composition/FieldPopover.d.ts +19 -0
  83. package/lib/query-form-v3/Field/Composition/FieldPopover.d.ts.map +1 -0
  84. package/lib/query-form-v3/Field/Composition/FieldPopover.js +381 -0
  85. package/lib/query-form-v3/Field/Composition/FieldPopover.js.map +1 -0
  86. package/lib/query-form-v3/Field/Composition/FieldPopover.less +35 -0
  87. package/lib/query-form-v3/Field/Composition/Select.d.ts +4 -0
  88. package/lib/query-form-v3/Field/Composition/Select.d.ts.map +1 -0
  89. package/lib/query-form-v3/Field/Composition/Select.js +131 -0
  90. package/lib/query-form-v3/Field/Composition/Select.js.map +1 -0
  91. package/lib/query-form-v3/Field/Composition/index.d.ts +10 -0
  92. package/lib/query-form-v3/Field/Composition/index.d.ts.map +1 -0
  93. package/lib/query-form-v3/Field/Composition/index.js +255 -0
  94. package/lib/query-form-v3/Field/Composition/index.js.map +1 -0
  95. package/lib/query-form-v3/Field/Composition/index.less +118 -0
  96. package/lib/query-form-v3/Field/Composition/utils.d.ts +22 -0
  97. package/lib/query-form-v3/Field/Composition/utils.d.ts.map +1 -0
  98. package/lib/query-form-v3/Field/Composition/utils.js +147 -0
  99. package/lib/query-form-v3/Field/Composition/utils.js.map +1 -0
  100. package/lib/query-form-v3/Field/Select.d.ts +4 -0
  101. package/lib/query-form-v3/Field/Select.d.ts.map +1 -0
  102. package/lib/query-form-v3/Field/Select.js +80 -0
  103. package/lib/query-form-v3/Field/Select.js.map +1 -0
  104. package/lib/query-form-v3/Field/SelectInput.d.ts +4 -0
  105. package/lib/query-form-v3/Field/SelectInput.d.ts.map +1 -0
  106. package/lib/query-form-v3/Field/SelectInput.js +100 -0
  107. package/lib/query-form-v3/Field/SelectInput.js.map +1 -0
  108. package/lib/query-form-v3/Field/fieldsMap.d.ts +27 -0
  109. package/lib/query-form-v3/Field/fieldsMap.d.ts.map +1 -0
  110. package/lib/query-form-v3/Field/fieldsMap.js +35 -0
  111. package/lib/query-form-v3/Field/fieldsMap.js.map +1 -0
  112. package/lib/query-form-v3/Field/index.d.ts +14 -0
  113. package/lib/query-form-v3/Field/index.d.ts.map +1 -0
  114. package/lib/query-form-v3/Field/index.js +147 -0
  115. package/lib/query-form-v3/Field/index.js.map +1 -0
  116. package/lib/query-form-v3/createActions.d.ts +14 -0
  117. package/lib/query-form-v3/createActions.d.ts.map +1 -0
  118. package/lib/query-form-v3/createActions.js +54 -0
  119. package/lib/query-form-v3/createActions.js.map +1 -0
  120. package/lib/query-form-v3/index.d.ts +27 -0
  121. package/lib/query-form-v3/index.d.ts.map +1 -0
  122. package/lib/query-form-v3/index.js +206 -0
  123. package/lib/query-form-v3/index.js.map +1 -0
  124. package/lib/query-form-v3/index.less +91 -0
  125. package/lib/query-form-v3/useForm.d.ts +13 -0
  126. package/lib/query-form-v3/useForm.d.ts.map +1 -0
  127. package/lib/query-form-v3/useForm.js +13 -0
  128. package/lib/query-form-v3/useForm.js.map +1 -0
  129. package/lib/scroll-bar/Bar.d.ts +4 -0
  130. package/lib/scroll-bar/Bar.d.ts.map +1 -0
  131. package/lib/scroll-bar/Bar.js +91 -0
  132. package/lib/scroll-bar/Bar.js.map +1 -0
  133. package/lib/scroll-bar/Context.d.ts +7 -0
  134. package/lib/scroll-bar/Context.d.ts.map +1 -0
  135. package/lib/scroll-bar/Context.js +13 -0
  136. package/lib/scroll-bar/Context.js.map +1 -0
  137. package/lib/scroll-bar/ScrollBar.d.ts +4 -0
  138. package/lib/scroll-bar/ScrollBar.d.ts.map +1 -0
  139. package/lib/scroll-bar/ScrollBar.js +97 -0
  140. package/lib/scroll-bar/ScrollBar.js.map +1 -0
  141. package/lib/scroll-bar/Thumb.d.ts +3 -0
  142. package/lib/scroll-bar/Thumb.d.ts.map +1 -0
  143. package/lib/scroll-bar/Thumb.js +125 -0
  144. package/lib/scroll-bar/Thumb.js.map +1 -0
  145. package/lib/scroll-bar/index.d.ts +3 -0
  146. package/lib/scroll-bar/index.d.ts.map +1 -0
  147. package/lib/scroll-bar/index.js +10 -0
  148. package/lib/scroll-bar/index.js.map +1 -0
  149. package/lib/scroll-bar/scrollBar.less +59 -0
  150. package/lib/scroll-bar/util.d.ts +40 -0
  151. package/lib/scroll-bar/util.d.ts.map +1 -0
  152. package/lib/scroll-bar/util.js +39 -0
  153. package/lib/scroll-bar/util.js.map +1 -0
  154. package/lib/table/table.d.ts +1 -1
  155. package/lib/table/table.d.ts.map +1 -1
  156. package/lib/table/table.js +7 -14
  157. package/lib/table/table.js.map +1 -1
  158. package/lib/utils/index.d.ts +0 -1
  159. package/lib/utils/index.d.ts.map +1 -1
  160. package/package.json +2 -2
  161. package/CHANGELOG.json +0 -1034
  162. package/CHANGELOG.md +0 -605
  163. package/es/checkbox/checkbox-group.js +0 -5
  164. package/es/checkbox/checkbox-group.js.map +0 -1
  165. package/es/radio/radio-group.js +0 -5
  166. package/es/radio/radio-group.js.map +0 -1
  167. package/es/steps/stepStyle/small.less +0 -5
  168. package/es/upload/svg/UploadSVG.js +0 -37
  169. package/es/upload/svg/UploadSVG.js.map +0 -1
  170. package/es/upload/upload.less +0 -108
  171. package/lib/checkbox/checkbox-group.d.ts +0 -8
  172. package/lib/checkbox/checkbox-group.d.ts.map +0 -1
  173. package/lib/checkbox/checkbox-group.js +0 -12
  174. package/lib/checkbox/checkbox-group.js.map +0 -1
  175. package/lib/radio/radio-group.d.ts +0 -8
  176. package/lib/radio/radio-group.d.ts.map +0 -1
  177. package/lib/radio/radio-group.js +0 -12
  178. package/lib/radio/radio-group.js.map +0 -1
  179. package/lib/steps/stepStyle/small.less +0 -5
  180. package/lib/upload/svg/UploadSVG.d.ts.map +0 -1
  181. package/lib/upload/svg/UploadSVG.js +0 -44
  182. package/lib/upload/svg/UploadSVG.js.map +0 -1
  183. package/lib/upload/upload.less +0 -108
@@ -0,0 +1,146 @@
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 _isArray2 = _interopRequireDefault(require("lodash/isArray"));
9
+ var _react = _interopRequireWildcard(require("react"));
10
+ var _classnames = _interopRequireDefault(require("classnames"));
11
+ var _icon = _interopRequireDefault(require("../../../icon"));
12
+ var _ellipsis = _interopRequireDefault(require("../../../ellipsis"));
13
+ var _utils = require("./utils");
14
+ 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); }
15
+ 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; }
16
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { "default": e }; }
17
+ 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; }
18
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
19
+ 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); }
20
+ function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
21
+ 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."); }
22
+ 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; } }
23
+ 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; }
24
+ 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; } }
25
+ function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
26
+ var __rest = void 0 && (void 0).__rest || function (s, e) {
27
+ var t = {};
28
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
29
+ if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
30
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
31
+ }
32
+ return t;
33
+ };
34
+ var _default = exports["default"] = function _default(props) {
35
+ var options = props.options,
36
+ params = props.params,
37
+ _props$queryKey = props.queryKey,
38
+ queryKey = _props$queryKey === void 0 ? 'name' : _props$queryKey,
39
+ _props$fieldNames = props.fieldNames,
40
+ fieldNames = _props$fieldNames === void 0 ? {
41
+ label: 'label',
42
+ value: 'value'
43
+ } : _props$fieldNames,
44
+ loadData = props.loadData,
45
+ onChange = props.onChange,
46
+ _value = props.value,
47
+ mode = props.mode,
48
+ propItem = props.propItem,
49
+ searchText = props.searchText,
50
+ rest = __rest(props, ["options", "params", "queryKey", "fieldNames", "loadData", "onChange", "value", "mode", "propItem", "searchText"]);
51
+ var _useState = (0, _react.useState)(options || []),
52
+ _useState2 = _slicedToArray(_useState, 2),
53
+ items = _useState2[0],
54
+ setItems = _useState2[1];
55
+ (0, _react.useEffect)(function () {
56
+ if (loadData) {
57
+ loadData(Object.assign(_defineProperty({}, queryKey, searchText), params || {})).then(function (items) {
58
+ setItems(items);
59
+ });
60
+ }
61
+ }, [params, searchText]);
62
+ (0, _react.useEffect)(function () {
63
+ setItems(options || []);
64
+ }, [options]);
65
+ var onValueChange = function onValueChange(item) {
66
+ onChange(item, mode === 'multiple' || mode === 'tags');
67
+ };
68
+ return _react["default"].createElement("ul", {
69
+ className: "ant-select-dropdown-menu"
70
+ }, items.map(function (item) {
71
+ var labelKey = (fieldNames === null || fieldNames === void 0 ? void 0 : fieldNames.label) || 'label';
72
+ var valueKey = (fieldNames === null || fieldNames === void 0 ? void 0 : fieldNames.value) || 'value';
73
+ var value = item instanceof Object ? item[valueKey] : item;
74
+ var label = item instanceof Object ? item[labelKey] : item + '';
75
+ var disabled = item instanceof Object ? item['disabled'] : false;
76
+ var isSelected = (0, _isArray2["default"])(_value) ? (_value === null || _value === void 0 ? void 0 : _value.indexOf(value)) > -1 : value === _value;
77
+ if (searchText) {
78
+ var isReactDom = _react["default"].isValidElement(label);
79
+ var _label = isReactDom ? (0, _utils.formatLabel)(label) : label;
80
+ if ((_label === null || _label === void 0 ? void 0 : _label.indexOf(searchText)) > -1) {
81
+ return _react["default"].createElement("li", {
82
+ className: (0, _classnames["default"])({
83
+ 'ant-select-dropdown-menu-item': true,
84
+ 'ant-select-dropdown-menu-item-selected': isSelected,
85
+ 'ant-select-dropdown-menu-item-disabled': disabled
86
+ }),
87
+ key: value,
88
+ value: value,
89
+ onMouseDown: function onMouseDown(e) {
90
+ return e.preventDefault();
91
+ },
92
+ onClick: function onClick() {
93
+ !disabled && onValueChange({
94
+ value: value,
95
+ propItem: propItem,
96
+ options: items
97
+ });
98
+ }
99
+ }, _react["default"].createElement("span", null, (propItem === null || propItem === void 0 ? void 0 : propItem.propsTitle) || (propItem === null || propItem === void 0 ? void 0 : propItem.name), ": "), _react["default"].createElement("span", {
100
+ style: {
101
+ display: 'inline-block'
102
+ }
103
+ }, _react["default"].createElement(_ellipsis["default"], {
104
+ widthLimit: 220,
105
+ title: isReactDom ? _react["default"].createElement("span", null, label) : _react["default"].createElement("span", {
106
+ dangerouslySetInnerHTML: {
107
+ __html: (0, _utils.highlightSubstring)(label, searchText)
108
+ }
109
+ })
110
+ })), isSelected && _react["default"].createElement(_icon["default"], {
111
+ type: "check",
112
+ className: "ant-select-selected-icon"
113
+ }));
114
+ }
115
+ return null;
116
+ }
117
+ return _react["default"].createElement("li", {
118
+ className: (0, _classnames["default"])({
119
+ 'ant-select-dropdown-menu-item': true,
120
+ 'ant-select-dropdown-menu-item-selected': isSelected,
121
+ 'ant-select-dropdown-menu-item-disabled': disabled
122
+ }),
123
+ key: value,
124
+ value: value,
125
+ onMouseDown: function onMouseDown(e) {
126
+ return e.preventDefault();
127
+ },
128
+ onClick: function onClick() {
129
+ !disabled && onValueChange({
130
+ value: value,
131
+ options: items
132
+ });
133
+ }
134
+ }, _react["default"].createElement("span", {
135
+ style: {
136
+ display: 'inline-block'
137
+ }
138
+ }, _react["default"].createElement(_ellipsis["default"], {
139
+ widthLimit: 220,
140
+ title: label
141
+ })), isSelected && _react["default"].createElement(_icon["default"], {
142
+ type: "check",
143
+ className: "ant-select-selected-icon"
144
+ }));
145
+ }));
146
+ };
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Select.js","sourceRoot":"","sources":["../../../../src/query-form/Field/Composition/Select.js"],"names":[],"mappings":"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","sourcesContent":["import React, { useState, useEffect } from 'react'\nimport { isArray } from 'lodash'\nimport classNames from 'classnames'\nimport Icon from '../../../icon'\nimport Ellipsis from '../../../ellipsis'\nimport { highlightSubstring, formatLabel } from './utils'\n\nexport default (props) => {\n const {\n options,\n params,\n queryKey = 'name',\n fieldNames = {\n label: 'label',\n value: 'value',\n },\n loadData,\n onChange,\n value: _value,\n mode,\n propItem,\n searchText,\n ...rest\n } = props\n const [items, setItems] = useState(options || [])\n\n useEffect(() => {\n if (loadData) {\n loadData({\n [queryKey]: searchText,\n ...(params || {}),\n }).then((items) => {\n setItems(items)\n })\n }\n }, [params, searchText])\n\n useEffect(() => {\n setItems(options || [])\n }, [options])\n\n const onValueChange = (item) => {\n onChange(item, mode === 'multiple' || mode === 'tags')\n }\n\n return (\n <ul className=\"ant-select-dropdown-menu\">\n {items.map((item) => {\n const labelKey = fieldNames?.label || 'label'\n const valueKey = fieldNames?.value || 'value'\n const value = item instanceof Object ? item[valueKey] : item\n const label = item instanceof Object ? item[labelKey] : item + ''\n const disabled = item instanceof Object ? item['disabled'] : false\n\n const isSelected = isArray(_value) ? _value?.indexOf(value) > -1 : value === _value\n if (searchText) {\n const isReactDom = React.isValidElement(label)\n const _label = isReactDom ? formatLabel(label) : label\n if (_label?.indexOf(searchText) > -1) {\n return (\n <li\n className={classNames({\n 'ant-select-dropdown-menu-item': true,\n 'ant-select-dropdown-menu-item-selected': isSelected,\n 'ant-select-dropdown-menu-item-disabled': disabled,\n })}\n key={value}\n value={value}\n onMouseDown={(e) => e.preventDefault()}\n onClick={() => {\n !disabled &&\n onValueChange({\n value,\n propItem,\n options: items,\n })\n }}\n >\n <span>{propItem?.propsTitle || propItem?.name}: </span>\n <span style={{ display: 'inline-block' }}>\n <Ellipsis\n widthLimit={220}\n title={\n isReactDom ? (\n <span>{label}</span>\n ) : (\n <span\n dangerouslySetInnerHTML={{\n __html: highlightSubstring(label, searchText),\n }}\n ></span>\n )\n }\n />\n </span>\n {isSelected && <Icon type=\"check\" className=\"ant-select-selected-icon\" />}\n </li>\n )\n }\n return null\n }\n return (\n <li\n className={classNames({\n 'ant-select-dropdown-menu-item': true,\n 'ant-select-dropdown-menu-item-selected': isSelected,\n 'ant-select-dropdown-menu-item-disabled': disabled,\n })}\n key={value}\n value={value}\n onMouseDown={(e) => e.preventDefault()}\n onClick={() => {\n !disabled && onValueChange({ value, options: items })\n }}\n >\n <span style={{ display: 'inline-block' }}>\n <Ellipsis widthLimit={220} title={label} />\n </span>\n {isSelected && <Icon type=\"check\" className=\"ant-select-selected-icon\" />}\n </li>\n )\n })}\n </ul>\n )\n}\n"]}
@@ -0,0 +1,12 @@
1
+ declare var _default: React.ForwardRefExoticComponent<{
2
+ fieldItems: any;
3
+ initialValues: any;
4
+ onChange: any;
5
+ form: any;
6
+ compositionShowReset: any;
7
+ clsPrefix: any;
8
+ _onReset: any;
9
+ } & React.RefAttributes<any>>;
10
+ export default _default;
11
+ import React from "react";
12
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/query-form/Field/Composition/index.js"],"names":[],"mappings":""}
@@ -0,0 +1,294 @@
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 _find2 = _interopRequireDefault(require("lodash/find"));
9
+ var _react = _interopRequireWildcard(require("react"));
10
+ var _LocaleReceiver = _interopRequireDefault(require("antd/lib/locale-provider/LocaleReceiver"));
11
+ var _icon = _interopRequireDefault(require("../../../icon"));
12
+ var _tag = _interopRequireDefault(require("../../../tag"));
13
+ var _input = _interopRequireDefault(require("../../../input"));
14
+ var _FieldPopover = _interopRequireDefault(require("./FieldPopover"));
15
+ var _utils = require("./utils");
16
+ require("./index.less");
17
+ 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); }
18
+ 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; }
19
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { "default": e }; }
20
+ function _toConsumableArray(r) { return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread(); }
21
+ 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."); }
22
+ function _iterableToArray(r) { if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); }
23
+ function _arrayWithoutHoles(r) { if (Array.isArray(r)) return _arrayLikeToArray(r); }
24
+ 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; }
25
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
26
+ 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); }
27
+ function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
28
+ 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."); }
29
+ 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; } }
30
+ 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; }
31
+ 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; } }
32
+ function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
33
+ /**
34
+ * @param value: [{
35
+ key: 'key1',
36
+ value: 'value1',
37
+ label: 'key1:value1'
38
+ }, {
39
+ key: 'key2',
40
+ value: ['value2', 'value3'],
41
+ label: 'key1:value2|value3'
42
+ }]
43
+ * @param {*} ref
44
+ * @returns
45
+ */
46
+ var regex = /^.+:.*$/;
47
+ var CompositionInput = function CompositionInput(_ref, ref) {
48
+ var fieldItems = _ref.fieldItems,
49
+ initialValues = _ref.initialValues,
50
+ onChange = _ref.onChange,
51
+ form = _ref.form,
52
+ compositionShowReset = _ref.compositionShowReset,
53
+ clsPrefix = _ref.clsPrefix,
54
+ _onReset = _ref._onReset;
55
+ var _a;
56
+ var prefix = "".concat(clsPrefix, "-composition-input");
57
+ var _useState = (0, _react.useState)([]),
58
+ _useState2 = _slicedToArray(_useState, 2),
59
+ value = _useState2[0],
60
+ setValue = _useState2[1];
61
+ var _useState3 = (0, _react.useState)(),
62
+ _useState4 = _slicedToArray(_useState3, 2),
63
+ tempItem = _useState4[0],
64
+ setTempItem = _useState4[1];
65
+ var _useState5 = (0, _react.useState)(''),
66
+ _useState6 = _slicedToArray(_useState5, 2),
67
+ searchText = _useState6[0],
68
+ setSearchText = _useState6[1];
69
+ var _useState7 = (0, _react.useState)(false),
70
+ _useState8 = _slicedToArray(_useState7, 2),
71
+ visible = _useState8[0],
72
+ setVisible = _useState8[1];
73
+ var _useState9 = (0, _react.useState)(undefined),
74
+ _useState10 = _slicedToArray(_useState9, 2),
75
+ fieldItem = _useState10[0],
76
+ setFieldItem = _useState10[1];
77
+ var fieldItemsRef = (0, _react.useRef)(fieldItems);
78
+ var _fieldItem = fieldItem ? ((_a = (0, _find2["default"])(fieldItems, function (f) {
79
+ var _a;
80
+ return ((_a = f.props) === null || _a === void 0 ? void 0 : _a.name) === fieldItem.name;
81
+ })) === null || _a === void 0 ? void 0 : _a.props) || fieldItem : {};
82
+ var _ref2 = fieldItem || {},
83
+ props = _ref2.props;
84
+ var inputRef = (0, _react.useRef)(null);
85
+ var widthRef = (0, _react.useRef)(null);
86
+ var fieldRef = (0, _react.useRef)(null);
87
+ fieldItemsRef.current = fieldItems;
88
+ var updateValues = (0, _react.useCallback)(function (obj) {
89
+ var newValueArr = (0, _utils.parseObjectToArray)(obj, fieldItemsRef.current);
90
+ // const newValueMap = keyBy(newValueArr, 'key')
91
+ // setValue((value) => [...filter(value || [], (it) => !newValueMap[it.key]), ...newValueArr])
92
+ setValue(newValueArr);
93
+ }, []);
94
+ var updateValue = (0, _react.useCallback)(function (name, value) {
95
+ updateValue(_defineProperty({}, name, value));
96
+ }, []);
97
+ (0, _react.useEffect)(function () {
98
+ form.on('setValue', updateValue);
99
+ form.on('setValues', updateValues);
100
+ return function () {
101
+ form.off('setValue', updateValue);
102
+ form.off('setValues', updateValues);
103
+ };
104
+ }, []);
105
+ var handleFocus = function handleFocus(e) {
106
+ e.preventDefault();
107
+ setTimeout(function () {
108
+ var _a;
109
+ (_a = inputRef === null || inputRef === void 0 ? void 0 : inputRef.current) === null || _a === void 0 ? void 0 : _a.focus();
110
+ }, 10);
111
+ if (!visible && !regex.test(searchText)) {
112
+ setVisible(true);
113
+ }
114
+ };
115
+ (0, _react.useImperativeHandle)(ref, function () {
116
+ return {
117
+ changeVal: function changeVal() {
118
+ return value;
119
+ }
120
+ };
121
+ });
122
+ (0, _react.useEffect)(function () {
123
+ if (initialValues) {
124
+ setValue((0, _utils.parseObjectToArray)(initialValues, fieldItems));
125
+ }
126
+ }, [fieldItems, form, initialValues]);
127
+ var onClear = function onClear(e) {
128
+ e.stopPropagation();
129
+ var initKeys = Object.keys(initialValues || {});
130
+ var deleteKeys = value === null || value === void 0 ? void 0 : value.filter(function (_ref3) {
131
+ var key = _ref3.key;
132
+ return !initKeys.includes(key);
133
+ }).map(function (_ref4) {
134
+ var key = _ref4.key;
135
+ return key;
136
+ });
137
+ setValue((0, _utils.parseObjectToArray)(initialValues || {}, fieldItems));
138
+ onChange(Object.assign({}, initialValues || {}), deleteKeys, false);
139
+ // 清除其他数据
140
+ setSearchText('');
141
+ setTempItem();
142
+ _onReset && _onReset();
143
+ };
144
+ var onDelete = function onDelete(key, e) {
145
+ e.preventDefault();
146
+ if (value.length > 0) {
147
+ var newValue = value.filter(function (v) {
148
+ return v.key !== key;
149
+ });
150
+ setValue(newValue);
151
+ var deleteKeys = [key];
152
+ onChange((0, _utils.parseArrayToObject)(newValue), deleteKeys, true);
153
+ }
154
+ };
155
+ var handleFieldChange = function handleFieldChange(value, isInput, hasValue) {
156
+ var needSearch = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : true;
157
+ if (isInput) {
158
+ // setSearchText(value?.label)
159
+ setSearchText((0, _utils.getLabel)(value, fieldItems));
160
+ setTempItem(value);
161
+ setTimeout(function () {
162
+ var _a;
163
+ (_a = inputRef === null || inputRef === void 0 ? void 0 : inputRef.current) === null || _a === void 0 ? void 0 : _a.focus();
164
+ }, 10);
165
+ return;
166
+ }
167
+ setValue(value);
168
+ setSearchText('');
169
+ setTempItem();
170
+ if (hasValue) onChange((0, _utils.parseArrayToObject)(value), undefined, needSearch);
171
+ };
172
+ // 输入框事件方法
173
+ var onInputChange = function onInputChange(e) {
174
+ var value = e.target.value;
175
+ if (tempItem) {
176
+ if (regex.test(value)) {
177
+ // 有输入值
178
+ setSearchText(value);
179
+ } else {
180
+ // 没有输入值, 清空选择的属性类型重新显示属性列表
181
+ setSearchText('');
182
+ setTempItem();
183
+ }
184
+ } else {
185
+ setSearchText(value);
186
+ }
187
+ };
188
+ var onPressEnter = function onPressEnter(e) {
189
+ var _a;
190
+ var inputValue = ((_a = searchText === null || searchText === void 0 ? void 0 : searchText.match(/[^:]+:(.*)/)) === null || _a === void 0 ? void 0 : _a[1]) || null;
191
+ if (tempItem && inputValue) {
192
+ setVisible(false);
193
+ tempItem.label = searchText;
194
+ tempItem.closable = true;
195
+ tempItem.value = inputValue; // 得到输入值
196
+ if (!(value === null || value === void 0 ? void 0 : value.find(function (v) {
197
+ return v.key === tempItem.key;
198
+ }))) {
199
+ var newValue = [].concat(_toConsumableArray(value), [tempItem]);
200
+ setValue(newValue);
201
+ onChange((0, _utils.parseArrayToObject)(newValue));
202
+ } else {
203
+ var _newValue = value.map(function (v) {
204
+ return v.key === tempItem.key ? tempItem : v;
205
+ });
206
+ setValue(_newValue);
207
+ onChange((0, _utils.parseArrayToObject)(_newValue));
208
+ }
209
+ e.target.value = inputValue;
210
+ form.emit('search', _defineProperty(_defineProperty({}, tempItem.key, inputValue), "current", 1));
211
+ (props === null || props === void 0 ? void 0 : props.onPressEnter) && props.onPressEnter(e);
212
+ }
213
+ setTempItem();
214
+ setSearchText('');
215
+ };
216
+ var handleTag = function handleTag(obj) {
217
+ var curItem = undefined;
218
+ for (var index = 0; index < fieldItems.length; index++) {
219
+ var item = fieldItems[index];
220
+ if (item.props.name === obj.key) {
221
+ curItem = item;
222
+ break;
223
+ }
224
+ }
225
+ fieldRef.current.onPropsClick(curItem.props);
226
+ };
227
+ return _react["default"].createElement(_LocaleReceiver["default"], {
228
+ componentName: "QueryForm"
229
+ }, function (locale) {
230
+ return _react["default"].createElement("div", {
231
+ className: prefix,
232
+ onClick: handleFocus
233
+ }, _react["default"].createElement("span", {
234
+ className: "".concat(prefix, "-width"),
235
+ ref: widthRef
236
+ }, searchText), _react["default"].createElement("ul", {
237
+ className: "".concat(prefix, "-items")
238
+ }, value && value.map(function (item, index) {
239
+ return _react["default"].createElement("li", {
240
+ key: index,
241
+ className: "".concat(prefix, "-items-item")
242
+ }, _react["default"].createElement(_tag["default"], {
243
+ closable: item.closable,
244
+ onClick: function onClick(e) {
245
+ e.preventDefault();
246
+ e.stopPropagation();
247
+ handleTag(item);
248
+ },
249
+ onClose: function onClose(e) {
250
+ return onDelete(item.key, e);
251
+ },
252
+ ellipsisOptions: {
253
+ widthLimit: '140px'
254
+ }
255
+ }, (0, _utils.getLabel)(item, fieldItems, locale)));
256
+ }), _react["default"].createElement("li", {
257
+ className: "".concat(prefix, "-items-input")
258
+ }, _react["default"].createElement(_FieldPopover["default"], {
259
+ ref: fieldRef,
260
+ onChange: handleFieldChange,
261
+ clsPrefix: clsPrefix,
262
+ fieldItems: fieldItems,
263
+ propItem: _fieldItem,
264
+ setFieldItem: setFieldItem,
265
+ form: form,
266
+ regex: regex,
267
+ visible: visible,
268
+ value: value,
269
+ setVisible: setVisible,
270
+ searchText: searchText,
271
+ locale: locale,
272
+ placement: "bottomLeft"
273
+ }, _react["default"].createElement(_input["default"], Object.assign({
274
+ ref: inputRef,
275
+ value: searchText,
276
+ className: "inputClass",
277
+ placeholder: !(value === null || value === void 0 ? void 0 : value.length) ? locale.placeholder : undefined
278
+ }, props, {
279
+ onPressEnter: onPressEnter,
280
+ onChange: onInputChange
281
+ }))))), _react["default"].createElement("div", {
282
+ className: "".concat(prefix, "-prefix")
283
+ }, _react["default"].createElement(_icon["default"], {
284
+ type: "filter"
285
+ })), compositionShowReset && _react["default"].createElement("div", {
286
+ className: "".concat(prefix, "-clear")
287
+ }, _react["default"].createElement(_icon["default"], {
288
+ onClick: onClear,
289
+ type: "close-circle",
290
+ theme: "filled"
291
+ })));
292
+ });
293
+ };
294
+ 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 { filter, keyBy, find } from 'lodash'\nimport Icon from '../../../icon'\nimport Tag from '../../../tag'\nimport Input from '../../../input'\nimport FieldPopover from './FieldPopover'\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 = ({ fieldItems, initialValues, onChange, form, compositionShowReset, clsPrefix, _onReset }, ref) => {\n const prefix = `${clsPrefix}-composition-input`\n const [value, setValue] = useState([])\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\n fieldItemsRef.current = fieldItems\n\n const updateValues = useCallback((obj) => {\n const newValueArr = parseObjectToArray(obj, fieldItemsRef.current)\n // const newValueMap = keyBy(newValueArr, 'key')\n // setValue((value) => [...filter(value || [], (it) => !newValueMap[it.key]), ...newValueArr])\n setValue(newValueArr)\n }, [])\n\n const updateValue = useCallback((name, value) => {\n updateValue({ [name]: value })\n }, [])\n\n useEffect(() => {\n form.on('setValue', updateValue)\n form.on('setValues', updateValues)\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 useEffect(() => {\n if (initialValues) {\n setValue(parseObjectToArray(initialValues, fieldItems))\n }\n }, [fieldItems, form, initialValues])\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)\n // 清除其他数据\n setSearchText('')\n setTempItem()\n _onReset && _onReset()\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 }\n }\n const handleFieldChange = (value, isInput, hasValue, needSearch = true) => {\n if (isInput) {\n // setSearchText(value?.label)\n setSearchText(getLabel(value, fieldItems))\n setTempItem(value)\n setTimeout(() => {\n inputRef?.current?.focus()\n }, 10)\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.closable = true\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 const handleTag = (obj) => {\n let curItem = undefined\n for (let index = 0; index < fieldItems.length; index++) {\n const item = fieldItems[index]\n if (item.props.name === obj.key) {\n curItem = item\n break\n }\n }\n fieldRef.current.onPropsClick(curItem.props)\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={index} className={`${prefix}-items-item`}>\n <Tag\n closable={item.closable}\n onClick={(e) => {\n e.preventDefault()\n e.stopPropagation()\n handleTag(item)\n }}\n onClose={(e) => onDelete(item.key, e)}\n ellipsisOptions={{ widthLimit: '140px' }}\n >\n {/* {item?.label} */}\n {getLabel(item, fieldItems, locale)}\n </Tag>\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>\n )\n }}\n </LocaleReceiver>\n )\n}\nexport default forwardRef(CompositionInput)\n"]}
@@ -0,0 +1,118 @@
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: tint(@bg-color-spotilight, 50%);
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
+ float: left;
42
+ padding: 0;
43
+ list-style: none;
44
+ margin: 0;
45
+ width: 100%;
46
+ &-item {
47
+ padding: 3px 0;
48
+ }
49
+ li {
50
+ float: left;
51
+ line-height: 1;
52
+ }
53
+ &-input {
54
+ .inputClass {
55
+ background: none;
56
+ border: none !important;
57
+ outline: none;
58
+ box-shadow: none !important;
59
+ width: 150px !important;
60
+ height: 26px;
61
+ line-height: 26px;
62
+ padding: 0;
63
+ input {
64
+ border: none !important;
65
+ outline: none !important;
66
+ box-shadow: none !important;
67
+ height: 26px;
68
+ line-height: 26px;
69
+ padding: 0;
70
+ }
71
+ textarea {
72
+ padding: 0;
73
+ }
74
+ }
75
+ .inputClass-with-placeholder {
76
+ min-width: 398px !important;
77
+ }
78
+ }
79
+ }
80
+ &-clear {
81
+ position: absolute;
82
+ right: @margin-sm;
83
+ top: 50%;
84
+ transform: translateY(-50%);
85
+ display: none;
86
+ i.anticon {
87
+ color: tint(@bg-color-spotilight, 50%);
88
+ }
89
+ &:hover {
90
+ .anticon {
91
+ color: @text-color-secondary !important;
92
+ }
93
+ }
94
+ }
95
+ &:hover {
96
+ border-color: @blue-6;
97
+ outline: 0;
98
+ .tnt-queryform-composition-input-clear {
99
+ display: block;
100
+ }
101
+ // box-shadow: 0 0 0 2px rgb(18 107 251 / 20%);
102
+ }
103
+ &:focus,
104
+ &:active {
105
+ border-color: @blue-5;
106
+ outline: 0;
107
+ // box-shadow: 0 0 0 2px rgb(18 107 251 / 20%);
108
+ }
109
+ .ant-tag {
110
+ padding: 0 @padding-xs;
111
+ border: none;
112
+ background: @fill-color-tertiary;
113
+ height: 20px;
114
+ .ant-tag-addon-wrap {
115
+ margin-top: -2px;
116
+ }
117
+ }
118
+ }
@@ -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
+ closable: boolean;
15
+ } | null)[];
16
+ export function parseArrayToObject(value: any): any;
17
+ export function getLabel({ key, value }: {
18
+ key: any;
19
+ value: any;
20
+ }, data: any, locale: any): string | false | null;
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;;;;YAkCC;AAED,oDAKC;AAED;;;kDAwCC"}