vxe-pc-ui 3.7.4 → 3.7.6

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 (198) hide show
  1. package/es/icon/style.css +1 -1
  2. package/es/language/ar-EG.js +19 -1
  3. package/es/language/de-DE.js +19 -1
  4. package/es/language/en-US.js +20 -2
  5. package/es/language/es-ES.js +19 -1
  6. package/es/language/fr-FR.js +19 -1
  7. package/es/language/hu-HU.js +19 -1
  8. package/es/language/hy-AM.js +18 -0
  9. package/es/language/id-ID.js +19 -1
  10. package/es/language/it-IT.js +19 -1
  11. package/es/language/ja-JP.js +19 -1
  12. package/es/language/ko-KR.js +19 -1
  13. package/es/language/ms-MY.js +19 -1
  14. package/es/language/nb-NO.js +19 -1
  15. package/es/language/pt-BR.js +19 -1
  16. package/es/language/ru-RU.js +19 -1
  17. package/es/language/th-TH.js +19 -1
  18. package/es/language/ug-CN.js +19 -1
  19. package/es/language/uk-UA.js +19 -1
  20. package/es/language/uz-UZ.js +19 -1
  21. package/es/language/vi-VN.js +19 -1
  22. package/es/language/zh-CHT.js +19 -1
  23. package/es/language/zh-CN.js +18 -0
  24. package/es/list/src/list.js +1 -1
  25. package/es/select/src/select.js +138 -41
  26. package/es/select/style.css +21 -0
  27. package/es/select/style.min.css +1 -1
  28. package/es/style.css +1 -1
  29. package/es/style.min.css +1 -1
  30. package/es/tree/src/tree.js +1160 -601
  31. package/es/tree/src/util.js +31 -0
  32. package/es/tree/style.css +23 -26
  33. package/es/tree/style.min.css +1 -1
  34. package/es/tree-select/src/tree-select.js +258 -24
  35. package/es/tree-select/style.css +36 -1
  36. package/es/tree-select/style.min.css +1 -1
  37. package/es/ui/index.js +20 -4
  38. package/es/ui/src/dom.js +9 -0
  39. package/es/ui/src/log.js +1 -1
  40. package/es/vxe-select/style.css +21 -0
  41. package/es/vxe-select/style.min.css +1 -1
  42. package/es/vxe-tree/style.css +23 -26
  43. package/es/vxe-tree/style.min.css +1 -1
  44. package/es/vxe-tree-select/style.css +36 -1
  45. package/es/vxe-tree-select/style.min.css +1 -1
  46. package/lib/icon/style/style.css +1 -1
  47. package/lib/icon/style/style.min.css +1 -1
  48. package/lib/index.umd.js +1541 -532
  49. package/lib/index.umd.min.js +1 -1
  50. package/lib/language/ar-EG.js +19 -1
  51. package/lib/language/ar-EG.min.js +1 -1
  52. package/lib/language/ar-EG.umd.js +19 -1
  53. package/lib/language/de-DE.js +19 -1
  54. package/lib/language/de-DE.min.js +1 -1
  55. package/lib/language/de-DE.umd.js +19 -1
  56. package/lib/language/en-US.js +20 -2
  57. package/lib/language/en-US.min.js +1 -1
  58. package/lib/language/en-US.umd.js +20 -2
  59. package/lib/language/es-ES.js +19 -1
  60. package/lib/language/es-ES.min.js +1 -1
  61. package/lib/language/es-ES.umd.js +19 -1
  62. package/lib/language/fr-FR.js +19 -1
  63. package/lib/language/fr-FR.min.js +1 -1
  64. package/lib/language/fr-FR.umd.js +19 -1
  65. package/lib/language/hu-HU.js +19 -1
  66. package/lib/language/hu-HU.min.js +1 -1
  67. package/lib/language/hu-HU.umd.js +19 -1
  68. package/lib/language/hy-AM.js +18 -0
  69. package/lib/language/hy-AM.min.js +1 -1
  70. package/lib/language/hy-AM.umd.js +18 -0
  71. package/lib/language/id-ID.js +19 -1
  72. package/lib/language/id-ID.min.js +1 -1
  73. package/lib/language/id-ID.umd.js +19 -1
  74. package/lib/language/it-IT.js +19 -1
  75. package/lib/language/it-IT.min.js +1 -1
  76. package/lib/language/it-IT.umd.js +19 -1
  77. package/lib/language/ja-JP.js +19 -1
  78. package/lib/language/ja-JP.min.js +1 -1
  79. package/lib/language/ja-JP.umd.js +19 -1
  80. package/lib/language/ko-KR.js +19 -1
  81. package/lib/language/ko-KR.min.js +1 -1
  82. package/lib/language/ko-KR.umd.js +19 -1
  83. package/lib/language/ms-MY.js +19 -1
  84. package/lib/language/ms-MY.min.js +1 -1
  85. package/lib/language/ms-MY.umd.js +19 -1
  86. package/lib/language/nb-NO.js +19 -1
  87. package/lib/language/nb-NO.min.js +1 -1
  88. package/lib/language/nb-NO.umd.js +19 -1
  89. package/lib/language/pt-BR.js +19 -1
  90. package/lib/language/pt-BR.min.js +1 -1
  91. package/lib/language/pt-BR.umd.js +19 -1
  92. package/lib/language/ru-RU.js +19 -1
  93. package/lib/language/ru-RU.min.js +1 -1
  94. package/lib/language/ru-RU.umd.js +19 -1
  95. package/lib/language/th-TH.js +19 -1
  96. package/lib/language/th-TH.min.js +1 -1
  97. package/lib/language/th-TH.umd.js +19 -1
  98. package/lib/language/ug-CN.js +19 -1
  99. package/lib/language/ug-CN.min.js +1 -1
  100. package/lib/language/ug-CN.umd.js +19 -1
  101. package/lib/language/uk-UA.js +19 -1
  102. package/lib/language/uk-UA.min.js +1 -1
  103. package/lib/language/uk-UA.umd.js +19 -1
  104. package/lib/language/uz-UZ.js +19 -1
  105. package/lib/language/uz-UZ.min.js +1 -1
  106. package/lib/language/uz-UZ.umd.js +19 -1
  107. package/lib/language/vi-VN.js +19 -1
  108. package/lib/language/vi-VN.min.js +1 -1
  109. package/lib/language/vi-VN.umd.js +19 -1
  110. package/lib/language/zh-CHT.js +19 -1
  111. package/lib/language/zh-CHT.min.js +1 -1
  112. package/lib/language/zh-CHT.umd.js +19 -1
  113. package/lib/language/zh-CN.js +18 -0
  114. package/lib/language/zh-CN.min.js +1 -1
  115. package/lib/language/zh-CN.umd.js +18 -0
  116. package/lib/list/src/list.js +1 -1
  117. package/lib/list/src/list.min.js +1 -1
  118. package/lib/select/src/select.js +145 -45
  119. package/lib/select/src/select.min.js +1 -1
  120. package/lib/select/style/style.css +21 -0
  121. package/lib/select/style/style.min.css +1 -1
  122. package/lib/style.css +1 -1
  123. package/lib/style.min.css +1 -1
  124. package/lib/tree/src/tree.js +1223 -626
  125. package/lib/tree/src/tree.min.js +1 -1
  126. package/lib/tree/src/util.js +37 -0
  127. package/lib/tree/src/util.min.js +1 -0
  128. package/lib/tree/style/style.css +23 -26
  129. package/lib/tree/style/style.min.css +1 -1
  130. package/lib/tree-select/src/tree-select.js +265 -26
  131. package/lib/tree-select/src/tree-select.min.js +1 -1
  132. package/lib/tree-select/style/style.css +36 -1
  133. package/lib/tree-select/style/style.min.css +1 -1
  134. package/lib/ui/index.js +20 -4
  135. package/lib/ui/index.min.js +1 -1
  136. package/lib/ui/src/dom.js +10 -0
  137. package/lib/ui/src/dom.min.js +1 -1
  138. package/lib/ui/src/log.js +1 -1
  139. package/lib/ui/src/log.min.js +1 -1
  140. package/lib/vxe-select/style/style.css +21 -0
  141. package/lib/vxe-select/style/style.min.css +1 -1
  142. package/lib/vxe-tree/style/style.css +23 -26
  143. package/lib/vxe-tree/style/style.min.css +1 -1
  144. package/lib/vxe-tree-select/style/style.css +36 -1
  145. package/lib/vxe-tree-select/style/style.min.css +1 -1
  146. package/package.json +1 -1
  147. package/packages/language/ar-EG.ts +19 -1
  148. package/packages/language/de-DE.ts +19 -1
  149. package/packages/language/en-US.ts +20 -2
  150. package/packages/language/es-ES.ts +19 -1
  151. package/packages/language/fr-FR.ts +19 -1
  152. package/packages/language/hu-HU.ts +19 -1
  153. package/packages/language/hy-AM.ts +18 -0
  154. package/packages/language/id-ID.ts +19 -1
  155. package/packages/language/it-IT.ts +19 -1
  156. package/packages/language/ja-JP.ts +19 -1
  157. package/packages/language/ko-KR.ts +19 -1
  158. package/packages/language/ms-MY.ts +19 -1
  159. package/packages/language/nb-NO.ts +19 -1
  160. package/packages/language/pt-BR.ts +19 -1
  161. package/packages/language/ru-RU.ts +19 -1
  162. package/packages/language/th-TH.ts +19 -1
  163. package/packages/language/ug-CN.ts +19 -1
  164. package/packages/language/uk-UA.ts +19 -1
  165. package/packages/language/uz-UZ.ts +19 -1
  166. package/packages/language/vi-VN.ts +19 -1
  167. package/packages/language/zh-CHT.ts +19 -1
  168. package/packages/language/zh-CN.ts +18 -0
  169. package/packages/list/src/list.ts +1 -1
  170. package/packages/select/src/select.ts +144 -44
  171. package/packages/tree/src/tree.ts +1206 -626
  172. package/packages/tree/src/util.ts +34 -0
  173. package/packages/tree-select/src/tree-select.ts +272 -26
  174. package/packages/ui/index.ts +19 -3
  175. package/packages/ui/src/dom.ts +10 -0
  176. package/styles/components/select.scss +19 -0
  177. package/styles/components/tree-select.scss +36 -1
  178. package/styles/components/tree.scss +28 -31
  179. package/types/components/button.d.ts +11 -1
  180. package/types/components/grid.d.ts +5 -0
  181. package/types/components/icon-picker.d.ts +11 -1
  182. package/types/components/input.d.ts +2 -2
  183. package/types/components/select.d.ts +29 -40
  184. package/types/components/table.d.ts +2 -4
  185. package/types/components/tree-select.d.ts +72 -12
  186. package/types/components/tree.d.ts +129 -8
  187. /package/es/icon/{iconfont.1752133985860.ttf → iconfont.1752416451473.ttf} +0 -0
  188. /package/es/icon/{iconfont.1752133985860.woff → iconfont.1752416451473.woff} +0 -0
  189. /package/es/icon/{iconfont.1752133985860.woff2 → iconfont.1752416451473.woff2} +0 -0
  190. /package/es/{iconfont.1752133985860.ttf → iconfont.1752416451473.ttf} +0 -0
  191. /package/es/{iconfont.1752133985860.woff → iconfont.1752416451473.woff} +0 -0
  192. /package/es/{iconfont.1752133985860.woff2 → iconfont.1752416451473.woff2} +0 -0
  193. /package/lib/icon/style/{iconfont.1752133985860.ttf → iconfont.1752416451473.ttf} +0 -0
  194. /package/lib/icon/style/{iconfont.1752133985860.woff → iconfont.1752416451473.woff} +0 -0
  195. /package/lib/icon/style/{iconfont.1752133985860.woff2 → iconfont.1752416451473.woff2} +0 -0
  196. /package/lib/{iconfont.1752133985860.ttf → iconfont.1752416451473.ttf} +0 -0
  197. /package/lib/{iconfont.1752133985860.woff → iconfont.1752416451473.woff} +0 -0
  198. /package/lib/{iconfont.1752133985860.woff2 → iconfont.1752416451473.woff2} +0 -0
@@ -11,6 +11,7 @@ var _dom = require("../../ui/src/dom");
11
11
  var _utils = require("../../ui/src/utils");
12
12
  var _log = require("../../ui/src/log");
13
13
  var _input = _interopRequireDefault(require("../../input/src/input"));
14
+ var _button = _interopRequireDefault(require("../../button/src/button"));
14
15
  var _tree = _interopRequireDefault(require("../../tree/src/tree"));
15
16
  function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
16
17
  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); }
@@ -45,6 +46,8 @@ var _default2 = exports.default = /* define-vxe-component start */(0, _comp.defi
45
46
  type: Boolean,
46
47
  default: null
47
48
  },
49
+ filterable: Boolean,
50
+ filterConfig: Object,
48
51
  multiple: Boolean,
49
52
  className: [String, Function],
50
53
  popupClassName: [String, Function],
@@ -55,17 +58,53 @@ var _default2 = exports.default = /* define-vxe-component start */(0, _comp.defi
55
58
  size: {
56
59
  type: String,
57
60
  default: function _default() {
58
- return (0, _ui.getConfig)().select.size || (0, _ui.getConfig)().size;
61
+ return (0, _ui.getConfig)().treeSelect.size || (0, _ui.getConfig)().size;
59
62
  }
60
63
  },
61
64
  remote: Boolean,
62
- remoteMethod: Function,
65
+ remoteConfig: Function,
63
66
  popupConfig: Object,
64
67
  treeConfig: Object,
68
+ virtualYConfig: Object,
69
+ autoClose: {
70
+ type: Boolean,
71
+ default: function _default() {
72
+ return (0, _ui.getConfig)().treeSelect.autoClose;
73
+ }
74
+ },
75
+ showTotalButoon: {
76
+ type: Boolean,
77
+ default: function _default() {
78
+ return (0, _ui.getConfig)().treeSelect.showTotalButoon;
79
+ }
80
+ },
81
+ showCheckedButoon: {
82
+ type: Boolean,
83
+ default: function _default() {
84
+ return (0, _ui.getConfig)().treeSelect.showCheckedButoon;
85
+ }
86
+ },
87
+ showClearButton: {
88
+ type: Boolean,
89
+ default: function _default() {
90
+ return (0, _ui.getConfig)().treeSelect.showClearButton;
91
+ }
92
+ },
93
+ showExpandButton: {
94
+ type: Boolean,
95
+ default: function _default() {
96
+ return (0, _ui.getConfig)().treeSelect.showExpandButton;
97
+ }
98
+ },
65
99
  transfer: {
66
100
  type: Boolean,
67
101
  default: null
68
- }
102
+ },
103
+ /**
104
+ * 已废弃,被 remote-config.queryMethod 替换
105
+ * @deprecated
106
+ */
107
+ remoteMethod: Function
69
108
  },
70
109
  inject: {
71
110
  $xeModal: {
@@ -95,8 +134,8 @@ var _default2 = exports.default = /* define-vxe-component start */(0, _comp.defi
95
134
  var xID = _xeUtils.default.uniqueId();
96
135
  var reactData = {
97
136
  initialized: false,
98
- fullOptionList: [],
99
- fullNodeMaps: {},
137
+ searchValue: '',
138
+ searchLoading: false,
100
139
  panelIndex: 0,
101
140
  panelStyle: {},
102
141
  panelPlacement: null,
@@ -106,7 +145,9 @@ var _default2 = exports.default = /* define-vxe-component start */(0, _comp.defi
106
145
  isActivated: false
107
146
  };
108
147
  var internalData = {
109
- hpTimeout: undefined
148
+ // hpTimeout: undefined,
149
+ fullOptionList: [],
150
+ fullNodeMaps: {}
110
151
  };
111
152
  return {
112
153
  xID: xID,
@@ -230,14 +271,31 @@ var _default2 = exports.default = /* define-vxe-component start */(0, _comp.defi
230
271
  var propsOpts = $xeTreeSelect.computePropsOpts;
231
272
  return propsOpts.hasChild || 'hasChild';
232
273
  },
274
+ computeVirtualYOpts: function computeVirtualYOpts() {
275
+ var $xeTreeSelect = this;
276
+ var props = $xeTreeSelect;
277
+ return Object.assign({}, (0, _ui.getConfig)().treeSelect.virtualYConfig, props.virtualYConfig);
278
+ },
279
+ computeRemoteOpts: function computeRemoteOpts() {
280
+ var $xeTreeSelect = this;
281
+ var props = $xeTreeSelect;
282
+ return Object.assign({}, (0, _ui.getConfig)().treeSelect.remoteConfig, props.remoteConfig);
283
+ },
284
+ computeFilterOpts: function computeFilterOpts() {
285
+ var $xeTreeSelect = this;
286
+ var props = $xeTreeSelect;
287
+ var treeOpts = $xeTreeSelect.computeTreeOpts;
288
+ return Object.assign({}, treeOpts.filterConfig, props.filterConfig);
289
+ },
233
290
  computeSelectLabel: function computeSelectLabel() {
234
291
  var $xeTreeSelect = this;
235
292
  var props = $xeTreeSelect;
236
- var reactData = $xeTreeSelect.reactData;
237
- var value = props.value;
238
- var fullNodeMaps = reactData.fullNodeMaps;
293
+ var internalData = $xeTreeSelect.internalData;
294
+ var modelValue = props.value;
295
+ var fullNodeMaps = internalData.fullNodeMaps;
239
296
  var labelField = $xeTreeSelect.computeLabelField;
240
- return (_xeUtils.default.isArray(value) ? value : [value]).map(function (val) {
297
+ var selectVals = _xeUtils.default.eqNull(modelValue) ? [] : _xeUtils.default.isArray(modelValue) ? modelValue : [modelValue];
298
+ return selectVals.map(function (val) {
241
299
  var cacheItem = fullNodeMaps[val];
242
300
  return cacheItem ? cacheItem.item[labelField] : val;
243
301
  }).join(', ');
@@ -286,7 +344,7 @@ var _default2 = exports.default = /* define-vxe-component start */(0, _comp.defi
286
344
  cacheDataMap: function cacheDataMap() {
287
345
  var $xeTreeSelect = this;
288
346
  var props = $xeTreeSelect;
289
- var reactData = $xeTreeSelect.reactData;
347
+ var internalData = $xeTreeSelect.internalData;
290
348
  var options = props.options;
291
349
  var nodeKeyField = $xeTreeSelect.computeNodeKeyField;
292
350
  var childrenField = $xeTreeSelect.computeChildrenField;
@@ -316,8 +374,8 @@ var _default2 = exports.default = /* define-vxe-component start */(0, _comp.defi
316
374
  }, {
317
375
  children: childrenField
318
376
  });
319
- reactData.fullOptionList = options || [];
320
- reactData.fullNodeMaps = nodeMaps;
377
+ internalData.fullOptionList = options || [];
378
+ internalData.fullNodeMaps = nodeMaps;
321
379
  },
322
380
  updateZindex: function updateZindex() {
323
381
  var $xeTreeSelect = this;
@@ -354,8 +412,12 @@ var _default2 = exports.default = /* define-vxe-component start */(0, _comp.defi
354
412
  var props = $xeTreeSelect;
355
413
  var reactData = $xeTreeSelect.reactData;
356
414
  var internalData = $xeTreeSelect.internalData;
357
- var loading = props.loading;
415
+ var loading = props.loading,
416
+ remote = props.remote,
417
+ filterable = props.filterable;
418
+ var fullOptionList = internalData.fullOptionList;
358
419
  var isDisabled = $xeTreeSelect.computeIsDisabled;
420
+ var remoteOpts = $xeTreeSelect.computeRemoteOpts;
359
421
  if (!loading && !isDisabled) {
360
422
  if (internalData.hpTimeout) {
361
423
  clearTimeout(internalData.hpTimeout);
@@ -372,8 +434,14 @@ var _default2 = exports.default = /* define-vxe-component start */(0, _comp.defi
372
434
  }
373
435
  reactData.isActivated = true;
374
436
  reactData.isAniVisible = true;
437
+ if (filterable) {
438
+ if (remote && remoteOpts.enabled && remoteOpts.autoLoad && !fullOptionList.length) {
439
+ $xeTreeSelect.handleSearchEvent();
440
+ }
441
+ }
375
442
  setTimeout(function () {
376
443
  reactData.visiblePanel = true;
444
+ $xeTreeSelect.handleFocusSearch();
377
445
  }, 10);
378
446
  $xeTreeSelect.updateZindex();
379
447
  $xeTreeSelect.updatePlacement();
@@ -391,10 +459,10 @@ var _default2 = exports.default = /* define-vxe-component start */(0, _comp.defi
391
459
  changeEvent: function changeEvent(evnt, selectValue) {
392
460
  var $xeTreeSelect = this;
393
461
  var props = $xeTreeSelect;
394
- var reactData = $xeTreeSelect.reactData;
462
+ var internalData = $xeTreeSelect.internalData;
395
463
  var $xeForm = $xeTreeSelect.$xeForm;
396
464
  var formItemInfo = $xeTreeSelect.formItemInfo;
397
- var fullNodeMaps = reactData.fullNodeMaps;
465
+ var fullNodeMaps = internalData.fullNodeMaps;
398
466
  $xeTreeSelect.emitModel(selectValue);
399
467
  if (selectValue !== props.value) {
400
468
  var cacheItem = fullNodeMaps[selectValue];
@@ -420,6 +488,62 @@ var _default2 = exports.default = /* define-vxe-component start */(0, _comp.defi
420
488
  $xeTreeSelect.clearValueEvent(evnt, null);
421
489
  $xeTreeSelect.hideOptionPanel();
422
490
  },
491
+ allCheckedPanelEvent: function allCheckedPanelEvent(params) {
492
+ var $xeTreeSelect = this;
493
+ var props = $xeTreeSelect;
494
+ var $event = params.$event;
495
+ var multiple = props.multiple,
496
+ autoClose = props.autoClose;
497
+ var $tree = $xeTreeSelect.$refs.refTree;
498
+ if (multiple) {
499
+ if ($tree) {
500
+ $tree.setAllCheckboxNode(true).then(function (_ref) {
501
+ var checkNodeKeys = _ref.checkNodeKeys;
502
+ $xeTreeSelect.changeEvent($event, checkNodeKeys);
503
+ $xeTreeSelect.dispatchEvent('all-change', {
504
+ value: checkNodeKeys
505
+ }, $event);
506
+ if (autoClose) {
507
+ $xeTreeSelect.hideOptionPanel();
508
+ }
509
+ });
510
+ }
511
+ }
512
+ },
513
+ clearCheckedPanelEvent: function clearCheckedPanelEvent(params) {
514
+ var $xeTreeSelect = this;
515
+ var props = $xeTreeSelect;
516
+ var $event = params.$event;
517
+ var multiple = props.multiple,
518
+ autoClose = props.autoClose;
519
+ var $tree = $xeTreeSelect.$refs.refTree;
520
+ if ($tree) {
521
+ var value = multiple ? [] : null;
522
+ $tree.clearCheckboxNode().then(function () {
523
+ if (autoClose) {
524
+ $xeTreeSelect.hideOptionPanel();
525
+ }
526
+ });
527
+ $xeTreeSelect.changeEvent($event, value);
528
+ $xeTreeSelect.dispatchEvent('clear', {
529
+ value: value
530
+ }, $event);
531
+ }
532
+ },
533
+ allExpandPanelEvent: function allExpandPanelEvent() {
534
+ var $xeTreeSelect = this;
535
+ var $tree = $xeTreeSelect.$refs.refTree;
536
+ if ($tree) {
537
+ $tree.setAllExpandNode(true);
538
+ }
539
+ },
540
+ clearExpandPanelEvent: function clearExpandPanelEvent() {
541
+ var $xeTreeSelect = this;
542
+ var $tree = $xeTreeSelect.$refs.refTree;
543
+ if ($tree) {
544
+ $tree.clearAllExpandNode();
545
+ }
546
+ },
423
547
  handleGlobalMousewheelEvent: function handleGlobalMousewheelEvent(evnt) {
424
548
  var $xeTreeSelect = this;
425
549
  var reactData = $xeTreeSelect.reactData;
@@ -462,6 +586,18 @@ var _default2 = exports.default = /* define-vxe-component start */(0, _comp.defi
462
586
  $xeTreeSelect.updatePlacement();
463
587
  }
464
588
  },
589
+ handleFocusSearch: function handleFocusSearch() {
590
+ var $xeSelect = this;
591
+ var props = $xeSelect;
592
+ if (props.filterable) {
593
+ $xeSelect.$nextTick(function () {
594
+ var inpSearch = $xeSelect.$refs.refInpSearch;
595
+ if (inpSearch) {
596
+ inpSearch.focus();
597
+ }
598
+ });
599
+ }
600
+ },
465
601
  focusEvent: function focusEvent(evnt) {
466
602
  var $xeTreeSelect = this;
467
603
  var reactData = $xeTreeSelect.reactData;
@@ -488,6 +624,36 @@ var _default2 = exports.default = /* define-vxe-component start */(0, _comp.defi
488
624
  reactData.isActivated = false;
489
625
  $xeTreeSelect.dispatchEvent('blur', {}, evnt);
490
626
  },
627
+ modelSearchEvent: function modelSearchEvent(value) {
628
+ var $xeTreeSelect = this;
629
+ var reactData = $xeTreeSelect.reactData;
630
+ reactData.searchValue = value;
631
+ },
632
+ handleSearchEvent: function handleSearchEvent() {
633
+ var $xeTreeSelect = this;
634
+ var props = $xeTreeSelect;
635
+ var reactData = $xeTreeSelect.reactData;
636
+ var modelValue = props.value,
637
+ remote = props.remote,
638
+ remoteMethod = props.remoteMethod;
639
+ var searchValue = reactData.searchValue;
640
+ var remoteOpts = $xeTreeSelect.computeRemoteOpts;
641
+ var queryMethod = remoteOpts.queryMethod || remoteMethod;
642
+ if (remote && queryMethod && remoteOpts.enabled) {
643
+ reactData.searchLoading = true;
644
+ Promise.resolve(queryMethod({
645
+ $treeSelect: $xeTreeSelect,
646
+ searchValue: searchValue,
647
+ value: modelValue
648
+ })).then(function () {
649
+ return $xeTreeSelect.$nextTick();
650
+ }).catch(function () {
651
+ return $xeTreeSelect.$nextTick();
652
+ }).finally(function () {
653
+ reactData.searchLoading = false;
654
+ });
655
+ }
656
+ },
491
657
  togglePanelEvent: function togglePanelEvent(params) {
492
658
  var $xeTreeSelect = this;
493
659
  var reactData = $xeTreeSelect.reactData;
@@ -534,14 +700,20 @@ var _default2 = exports.default = /* define-vxe-component start */(0, _comp.defi
534
700
  var slots = $xeTreeSelect.$scopedSlots;
535
701
  var reactData = $xeTreeSelect.reactData;
536
702
  var className = props.className,
537
- value = props.value,
703
+ modelValue = props.value,
538
704
  multiple = props.multiple,
539
705
  options = props.options,
540
- loading = props.loading;
706
+ loading = props.loading,
707
+ filterable = props.filterable,
708
+ showTotalButoon = props.showTotalButoon,
709
+ showCheckedButoon = props.showCheckedButoon,
710
+ showClearButton = props.showClearButton,
711
+ showExpandButton = props.showExpandButton;
541
712
  var initialized = reactData.initialized,
542
713
  isActivated = reactData.isActivated,
543
714
  isAniVisible = reactData.isAniVisible,
544
- visiblePanel = reactData.visiblePanel;
715
+ visiblePanel = reactData.visiblePanel,
716
+ searchValue = reactData.searchValue;
545
717
  var vSize = $xeTreeSelect.computeSize;
546
718
  var isDisabled = $xeTreeSelect.computeIsDisabled;
547
719
  var selectLabel = $xeTreeSelect.computeSelectLabel;
@@ -563,6 +735,8 @@ var _default2 = exports.default = /* define-vxe-component start */(0, _comp.defi
563
735
  var childrenField = $xeTreeSelect.computeChildrenField;
564
736
  var parentField = $xeTreeSelect.computeParentField;
565
737
  var hasChildField = $xeTreeSelect.computeHasChildField;
738
+ var virtualYOpts = $xeTreeSelect.computeVirtualYOpts;
739
+ var filterOpts = $xeTreeSelect.computeFilterOpts;
566
740
  if (formReadonly) {
567
741
  return h('div', {
568
742
  ref: 'refElem',
@@ -571,11 +745,12 @@ var _default2 = exports.default = /* define-vxe-component start */(0, _comp.defi
571
745
  class: 'vxe-tree-select-label'
572
746
  }, selectLabel)]);
573
747
  }
748
+ var selectVals = _xeUtils.default.eqNull(modelValue) ? [] : _xeUtils.default.isArray(modelValue) ? modelValue : [modelValue];
574
749
  return h('div', {
575
750
  ref: 'refElem',
576
751
  class: ['vxe-tree-select', className ? _xeUtils.default.isFunction(className) ? className({
577
752
  $treeSelect: $xeTreeSelect
578
- }) : className : '', _defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty({}, "size--".concat(vSize), vSize), 'is--visible', visiblePanel), 'is--disabled', isDisabled), 'is--loading', loading), 'is--active', isActivated)]
753
+ }) : className : '', _defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty({}, "size--".concat(vSize), vSize), 'is--filterable', filterable), 'is--visible', visiblePanel), 'is--disabled', isDisabled), 'is--loading', loading), 'is--active', isActivated)]
579
754
  }, [h(_input.default, {
580
755
  ref: 'refInput',
581
756
  props: {
@@ -586,7 +761,8 @@ var _default2 = exports.default = /* define-vxe-component start */(0, _comp.defi
586
761
  type: 'text',
587
762
  prefixIcon: props.prefixIcon,
588
763
  suffixIcon: loading ? (0, _ui.getIcon)().TREE_SELECT_LOADED : visiblePanel ? (0, _ui.getIcon)().TREE_SELECT_OPEN : (0, _ui.getIcon)().TREE_SELECT_CLOSE,
589
- value: loading ? (0, _ui.getI18n)('vxe.select.loadingText') : selectLabel
764
+ value: loading ? (0, _ui.getI18n)('vxe.select.loadingText') : selectLabel,
765
+ title: selectLabel
590
766
  },
591
767
  on: {
592
768
  clear: $xeTreeSelect.clearEvent,
@@ -611,24 +787,84 @@ var _default2 = exports.default = /* define-vxe-component start */(0, _comp.defi
611
787
  style: reactData.panelStyle
612
788
  }, initialized ? [h('div', {
613
789
  class: 'vxe-tree-select--panel-wrapper'
614
- }, [headerSlot ? h('div', {
790
+ }, [filterable ? h('div', {
791
+ class: 'vxe-tree-select--panel-search'
792
+ }, [h(_input.default, {
793
+ ref: 'refInpSearch',
794
+ class: 'vxe-tree-select-search--input',
795
+ props: {
796
+ value: searchValue,
797
+ title: selectLabel,
798
+ clearable: true,
799
+ disabled: false,
800
+ readonly: false,
801
+ placeholder: (0, _ui.getI18n)('vxe.treeSelect.search'),
802
+ prefixIcon: (0, _ui.getIcon)().INPUT_SEARCH
803
+ },
804
+ on: {
805
+ 'model-value': $xeTreeSelect.modelSearchEvent
806
+ }
807
+ })]) : (0, _ui.renderEmptyElement)($xeTreeSelect), showTotalButoon || showCheckedButoon && multiple || showClearButton || showExpandButton || headerSlot ? h('div', {
615
808
  class: 'vxe-tree-select--panel-header'
616
- }, headerSlot({})) : (0, _ui.renderEmptyElement)($xeTreeSelect), h('div', {
809
+ }, headerSlot ? headerSlot({}) : [h('div', {
810
+ class: 'vxe-tree-select--header-button'
811
+ }, [showTotalButoon ? h('div', {
812
+ class: 'vxe-tree-select--header-total'
813
+ }, (0, _ui.getI18n)('vxe.treeSelect.total', [selectVals.length])) : (0, _ui.renderEmptyElement)($xeTreeSelect), h('div', {
814
+ class: 'vxe-tree-select--header-btns'
815
+ }, [showCheckedButoon && multiple ? h(_button.default, {
816
+ props: {
817
+ content: (0, _ui.getI18n)('vxe.treeSelect.allChecked'),
818
+ mode: 'text'
819
+ },
820
+ on: {
821
+ click: $xeTreeSelect.allCheckedPanelEvent
822
+ }
823
+ }) : (0, _ui.renderEmptyElement)($xeTreeSelect), showClearButton ? h(_button.default, {
824
+ props: {
825
+ content: (0, _ui.getI18n)('vxe.treeSelect.clearChecked'),
826
+ mode: 'text'
827
+ },
828
+ on: {
829
+ click: $xeTreeSelect.clearCheckedPanelEvent
830
+ }
831
+ }) : (0, _ui.renderEmptyElement)($xeTreeSelect), showExpandButton ? h(_button.default, {
832
+ props: {
833
+ content: (0, _ui.getI18n)('vxe.treeSelect.allExpand'),
834
+ mode: 'text'
835
+ },
836
+ on: {
837
+ click: $xeTreeSelect.allExpandPanelEvent
838
+ }
839
+ }) : (0, _ui.renderEmptyElement)($xeTreeSelect), showExpandButton ? h(_button.default, {
840
+ props: {
841
+ content: (0, _ui.getI18n)('vxe.treeSelect.clearExpand'),
842
+ mode: 'text'
843
+ },
844
+ on: {
845
+ click: $xeTreeSelect.clearExpandPanelEvent
846
+ }
847
+ }) : (0, _ui.renderEmptyElement)($xeTreeSelect)])])]) : (0, _ui.renderEmptyElement)($xeTreeSelect), h('div', {
617
848
  class: 'vxe-tree-select--panel-body'
618
849
  }, [h('div', {
619
850
  ref: 'refTreeWrapper',
620
851
  class: 'vxe-tree-select-tree--wrapper',
621
852
  style: popupWrapperStyle
622
853
  }, [h(_tree.default, {
854
+ ref: 'refTree',
623
855
  class: 'vxe-tree-select--tree',
624
856
  props: {
625
857
  data: options,
858
+ height: popupOpts.height ? '100%' : treeOpts.height,
859
+ minHeight: treeOpts.minHeight,
860
+ maxHeight: popupOpts.height ? '' : treeOpts.maxHeight,
861
+ autoResize: true,
626
862
  indent: treeOpts.indent,
627
863
  showRadio: !multiple,
628
864
  radioConfig: treeRadioOpts,
629
- checkNodeKey: multiple ? null : value,
865
+ checkNodeKey: multiple ? null : modelValue,
630
866
  showCheckbox: !!multiple,
631
- checkNodeKeys: multiple ? value : null,
867
+ checkNodeKeys: multiple ? modelValue : null,
632
868
  checkboxConfig: treeCheckboxOpts,
633
869
  titleField: labelField,
634
870
  valueField: valueField,
@@ -648,7 +884,10 @@ var _default2 = exports.default = /* define-vxe-component start */(0, _comp.defi
648
884
  showLine: treeOpts.showLine,
649
885
  iconOpen: treeOpts.iconOpen,
650
886
  iconLoaded: treeOpts.iconLoaded,
651
- iconClose: treeOpts.iconClose
887
+ iconClose: treeOpts.iconClose,
888
+ filterValue: searchValue,
889
+ filterConfig: filterOpts,
890
+ virtualYConfig: virtualYOpts
652
891
  },
653
892
  on: {
654
893
  'node-click': $xeTreeSelect.nodeClickEvent,
@@ -1 +1 @@
1
- Object.defineProperty(exports,"__esModule",{value:!0}),exports.default=void 0;var _comp=require("../../ui/src/comp"),_xeUtils=_interopRequireDefault(require("xe-utils")),_ui=require("../../ui"),_dom=require("../../ui/src/dom"),_utils=require("../../ui/src/utils"),_log=require("../../ui/src/log"),_input=_interopRequireDefault(require("../../input/src/input")),_tree=_interopRequireDefault(require("../../tree/src/tree"));function _interopRequireDefault(e){return e&&e.__esModule?e:{default:e}}function _typeof(e){return(_typeof="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e})(e)}function _defineProperty(e,t,n){return(t=_toPropertyKey(t))in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function _toPropertyKey(e){e=_toPrimitive(e,"string");return"symbol"==_typeof(e)?e:e+""}function _toPrimitive(e,t){if("object"!=_typeof(e)||!e)return e;var n=e[Symbol.toPrimitive];if(void 0===n)return("string"===t?String:Number)(e);n=n.call(e,t||"default");if("object"!=_typeof(n))return n;throw new TypeError("@@toPrimitive must return a primitive value.")}function getOptUniqueId(){return _xeUtils.default.uniqueId("node_")}var _default2=exports.default=(0,_comp.defineVxeComponent)({name:"VxeTreeSelect",mixins:[_ui.globalMixins.sizeMixin],model:{prop:"value",event:"modelValue"},props:{value:[String,Number,Array],clearable:Boolean,placeholder:{type:String,default:function(){return _xeUtils.default.eqNull((0,_ui.getConfig)().treeSelect.placeholder)?(0,_ui.getI18n)("vxe.base.pleaseSelect"):(0,_ui.getConfig)().treeSelect.placeholder}},readonly:{type:Boolean,default:null},loading:Boolean,disabled:{type:Boolean,default:null},multiple:Boolean,className:[String,Function],popupClassName:[String,Function],prefixIcon:String,placement:String,options:Array,optionProps:Object,size:{type:String,default:function(){return(0,_ui.getConfig)().select.size||(0,_ui.getConfig)().size}},remote:Boolean,remoteMethod:Function,popupConfig:Object,treeConfig:Object,transfer:{type:Boolean,default:null}},inject:{$xeModal:{default:null},$xeDrawer:{default:null},$xeTable:{default:null},$xeForm:{default:null},formItemInfo:{from:"xeFormItemInfo",default:null}},provide:function(){return{$xeTreeSelect:this}},data:function(){return{xID:_xeUtils.default.uniqueId(),reactData:{initialized:!1,fullOptionList:[],fullNodeMaps:{},panelIndex:0,panelStyle:{},panelPlacement:null,triggerFocusPanel:!1,visiblePanel:!1,isAniVisible:!1,isActivated:!1},internalData:{hpTimeout:void 0}}},computed:Object.assign(Object.assign({},{}),{computeFormReadonly:function(){var e=this.$xeForm,t=this.readonly;return null===t?!!e&&e.readonly:t},computeIsDisabled:function(){var e=this.$xeForm,t=this.disabled;return null===t?!!e&&e.disabled:t},computeBtnTransfer:function(){var e=this,t=e.$xeTable,n=e.$xeModal,i=e.$xeDrawer,o=e.$xeForm,e=e.transfer;if(null===e){var l=(0,_ui.getConfig)().treeSelect.transfer;if(_xeUtils.default.isBoolean(l))return l;if(t||n||i||o)return!0}return e},computePopupOpts:function(){return Object.assign({},(0,_ui.getConfig)().treeSelect.popupConfig,this.popupConfig)},computeTreeOpts:function(){return Object.assign({},(0,_ui.getConfig)().treeSelect.treeConfig,this.treeConfig)},computeTreeNodeOpts:function(){var e=this.computeTreeOpts;return Object.assign({isHover:!0},e.nodeConfig)},computeTreeCheckboxOpts:function(){var e=this.computeTreeOpts;return Object.assign({showIcon:!!e.showCheckbox},e.checkboxConfig,{trigger:"node"})},computeTreeRadioOpts:function(){var e=this.computeTreeOpts;return Object.assign({showIcon:!!e.showRadio},e.radioConfig,{trigger:"node"})},computePropsOpts:function(){return Object.assign({},this.optionProps)},computeNodeKeyField:function(){return this.computeTreeOpts.keyField||"id"},computeLabelField:function(){return this.computePropsOpts.label||"label"},computeValueField:function(){return this.computePropsOpts.value||"value"},computeChildrenField:function(){return this.computePropsOpts.children||"children"},computeParentField:function(){return this.computePropsOpts.parent||"parentField"},computeHasChildField:function(){return this.computePropsOpts.hasChild||"hasChild"},computeSelectLabel:function(){var e=this.reactData,t=this.value,n=e.fullNodeMaps,i=this.computeLabelField;return(_xeUtils.default.isArray(t)?t:[t]).map(function(e){var t=n[e];return t?t.item[i]:e}).join(", ")},computePopupWrapperStyle:function(){var e=this.computePopupOpts,t=e.height,e=e.width,n={};return e&&(n.width=(0,_dom.toCssUnit)(e)),t&&(n.height=(0,_dom.toCssUnit)(t),n.maxHeight=(0,_dom.toCssUnit)(t)),n}}),methods:{dispatchEvent:function(e,t,n){this.$emit(e,(0,_ui.createEvent)(n,{$treeSelect:this},t))},emitModel:function(e){var t=this._events;t&&t.modelValue?this.$emit("modelValue",e):this.$emit("model-value",e)},getNodeid:function(e){e=e[this.computeNodeKeyField];return e?encodeURIComponent(e):""},cacheDataMap:function(){var a=this,e=a.reactData,t=a.options,u=a.computeNodeKeyField,s=a.computeValueField,c={},p={};_xeUtils.default.eachTree(t,function(e,t,n,i,o,l){var r=(r=a.getNodeid(e))||getOptUniqueId(),r=(p[r]&&(0,_log.errLog)("vxe.error.repeatKey",[u,r]),p[r]=!0,e[s]);c[r]&&(0,_log.errLog)("vxe.error.repeatKey",[s,r]),c[r]={item:e,index:t,items:n,parent:o,nodes:l}},{children:a.computeChildrenField}),e.fullOptionList=t||[],e.fullNodeMaps=c},updateZindex:function(){var e=this.reactData;e.panelIndex<(0,_utils.getLastZIndex)()&&(e.panelIndex=(0,_utils.nextZIndex)())},updatePlacement:function(){function e(){var e=(0,_dom.updatePanelPlacement)(l,r,{placement:i,teleportTo:a}),t=Object.assign(e.style,{zIndex:o});n.panelStyle=t,n.panelPlacement=e.placement}var t=this,n=t.reactData,i=t.placement,o=n.panelIndex,l=t.$refs.refElem,r=t.$refs.refOptionPanel,a=t.computeBtnTransfer;return e(),t.$nextTick().then(e)},showOptionPanel:function(){var e,t=this,n=t.reactData,i=t.internalData;t.loading||t.computeIsDisabled||(i.hpTimeout&&clearTimeout(i.hpTimeout),n.initialized||(n.initialized=!0,i=t.computeBtnTransfer,e=t.$refs.refOptionPanel,i&&e&&document.body.appendChild(e)),n.isActivated=!0,n.isAniVisible=!0,setTimeout(function(){n.visiblePanel=!0},10),t.updateZindex(),t.updatePlacement())},hideOptionPanel:function(){var e=this.reactData,t=this.internalData;e.visiblePanel=!1,t.hpTimeout=setTimeout(function(){e.isAniVisible=!1},350)},changeEvent:function(e,t){var n=this,i=n,o=n.reactData,l=n.$xeForm,r=n.formItemInfo,o=o.fullNodeMaps;n.emitModel(t),t!==i.value&&(i=o[t],n.dispatchEvent("change",{value:t,option:i?i.item:null},e),l)&&r&&l.triggerItemEvent(e,r.itemConfig.field,t)},clearValueEvent:function(e,t){this.changeEvent(e,t),this.dispatchEvent("clear",{value:t},e)},clearEvent:function(e,t){this.clearValueEvent(t,null),this.hideOptionPanel()},handleGlobalMousewheelEvent:function(e){var t=this,n=t.reactData.visiblePanel;t.computeIsDisabled||n&&(n=t.$refs.refOptionPanel,(0,_dom.getEventTargetNode)(e,n).flag?t.updatePlacement():t.hideOptionPanel())},handleGlobalMousedownEvent:function(e){var t,n,i=this,o=i.reactData,l=o.visiblePanel;i.computeIsDisabled||(t=i.$refs.refElem,n=i.$refs.refOptionPanel,o.isActivated=(0,_dom.getEventTargetNode)(e,t).flag||(0,_dom.getEventTargetNode)(e,n).flag,l&&!o.isActivated&&i.hideOptionPanel())},handleGlobalBlurEvent:function(){this.hideOptionPanel()},handleGlobalResizeEvent:function(){this.reactData.visiblePanel&&this.updatePlacement()},focusEvent:function(e){var t=this.reactData;this.computeIsDisabled||t.visiblePanel||(t.triggerFocusPanel=!0,this.showOptionPanel(),setTimeout(function(){t.triggerFocusPanel=!1},150)),this.dispatchEvent("focus",{},e)},clickEvent:function(e){this.togglePanelEvent(e),this.dispatchEvent("click",{},e)},blurEvent:function(e){this.reactData.isActivated=!1,this.dispatchEvent("blur",{},e)},togglePanelEvent:function(e){var t=this.reactData;e.$event.preventDefault(),t.triggerFocusPanel?t.triggerFocusPanel=!1:t.visiblePanel?this.hideOptionPanel():this.showOptionPanel()},nodeClickEvent:function(e){var t=e.$event;this.dispatchEvent("node-click",e,t)},radioChangeEvent:function(e){var t=e.value;this.changeEvent(e.$event,t),this.hideOptionPanel()},checkboxChangeEvent:function(e){var t=e.value;this.changeEvent(e.$event,t)},loadSuccessEvent:function(){this.cacheDataMap()},renderVN:function(e){var t=this,n=t,i=t.$scopedSlots,o=t.reactData,l=n.className,r=n.value,a=n.multiple,u=n.options,s=n.loading,c=o.initialized,p=o.isActivated,d=o.isAniVisible,f=o.visiblePanel,h=t.computeSize,m=t.computeIsDisabled,v=t.computeSelectLabel,g=t.computeBtnTransfer,b=t.computePopupWrapperStyle,_=i.header,x=i.footer,y=i.prefix,i=t.computePopupOpts.className||n.popupClassName,E=t.computeTreeOpts,P=t.computeTreeNodeOpts,O=t.computeTreeCheckboxOpts,C=t.computeTreeRadioOpts,F=t.computeNodeKeyField,T=t.computeLabelField,S=t.computeValueField,I=t.computeChildrenField,D=t.computeParentField,w=t.computeHasChildField;return t.computeFormReadonly?e("div",{ref:"refElem",class:["vxe-tree-select--readonly",l]},[e("span",{class:"vxe-tree-select-label"},v)]):e("div",{ref:"refElem",class:["vxe-tree-select",l?_xeUtils.default.isFunction(l)?l({$treeSelect:t}):l:"",_defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty({},"size--".concat(h),h),"is--visible",f),"is--disabled",m),"is--loading",s),"is--active",p)]},[e(_input.default,{ref:"refInput",props:{clearable:n.clearable,placeholder:n.placeholder,readonly:!0,disabled:m,type:"text",prefixIcon:n.prefixIcon,suffixIcon:s?(0,_ui.getIcon)().TREE_SELECT_LOADED:f?(0,_ui.getIcon)().TREE_SELECT_OPEN:(0,_ui.getIcon)().TREE_SELECT_CLOSE,value:s?(0,_ui.getI18n)("vxe.select.loadingText"):v},on:{clear:t.clearEvent,click:t.clickEvent,focus:t.focusEvent,blur:t.blurEvent,"suffix-click":t.togglePanelEvent},scopedSlots:y?{prefix:function(){return y({})}}:{}}),e("div",{ref:"refOptionPanel",class:["vxe-table--ignore-clear vxe-tree-select--panel",i?_xeUtils.default.isFunction(i)?i({$treeSelect:t}):i:"",_defineProperty(_defineProperty(_defineProperty(_defineProperty({},"size--".concat(h),h),"is--transfer",g),"ani--leave",!s&&d),"ani--enter",!s&&f)],attrs:{placement:o.panelPlacement},style:o.panelStyle},c?[e("div",{class:"vxe-tree-select--panel-wrapper"},[_?e("div",{class:"vxe-tree-select--panel-header"},_({})):(0,_ui.renderEmptyElement)(t),e("div",{class:"vxe-tree-select--panel-body"},[e("div",{ref:"refTreeWrapper",class:"vxe-tree-select-tree--wrapper",style:b},[e(_tree.default,{class:"vxe-tree-select--tree",props:{data:u,indent:E.indent,showRadio:!a,radioConfig:C,checkNodeKey:a?null:r,showCheckbox:!!a,checkNodeKeys:a?r:null,checkboxConfig:O,titleField:T,valueField:S,keyField:F,childrenField:E.childrenField||I,parentField:E.parentField||D,hasChildField:E.hasChildField||w,accordion:E.accordion,expandAll:E.expandAll,nodeConfig:P,lazy:E.lazy,loadMethod:E.loadMethod,toggleMethod:E.toggleMethod,transform:E.transform,trigger:E.trigger,showIcon:E.showIcon,showLine:E.showLine,iconOpen:E.iconOpen,iconLoaded:E.iconLoaded,iconClose:E.iconClose},on:{"node-click":t.nodeClickEvent,"radio-change":t.radioChangeEvent,"checkbox-change":t.checkboxChangeEvent,"load-success":t.loadSuccessEvent}})])]),x?e("div",{class:"vxe-tree-select--panel-footer"},x({})):(0,_ui.renderEmptyElement)(t)])]:[])])}},watch:{options:function(){this.cacheDataMap()}},created:function(){this.cacheDataMap()},mounted:function(){var e=this;_ui.globalEvents.on(e,"mousewheel",e.handleGlobalMousewheelEvent),_ui.globalEvents.on(e,"mousedown",e.handleGlobalMousedownEvent),_ui.globalEvents.on(e,"blur",e.handleGlobalBlurEvent),_ui.globalEvents.on(e,"resize",e.handleGlobalResizeEvent)},beforeDestroy:function(){var e=this,t=e.$refs.refOptionPanel;t&&t.parentNode&&t.parentNode.removeChild(t),_ui.globalEvents.off(e,"mousewheel"),_ui.globalEvents.off(e,"mousedown"),_ui.globalEvents.off(e,"blur"),_ui.globalEvents.off(e,"resize")},render:function(e){return this.renderVN(e)}});
1
+ Object.defineProperty(exports,"__esModule",{value:!0}),exports.default=void 0;var _comp=require("../../ui/src/comp"),_xeUtils=_interopRequireDefault(require("xe-utils")),_ui=require("../../ui"),_dom=require("../../ui/src/dom"),_utils=require("../../ui/src/utils"),_log=require("../../ui/src/log"),_input=_interopRequireDefault(require("../../input/src/input")),_button=_interopRequireDefault(require("../../button/src/button")),_tree=_interopRequireDefault(require("../../tree/src/tree"));function _interopRequireDefault(e){return e&&e.__esModule?e:{default:e}}function _typeof(e){return(_typeof="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e})(e)}function _defineProperty(e,t,n){return(t=_toPropertyKey(t))in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function _toPropertyKey(e){e=_toPrimitive(e,"string");return"symbol"==_typeof(e)?e:e+""}function _toPrimitive(e,t){if("object"!=_typeof(e)||!e)return e;var n=e[Symbol.toPrimitive];if(void 0===n)return("string"===t?String:Number)(e);n=n.call(e,t||"default");if("object"!=_typeof(n))return n;throw new TypeError("@@toPrimitive must return a primitive value.")}function getOptUniqueId(){return _xeUtils.default.uniqueId("node_")}var _default2=exports.default=(0,_comp.defineVxeComponent)({name:"VxeTreeSelect",mixins:[_ui.globalMixins.sizeMixin],model:{prop:"value",event:"modelValue"},props:{value:[String,Number,Array],clearable:Boolean,placeholder:{type:String,default:function(){return _xeUtils.default.eqNull((0,_ui.getConfig)().treeSelect.placeholder)?(0,_ui.getI18n)("vxe.base.pleaseSelect"):(0,_ui.getConfig)().treeSelect.placeholder}},readonly:{type:Boolean,default:null},loading:Boolean,disabled:{type:Boolean,default:null},filterable:Boolean,filterConfig:Object,multiple:Boolean,className:[String,Function],popupClassName:[String,Function],prefixIcon:String,placement:String,options:Array,optionProps:Object,size:{type:String,default:function(){return(0,_ui.getConfig)().treeSelect.size||(0,_ui.getConfig)().size}},remote:Boolean,remoteConfig:Function,popupConfig:Object,treeConfig:Object,virtualYConfig:Object,autoClose:{type:Boolean,default:function(){return(0,_ui.getConfig)().treeSelect.autoClose}},showTotalButoon:{type:Boolean,default:function(){return(0,_ui.getConfig)().treeSelect.showTotalButoon}},showCheckedButoon:{type:Boolean,default:function(){return(0,_ui.getConfig)().treeSelect.showCheckedButoon}},showClearButton:{type:Boolean,default:function(){return(0,_ui.getConfig)().treeSelect.showClearButton}},showExpandButton:{type:Boolean,default:function(){return(0,_ui.getConfig)().treeSelect.showExpandButton}},transfer:{type:Boolean,default:null},remoteMethod:Function},inject:{$xeModal:{default:null},$xeDrawer:{default:null},$xeTable:{default:null},$xeForm:{default:null},formItemInfo:{from:"xeFormItemInfo",default:null}},provide:function(){return{$xeTreeSelect:this}},data:function(){return{xID:_xeUtils.default.uniqueId(),reactData:{initialized:!1,searchValue:"",searchLoading:!1,panelIndex:0,panelStyle:{},panelPlacement:null,triggerFocusPanel:!1,visiblePanel:!1,isAniVisible:!1,isActivated:!1},internalData:{fullOptionList:[],fullNodeMaps:{}}}},computed:Object.assign(Object.assign({},{}),{computeFormReadonly:function(){var e=this.$xeForm,t=this.readonly;return null===t?!!e&&e.readonly:t},computeIsDisabled:function(){var e=this.$xeForm,t=this.disabled;return null===t?!!e&&e.disabled:t},computeBtnTransfer:function(){var e=this,t=e.$xeTable,n=e.$xeModal,i=e.$xeDrawer,o=e.$xeForm,e=e.transfer;if(null===e){var l=(0,_ui.getConfig)().treeSelect.transfer;if(_xeUtils.default.isBoolean(l))return l;if(t||n||i||o)return!0}return e},computePopupOpts:function(){return Object.assign({},(0,_ui.getConfig)().treeSelect.popupConfig,this.popupConfig)},computeTreeOpts:function(){return Object.assign({},(0,_ui.getConfig)().treeSelect.treeConfig,this.treeConfig)},computeTreeNodeOpts:function(){var e=this.computeTreeOpts;return Object.assign({isHover:!0},e.nodeConfig)},computeTreeCheckboxOpts:function(){var e=this.computeTreeOpts;return Object.assign({showIcon:!!e.showCheckbox},e.checkboxConfig,{trigger:"node"})},computeTreeRadioOpts:function(){var e=this.computeTreeOpts;return Object.assign({showIcon:!!e.showRadio},e.radioConfig,{trigger:"node"})},computePropsOpts:function(){return Object.assign({},this.optionProps)},computeNodeKeyField:function(){return this.computeTreeOpts.keyField||"id"},computeLabelField:function(){return this.computePropsOpts.label||"label"},computeValueField:function(){return this.computePropsOpts.value||"value"},computeChildrenField:function(){return this.computePropsOpts.children||"children"},computeParentField:function(){return this.computePropsOpts.parent||"parentField"},computeHasChildField:function(){return this.computePropsOpts.hasChild||"hasChild"},computeVirtualYOpts:function(){return Object.assign({},(0,_ui.getConfig)().treeSelect.virtualYConfig,this.virtualYConfig)},computeRemoteOpts:function(){return Object.assign({},(0,_ui.getConfig)().treeSelect.remoteConfig,this.remoteConfig)},computeFilterOpts:function(){var e=this.computeTreeOpts;return Object.assign({},e.filterConfig,this.filterConfig)},computeSelectLabel:function(){var e=this.internalData,t=this.value,n=e.fullNodeMaps,i=this.computeLabelField;return(_xeUtils.default.eqNull(t)?[]:_xeUtils.default.isArray(t)?t:[t]).map(function(e){var t=n[e];return t?t.item[i]:e}).join(", ")},computePopupWrapperStyle:function(){var e=this.computePopupOpts,t=e.height,e=e.width,n={};return e&&(n.width=(0,_dom.toCssUnit)(e)),t&&(n.height=(0,_dom.toCssUnit)(t),n.maxHeight=(0,_dom.toCssUnit)(t)),n}}),methods:{dispatchEvent:function(e,t,n){this.$emit(e,(0,_ui.createEvent)(n,{$treeSelect:this},t))},emitModel:function(e){var t=this._events;t&&t.modelValue?this.$emit("modelValue",e):this.$emit("model-value",e)},getNodeid:function(e){e=e[this.computeNodeKeyField];return e?encodeURIComponent(e):""},cacheDataMap:function(){var r=this,e=r.internalData,t=r.options,u=r.computeNodeKeyField,c=r.computeValueField,s={},d={};_xeUtils.default.eachTree(t,function(e,t,n,i,o,l){var a=(a=r.getNodeid(e))||getOptUniqueId(),a=(d[a]&&(0,_log.errLog)("vxe.error.repeatKey",[u,a]),d[a]=!0,e[c]);s[a]&&(0,_log.errLog)("vxe.error.repeatKey",[c,a]),s[a]={item:e,index:t,items:n,parent:o,nodes:l}},{children:r.computeChildrenField}),e.fullOptionList=t||[],e.fullNodeMaps=s},updateZindex:function(){var e=this.reactData;e.panelIndex<(0,_utils.getLastZIndex)()&&(e.panelIndex=(0,_utils.nextZIndex)())},updatePlacement:function(){function e(){var e=(0,_dom.updatePanelPlacement)(l,a,{placement:i,teleportTo:r}),t=Object.assign(e.style,{zIndex:o});n.panelStyle=t,n.panelPlacement=e.placement}var t=this,n=t.reactData,i=t.placement,o=n.panelIndex,l=t.$refs.refElem,a=t.$refs.refOptionPanel,r=t.computeBtnTransfer;return e(),t.$nextTick().then(e)},showOptionPanel:function(){var e=this,t=e.reactData,n=e.internalData,i=e.loading,o=e.remote,l=e.filterable,a=n.fullOptionList,r=e.computeRemoteOpts;i||e.computeIsDisabled||(n.hpTimeout&&clearTimeout(n.hpTimeout),t.initialized||(t.initialized=!0,i=e.computeBtnTransfer,n=e.$refs.refOptionPanel,i&&n&&document.body.appendChild(n)),t.isActivated=!0,t.isAniVisible=!0,l&&o&&r.enabled&&r.autoLoad&&!a.length&&e.handleSearchEvent(),setTimeout(function(){t.visiblePanel=!0,e.handleFocusSearch()},10),e.updateZindex(),e.updatePlacement())},hideOptionPanel:function(){var e=this.reactData,t=this.internalData;e.visiblePanel=!1,t.hpTimeout=setTimeout(function(){e.isAniVisible=!1},350)},changeEvent:function(e,t){var n=this,i=n,o=n.internalData,l=n.$xeForm,a=n.formItemInfo,o=o.fullNodeMaps;n.emitModel(t),t!==i.value&&(i=o[t],n.dispatchEvent("change",{value:t,option:i?i.item:null},e),l)&&a&&l.triggerItemEvent(e,a.itemConfig.field,t)},clearValueEvent:function(e,t){this.changeEvent(e,t),this.dispatchEvent("clear",{value:t},e)},clearEvent:function(e,t){this.clearValueEvent(t,null),this.hideOptionPanel()},allCheckedPanelEvent:function(e){var t=this,n=e.$event,e=t.multiple,i=t.autoClose,o=t.$refs.refTree;e&&o&&o.setAllCheckboxNode(!0).then(function(e){e=e.checkNodeKeys;t.changeEvent(n,e),t.dispatchEvent("all-change",{value:e},n),i&&t.hideOptionPanel()})},clearCheckedPanelEvent:function(e){var t=this,e=e.$event,n=t.multiple,i=t.autoClose,o=t.$refs.refTree;o&&(n=n?[]:null,o.clearCheckboxNode().then(function(){i&&t.hideOptionPanel()}),t.changeEvent(e,n),t.dispatchEvent("clear",{value:n},e))},allExpandPanelEvent:function(){var e=this.$refs.refTree;e&&e.setAllExpandNode(!0)},clearExpandPanelEvent:function(){var e=this.$refs.refTree;e&&e.clearAllExpandNode()},handleGlobalMousewheelEvent:function(e){var t=this,n=t.reactData.visiblePanel;t.computeIsDisabled||n&&(n=t.$refs.refOptionPanel,(0,_dom.getEventTargetNode)(e,n).flag?t.updatePlacement():t.hideOptionPanel())},handleGlobalMousedownEvent:function(e){var t,n,i=this,o=i.reactData,l=o.visiblePanel;i.computeIsDisabled||(t=i.$refs.refElem,n=i.$refs.refOptionPanel,o.isActivated=(0,_dom.getEventTargetNode)(e,t).flag||(0,_dom.getEventTargetNode)(e,n).flag,l&&!o.isActivated&&i.hideOptionPanel())},handleGlobalBlurEvent:function(){this.hideOptionPanel()},handleGlobalResizeEvent:function(){this.reactData.visiblePanel&&this.updatePlacement()},handleFocusSearch:function(){var t=this;t.filterable&&t.$nextTick(function(){var e=t.$refs.refInpSearch;e&&e.focus()})},focusEvent:function(e){var t=this.reactData;this.computeIsDisabled||t.visiblePanel||(t.triggerFocusPanel=!0,this.showOptionPanel(),setTimeout(function(){t.triggerFocusPanel=!1},150)),this.dispatchEvent("focus",{},e)},clickEvent:function(e){this.togglePanelEvent(e),this.dispatchEvent("click",{},e)},blurEvent:function(e){this.reactData.isActivated=!1,this.dispatchEvent("blur",{},e)},modelSearchEvent:function(e){this.reactData.searchValue=e},handleSearchEvent:function(){var e=this,t=e.reactData,n=e.value,i=t.searchValue,o=e.computeRemoteOpts,l=o.queryMethod||e.remoteMethod;e.remote&&l&&o.enabled&&(t.searchLoading=!0,Promise.resolve(l({$treeSelect:e,searchValue:i,value:n})).then(function(){return e.$nextTick()}).catch(function(){return e.$nextTick()}).finally(function(){t.searchLoading=!1}))},togglePanelEvent:function(e){var t=this.reactData;e.$event.preventDefault(),t.triggerFocusPanel?t.triggerFocusPanel=!1:t.visiblePanel?this.hideOptionPanel():this.showOptionPanel()},nodeClickEvent:function(e){var t=e.$event;this.dispatchEvent("node-click",e,t)},radioChangeEvent:function(e){var t=e.value;this.changeEvent(e.$event,t),this.hideOptionPanel()},checkboxChangeEvent:function(e){var t=e.value;this.changeEvent(e.$event,t)},loadSuccessEvent:function(){this.cacheDataMap()},renderVN:function(e){var t,n=this,i=n,o=n.$scopedSlots,l=n.reactData,a=i.className,r=i.value,u=i.multiple,c=i.options,s=i.loading,d=i.filterable,p=i.showTotalButoon,f=i.showCheckedButoon,h=i.showClearButton,m=i.showExpandButton,v=l.initialized,g=l.isActivated,b=l.isAniVisible,_=l.visiblePanel,x=l.searchValue,E=n.computeSize,y=n.computeIsDisabled,C=n.computeSelectLabel,P=n.computeBtnTransfer,O=n.computePopupWrapperStyle,S=o.header,T=o.footer,F=o.prefix,o=n.computePopupOpts,I=o.className||i.popupClassName,w=n.computeTreeOpts,k=n.computeTreeNodeOpts,D=n.computeTreeCheckboxOpts,$=n.computeTreeRadioOpts,N=n.computeNodeKeyField,B=n.computeLabelField,M=n.computeValueField,L=n.computeChildrenField,V=n.computeParentField,j=n.computeHasChildField,q=n.computeVirtualYOpts,R=n.computeFilterOpts;return n.computeFormReadonly?e("div",{ref:"refElem",class:["vxe-tree-select--readonly",a]},[e("span",{class:"vxe-tree-select-label"},C)]):(t=_xeUtils.default.eqNull(r)?[]:_xeUtils.default.isArray(r)?r:[r],e("div",{ref:"refElem",class:["vxe-tree-select",a?_xeUtils.default.isFunction(a)?a({$treeSelect:n}):a:"",_defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty({},"size--".concat(E),E),"is--filterable",d),"is--visible",_),"is--disabled",y),"is--loading",s),"is--active",g)]},[e(_input.default,{ref:"refInput",props:{clearable:i.clearable,placeholder:i.placeholder,readonly:!0,disabled:y,type:"text",prefixIcon:i.prefixIcon,suffixIcon:s?(0,_ui.getIcon)().TREE_SELECT_LOADED:_?(0,_ui.getIcon)().TREE_SELECT_OPEN:(0,_ui.getIcon)().TREE_SELECT_CLOSE,value:s?(0,_ui.getI18n)("vxe.select.loadingText"):C,title:C},on:{clear:n.clearEvent,click:n.clickEvent,focus:n.focusEvent,blur:n.blurEvent,"suffix-click":n.togglePanelEvent},scopedSlots:F?{prefix:function(){return F({})}}:{}}),e("div",{ref:"refOptionPanel",class:["vxe-table--ignore-clear vxe-tree-select--panel",I?_xeUtils.default.isFunction(I)?I({$treeSelect:n}):I:"",_defineProperty(_defineProperty(_defineProperty(_defineProperty({},"size--".concat(E),E),"is--transfer",P),"ani--leave",!s&&b),"ani--enter",!s&&_)],attrs:{placement:l.panelPlacement},style:l.panelStyle},v?[e("div",{class:"vxe-tree-select--panel-wrapper"},[d?e("div",{class:"vxe-tree-select--panel-search"},[e(_input.default,{ref:"refInpSearch",class:"vxe-tree-select-search--input",props:{value:x,title:C,clearable:!0,disabled:!1,readonly:!1,placeholder:(0,_ui.getI18n)("vxe.treeSelect.search"),prefixIcon:(0,_ui.getIcon)().INPUT_SEARCH},on:{"model-value":n.modelSearchEvent}})]):(0,_ui.renderEmptyElement)(n),p||f&&u||h||m||S?e("div",{class:"vxe-tree-select--panel-header"},S?S({}):[e("div",{class:"vxe-tree-select--header-button"},[p?e("div",{class:"vxe-tree-select--header-total"},(0,_ui.getI18n)("vxe.treeSelect.total",[t.length])):(0,_ui.renderEmptyElement)(n),e("div",{class:"vxe-tree-select--header-btns"},[f&&u?e(_button.default,{props:{content:(0,_ui.getI18n)("vxe.treeSelect.allChecked"),mode:"text"},on:{click:n.allCheckedPanelEvent}}):(0,_ui.renderEmptyElement)(n),h?e(_button.default,{props:{content:(0,_ui.getI18n)("vxe.treeSelect.clearChecked"),mode:"text"},on:{click:n.clearCheckedPanelEvent}}):(0,_ui.renderEmptyElement)(n),m?e(_button.default,{props:{content:(0,_ui.getI18n)("vxe.treeSelect.allExpand"),mode:"text"},on:{click:n.allExpandPanelEvent}}):(0,_ui.renderEmptyElement)(n),m?e(_button.default,{props:{content:(0,_ui.getI18n)("vxe.treeSelect.clearExpand"),mode:"text"},on:{click:n.clearExpandPanelEvent}}):(0,_ui.renderEmptyElement)(n)])])]):(0,_ui.renderEmptyElement)(n),e("div",{class:"vxe-tree-select--panel-body"},[e("div",{ref:"refTreeWrapper",class:"vxe-tree-select-tree--wrapper",style:O},[e(_tree.default,{ref:"refTree",class:"vxe-tree-select--tree",props:{data:c,height:o.height?"100%":w.height,minHeight:w.minHeight,maxHeight:o.height?"":w.maxHeight,autoResize:!0,indent:w.indent,showRadio:!u,radioConfig:$,checkNodeKey:u?null:r,showCheckbox:!!u,checkNodeKeys:u?r:null,checkboxConfig:D,titleField:B,valueField:M,keyField:N,childrenField:w.childrenField||L,parentField:w.parentField||V,hasChildField:w.hasChildField||j,accordion:w.accordion,expandAll:w.expandAll,nodeConfig:k,lazy:w.lazy,loadMethod:w.loadMethod,toggleMethod:w.toggleMethod,transform:w.transform,trigger:w.trigger,showIcon:w.showIcon,showLine:w.showLine,iconOpen:w.iconOpen,iconLoaded:w.iconLoaded,iconClose:w.iconClose,filterValue:x,filterConfig:R,virtualYConfig:q},on:{"node-click":n.nodeClickEvent,"radio-change":n.radioChangeEvent,"checkbox-change":n.checkboxChangeEvent,"load-success":n.loadSuccessEvent}})])]),T?e("div",{class:"vxe-tree-select--panel-footer"},T({})):(0,_ui.renderEmptyElement)(n)])]:[])]))}},watch:{options:function(){this.cacheDataMap()}},created:function(){this.cacheDataMap()},mounted:function(){var e=this;_ui.globalEvents.on(e,"mousewheel",e.handleGlobalMousewheelEvent),_ui.globalEvents.on(e,"mousedown",e.handleGlobalMousedownEvent),_ui.globalEvents.on(e,"blur",e.handleGlobalBlurEvent),_ui.globalEvents.on(e,"resize",e.handleGlobalResizeEvent)},beforeDestroy:function(){var e=this,t=e.$refs.refOptionPanel;t&&t.parentNode&&t.parentNode.removeChild(t),_ui.globalEvents.off(e,"mousewheel"),_ui.globalEvents.off(e,"mousedown"),_ui.globalEvents.off(e,"blur"),_ui.globalEvents.off(e,"resize")},render:function(e){return this.renderVN(e)}});
@@ -8,6 +8,12 @@
8
8
  .vxe-tree-select > .vxe-input .vxe-input--inner {
9
9
  cursor: pointer;
10
10
  }
11
+ .vxe-tree-select.is--filterable .vxe-tree-select-tree--wrapper {
12
+ padding-top: 0;
13
+ }
14
+ .vxe-tree-select.is--filterable .vxe-tree-select--panel-header {
15
+ border-top: 1px solid var(--vxe-ui-base-popup-border-color);
16
+ }
11
17
  .vxe-tree-select.is--disabled > .vxe-input .vxe-input--inner {
12
18
  cursor: no-drop;
13
19
  }
@@ -83,8 +89,30 @@
83
89
  width: 100%;
84
90
  }
85
91
 
92
+ .vxe-tree-select--header-button {
93
+ display: flex;
94
+ flex-direction: row;
95
+ }
96
+
97
+ .vxe-tree-select--header-total {
98
+ display: flex;
99
+ flex-direction: row;
100
+ align-items: center;
101
+ justify-content: center;
102
+ flex-shrink: 0;
103
+ padding-left: 0.8em;
104
+ }
105
+
106
+ .vxe-tree-select--header-btns {
107
+ display: flex;
108
+ flex-direction: row;
109
+ flex-grow: 1;
110
+ justify-content: right;
111
+ }
112
+
86
113
  .vxe-tree-select--panel-wrapper {
87
114
  display: inline-flex;
115
+ flex-direction: column;
88
116
  position: relative;
89
117
  border-radius: var(--vxe-ui-base-border-radius);
90
118
  border: 1px solid var(--vxe-ui-base-popup-border-color);
@@ -93,6 +121,14 @@
93
121
  pointer-events: auto;
94
122
  }
95
123
 
124
+ .vxe-tree-select--panel-search {
125
+ display: block;
126
+ padding: var(--vxe-ui-layout-padding-default);
127
+ }
128
+ .vxe-tree-select--panel-search .vxe-tree-select-search--input {
129
+ width: 100%;
130
+ }
131
+
96
132
  .vxe-tree-select--panel-header {
97
133
  border-bottom: 1px solid var(--vxe-ui-base-popup-border-color);
98
134
  }
@@ -110,7 +146,6 @@
110
146
  position: relative;
111
147
  overflow: auto;
112
148
  padding: var(--vxe-ui-layout-padding-default);
113
- max-height: 21em;
114
149
  width: 30em;
115
150
  outline: 0;
116
151
  }
@@ -1 +1 @@
1
- .vxe-tree-select{position:relative;display:inline-block;width:180px;color:var(--vxe-ui-font-color);text-align:left}.vxe-tree-select>.vxe-input .vxe-input--inner{cursor:pointer}.vxe-tree-select.is--disabled>.vxe-input .vxe-input--inner{cursor:no-drop}.vxe-tree-select.is--loading>.vxe-input .vxe-input--inner{cursor:progress}.vxe-tree-select>.vxe-input{width:100%}.vxe-tree-select>.vxe-input .vxe-input--suffix-icon>i{display:inline-block;transition:transform .2s ease-in-out}.vxe-tree-select.is--active:not(.is--filter)>.vxe-input{border-color:var(--vxe-ui-font-primary-color)}.vxe-tree-select--readonly{color:var(--vxe-ui-font-color);display:inline-flex}.vxe-tree-select--panel{display:none;position:absolute;left:0;padding:4px 0;color:var(--vxe-ui-font-color);text-align:left}.vxe-tree-select--panel:not(.is--transfer){min-width:100%}.vxe-tree-select--panel.is--transfer{position:fixed}.vxe-tree-select--panel.ani--leave{display:block;opacity:0;transform:scaleY(.5);transition:transform .3s cubic-bezier(.23,1,.32,1),opacity .3s cubic-bezier(.23,1,.32,1);transform-origin:center top;backface-visibility:hidden}.vxe-tree-select--panel.ani--leave[placement=top]{transform-origin:center bottom}.vxe-tree-select--panel.ani--enter{opacity:1;transform:scaleY(1)}.vxe-tree-select--panel.ani--enter>div::after{display:none}.vxe-tree-select--panel>div::after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;z-index:1;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.vxe-tree-select--panel-search{display:block}.vxe-tree-select--panel-search .vxe-tree-select-search--input{width:100%}.vxe-tree-select--panel-wrapper{display:inline-flex;position:relative;border-radius:var(--vxe-ui-base-border-radius);border:1px solid var(--vxe-ui-base-popup-border-color);box-shadow:var(--vxe-ui-base-popup-box-shadow);background-color:var(--vxe-ui-layout-background-color);pointer-events:auto}.vxe-tree-select--panel-header{border-bottom:1px solid var(--vxe-ui-base-popup-border-color)}.vxe-tree-select--panel-footer{border-top:1px solid var(--vxe-ui-base-popup-border-color)}.vxe-tree-select--panel-footer,.vxe-tree-select--panel-header{padding:4px 0}.vxe-tree-select-tree--wrapper{position:relative;overflow:auto;padding:var(--vxe-ui-layout-padding-default);max-height:21em;width:30em;outline:0}.vxe-tree-select--tree{width:100%}.vxe-tree-select--tree .vxe-tree--node-item.is-checkbox--checked>.vxe-tree--node-item-inner,.vxe-tree-select--tree .vxe-tree--node-item.is-radio--checked>.vxe-tree--node-item-inner{color:var(--vxe-ui-font-primary-color)}.vxe-tree-select--tree .vxe-tree--node-item-inner{cursor:pointer}.vxe-tree-select,.vxe-tree-select--panel{font-size:var(--vxe-ui-font-size-default)}.vxe-tree-select--panel.size--medium,.vxe-tree-select.size--medium{font-size:var(--vxe-ui-font-size-medium)}.vxe-tree-select--panel.size--small,.vxe-tree-select.size--small{font-size:var(--vxe-ui-font-size-small)}.vxe-tree-select--panel.size--mini,.vxe-tree-select.size--mini{font-size:var(--vxe-ui-font-size-mini)}
1
+ .vxe-tree-select{position:relative;display:inline-block;width:180px;color:var(--vxe-ui-font-color);text-align:left}.vxe-tree-select>.vxe-input .vxe-input--inner{cursor:pointer}.vxe-tree-select.is--filterable .vxe-tree-select-tree--wrapper{padding-top:0}.vxe-tree-select.is--filterable .vxe-tree-select--panel-header{border-top:1px solid var(--vxe-ui-base-popup-border-color)}.vxe-tree-select.is--disabled>.vxe-input .vxe-input--inner{cursor:no-drop}.vxe-tree-select.is--loading>.vxe-input .vxe-input--inner{cursor:progress}.vxe-tree-select>.vxe-input{width:100%}.vxe-tree-select>.vxe-input .vxe-input--suffix-icon>i{display:inline-block;transition:transform .2s ease-in-out}.vxe-tree-select.is--active:not(.is--filter)>.vxe-input{border-color:var(--vxe-ui-font-primary-color)}.vxe-tree-select--readonly{color:var(--vxe-ui-font-color);display:inline-flex}.vxe-tree-select--panel{display:none;position:absolute;left:0;padding:4px 0;color:var(--vxe-ui-font-color);text-align:left}.vxe-tree-select--panel:not(.is--transfer){min-width:100%}.vxe-tree-select--panel.is--transfer{position:fixed}.vxe-tree-select--panel.ani--leave{display:block;opacity:0;transform:scaleY(.5);transition:transform .3s cubic-bezier(.23,1,.32,1),opacity .3s cubic-bezier(.23,1,.32,1);transform-origin:center top;backface-visibility:hidden}.vxe-tree-select--panel.ani--leave[placement=top]{transform-origin:center bottom}.vxe-tree-select--panel.ani--enter{opacity:1;transform:scaleY(1)}.vxe-tree-select--panel.ani--enter>div::after{display:none}.vxe-tree-select--panel>div::after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;z-index:1;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.vxe-tree-select--panel-search{display:block}.vxe-tree-select--panel-search .vxe-tree-select-search--input{width:100%}.vxe-tree-select--header-button{display:flex;flex-direction:row}.vxe-tree-select--header-total{display:flex;flex-direction:row;align-items:center;justify-content:center;flex-shrink:0;padding-left:.8em}.vxe-tree-select--header-btns{display:flex;flex-direction:row;flex-grow:1;justify-content:right}.vxe-tree-select--panel-wrapper{display:inline-flex;flex-direction:column;position:relative;border-radius:var(--vxe-ui-base-border-radius);border:1px solid var(--vxe-ui-base-popup-border-color);box-shadow:var(--vxe-ui-base-popup-box-shadow);background-color:var(--vxe-ui-layout-background-color);pointer-events:auto}.vxe-tree-select--panel-search{display:block;padding:var(--vxe-ui-layout-padding-default)}.vxe-tree-select--panel-search .vxe-tree-select-search--input{width:100%}.vxe-tree-select--panel-header{border-bottom:1px solid var(--vxe-ui-base-popup-border-color)}.vxe-tree-select--panel-footer{border-top:1px solid var(--vxe-ui-base-popup-border-color)}.vxe-tree-select--panel-footer,.vxe-tree-select--panel-header{padding:4px 0}.vxe-tree-select-tree--wrapper{position:relative;overflow:auto;padding:var(--vxe-ui-layout-padding-default);width:30em;outline:0}.vxe-tree-select--tree{width:100%}.vxe-tree-select--tree .vxe-tree--node-item.is-checkbox--checked>.vxe-tree--node-item-inner,.vxe-tree-select--tree .vxe-tree--node-item.is-radio--checked>.vxe-tree--node-item-inner{color:var(--vxe-ui-font-primary-color)}.vxe-tree-select--tree .vxe-tree--node-item-inner{cursor:pointer}.vxe-tree-select,.vxe-tree-select--panel{font-size:var(--vxe-ui-font-size-default)}.vxe-tree-select--panel.size--medium,.vxe-tree-select.size--medium{font-size:var(--vxe-ui-font-size-medium)}.vxe-tree-select--panel.size--small,.vxe-tree-select.size--small{font-size:var(--vxe-ui-font-size-small)}.vxe-tree-select--panel.size--mini,.vxe-tree-select.size--mini{font-size:var(--vxe-ui-font-size-mini)}