hy-virtual-tree 1.1.63 → 1.1.64

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.
package/CHANGELOG.md CHANGED
@@ -1,5 +1,12 @@
1
1
  ## Changelog
2
2
 
3
+ ### 1.1.64
4
+
5
+ _2026-01-23_
6
+
7
+ - 扩展[VirtualTree] 功能
8
+ (1)优化树形,节点内容添加溢出省略时,移入显示tooltip
9
+
3
10
  ### 1.1.63
4
11
 
5
12
  _2026-01-16_
package/dist/index.js CHANGED
@@ -8,6 +8,7 @@ const isBoolean = (e) => typeof e === 'boolean';
8
8
  const isUndefined = (e) => e === undefined;
9
9
  const isNull = (e) => e === null;
10
10
  const isEmpty = (e) => isUndefined(e) || isNull(e) || (!isNumber(e) && !e);
11
+ const isOverflowing = (e) => e.clientWidth < e.scrollWidth;
11
12
 
12
13
  var workCard_svg = '';
13
14
 
@@ -185,6 +186,8 @@ class Tooltip {
185
186
  };
186
187
  }
187
188
  _render() {
189
+ if (!this._config)
190
+ return;
188
191
  const { bind, content } = this._config;
189
192
  const el = document.createElement('div');
190
193
  el.classList.add('hy-tooltip');
@@ -200,15 +203,17 @@ class Tooltip {
200
203
  this._el = el;
201
204
  this._focus = setElementFocus({
202
205
  container: bind,
203
- trigger: this._config.trigger,
206
+ trigger: this._config.trigger === 'click' ? 'click' : 'hover',
204
207
  onFocus: () => {
205
208
  closeActiveTooltip && closeActiveTooltip();
206
209
  if (!this._el)
207
210
  return;
211
+ if (this._config?.trigger === 'hover-overflow' && !isOverflowing(this._config.bind))
212
+ return;
208
213
  const container = getContainer$1();
209
214
  container.appendChild(this._el);
210
215
  this.setPopper();
211
- if (this._config?.autoClose && isNumber(this._config?.autoClose)) {
216
+ if (this._config?.autoClose && isNumber(this._config.autoClose)) {
212
217
  this._timer && clearTimeout(this._timer);
213
218
  this._timer = setTimeout(() => {
214
219
  this._focus && this._focus.blur();
@@ -1952,6 +1957,24 @@ const useIcon = (config, data, node) => {
1952
1957
  return new Icon({ svgName: 'menu_acquisitionStation_svg' });
1953
1958
  }
1954
1959
  };
1960
+ // 生成内容节点
1961
+ const useContent = (data, node) => {
1962
+ const el = document.createElement('div');
1963
+ el.innerHTML = node.label || '';
1964
+ if (node.label) {
1965
+ let tooltip = new Tooltip({
1966
+ bind: el,
1967
+ content: node.label,
1968
+ placement: 'top',
1969
+ trigger: 'hover-overflow'
1970
+ });
1971
+ // @ts-ignore
1972
+ el.$destroy = () => {
1973
+ tooltip && tooltip.destroy();
1974
+ };
1975
+ }
1976
+ return el;
1977
+ };
1955
1978
 
1956
1979
  function decodeBase64(base64, enableUnicode) {
1957
1980
  var binaryString = atob(base64);
@@ -9140,6 +9163,9 @@ class VirtualTree {
9140
9163
  let value, el, $destroy;
9141
9164
  if (!fn || !isFunction(fn)) {
9142
9165
  value = defaultFn && isFunction(defaultFn) && defaultFn(node.data, node);
9166
+ if (value) {
9167
+ $destroy = value.$destroy;
9168
+ }
9143
9169
  }
9144
9170
  else {
9145
9171
  let dom = fn(node.data, node);
@@ -9267,12 +9293,6 @@ class VirtualTree {
9267
9293
  return;
9268
9294
  return icon._el;
9269
9295
  };
9270
- /** 生成内容 */
9271
- const generateContent = (data, item) => {
9272
- const el = document.createElement('div');
9273
- el.innerHTML = item.label || '';
9274
- return el;
9275
- };
9276
9296
  /** 生成统计 */
9277
9297
  const generateStats = (data, item) => {
9278
9298
  if (!isShowCount(this._props.showCount, item))
@@ -9403,7 +9423,7 @@ class VirtualTree {
9403
9423
  // 图标
9404
9424
  this._customRender(config.renderIcon, node, { inset: true, parent: content, className: 'hy-tree-icon', defaultFn: generateIcon });
9405
9425
  // 内容
9406
- this._customRender(config.renderContent, node, { inset: true, parent: content, className: 'hy-tree-node__content', defaultFn: generateContent });
9426
+ this._customRender(config.renderContent, node, { inset: true, parent: content, className: 'hy-tree-node__content', defaultFn: useContent });
9407
9427
  // 统计
9408
9428
  this._customRender(generateStats, node, { parent: content });
9409
9429
  // 右侧内容
@@ -9864,4 +9884,4 @@ class VirtualTree {
9864
9884
  };
9865
9885
  }
9866
9886
 
9867
- export { Business, DataType, DeviceStatus, VirtualScroll, VirtualTree, getGlobalDeviceStatus, isArray, isBoolean, isElement, isEmpty, isFunction, isNull, isNumber, isObject, isString, isUndefined, setGlobalDeviceStatus };
9887
+ export { Business, DataType, DeviceStatus, VirtualScroll, VirtualTree, getGlobalDeviceStatus, isArray, isBoolean, isElement, isEmpty, isFunction, isNull, isNumber, isObject, isOverflowing, isString, isUndefined, setGlobalDeviceStatus };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "hy-virtual-tree",
3
- "version": "1.1.63",
3
+ "version": "1.1.64",
4
4
  "type": "module",
5
5
  "scripts": {
6
6
  "dev": "vite",