@teamix/pro 1.2.11 → 1.2.15

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 (211) hide show
  1. package/dist/212.js +799 -767
  2. package/dist/pro.css +1 -1
  3. package/dist/pro.js +2518 -1793
  4. package/dist/pro.min.css +1 -1
  5. package/dist/pro.min.js +1 -1
  6. package/es/actions/dialog-component.js +2 -2
  7. package/es/actions/dialog-form.js +2 -2
  8. package/es/actions/dialog.js +5 -3
  9. package/es/actions/index.js +11 -7
  10. package/es/actions/index.scss +14 -0
  11. package/es/actions/link.js +2 -2
  12. package/es/actions/request.js +2 -2
  13. package/es/actions/utils.js +2 -2
  14. package/es/card/card-container.js +2 -2
  15. package/es/card/divider.js +2 -2
  16. package/es/card/index.d.ts +6 -3
  17. package/es/card/index.js +11 -6
  18. package/es/card/index.scss +4 -0
  19. package/es/card/selectable.js +2 -2
  20. package/es/card/tab.js +2 -2
  21. package/es/form/Components/Editable/index.js +2 -2
  22. package/es/form/Components/FormGroup/index.js +2 -2
  23. package/es/form/Components/LightFilter/componentMap.d.ts +2 -0
  24. package/es/form/Components/LightFilter/componentMap.js +5 -0
  25. package/es/form/Components/LightFilter/index.d.ts +15 -0
  26. package/es/form/Components/{QueryFilter → LightFilter}/index.js +46 -44
  27. package/es/form/Components/LightFilter/index.scss +74 -0
  28. package/es/form/Components/ProField/index.js +2 -2
  29. package/es/form/Components/Text/index.js +2 -2
  30. package/es/form/Filter/index.d.ts +2 -5
  31. package/es/form/Filter/index.js +5 -46
  32. package/es/form/Filter/index.scss +25 -0
  33. package/es/form/Filter/index2.d.ts +8 -0
  34. package/es/form/Filter/index2.js +366 -0
  35. package/es/form/Filter/index2.scss +73 -0
  36. package/es/form/ProForm/index.js +2 -2
  37. package/es/form/ProForm/index.scss +10 -28
  38. package/es/form/ProForm/useAutoSubmit.js +2 -2
  39. package/es/form/ProForm/useFieldRequest.js +2 -2
  40. package/es/form/ProForm/useFormDisplayValues.d.ts +3 -5
  41. package/es/form/ProForm/useFormDisplayValues.js +79 -42
  42. package/es/form/ProForm/useInitialRequest.js +2 -2
  43. package/es/form/SchemaForm/adapterType.js +1 -0
  44. package/es/form/SchemaForm/index.js +4 -4
  45. package/es/form/SchemaForm/initializeArrayCards.js +2 -2
  46. package/es/form/SchemaForm/initializeArrayCollapse.js +2 -2
  47. package/es/form/SchemaForm/initializeArrayItems.js +2 -2
  48. package/es/form/SchemaForm/initializeArrayTable.js +2 -2
  49. package/es/form/SchemaForm/initializeFormButton.js +2 -2
  50. package/es/form/SchemaForm/initializeFormCollapse.js +2 -2
  51. package/es/form/SchemaForm/initializeFormGroup.js +2 -2
  52. package/es/form/SchemaForm/initializeFormStep.js +2 -2
  53. package/es/form/SchemaForm/initializeFormTab.js +2 -2
  54. package/es/form/SchemaForm/initializeReactions.js +2 -2
  55. package/es/form/SchemaForm/initializeRules.js +2 -2
  56. package/es/form/SchemaForm/reactions.js +4 -8
  57. package/es/form/fieldTypeMap.js +1 -0
  58. package/es/form/global.scss +1 -0
  59. package/es/form/index.d.ts +2 -1
  60. package/es/form/index.js +5 -4
  61. package/es/form/typing.d.ts +9 -0
  62. package/es/form/utils.js +2 -2
  63. package/es/form/warning.js +2 -2
  64. package/es/index.d.ts +1 -1
  65. package/es/index.js +1 -1
  66. package/es/info/components/InfoGroup/index.js +2 -2
  67. package/es/info/components/InfoValueItem/index.js +2 -2
  68. package/es/info/components/ProInfoItem/index.js +3 -1
  69. package/es/info/components/tableInfo/index.js +2 -2
  70. package/es/info/index.js +2 -2
  71. package/es/info/utils/index.js +2 -2
  72. package/es/nocode/pages/playground.js +2 -2
  73. package/es/nocode/pages/renderer.d.ts +2 -2
  74. package/es/nocode/pages/renderer.js +5 -5
  75. package/es/nocode/playground.js +2 -2
  76. package/es/page-header/index.d.ts +1 -2
  77. package/es/page-header/index.js +4 -14
  78. package/es/sidebar/components/sidebar-container/index.js +2 -2
  79. package/es/sidebar/components/tree/index.js +2 -2
  80. package/es/sidebar/index.js +2 -2
  81. package/es/table/components/Filter/index.js +10 -8
  82. package/es/table/components/Filter/index.scss +7 -3
  83. package/es/table/components/Layout/index.js +13 -4
  84. package/es/table/components/QuickAction/index.js +3 -3
  85. package/es/table/components/ToolBar/FilterColumnIcon.js +54 -19
  86. package/es/table/components/ToolBar/index.js +2 -2
  87. package/es/table/components/ToolBar/index.scss +1 -0
  88. package/es/table/index.js +30 -14
  89. package/es/table/typing.d.ts +9 -1
  90. package/es/table/utils/columnRender.js +61 -3
  91. package/es/table/utils/genProColumnToColumn.js +2 -2
  92. package/es/table/utils/index.js +24 -4
  93. package/es/table/utils/useTableSelection.js +2 -2
  94. package/es/templates/List/index.js +2 -2
  95. package/es/utils/message.d.ts +1 -1
  96. package/es/utils/message.js +9 -9
  97. package/lib/actions/dialog-component.js +2 -2
  98. package/lib/actions/dialog-form.js +3 -3
  99. package/lib/actions/dialog.js +6 -4
  100. package/lib/actions/index.js +11 -7
  101. package/lib/actions/index.scss +14 -0
  102. package/lib/actions/link.js +2 -2
  103. package/lib/actions/request.js +2 -2
  104. package/lib/actions/utils.js +2 -2
  105. package/lib/card/card-container.js +2 -2
  106. package/lib/card/divider.js +2 -2
  107. package/lib/card/index.d.ts +6 -3
  108. package/lib/card/index.js +11 -6
  109. package/lib/card/index.scss +4 -0
  110. package/lib/card/selectable.js +2 -2
  111. package/lib/card/tab.js +2 -2
  112. package/lib/field/index.js +1 -1
  113. package/lib/form/Components/Editable/index.js +3 -3
  114. package/lib/form/Components/FormGroup/index.js +2 -2
  115. package/lib/form/Components/LightFilter/componentMap.d.ts +2 -0
  116. package/lib/form/Components/LightFilter/componentMap.js +12 -0
  117. package/lib/form/Components/LightFilter/index.d.ts +15 -0
  118. package/lib/form/Components/{QueryFilter → LightFilter}/index.js +51 -44
  119. package/lib/form/Components/LightFilter/index.scss +74 -0
  120. package/lib/form/Components/ProField/index.js +2 -2
  121. package/lib/form/Components/Text/index.js +2 -2
  122. package/lib/form/Filter/index.d.ts +2 -5
  123. package/lib/form/Filter/index.js +7 -48
  124. package/lib/form/Filter/index.scss +25 -0
  125. package/lib/form/Filter/index2.d.ts +8 -0
  126. package/lib/form/Filter/index2.js +392 -0
  127. package/lib/form/Filter/index2.scss +73 -0
  128. package/lib/form/ProForm/index.js +3 -3
  129. package/lib/form/ProForm/index.scss +10 -28
  130. package/lib/form/ProForm/useAutoSubmit.js +2 -2
  131. package/lib/form/ProForm/useFieldRequest.js +2 -2
  132. package/lib/form/ProForm/useFormDisplayValues.d.ts +3 -5
  133. package/lib/form/ProForm/useFormDisplayValues.js +83 -44
  134. package/lib/form/ProForm/useInitialRequest.js +2 -2
  135. package/lib/form/SchemaForm/adapterType.js +1 -0
  136. package/lib/form/SchemaForm/index.js +5 -5
  137. package/lib/form/SchemaForm/initializeArrayCards.js +2 -2
  138. package/lib/form/SchemaForm/initializeArrayCollapse.js +2 -2
  139. package/lib/form/SchemaForm/initializeArrayItems.js +2 -2
  140. package/lib/form/SchemaForm/initializeArrayTable.js +2 -2
  141. package/lib/form/SchemaForm/initializeFormButton.js +2 -2
  142. package/lib/form/SchemaForm/initializeFormCollapse.js +2 -2
  143. package/lib/form/SchemaForm/initializeFormGroup.js +2 -2
  144. package/lib/form/SchemaForm/initializeFormStep.js +2 -2
  145. package/lib/form/SchemaForm/initializeFormTab.js +2 -2
  146. package/lib/form/SchemaForm/initializeReactions.js +2 -2
  147. package/lib/form/SchemaForm/initializeRules.js +2 -2
  148. package/lib/form/SchemaForm/reactions.js +3 -7
  149. package/lib/form/fieldTypeMap.js +1 -0
  150. package/lib/form/global.scss +1 -0
  151. package/lib/form/index.d.ts +2 -1
  152. package/lib/form/index.js +8 -6
  153. package/lib/form/typing.d.ts +9 -0
  154. package/lib/form/utils.js +2 -2
  155. package/lib/form/warning.js +2 -2
  156. package/lib/hooks/index.js +1 -1
  157. package/lib/index.d.ts +1 -1
  158. package/lib/index.js +2 -2
  159. package/lib/info/components/InfoGroup/index.js +3 -3
  160. package/lib/info/components/InfoValueItem/index.js +3 -3
  161. package/lib/info/components/ProInfoItem/index.js +3 -1
  162. package/lib/info/components/tableInfo/index.js +3 -3
  163. package/lib/info/index.js +3 -3
  164. package/lib/info/utils/index.js +2 -2
  165. package/lib/nocode/configurators/index.js +1 -1
  166. package/lib/nocode/pages/playground.js +3 -3
  167. package/lib/nocode/pages/renderer.d.ts +2 -2
  168. package/lib/nocode/pages/renderer.js +5 -5
  169. package/lib/nocode/playground.js +3 -3
  170. package/lib/page-container/index.js +1 -1
  171. package/lib/page-header/index.d.ts +1 -2
  172. package/lib/page-header/index.js +6 -17
  173. package/lib/sidebar/components/sidebar-container/index.js +2 -2
  174. package/lib/sidebar/components/tree/index.js +3 -3
  175. package/lib/sidebar/index.js +3 -3
  176. package/lib/skeleton/index.js +1 -1
  177. package/lib/table/components/Filter/index.js +11 -9
  178. package/lib/table/components/Filter/index.scss +7 -3
  179. package/lib/table/components/Layout/index.js +13 -4
  180. package/lib/table/components/QuickAction/index.js +3 -3
  181. package/lib/table/components/ToolBar/DensityIcon.js +1 -1
  182. package/lib/table/components/ToolBar/FilterColumnIcon.js +55 -20
  183. package/lib/table/components/ToolBar/FullScreenIcon.js +1 -1
  184. package/lib/table/components/ToolBar/Fullscreen.js +1 -1
  185. package/lib/table/components/ToolBar/index.js +2 -2
  186. package/lib/table/components/ToolBar/index.scss +1 -0
  187. package/lib/table/index.js +29 -13
  188. package/lib/table/typing.d.ts +9 -1
  189. package/lib/table/utils/columnRender.js +61 -3
  190. package/lib/table/utils/genProColumnToColumn.js +2 -2
  191. package/lib/table/utils/index.js +24 -4
  192. package/lib/table/utils/useTableSelection.js +2 -2
  193. package/lib/templates/List/index.js +3 -3
  194. package/lib/utils/index.js +1 -1
  195. package/lib/utils/message.d.ts +1 -1
  196. package/lib/utils/message.js +9 -9
  197. package/package.json +4 -4
  198. package/es/form/Components/Query/index.d.ts +0 -4
  199. package/es/form/Components/Query/index.js +0 -70
  200. package/es/form/Components/Query/index.scss +0 -85
  201. package/es/form/Components/QueryFilter/index.d.ts +0 -3
  202. package/es/utils/components/tags/index.d.ts +0 -11
  203. package/es/utils/components/tags/index.js +0 -50
  204. package/es/utils/components/tags/index.scss +0 -12
  205. package/lib/form/Components/Query/index.d.ts +0 -4
  206. package/lib/form/Components/Query/index.js +0 -91
  207. package/lib/form/Components/Query/index.scss +0 -85
  208. package/lib/form/Components/QueryFilter/index.d.ts +0 -3
  209. package/lib/utils/components/tags/index.d.ts +0 -11
  210. package/lib/utils/components/tags/index.js +0 -66
  211. package/lib/utils/components/tags/index.scss +0 -12
@@ -0,0 +1,392 @@
1
+ "use strict";
2
+
3
+ function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.QueryFilter = void 0;
9
+
10
+ var _react = _interopRequireWildcard(require("react"));
11
+
12
+ var _classnames = _interopRequireDefault(require("classnames"));
13
+
14
+ var _components = require("@alicloudfe/components");
15
+
16
+ var _icon = _interopRequireDefault(require("@teamix/icon"));
17
+
18
+ var _core = require("@formily/core");
19
+
20
+ var _utils = require("@teamix/utils");
21
+
22
+ var _index = _interopRequireDefault(require("../../field/index"));
23
+
24
+ var _ProForm = _interopRequireDefault(require("../ProForm"));
25
+
26
+ var _fieldTypeMap = _interopRequireDefault(require("../fieldTypeMap"));
27
+
28
+ var _useFormDisplayValues = require("../ProForm/useFormDisplayValues");
29
+
30
+ var _utils2 = require("../utils");
31
+
32
+ require("./index2.scss");
33
+
34
+ var _excluded = ["schema", "onChange", "onSubmit"],
35
+ _excluded2 = ["form", "schema", "onSubmit", "onChange"],
36
+ _excluded3 = ["schema", "onSubmit", "onChange", "onReset", "layout", "labelAlign", "wrapperAlign", "labelCol", "wrapperCol"],
37
+ _excluded4 = ["addonAfter", "addonBefore", "onFilter", "mode", "expand"];
38
+
39
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
40
+
41
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
42
+
43
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
44
+
45
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
46
+
47
+ 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."); }
48
+
49
+ function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
50
+
51
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
52
+
53
+ function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
54
+
55
+ 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."); }
56
+
57
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
58
+
59
+ function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
60
+
61
+ function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
62
+
63
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
64
+
65
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
66
+
67
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
68
+
69
+ function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
70
+
71
+ function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
72
+
73
+ function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
74
+
75
+ /**
76
+ * 简单筛选
77
+ */
78
+ var SimpleFilter = /*#__PURE__*/(0, _react.memo)(function (props) {
79
+ var schema = props.schema,
80
+ onChange = props.onChange,
81
+ onSubmit = props.onSubmit,
82
+ otherProps = _objectWithoutProperties(props, _excluded);
83
+
84
+ var prefixCls = (0, _utils.usePrefixCls)('', {
85
+ prefix: 'teamix-pro-form-query-filter-simple'
86
+ });
87
+ var simpleSchema = (0, _react.useMemo)(function () {
88
+ return [{
89
+ component: 'FormFlex',
90
+ props: {
91
+ size: 8
92
+ },
93
+ children: schema
94
+ }, {
95
+ component: 'Submit',
96
+ props: {
97
+ style: {
98
+ display: 'none'
99
+ }
100
+ }
101
+ }];
102
+ }, [schema]);
103
+ return /*#__PURE__*/_react.default.createElement(_ProForm.default, _objectSpread(_objectSpread({}, otherProps), {}, {
104
+ className: (0, _classnames.default)(prefixCls, props.className),
105
+ schema: simpleSchema,
106
+ feedbackLayout: "popover",
107
+ breakpoints: [],
108
+ inset: true,
109
+ onSubmit: onSubmit,
110
+ onChange: onChange
111
+ }));
112
+ });
113
+ /**
114
+ * 轻量筛选
115
+ */
116
+
117
+ var LightFilter = /*#__PURE__*/(0, _react.memo)(function (props) {
118
+ var form = props.form,
119
+ schema = props.schema,
120
+ onSubmit = props.onSubmit,
121
+ onChange = props.onChange,
122
+ otherProps = _objectWithoutProperties(props, _excluded2);
123
+
124
+ var prefixCls = (0, _utils.usePrefixCls)('', {
125
+ prefix: 'teamix-pro-form-query-filter-light'
126
+ });
127
+ var LightSchema = (0, _react.useMemo)(function () {
128
+ return [{
129
+ component: 'LightFilter',
130
+ children: schema
131
+ }, {
132
+ component: 'Submit',
133
+ props: {
134
+ style: {
135
+ display: 'none'
136
+ }
137
+ }
138
+ }];
139
+ }, [schema]); // useEffect(() => {
140
+ // form.addEffects('onChange', () => {
141
+ // onFieldValueChange('',(field:any) => {
142
+ // console.log(field.value);
143
+ // });
144
+ // });
145
+ // }, [form, onChange]);
146
+
147
+ return /*#__PURE__*/_react.default.createElement(_ProForm.default, _objectSpread(_objectSpread({}, otherProps), {}, {
148
+ form: form,
149
+ className: (0, _classnames.default)(prefixCls, props.className),
150
+ schema: LightSchema,
151
+ feedbackLayout: "popover",
152
+ breakpoints: [],
153
+ bordered: false,
154
+ onSubmit: onSubmit,
155
+ onChange: onChange
156
+ }));
157
+ });
158
+ /**
159
+ * 高级筛选
160
+ */
161
+
162
+ var AdvancedFilter = /*#__PURE__*/(0, _react.memo)(function (props) {
163
+ var schema = props.schema,
164
+ onSubmit = props.onSubmit,
165
+ onChange = props.onChange,
166
+ onReset = props.onReset,
167
+ layout = props.layout,
168
+ labelAlign = props.labelAlign,
169
+ wrapperAlign = props.wrapperAlign,
170
+ labelCol = props.labelCol,
171
+ wrapperCol = props.wrapperCol,
172
+ otherProps = _objectWithoutProperties(props, _excluded3);
173
+
174
+ var prefixCls = (0, _utils.usePrefixCls)('', {
175
+ prefix: 'teamix-pro-form-query-filter-advanced'
176
+ });
177
+ var gridSchema = (0, _react.useMemo)(function () {
178
+ return [{
179
+ name: 'FormGrid',
180
+ component: 'FormGrid',
181
+ props: {
182
+ breakpoints: [480, 720, 990, 1200, Infinity],
183
+ maxColumns: [1, 2, 3, 3, 4],
184
+ columnGap: 16,
185
+ rowGap: 12
186
+ },
187
+ children: [].concat(_toConsumableArray(schema), [{
188
+ component: 'FormGrid.GridColumn',
189
+ props: {
190
+ gridSpan: -1
191
+ },
192
+ children: [{
193
+ component: 'FormButtonGroup',
194
+ props: {
195
+ align: 'right'
196
+ },
197
+ children: [{
198
+ component: 'Reset',
199
+ props: {
200
+ onResetValidateSuccess: onReset,
201
+ children: (0, _utils.getMessage)('reset')
202
+ }
203
+ }, {
204
+ component: 'Submit',
205
+ props: {
206
+ style: {
207
+ marginRight: -8
208
+ },
209
+ children: (0, _utils.getMessage)('search')
210
+ }
211
+ }]
212
+ }]
213
+ }])
214
+ }];
215
+ }, [schema, onReset]);
216
+ var getTeamixLayout = (0, _react.useMemo)(function () {
217
+ return {
218
+ breakpoints: [990],
219
+ layout: (0, _utils2.mergeArrayValue)(['vertical'], layout),
220
+ labelAlign: (0, _utils2.mergeArrayValue)(['left'], labelAlign),
221
+ wrapperAlign: (0, _utils2.mergeArrayValue)(['left'], wrapperAlign),
222
+ labelCol: (0, _utils2.mergeArrayValue)([24], labelCol),
223
+ wrapperCol: (0, _utils2.mergeArrayValue)([24], wrapperCol)
224
+ };
225
+ }, [layout, labelAlign, wrapperAlign, labelCol, wrapperCol]);
226
+ return /*#__PURE__*/_react.default.createElement(_ProForm.default, _objectSpread(_objectSpread(_objectSpread({
227
+ className: (0, _classnames.default)(prefixCls, props.className),
228
+ schema: gridSchema,
229
+ feedbackLayout: "popover"
230
+ }, otherProps), getTeamixLayout), {}, {
231
+ onSubmit: onSubmit
232
+ }));
233
+ });
234
+ AdvancedFilter.defaultProps = {
235
+ layout: 'horizontal',
236
+ labelAlign: 'right',
237
+ labelCol: 6,
238
+ wrapperCol: 18
239
+ };
240
+ /**
241
+ * 查询筛选
242
+ */
243
+
244
+ var QueryFilter = /*#__PURE__*/(0, _react.memo)(function (props) {
245
+ var addonAfter = props.addonAfter,
246
+ addonBefore = props.addonBefore,
247
+ onFilter = props.onFilter,
248
+ mode = props.mode,
249
+ expand = props.expand,
250
+ otherProps = _objectWithoutProperties(props, _excluded4);
251
+
252
+ var form = (0, _react.useMemo)(function () {
253
+ return props.form || (0, _core.createForm)({
254
+ validateFirst: true
255
+ });
256
+ }, []);
257
+
258
+ var _useState = (0, _react.useState)(expand),
259
+ _useState2 = _slicedToArray(_useState, 2),
260
+ advancedFilterVisible = _useState2[0],
261
+ setAdvancedFilterVisible = _useState2[1];
262
+
263
+ var _useState3 = (0, _react.useState)([]),
264
+ _useState4 = _slicedToArray(_useState3, 2),
265
+ tagDataSource = _useState4[0],
266
+ setTagDataSource = _useState4[1];
267
+
268
+ var prefixCls = (0, _utils.usePrefixCls)('', {
269
+ prefix: 'teamix-pro-form-query-filter'
270
+ }); // 展开收起高级筛选
271
+
272
+ var toggleAdvancedFilter = (0, _react.useCallback)(function () {
273
+ setAdvancedFilterVisible(function (visible) {
274
+ return !visible;
275
+ });
276
+ }, []); // 获取标签数据
277
+
278
+ var getTagDataSource = (0, _react.useCallback)(function (form) {
279
+ var displayValues = (0, _useFormDisplayValues.getFormDisplayValues)(form);
280
+ return Object.entries(displayValues).map(function (_ref) {
281
+ var _data$displayValue;
282
+
283
+ var _ref2 = _slicedToArray(_ref, 2),
284
+ key = _ref2[0],
285
+ data = _ref2[1];
286
+
287
+ return {
288
+ key: key,
289
+ type: _fieldTypeMap.default[data.component] || 'text',
290
+ label: data.title,
291
+ value: (_data$displayValue = data.displayValue) !== null && _data$displayValue !== void 0 ? _data$displayValue : data.value
292
+ };
293
+ }).filter(function (item) {
294
+ return (0, _utils.isSignificative)(item.value);
295
+ });
296
+ }, []); // 表单值提交
297
+
298
+ var onFormSubmit = (0, _react.useCallback)(function (values) {
299
+ setTagDataSource(getTagDataSource(form));
300
+ onFilter && onFilter(values);
301
+ }, []); // 轻量表单onChange
302
+
303
+ var onLightValueChange = (0, _react.useCallback)(function (values) {
304
+ form.reset();
305
+ setTagDataSource(getTagDataSource(form));
306
+ onFilter && onFilter(values);
307
+ }, [form]); // 简单表单onChange
308
+
309
+ var onSimpleValueChange = (0, _react.useCallback)(function (values) {
310
+ setTagDataSource(getTagDataSource(form));
311
+ onFilter && onFilter(values);
312
+ }, []); // 关闭标签清空表单字段值
313
+
314
+ var onTagClose = (0, _react.useCallback)(function (key) {
315
+ form.setValuesIn(key, undefined);
316
+ }, [form]); // 设置默认值标签数据
317
+
318
+ (0, _react.useEffect)(function () {
319
+ setTagDataSource(getTagDataSource(form));
320
+ }, []);
321
+ return /*#__PURE__*/_react.default.createElement("div", {
322
+ className: (0, _classnames.default)(prefixCls, props.className)
323
+ }, /*#__PURE__*/_react.default.createElement("div", {
324
+ className: "".concat(prefixCls, "-inline")
325
+ }, /*#__PURE__*/_react.default.createElement("div", {
326
+ className: "".concat(prefixCls, "-left")
327
+ }, addonBefore ? /*#__PURE__*/_react.default.createElement("div", {
328
+ className: "".concat(prefixCls, "-addonBefore")
329
+ }, addonBefore) : null, mode === 'panel' ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
330
+ className: "".concat(prefixCls, "-inline-form")
331
+ }, /*#__PURE__*/_react.default.createElement(LightFilter, _objectSpread(_objectSpread({}, otherProps), {}, {
332
+ form: form,
333
+ onFilter: onLightValueChange,
334
+ onSubmit: onFormSubmit
335
+ }))), /*#__PURE__*/_react.default.createElement("div", {
336
+ className: "".concat(prefixCls, "-toggle")
337
+ }, /*#__PURE__*/_react.default.createElement(_components.Badge, {
338
+ count: tagDataSource.length,
339
+ style: _objectSpread({
340
+ backgroundColor: 'var(--color-brand1-6, #0064c8)',
341
+ color: 'var(--color-white, #fff)'
342
+ }, advancedFilterVisible ? {
343
+ display: 'none'
344
+ } : {})
345
+ }, /*#__PURE__*/_react.default.createElement(_components.Button, {
346
+ onClick: toggleAdvancedFilter
347
+ }, advancedFilterVisible ? /*#__PURE__*/_react.default.createElement(_icon.default, {
348
+ type: "up-line"
349
+ }) : /*#__PURE__*/_react.default.createElement(_icon.default, {
350
+ type: "filter-line"
351
+ }), (0, _utils.getMessage)('advancedFilter'))))) : /*#__PURE__*/_react.default.createElement("div", {
352
+ className: "".concat(prefixCls, "-inline-form")
353
+ }, /*#__PURE__*/_react.default.createElement(SimpleFilter, _objectSpread(_objectSpread({}, otherProps), {}, {
354
+ form: form,
355
+ onFilter: onSimpleValueChange,
356
+ onSubmit: onFormSubmit
357
+ })))), addonAfter ? /*#__PURE__*/_react.default.createElement("div", {
358
+ className: "".concat(prefixCls, "-addonAfter")
359
+ }, addonAfter) : null), mode === 'panel' ? /*#__PURE__*/_react.default.createElement("div", {
360
+ className: "".concat(prefixCls, "-panel")
361
+ }, /*#__PURE__*/_react.default.createElement("div", {
362
+ className: (0, _classnames.default)("".concat(prefixCls, "-tag"), advancedFilterVisible ? "".concat(prefixCls, "-tag-hidden") : '')
363
+ }, /*#__PURE__*/_react.default.createElement(_components.Tag.Group, null, tagDataSource.map(function (_ref3) {
364
+ var key = _ref3.key,
365
+ label = _ref3.label,
366
+ value = _ref3.value,
367
+ type = _ref3.type;
368
+ return /*#__PURE__*/_react.default.createElement(_components.Tag.Closeable, {
369
+ key: key,
370
+ afterClose: function afterClose() {
371
+ return onTagClose(key);
372
+ }
373
+ }, /*#__PURE__*/_react.default.createElement("span", {
374
+ className: "".concat(prefixCls, "-tag-title")
375
+ }, label), /*#__PURE__*/_react.default.createElement("span", {
376
+ className: "".concat(prefixCls, "-tag-content")
377
+ }, /*#__PURE__*/_react.default.createElement(_index.default, {
378
+ type: type,
379
+ value: value
380
+ })));
381
+ }))), /*#__PURE__*/_react.default.createElement("div", {
382
+ className: (0, _classnames.default)("".concat(prefixCls, "-advanced-wrap"), !advancedFilterVisible ? "".concat(prefixCls, "-advanced-wrap-hidden") : '')
383
+ }, /*#__PURE__*/_react.default.createElement(AdvancedFilter, _objectSpread(_objectSpread({}, otherProps), {}, {
384
+ form: form,
385
+ onSubmit: onFormSubmit
386
+ })))) : null);
387
+ });
388
+ exports.QueryFilter = QueryFilter;
389
+ QueryFilter.defaultProps = {
390
+ mode: 'inline',
391
+ expand: false
392
+ };
@@ -0,0 +1,73 @@
1
+ @import '../global.scss';
2
+
3
+ $query-filter: #{$teamix-pro-form}-query-filter;
4
+
5
+ .#{$query-filter} {
6
+ .#{$query-filter}-inline {
7
+ display: flex;
8
+ justify-content: space-between;
9
+ }
10
+ .#{$query-filter}-left {
11
+ display: flex;
12
+ }
13
+ .#{$query-filter}-addonBefore {
14
+ flex: 0 1 auto;
15
+ margin-right: 8px;
16
+ }
17
+ .#{$query-filter}-inline-form {
18
+ flex: 0 0 auto;
19
+ margin-right: 8px;
20
+ margin-bottom: 8px;
21
+ }
22
+ .#{$query-filter}-toggle {
23
+ margin-bottom: 8px;
24
+ }
25
+ .#{$query-filter}-addonAfter {
26
+ flex: 0 1 auto;
27
+ margin-left: 8px;
28
+ }
29
+ .#{$query-filter}-tag-title {
30
+ margin-right: 12px;
31
+ color: var(--color-text1-8, #848484);
32
+ }
33
+ .#{$query-filter}-tag-content {
34
+ .#{$teamix-pro-field} {
35
+ display: inline-block;
36
+ .#{$css-prefix}form-preview {
37
+ color: var(--color-text1-2, #5a5a5a);
38
+ font-weight: bold;
39
+ }
40
+ }
41
+ }
42
+ .#{$query-filter}-tag-hidden {
43
+ display: none;
44
+ }
45
+ .#{$query-filter}-advanced-wrap {
46
+ padding: 16px;
47
+ background-color: var(--color-fill1-2, #f7f7f7);
48
+ }
49
+ .#{$query-filter}-advanced-wrap-hidden {
50
+ display: none;
51
+ }
52
+
53
+ .#{$query-filter}-advanced {
54
+ .#{$css-prefix}formily-button-group {
55
+ margin-top: 0;
56
+ }
57
+ }
58
+ .#{$query-filter}-advanced,
59
+ .#{$query-filter}-simple,
60
+ .#{$query-filter}-light {
61
+ .#{$form-item-cls}-feedback-layout-popover {
62
+ margin-bottom: 0;
63
+ }
64
+ .#{$css-prefix}date-picker2-input {
65
+ .#{$css-prefix}input {
66
+ width: inherit;
67
+ input {
68
+ width: inherit;
69
+ }
70
+ }
71
+ }
72
+ }
73
+ }
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
 
3
- function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
3
+ function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
4
4
 
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
@@ -39,9 +39,9 @@ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "functio
39
39
 
40
40
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
41
41
 
42
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
42
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
43
43
 
44
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
44
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
45
45
 
46
46
  function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
47
47
 
@@ -32,11 +32,11 @@
32
32
  > .#{$form-item-cls}-control-content {
33
33
  > .#{$form-item-cls}-control-content-component {
34
34
  line-height: initial;
35
- > .teamix-pro-field-checkbox,
36
- .teamix-pro-field-radio,
37
- .teamix-pro-field-switch,
38
- .teamix-pro-field-colorradio,
39
- .teamix-pro-field-range,
35
+ > .#{$teamix-pro-field}-checkbox,
36
+ .#{$teamix-pro-field}-radio,
37
+ .#{$teamix-pro-field}-switch,
38
+ .#{$teamix-pro-field}-colorradio,
39
+ .#{$teamix-pro-field}-range,
40
40
  .#{$css-prefix}btn-text {
41
41
  line-height: var(--form-element-medium-height, 32px);
42
42
  }
@@ -160,11 +160,11 @@
160
160
  margin-right: 4px;
161
161
  }
162
162
  }
163
- .teamix-pro-field-money button,
164
- .teamix-pro-field-icon button {
163
+ .#{$teamix-pro-field}-money button,
164
+ .#{$teamix-pro-field}-icon button {
165
165
  border: 0 !important;
166
166
  }
167
- .teamix-pro-field-color-swatch {
167
+ .#{$teamix-pro-field}-color-swatch {
168
168
  box-shadow: none !important;
169
169
  }
170
170
  .#{$css-prefix}date-picker2-input,
@@ -230,14 +230,12 @@
230
230
  }
231
231
  }
232
232
 
233
- // 筛选和抽屉按钮
234
- .#{$teamix-pro-form}-filter-advanced,
233
+ // 抽屉按钮
235
234
  .#{$css-prefix}drawer-footer {
236
235
  .#{$css-prefix}formily-button-group {
237
236
  margin-top: 0;
238
237
  }
239
238
  }
240
-
241
239
  .#{$teamix-pro-form}-button-affix-auto.#{$css-prefix}affix,
242
240
  .#{$teamix-pro-form}-button-affix-always.#{$css-prefix}affix {
243
241
  left: 0;
@@ -259,22 +257,6 @@
259
257
  }
260
258
  }
261
259
 
262
- // 高级筛选
263
- .#{$teamix-pro-form}-filter-advanced,
264
- .#{$teamix-pro-form}-filter-simple {
265
- .#{$form-item-cls}-feedback-layout-popover {
266
- margin-bottom: 0;
267
- }
268
- .#{$css-prefix}date-picker2-input {
269
- .#{$css-prefix}input {
270
- width: inherit;
271
- input {
272
- width: inherit;
273
- }
274
- }
275
- }
276
- }
277
-
278
260
  // ArrayItems
279
261
  .#{$css-prefix}formily-array-items {
280
262
  .#{$css-prefix}formily-grid-layout {
@@ -291,7 +273,7 @@
291
273
 
292
274
  /* hack todo remove */
293
275
  .#{$form-item-cls}-control-content-component {
294
- .teamix-pro-field-tooltip.teamix-pro-field-checkbox {
276
+ .#{$teamix-pro-field}-tooltip.#{$teamix-pro-field}-checkbox {
295
277
  .teamix-pro-lable-icon-tip-icon {
296
278
  transform: translate(0px, 4px);
297
279
  }
@@ -9,9 +9,9 @@ var _reactRouterDom = require("react-router-dom");
9
9
 
10
10
  var _utils = require("@teamix/utils");
11
11
 
12
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
12
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
13
13
 
14
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
14
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
15
15
 
16
16
  function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
17
17
 
@@ -9,9 +9,9 @@ var _react = require("@formily/react");
9
9
 
10
10
  var _utils = require("@teamix/utils");
11
11
 
12
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
12
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
13
13
 
14
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
14
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
15
15
 
16
16
  function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
17
17
 
@@ -1,6 +1,4 @@
1
- /**
2
- * 获取表单值的可显示值
3
- * @returns 如果某字段有dataSource,则返回value对应label
4
- */
1
+ import type { Form } from '@formily/core';
5
2
  declare const useFormDisplayValues: () => any;
6
- export default useFormDisplayValues;
3
+ declare const getFormDisplayValues: (form: Form) => any;
4
+ export { useFormDisplayValues, getFormDisplayValues };