hy-virtual-tree 1.1.26 → 1.1.28
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 +19 -0
- package/dist/index.js +137 -61
- package/package.json +1 -1
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,24 @@
|
|
|
1
1
|
## Changelog
|
|
2
2
|
|
|
3
|
+
### 1.1.28
|
|
4
|
+
|
|
5
|
+
_2025-09-16_
|
|
6
|
+
|
|
7
|
+
- 扩展[VirtualTree] 功能
|
|
8
|
+
(1)添加 businessConfig.integratedBusiness,部门和群组会集成所有下级业务数据到 childrenDeviceList 字段
|
|
9
|
+
(2)添加 businessConfig.showOnlineState,仅显示在线设备,更新数据时也会同时更新展示列表
|
|
10
|
+
(3)setData方法添加 config.props 传参
|
|
11
|
+
(4)修改props.clearEmptyBusiness为businessConfig.clearEmptyBusiness
|
|
12
|
+
(5)修复异步渲染节点导致缓存节点判断错误问题
|
|
13
|
+
|
|
14
|
+
### 1.1.27
|
|
15
|
+
|
|
16
|
+
_2025-09-16_
|
|
17
|
+
|
|
18
|
+
- 扩展[VirtualTree] 功能
|
|
19
|
+
(1)添加双击回调onNodeDblClick
|
|
20
|
+
(2)onNodeClick 和 onNodeDblClick 添加返回 Promise 拦截内置逻辑
|
|
21
|
+
|
|
3
22
|
### 1.1.26
|
|
4
23
|
|
|
5
24
|
_2025-09-16_
|
package/dist/index.js
CHANGED
|
@@ -11,7 +11,8 @@ class VirtualScroll {
|
|
|
11
11
|
* @param {number} [options.maxHeight=26840000] Maximum height in pixels for the content wrapper
|
|
12
12
|
* @param {Function} [options.onRender] 节点刷新回调
|
|
13
13
|
*/
|
|
14
|
-
|
|
14
|
+
_cacheNodeMap = new Map();
|
|
15
|
+
_isCanCache = true;
|
|
15
16
|
constructor(options) {
|
|
16
17
|
this.container = options.container;
|
|
17
18
|
this.items = options.items || [];
|
|
@@ -116,7 +117,9 @@ class VirtualScroll {
|
|
|
116
117
|
renderVisibleItems(startIndex, endIndex) {
|
|
117
118
|
this._onRender && this._onRender();
|
|
118
119
|
// Clear content container
|
|
119
|
-
|
|
120
|
+
if (!this._isCanCache) {
|
|
121
|
+
this.contentContainer.innerHTML = '';
|
|
122
|
+
}
|
|
120
123
|
// Set position considering scaling factor
|
|
121
124
|
// const fragment = document.createDocumentFragment()
|
|
122
125
|
// const fragment = []
|
|
@@ -133,12 +136,22 @@ class VirtualScroll {
|
|
|
133
136
|
itemElement.style.height = `${this.itemHeight * this.heightScale}px`;
|
|
134
137
|
itemElement.style.boxSizing = 'border-box';
|
|
135
138
|
itemElement.style.width = '100%';
|
|
139
|
+
if (!this._isCanCache) {
|
|
140
|
+
this.contentContainer.appendChild(itemElement);
|
|
141
|
+
continue;
|
|
142
|
+
}
|
|
136
143
|
const innerHTML = itemElement.innerHTML;
|
|
137
|
-
if (
|
|
138
|
-
|
|
144
|
+
if (nodeMap.has(innerHTML)) {
|
|
145
|
+
this._isCanCache = false;
|
|
146
|
+
i = startIndex - 1;
|
|
147
|
+
this.contentContainer.innerHTML = '';
|
|
148
|
+
continue;
|
|
149
|
+
}
|
|
150
|
+
if (this._cacheNodeMap.has(innerHTML)) {
|
|
151
|
+
const target = this._cacheNodeMap.get(innerHTML);
|
|
139
152
|
this.contentContainer.appendChild(target);
|
|
140
153
|
nodeMap.set(innerHTML, target);
|
|
141
|
-
this.
|
|
154
|
+
this._cacheNodeMap.delete(innerHTML);
|
|
142
155
|
}
|
|
143
156
|
else {
|
|
144
157
|
this.contentContainer.appendChild(itemElement);
|
|
@@ -160,11 +173,13 @@ class VirtualScroll {
|
|
|
160
173
|
this.contentContainer.appendChild(row);
|
|
161
174
|
}
|
|
162
175
|
}
|
|
163
|
-
|
|
164
|
-
this.
|
|
176
|
+
if (this._isCanCache) {
|
|
177
|
+
for (const [key, value] of this._cacheNodeMap) {
|
|
178
|
+
this.contentContainer.removeChild(value);
|
|
179
|
+
}
|
|
180
|
+
this._cacheNodeMap.clear();
|
|
181
|
+
this._cacheNodeMap = nodeMap;
|
|
165
182
|
}
|
|
166
|
-
this.cacheNodeMap.clear();
|
|
167
|
-
this.cacheNodeMap = nodeMap;
|
|
168
183
|
}
|
|
169
184
|
/**
|
|
170
185
|
* Update data items and re-render
|
|
@@ -395,8 +410,7 @@ const useConfig = (config) => {
|
|
|
395
410
|
showCount: false,
|
|
396
411
|
total: 'total',
|
|
397
412
|
count: 'count',
|
|
398
|
-
showStatus: false
|
|
399
|
-
clearEmptyBusiness: false
|
|
413
|
+
showStatus: false
|
|
400
414
|
}, config.props);
|
|
401
415
|
let rowSelection = Object.assign({
|
|
402
416
|
type: 'checkbox',
|
|
@@ -408,7 +422,10 @@ const useConfig = (config) => {
|
|
|
408
422
|
// 业务配置
|
|
409
423
|
let businessConfig = {
|
|
410
424
|
statusTextList: [],
|
|
411
|
-
filterConfig: []
|
|
425
|
+
filterConfig: [],
|
|
426
|
+
clearEmptyBusiness: false,
|
|
427
|
+
integratedBusiness: false,
|
|
428
|
+
...(config.businessConfig || {})
|
|
412
429
|
};
|
|
413
430
|
// 设备树
|
|
414
431
|
if (['device', 'groupDevice'].includes(`${config.business}`)) {
|
|
@@ -424,6 +441,8 @@ const useConfig = (config) => {
|
|
|
424
441
|
'SOS'
|
|
425
442
|
],
|
|
426
443
|
filterConfig: [],
|
|
444
|
+
clearEmptyBusiness: false,
|
|
445
|
+
integratedBusiness: false,
|
|
427
446
|
...(config.businessConfig || {})
|
|
428
447
|
};
|
|
429
448
|
props = {
|
|
@@ -431,7 +450,6 @@ const useConfig = (config) => {
|
|
|
431
450
|
disabled: 'disabled',
|
|
432
451
|
showStatus: false,
|
|
433
452
|
showCount: (data) => data.dataType !== 3,
|
|
434
|
-
clearEmptyBusiness: false,
|
|
435
453
|
...(config.props || {}),
|
|
436
454
|
value: 'onlyId',
|
|
437
455
|
label: 'label',
|
|
@@ -455,7 +473,6 @@ const useConfig = (config) => {
|
|
|
455
473
|
disabled: 'disabled',
|
|
456
474
|
showStatus: false,
|
|
457
475
|
showCount: false,
|
|
458
|
-
clearEmptyBusiness: false,
|
|
459
476
|
...(config.props || {}),
|
|
460
477
|
value: 'onlyId',
|
|
461
478
|
label: 'label',
|
|
@@ -471,7 +488,6 @@ const useConfig = (config) => {
|
|
|
471
488
|
disabled: 'disabled',
|
|
472
489
|
showStatus: false,
|
|
473
490
|
showCount: (data) => data.dataType !== 5,
|
|
474
|
-
clearEmptyBusiness: false,
|
|
475
491
|
...(config.props || {}),
|
|
476
492
|
value: 'onlyId',
|
|
477
493
|
label: 'label',
|
|
@@ -487,7 +503,6 @@ const useConfig = (config) => {
|
|
|
487
503
|
disabled: 'disabled',
|
|
488
504
|
showStatus: false,
|
|
489
505
|
showCount: false,
|
|
490
|
-
clearEmptyBusiness: false,
|
|
491
506
|
...(config.props || {}),
|
|
492
507
|
value: 'onlyId',
|
|
493
508
|
label: 'label',
|
|
@@ -964,7 +979,8 @@ function useFilter(config, filterMethod, tree = {
|
|
|
964
979
|
treeNodeMap: new Map(),
|
|
965
980
|
levelTreeNodeMap: new Map(),
|
|
966
981
|
treeNodes: [],
|
|
967
|
-
maxLevel: 0
|
|
982
|
+
maxLevel: 0,
|
|
983
|
+
hiddenNodeKeySet: new Set()
|
|
968
984
|
}) {
|
|
969
985
|
const hiddenNodeKeySet = new Set([]);
|
|
970
986
|
const hiddenExpandIconKeySet = new Set([]);
|
|
@@ -974,6 +990,7 @@ function useFilter(config, filterMethod, tree = {
|
|
|
974
990
|
if (!isFunction(filterMethod)) {
|
|
975
991
|
return;
|
|
976
992
|
}
|
|
993
|
+
const { integratedBusiness } = config.businessConfig;
|
|
977
994
|
const { getCount, getTotal, countFilter, totalFilter } = useHandleFun(config);
|
|
978
995
|
const isCountFiler = countFilter && isFunction(countFilter);
|
|
979
996
|
const isTotalFiler = totalFilter && isFunction(totalFilter);
|
|
@@ -984,21 +1001,39 @@ function useFilter(config, filterMethod, tree = {
|
|
|
984
1001
|
const nodes = tree.treeNodes || [];
|
|
985
1002
|
hiddenKeys.clear();
|
|
986
1003
|
function traverse(nodes, isShow = false) {
|
|
1004
|
+
const deepBusinessList = [];
|
|
987
1005
|
let count = 0;
|
|
988
1006
|
let total = 0;
|
|
989
1007
|
nodes.forEach((node) => {
|
|
1008
|
+
const businessList = [];
|
|
990
1009
|
family.push(node);
|
|
1010
|
+
if (tree.hiddenNodeKeySet.has(node.key))
|
|
1011
|
+
return;
|
|
991
1012
|
if (isShow || (filterMethod && filterMethod(params, node.data, node))) {
|
|
992
1013
|
family.forEach((member) => {
|
|
993
1014
|
expandKeySet.add(member.key);
|
|
994
1015
|
});
|
|
1016
|
+
if (integratedBusiness && !/^1|4$/.test(node.data.dataType)) {
|
|
1017
|
+
businessList.push(node.data);
|
|
1018
|
+
deepBusinessList.push(node.data);
|
|
1019
|
+
}
|
|
995
1020
|
}
|
|
996
1021
|
else if (node.isLeaf) {
|
|
997
1022
|
hiddenKeys.add(node.key);
|
|
998
1023
|
}
|
|
999
1024
|
const children = node.children;
|
|
1000
1025
|
if (children) {
|
|
1001
|
-
const { count: childCount, total: childTotal } = traverse(children, filterAll ? false : expandKeySet.has(node.key));
|
|
1026
|
+
const { count: childCount, total: childTotal, businessList: list2 } = traverse(children, filterAll ? false : expandKeySet.has(node.key));
|
|
1027
|
+
// 保存下层业务数据
|
|
1028
|
+
if (integratedBusiness) {
|
|
1029
|
+
for (const target of list2) {
|
|
1030
|
+
if (!/^1|4$/.test(target.dataType)) {
|
|
1031
|
+
businessList.push(target);
|
|
1032
|
+
deepBusinessList.push(target);
|
|
1033
|
+
}
|
|
1034
|
+
}
|
|
1035
|
+
node.data.childrenDeviceList = businessList;
|
|
1036
|
+
}
|
|
1002
1037
|
node.count = isCountFiler ? childCount : getCount(node);
|
|
1003
1038
|
node.total = isTotalFiler ? childTotal : getTotal(node);
|
|
1004
1039
|
count += childCount;
|
|
@@ -1037,7 +1072,7 @@ function useFilter(config, filterMethod, tree = {
|
|
|
1037
1072
|
}
|
|
1038
1073
|
family.pop();
|
|
1039
1074
|
});
|
|
1040
|
-
return { count, total };
|
|
1075
|
+
return { count, total, businessList: deepBusinessList };
|
|
1041
1076
|
}
|
|
1042
1077
|
traverse(nodes);
|
|
1043
1078
|
return expandKeySet;
|
|
@@ -1059,6 +1094,8 @@ function useFilter(config, filterMethod, tree = {
|
|
|
1059
1094
|
let total = 0;
|
|
1060
1095
|
nodes.forEach((node) => {
|
|
1061
1096
|
family.push(node);
|
|
1097
|
+
if (tree.hiddenNodeKeySet.has(node.key))
|
|
1098
|
+
return;
|
|
1062
1099
|
if (isShow || (filterMethod && filterMethod(params, node.data, node))) {
|
|
1063
1100
|
family.forEach((member) => {
|
|
1064
1101
|
expandKeySet.add(member.key);
|
|
@@ -1352,13 +1389,14 @@ function createBase64WorkerFactory(base64, sourcemapArg, enableUnicodeArg) {
|
|
|
1352
1389
|
};
|
|
1353
1390
|
}
|
|
1354
1391
|
|
|
1355
|
-
var WorkerFactory = /*#__PURE__*/createBase64WorkerFactory('/* rollup-plugin-web-worker-loader */
(function () {
  'use strict';

  /** 生成配置项 */
  /** 生成处理函数 */
  const useHandleFun = (config) => {
      const { business } = config;
      const props = { ...config.props };
      let { countFilter, totalFilter } = props;
      /** 获取key值 */
      function getKey(node, isBusiness = false) {
          if (!node)
              return '';
          if (business && isBusiness) {
              switch (business) {
                  case 'device':
                  case 'groupDevice':
                      return node.deviceId;
                  case 'user':
                  case 'cs':
                      return node.id;
              }
          }
          return node[props.value];
      }
      /** 获取label值 */
      function getLabel(node) {
          if (!node)
              return '';
          return node[props.label];
      }
      /** 获取children值 */
      function getChildren(node) {
          if (!node)
              return [];
          const children = node[props.children];
          return children ? [...children] : [];
      }
      /** 获取count值 */
      function getCount(node) {
          if (!node)
              return;
          return node[props.count];
      }
      /** 获取total值 */
      function getTotal(node) {
          if (!node)
              return;
          return node[props.total];
      }
      if (['device', 'groupDevice'].includes(`${business}`)) {
          countFilter = (data) => {
              return data.dataType === 3 && data.onlineState === 1;
          };
          totalFilter = (data) => {
              return data.dataType === 3;
          };
      }
      else if (business === 'user') {
          countFilter = totalFilter = (data) => {
              return data.dataType === 5;
          };
      }
      else if (business === 'cs') {
          countFilter = totalFilter = (data) => {
              return data.dataType === 8;
          };
      }
      return {
          getKey,
          getLabel,
          getChildren,
          getCount,
          getTotal,
          countFilter,
          totalFilter,
          // 设置设备状态
          setDeviceStatus: (data) => {
              if (data.onlineState === 1) {
                  // 监控中
                  if (data.monitor === 1 || data.beMonitor === 1) {
                      return 2;
                  }
                  // 通话中
                  if (data.videoCall === 1) {
                      return 3;
                  }
                  // 录像中
                  if (data.videoRecording === 1) {
                      return 4;
                  }
                  // 录音中
                  if (data.audioRecording === 1) {
                      return 5;
                  }
                  // 广播中
                  if (data.broadcast === 1) {
                      return 6;
                  }
                  // SOS
                  if (data.sos === 1) {
                      return 7;
                  }
                  // 在线
                  return 1;
              }
              // 离线
              return 0;
          }
      };
  };

  const isString = (e) => typeof e === 'string';
  const isNumber = (e) => typeof e === 'number';
  const isArray = (e) => Array.isArray(e);

  // 处理filterConfig
  function handleFilterConfig(filterConfig) {
      return (filterConfig || []).filter((item) => {
          return (isString(item.prop) &&
              (isString(item.value) ||
                  isNumber(item.value) ||
                  (isArray(item.value) && item.condition === 'between')) &&
              /^(eq|ne|in|notIn|between|gt|lt|ge|le)$/.test(item.condition));
      });
  }
  // 校验filterConfig
  function useFilterConfig(data, filterList) {
      if (!filterList || !filterList.length)
          return true;
      return filterList.every(({ prop, value, condition }) => {
          const target = data[prop];
          switch (condition) {
              case 'eq':
                  return target === value;
              case 'ne':
                  return target !== value;
          }
          if (Array.isArray(value)) {
              if (condition === 'between') {
                  return Array.isArray(value) && value.length
                      ? target >= value[0] && target <= value[1]
                      : false;
              }
          }
          if (isNumber(target)) {
              if (!isNumber(value))
                  return false;
              switch (condition) {
                  case 'gt':
                      return target > value;
                  case 'lt':
                      return target < value;
                  case 'ge':
                      return target >= value;
                  case 'le':
                      return target <= value;
              }
          }
          else if (isString(target)) {
              const isIn = target.includes(`${value}`);
              switch (condition) {
                  case 'in':
                      return isIn;
                  case 'notIn':
                      return !isIn;
              }
          }
          return false;
      });
  }

  self.onmessage = async (event) => {
      const { data, config } = event.data;
      const generateTree = generateMap[config.business];
      if (!generateTree) {
          self.close();
          return;
      }
      const tree = generateTree(data, config);
      self.postMessage(tree);
  };
  // 设备树结构
  function generateDeviceTree(data, config) {
      const { expandedKeySet } = config;
      const { clearEmptyBusiness } = config.props;
      const { getKey, getLabel, getChildren, countFilter, totalFilter, setDeviceStatus } = useHandleFun(config);
      const filterList = handleFilterConfig(config.businessConfig?.filterConfig);
      /** 设备树 */
      function createDeviceTree(data) {
          let maxLevel = 1;
          const treeNodeMap = new Map();
          const levelTreeNodeMap = new Map();
          const deviceMap = new Map();
          const traverse = (nodes, level = 1, parent = undefined) => {
              const siblings = [];
              let count = 0;
              let total = 0;
              for (let rawNode of nodes) {
                  // 业务逻辑
                  let children = getChildren(rawNode);
                  if (rawNode.dataType !== 3) {
                      const deviceList = [[], []];
                      children = children ? children : [];
                      if (rawNode.deviceList) {
                          rawNode.deviceList.forEach((v) => {
                              const target = {
                                  ...v,
                                  onlyId: rawNode.id + '' + v.deviceId,
                                  label: v.devName || v.deviceId,
                                  dataType: 3, // 代表设备
                                  deviceStatus: setDeviceStatus(v) // 设备状态
                              };
                              if (useFilterConfig(target, filterList)) {
                                  if (target.deviceStatus === 0) {
                                      deviceList[1].push(target);
                                  }
                                  else {
                                      deviceList[0].push(target);
                                  }
                              }
                          });
                          children = [...children, ...deviceList[0], ...deviceList[1]];
                      }
                      rawNode = {
                          ...rawNode,
                          children,
                          onlyId: rawNode.id,
                          dataType: 1, // 部门
                          label: rawNode.orgName || rawNode.companyName
                      };
                  }
                  // 过滤没有设备的部门和群组 步骤一
                  if (clearEmptyBusiness) {
                      if (!children || children.length === 0 && rawNode.dataType !== 3) {
                          continue;
                      }
                  }
                  // 通用逻辑
                  const value = getKey(rawNode);
                  const node = {
                      level,
                      key: value,
                      data: rawNode
                  };
                  node.label = getLabel(rawNode);
                  node.parent = parent;
                  node.isLeaf = !children || children.length === 0;
                  node.expanded = expandedKeySet.has(value);
                  if (children && children.length) {
                      const { list, count: childCount, total: childTotal } = traverse(children, level + 1, node);
                      // 过滤没有用户的部门 步骤二
                      if (clearEmptyBusiness && childTotal === 0) {
                          continue;
                      }
                      node.children = list;
                      node.count = childCount ;
                      node.total = childTotal ;
                      count += childCount;
                      total += childTotal;
                  }
                  else {
                      node.count = 0;
                      node.total = 0;
                      // 统计
                      {
                          count += countFilter(rawNode) ? 1 : 0;
                      }
                      {
                          total += totalFilter(rawNode) ? 1 : 0;
                      }
                  }
                  siblings.push(node);
                  treeNodeMap.set(value, node);
                  if (!levelTreeNodeMap.has(level)) {
                      levelTreeNodeMap.set(level, []);
                  }
                  if (levelTreeNodeMap.has(level)) {
                      levelTreeNodeMap.get(level).push(node);
                  }
                  // 设备
                  if (rawNode.dataType === 3) {
                      const { deviceId } = node.data;
                      const deviceInfo = deviceMap.get(deviceId) || [];
                      deviceInfo.push(node);
                      deviceMap.set(deviceId, deviceInfo);
                  }
              }
              if (level > maxLevel) {
                  maxLevel = level;
              }
              return { list: siblings, count, total };
          };
          const { list } = traverse(data || []);
          const treeNodes = list;
          return {
              treeNodeMap,
              deviceMap,
              levelTreeNodeMap,
              maxLevel,
              treeNodes
          };
      }
      return createDeviceTree(data);
  }
  // 群组设备树结构
  function generateGroupDeviceTree(data, config) {
      const { expandedKeySet } = config;
      const { clearEmptyBusiness } = config.props;
      const { getKey, getLabel, getChildren, countFilter, totalFilter, setDeviceStatus } = useHandleFun(config);
      const filterList = handleFilterConfig(config.businessConfig?.filterConfig);
      /** 群组设备树 */
      function createDeviceTree(data) {
          let maxLevel = 1;
          const treeNodeMap = new Map();
          const levelTreeNodeMap = new Map();
          const deviceMap = new Map();
          const traverse = (nodes, level = 1, parent = undefined) => {
              const siblings = [];
              let count = 0;
              let total = 0;
              for (let rawNode of nodes) {
                  // 业务逻辑
                  let children = getChildren(rawNode);
                  // 群组
                  if (rawNode.children?.length ||
                      rawNode.groupList?.length ||
                      ![3, 4].includes(rawNode.dataType)) {
                      const groupList = [];
                      children = children ? children : [];
                      if (rawNode.groupList?.length) {
                          rawNode.groupList.forEach((v) => {
                              const target = {
                                  ...v,
                                  onlyId: rawNode.id + '' + v.id,
                                  label: v.groupName || v.id,
                                  dataType: 4 // 代表群组
                              };
                              groupList.push(target);
                          });
                          children = [...children, ...groupList];
                      }
                      rawNode = {
                          ...rawNode,
                          children,
                          onlyId: rawNode.id,
                          dataType: 1, // 部门
                          label: rawNode.orgName || rawNode.companyName
                      };
                  }
                  // 设备
                  if (rawNode.deviceList?.length) {
                      const deviceList = [[], []];
                      children = children ? children : [];
                      rawNode.deviceList.forEach((v) => {
                          const target = {
                              ...v,
                              onlyId: rawNode.id + '' + v.deviceId,
                              label: v.devName || v.deviceId,
                              dataType: 3, // 代表设备
                              deviceStatus: setDeviceStatus(v) // 设备状态
                          };
                          if (useFilterConfig(target, filterList)) {
                              if (target.deviceStatus === 0) {
                                  deviceList[1].push(target);
                              }
                              else {
                                  deviceList[0].push(target);
                              }
                          }
                      });
                      children = [...children, ...deviceList[0], ...deviceList[1]];
                  }
                  // 过滤没有设备的部门和群组 步骤一
                  if (clearEmptyBusiness) {
                      if (!children || children.length === 0 && rawNode.dataType !== 3) {
                          continue;
                      }
                  }
                  // 通用逻辑
                  const value = getKey(rawNode);
                  const node = {
                      level,
                      key: value,
                      data: rawNode
                  };
                  node.label = getLabel(rawNode);
                  node.parent = parent;
                  node.isLeaf = !children || children.length === 0;
                  node.expanded = expandedKeySet.has(value);
                  if (children && children.length) {
                      const { list, count: childCount, total: childTotal } = traverse(children, level + 1, node);
                      // 过滤没有设备的部门和群组 步骤二
                      if (clearEmptyBusiness && childTotal === 0) {
                          continue;
                      }
                      node.children = list;
                      node.count = childCount ;
                      node.total = childTotal ;
                      count += childCount;
                      total += childTotal;
                  }
                  else {
                      node.count = 0;
                      node.total = 0;
                      // 统计
                      {
                          count += countFilter(rawNode) ? 1 : 0;
                      }
                      {
                          total += totalFilter(rawNode) ? 1 : 0;
                      }
                  }
                  siblings.push(node);
                  treeNodeMap.set(value, node);
                  if (!levelTreeNodeMap.has(level)) {
                      levelTreeNodeMap.set(level, []);
                  }
                  if (levelTreeNodeMap.has(level)) {
                      levelTreeNodeMap.get(level).push(node);
                  }
                  // 设备
                  if (rawNode.dataType === 3) {
                      const { deviceId } = node.data;
                      const deviceInfo = deviceMap.get(deviceId) || [];
                      deviceInfo.push(node);
                      deviceMap.set(deviceId, deviceInfo);
                  }
              }
              if (level > maxLevel) {
                  maxLevel = level;
              }
              return { list: siblings, count, total };
          };
          const { list } = traverse(data || []);
          const treeNodes = list;
          return {
              treeNodeMap,
              deviceMap,
              levelTreeNodeMap,
              maxLevel,
              treeNodes
          };
      }
      return createDeviceTree(data);
  }
  // 群组树结构
  function generateGroupTree(data, config) {
      const { expandedKeySet } = config;
      const { clearEmptyBusiness } = config.props;
      const { getKey, getLabel, getChildren} = useHandleFun(config);
      /** 群组树 */
      function createGroupTree(data) {
          let maxLevel = 1;
          const treeNodeMap = new Map();
          const levelTreeNodeMap = new Map();
          const traverse = (nodes, level = 1, parent = undefined) => {
              const siblings = [];
              let count = 0;
              let total = 0;
              for (let rawNode of nodes) {
                  let deviceCount = 0;
                  let deviceTotal = 0;
                  // 业务逻辑
                  let children = getChildren(rawNode);
                  // 群组
                  if (rawNode.children?.length ||
                      rawNode.groupList?.length ||
                      ![3, 4].includes(rawNode.dataType)) {
                      const groupList = [];
                      children = children ? children : [];
                      if (rawNode.groupList?.length) {
                          rawNode.groupList.forEach((v) => {
                              const target = {
                                  ...v,
                                  onlyId: rawNode.id + '' + v.id,
                                  label: v.groupName || v.id,
                                  dataType: 4 // 代表群组
                              };
                              groupList.push(target);
                          });
                          children = [...children, ...groupList];
                      }
                      rawNode = {
                          ...rawNode,
                          children,
                          onlyId: rawNode.id,
                          dataType: 1, // 部门
                          label: rawNode.orgName || rawNode.companyName
                      };
                  }
                  // 设备
                  if (rawNode.deviceList?.length) {
                      deviceCount = rawNode.deviceList.reduce((value, v) => {
                          return value + (v.onlineState === 1 ? 1 : 0);
                      }, deviceCount);
                      deviceTotal = rawNode.deviceList.length || 0;
                      count += deviceCount;
                      total += deviceTotal;
                  }
                  // 过滤没有设备和群组的部门 步骤一
                  if (clearEmptyBusiness) {
                      if (!children || children.length === 0 && ![3, 4].includes(rawNode.dataType)) {
                          continue;
                      }
                  }
                  // 处理逻辑
                  const value = getKey(rawNode);
                  const node = {
                      level,
                      key: value,
                      data: rawNode
                  };
                  node.label = getLabel(rawNode);
                  node.parent = parent;
                  node.isLeaf = !children || children.length === 0;
                  node.expanded = expandedKeySet.has(value);
                  if (children && children.length) {
                      const { list, count: childCount, total: childTotal } = traverse(children, level + 1, node);
                      // 过滤没有设备的部门和群组 步骤二
                      if (clearEmptyBusiness && childTotal === 0) {
                          continue;
                      }
                      node.children = list;
                      node.count = childCount ;
                      node.total = childTotal ;
                      count += childCount;
                      total += childTotal;
                  }
                  else if (rawNode.dataType !== 3) {
                      node.count = deviceCount;
                      node.total = deviceTotal;
                  }
                  siblings.push(node);
                  treeNodeMap.set(value, node);
                  if (!levelTreeNodeMap.has(level)) {
                      levelTreeNodeMap.set(level, []);
                  }
                  if (levelTreeNodeMap.has(level)) {
                      levelTreeNodeMap.get(level).push(node);
                  }
              }
              if (level > maxLevel) {
                  maxLevel = level;
              }
              return { list: siblings, count, total };
          };
          const { list } = traverse(data || []);
          const treeNodes = list;
          return {
              treeNodeMap,
              levelTreeNodeMap,
              maxLevel,
              treeNodes
          };
      }
      return createGroupTree(data);
  }
  // 用户树结构
  function generateUserTree(data, config) {
      const { expandedKeySet } = config;
      const { clearEmptyBusiness } = config.props;
      const { getKey, getLabel, getChildren, countFilter, totalFilter } = useHandleFun(config);
      const filterList = handleFilterConfig(config.businessConfig?.filterConfig);
      /** 用户树 */
      function createUserTree(data) {
          let maxLevel = 1;
          const treeNodeMap = new Map();
          const levelTreeNodeMap = new Map();
          const userMap = new Map();
          const traverse = (nodes, level = 1, parent = undefined) => {
              const siblings = [];
              let count = 0;
              let total = 0;
              for (let rawNode of nodes) {
                  // 业务逻辑
                  let children = getChildren(rawNode);
                  if (rawNode.dataType !== 5) {
                      children = children ? children : [];
                      if (rawNode.deviceUserList) {
                          rawNode.deviceUserList.forEach((v) => {
                              const target = {
                                  ...v,
                                  onlyId: rawNode.id + '' + v.id,
                                  label: v.name || v.id,
                                  dataType: 5, // 代表用户
                              };
                              if (useFilterConfig(target, filterList)) {
                                  children.push(target);
                              }
                          });
                      }
                      rawNode = {
                          ...rawNode,
                          children,
                          onlyId: rawNode.id,
                          dataType: 1, // 部门
                          label: rawNode.orgName || rawNode.companyName
                      };
                  }
                  // 过滤没有用户的部门 步骤一
                  if (clearEmptyBusiness) {
                      if (!children || children.length === 0 && rawNode.dataType !== 5) {
                          continue;
                      }
                  }
                  // 通用逻辑
                  const value = getKey(rawNode);
                  const node = {
                      level,
                      key: value,
                      data: rawNode
                  };
                  node.label = getLabel(rawNode);
                  node.parent = parent;
                  node.isLeaf = !children || children.length === 0;
                  node.expanded = expandedKeySet.has(value);
                  if (children && children.length) {
                      const { list, count: childCount, total: childTotal } = traverse(children, level + 1, node);
                      // 过滤没有用户的部门 步骤二
                      if (clearEmptyBusiness && childTotal === 0) {
                          continue;
                      }
                      node.children = list;
                      node.count = childCount ;
                      node.total = childTotal ;
                      count += childCount;
                      total += childTotal;
                  }
                  else {
                      node.count = 0;
                      node.total = 0;
                      // 统计
                      {
                          count += countFilter(rawNode) ? 1 : 0;
                      }
                      {
                          total += totalFilter(rawNode) ? 1 : 0;
                      }
                  }
                  siblings.push(node);
                  treeNodeMap.set(value, node);
                  if (!levelTreeNodeMap.has(level)) {
                      levelTreeNodeMap.set(level, []);
                  }
                  if (levelTreeNodeMap.has(level)) {
                      levelTreeNodeMap.get(level).push(node);
                  }
                  // 用户
                  if (rawNode.dataType === 5) {
                      const { id } = node.data;
                      const userList = userMap.get(id) || [];
                      userList.push(node);
                      userMap.set(id, userList);
                  }
              }
              if (level > maxLevel) {
                  maxLevel = level;
              }
              return { list: siblings, count, total };
          };
          const { list } = traverse(data || []);
          const treeNodes = list;
          return {
              treeNodeMap,
              userMap,
              levelTreeNodeMap,
              maxLevel,
              treeNodes
          };
      }
      return createUserTree(data);
  }
  // 采集站树结构
  function generateCsTree(data, config) {
      const { expandedKeySet } = config;
      const { clearEmptyBusiness } = config.props;
      const { getKey, getLabel, getChildren, countFilter, totalFilter } = useHandleFun(config);
      const filterList = handleFilterConfig(config.businessConfig?.filterConfig);
      /** 采集站树 */
      function createCsTree(data) {
          let maxLevel = 1;
          const treeNodeMap = new Map();
          const levelTreeNodeMap = new Map();
          const csMap = new Map();
          const traverse = (nodes, level = 1, parent = undefined) => {
              const siblings = [];
              let count = 0;
              let total = 0;
              for (let rawNode of nodes) {
                  // 业务逻辑
                  let children = getChildren(rawNode);
                  if (rawNode.dataType !== 8) {
                      children = children ? children : [];
                      if (rawNode.csList) {
                          rawNode.csList.forEach((v) => {
                              const target = {
                                  ...v,
                                  onlyId: rawNode.id + '' + v.id,
                                  label: v.sname || v.scode,
                                  dataType: 8, // 代表采集站
                              };
                              if (useFilterConfig(target, filterList)) {
                                  children.push(target);
                              }
                          });
                      }
                      rawNode = {
                          ...rawNode,
                          children,
                          onlyId: rawNode.id,
                          dataType: 1, // 部门
                          label: rawNode.orgName || rawNode.companyName
                      };
                  }
                  // 过滤没有采集器的部门 步骤一
                  if (clearEmptyBusiness) {
                      if (!children || children.length === 0 && rawNode.dataType !== 8) {
                          continue;
                      }
                  }
                  // 通用逻辑
                  const value = getKey(rawNode);
                  const node = {
                      level,
                      key: value,
                      data: rawNode
                  };
                  node.label = getLabel(rawNode);
                  node.parent = parent;
                  node.isLeaf = !children || children.length === 0;
                  node.expanded = expandedKeySet.has(value);
                  if (children && children.length) {
                      const { list, count: childCount, total: childTotal } = traverse(children, level + 1, node);
                      // 过滤没有采集器的部门 步骤二
                      if (clearEmptyBusiness && childTotal === 0) {
                          continue;
                      }
                      node.children = list;
                      node.count = childCount ;
                      node.total = childTotal ;
                      count += childCount;
                      total += childTotal;
                  }
                  else {
                      node.count = 0;
                      node.total = 0;
                      // 统计
                      {
                          count += countFilter(rawNode) ? 1 : 0;
                      }
                      {
                          total += totalFilter(rawNode) ? 1 : 0;
                      }
                  }
                  siblings.push(node);
                  treeNodeMap.set(value, node);
                  if (!levelTreeNodeMap.has(level)) {
                      levelTreeNodeMap.set(level, []);
                  }
                  if (levelTreeNodeMap.has(level)) {
                      levelTreeNodeMap.get(level).push(node);
                  }
                  // 采集站
                  if (rawNode.dataType === 8) {
                      const { id } = node.data;
                      const userList = csMap.get(id) || [];
                      userList.push(node);
                      csMap.set(id, userList);
                  }
              }
              if (level > maxLevel) {
                  maxLevel = level;
              }
              return { list: siblings, count, total };
          };
          const { list } = traverse(data || []);
          const treeNodes = list;
          return {
              treeNodeMap,
              csMap,
              levelTreeNodeMap,
              maxLevel,
              treeNodes
          };
      }
      return createCsTree(data);
  }
  const generateMap = {
      // 设备树
      device: generateDeviceTree,
      // 群组设备树
      groupDevice: generateGroupDeviceTree,
      // 群组树
      group: generateGroupTree,
      // 用户树
      user: generateUserTree,
      // 采集站
      cs: generateCsTree
  };

})();
//# sourceMappingURL=generateTree.js.map

');
|
|
1392
|
+
var WorkerFactory = /*#__PURE__*/createBase64WorkerFactory('/* rollup-plugin-web-worker-loader */
(function () {
  'use strict';

  /** 生成配置项 */
  /** 生成处理函数 */
  const useHandleFun = (config) => {
      const { business } = config;
      const props = { ...config.props };
      let { countFilter, totalFilter } = props;
      /** 获取key值 */
      function getKey(node, isBusiness = false) {
          if (!node)
              return '';
          if (business && isBusiness) {
              switch (business) {
                  case 'device':
                  case 'groupDevice':
                      return node.deviceId;
                  case 'user':
                  case 'cs':
                      return node.id;
              }
          }
          return node[props.value];
      }
      /** 获取label值 */
      function getLabel(node) {
          if (!node)
              return '';
          return node[props.label];
      }
      /** 获取children值 */
      function getChildren(node) {
          if (!node)
              return [];
          const children = node[props.children];
          return children ? [...children] : [];
      }
      /** 获取count值 */
      function getCount(node) {
          if (!node)
              return;
          return node[props.count];
      }
      /** 获取total值 */
      function getTotal(node) {
          if (!node)
              return;
          return node[props.total];
      }
      if (['device', 'groupDevice'].includes(`${business}`)) {
          countFilter = (data) => {
              return data.dataType === 3 && data.onlineState === 1;
          };
          totalFilter = (data) => {
              return data.dataType === 3;
          };
      }
      else if (business === 'user') {
          countFilter = totalFilter = (data) => {
              return data.dataType === 5;
          };
      }
      else if (business === 'cs') {
          countFilter = totalFilter = (data) => {
              return data.dataType === 8;
          };
      }
      return {
          getKey,
          getLabel,
          getChildren,
          getCount,
          getTotal,
          countFilter,
          totalFilter,
          // 设置设备状态
          setDeviceStatus: (data) => {
              if (data.onlineState === 1) {
                  // 监控中
                  if (data.monitor === 1 || data.beMonitor === 1) {
                      return 2;
                  }
                  // 通话中
                  if (data.videoCall === 1) {
                      return 3;
                  }
                  // 录像中
                  if (data.videoRecording === 1) {
                      return 4;
                  }
                  // 录音中
                  if (data.audioRecording === 1) {
                      return 5;
                  }
                  // 广播中
                  if (data.broadcast === 1) {
                      return 6;
                  }
                  // SOS
                  if (data.sos === 1) {
                      return 7;
                  }
                  // 在线
                  return 1;
              }
              // 离线
              return 0;
          }
      };
  };

  const isString = (e) => typeof e === 'string';
  const isNumber = (e) => typeof e === 'number';
  const isArray = (e) => Array.isArray(e);

  // 处理filterConfig
  function handleFilterConfig(filterConfig) {
      return (filterConfig || []).filter((item) => {
          return (isString(item.prop) &&
              (isString(item.value) ||
                  isNumber(item.value) ||
                  (isArray(item.value) && item.condition === 'between')) &&
              /^(eq|ne|in|notIn|between|gt|lt|ge|le)$/.test(item.condition));
      });
  }
  // 校验filterConfig
  function useFilterConfig(data, filterList) {
      if (!filterList || !filterList.length)
          return true;
      return filterList.every(({ prop, value, condition }) => {
          const target = data[prop];
          switch (condition) {
              case 'eq':
                  return target === value;
              case 'ne':
                  return target !== value;
          }
          if (Array.isArray(value)) {
              if (condition === 'between') {
                  return Array.isArray(value) && value.length
                      ? target >= value[0] && target <= value[1]
                      : false;
              }
          }
          if (isNumber(target)) {
              if (!isNumber(value))
                  return false;
              switch (condition) {
                  case 'gt':
                      return target > value;
                  case 'lt':
                      return target < value;
                  case 'ge':
                      return target >= value;
                  case 'le':
                      return target <= value;
              }
          }
          else if (isString(target)) {
              const isIn = target.includes(`${value}`);
              switch (condition) {
                  case 'in':
                      return isIn;
                  case 'notIn':
                      return !isIn;
              }
          }
          return false;
      });
  }

  self.onmessage = async (event) => {
      const { data, config } = event.data;
      const generateTree = generateMap[config.business];
      if (!generateTree) {
          self.close();
          return;
      }
      const tree = generateTree(data, config);
      self.postMessage(tree);
  };
  // 设备树结构
  function generateDeviceTree(data, config) {
      const { expandedKeySet } = config;
      const { showOnlineState, clearEmptyBusiness, integratedBusiness } = config.businessConfig;
      const { getKey, getLabel, getChildren, countFilter, totalFilter, setDeviceStatus } = useHandleFun(config);
      const filterList = handleFilterConfig(config.businessConfig?.filterConfig);
      /** 设备树 */
      function createDeviceTree(data) {
          let maxLevel = 1;
          const treeNodeMap = new Map();
          const levelTreeNodeMap = new Map();
          const deviceMap = new Map();
          const hiddenNodeKeySet = new Set();
          const traverse = (nodes, level = 1, parent = undefined) => {
              const siblings = [];
              const deepBusinessList = [];
              let count = 0;
              let total = 0;
              for (let rawNode of nodes) {
                  // 业务逻辑
                  const businessList = [];
                  let children = getChildren(rawNode);
                  if (rawNode.dataType !== 3) {
                      const deviceList = [[], []];
                      children = children ? children : [];
                      if (rawNode.deviceList) {
                          rawNode.deviceList.forEach((v) => {
                              const target = {
                                  ...v,
                                  onlyId: rawNode.id + '' + v.deviceId,
                                  label: v.devName || v.deviceId,
                                  dataType: 3, // 代表设备
                                  deviceStatus: setDeviceStatus(v) // 设备状态
                              };
                              if (useFilterConfig(target, filterList)) {
                                  if (target.deviceStatus === 0) {
                                      deviceList[1].push(target);
                                      if (showOnlineState) {
                                          hiddenNodeKeySet.add(getKey(target));
                                      }
                                  }
                                  else {
                                      deviceList[0].push(target);
                                  }
                                  // 保存业务数据
                                  if (integratedBusiness && !hiddenNodeKeySet.has(getKey(target))) {
                                      businessList.push(target);
                                      deepBusinessList.push(target);
                                  }
                              }
                          });
                          children = [...children, ...deviceList[0], ...deviceList[1]];
                      }
                      rawNode = {
                          ...rawNode,
                          children,
                          onlyId: rawNode.id,
                          dataType: 1, // 部门
                          label: rawNode.orgName || rawNode.companyName
                      };
                  }
                  // 过滤没有设备的部门和群组 步骤一
                  if (clearEmptyBusiness) {
                      if (!children || children.length === 0 && rawNode.dataType !== 3) {
                          continue;
                      }
                  }
                  // 通用逻辑
                  const value = getKey(rawNode);
                  const node = {
                      level,
                      key: value,
                      data: rawNode
                  };
                  node.label = getLabel(rawNode);
                  node.parent = parent;
                  node.isLeaf = !children || children.length === 0;
                  node.expanded = expandedKeySet.has(value);
                  // 隐藏没有在线设备的部门和群组
                  if (showOnlineState) {
                      if (!children || children.length === 0 && rawNode.dataType !== 3) {
                          hiddenNodeKeySet.add(node.key);
                      }
                  }
                  if (children && children.length) {
                      const { list, count: childCount, total: childTotal, businessList: list2 } = traverse(children, level + 1, node);
                      // 过滤没有用户的部门 步骤二
                      if (!showOnlineState && clearEmptyBusiness && childTotal === 0) {
                          continue;
                      }
                      // 保存下层业务数据
                      if (integratedBusiness) {
                          for (const target of list2) {
                              businessList.push(target);
                              deepBusinessList.push(target);
                          }
                          node.data.childrenDeviceList = businessList;
                      }
                      node.children = list;
                      node.count = childCount ;
                      node.total = childTotal ;
                      count += childCount;
                      total += childTotal;
                      // 仅显示在线设备时，隐藏没有在线设备的部门和群组
                      if (showOnlineState && !childCount) {
                          hiddenNodeKeySet.add(node.key);
                      }
                  }
                  else {
                      node.count = 0;
                      node.total = 0;
                      // 统计
                      if (!showOnlineState || !hiddenNodeKeySet.has(node.key)) {
                          {
                              count += countFilter(rawNode) ? 1 : 0;
                          }
                          {
                              total += totalFilter(rawNode) ? 1 : 0;
                          }
                      }
                  }
                  siblings.push(node);
                  treeNodeMap.set(value, node);
                  if (!levelTreeNodeMap.has(level)) {
                      levelTreeNodeMap.set(level, []);
                  }
                  if (levelTreeNodeMap.has(level)) {
                      levelTreeNodeMap.get(level).push(node);
                  }
                  // 设备
                  if (rawNode.dataType === 3) {
                      const { deviceId } = node.data;
                      const deviceInfo = deviceMap.get(deviceId) || [];
                      deviceInfo.push(node);
                      deviceMap.set(deviceId, deviceInfo);
                  }
              }
              if (level > maxLevel) {
                  maxLevel = level;
              }
              return { list: siblings, count, total, businessList: deepBusinessList };
          };
          const { list } = traverse(data || []);
          const treeNodes = list;
          return {
              treeNodeMap,
              deviceMap,
              levelTreeNodeMap,
              maxLevel,
              treeNodes,
              hiddenNodeKeySet
          };
      }
      return createDeviceTree(data);
  }
  // 群组设备树结构
  function generateGroupDeviceTree(data, config) {
      const { expandedKeySet } = config;
      const { showOnlineState, clearEmptyBusiness, integratedBusiness } = config.businessConfig;
      const { getKey, getLabel, getChildren, countFilter, totalFilter, setDeviceStatus } = useHandleFun(config);
      const filterList = handleFilterConfig(config.businessConfig?.filterConfig);
      /** 群组设备树 */
      function createDeviceTree(data) {
          let maxLevel = 1;
          const treeNodeMap = new Map();
          const levelTreeNodeMap = new Map();
          const deviceMap = new Map();
          const hiddenNodeKeySet = new Set();
          const traverse = (nodes, level = 1, parent = undefined) => {
              const siblings = [];
              const deepBusinessList = [];
              let count = 0;
              let total = 0;
              for (let rawNode of nodes) {
                  const businessList = [];
                  // 业务逻辑
                  let children = getChildren(rawNode);
                  // 群组
                  if (rawNode.children?.length ||
                      rawNode.groupList?.length ||
                      ![3, 4].includes(rawNode.dataType)) {
                      const groupList = [];
                      children = children ? children : [];
                      if (rawNode.groupList?.length) {
                          rawNode.groupList.forEach((v) => {
                              const target = {
                                  ...v,
                                  onlyId: rawNode.id + '' + v.id,
                                  label: v.groupName || v.id,
                                  dataType: 4 // 代表群组
                              };
                              groupList.push(target);
                          });
                          children = [...children, ...groupList];
                      }
                      rawNode = {
                          ...rawNode,
                          children,
                          onlyId: rawNode.id,
                          dataType: 1, // 部门
                          label: rawNode.orgName || rawNode.companyName
                      };
                  }
                  // 设备
                  if (rawNode.deviceList?.length) {
                      const deviceList = [[], []];
                      children = children ? children : [];
                      rawNode.deviceList.forEach((v) => {
                          const target = {
                              ...v,
                              onlyId: rawNode.id + '' + v.deviceId,
                              label: v.devName || v.deviceId,
                              dataType: 3, // 代表设备
                              deviceStatus: setDeviceStatus(v) // 设备状态
                          };
                          if (useFilterConfig(target, filterList)) {
                              if (target.deviceStatus === 0) {
                                  deviceList[1].push(target);
                                  if (showOnlineState) {
                                      hiddenNodeKeySet.add(getKey(target));
                                  }
                              }
                              else {
                                  deviceList[0].push(target);
                              }
                              if (integratedBusiness && !hiddenNodeKeySet.has(getKey(target))) {
                                  businessList.push(target);
                                  deepBusinessList.push(target);
                              }
                          }
                      });
                      children = [...children, ...deviceList[0], ...deviceList[1]];
                  }
                  // 过滤没有设备的部门和群组 步骤一
                  if (clearEmptyBusiness) {
                      if (!children || children.length === 0 && rawNode.dataType !== 3) {
                          continue;
                      }
                  }
                  // 通用逻辑
                  const value = getKey(rawNode);
                  const node = {
                      level,
                      key: value,
                      data: rawNode
                  };
                  node.label = getLabel(rawNode);
                  node.parent = parent;
                  node.isLeaf = !children || children.length === 0;
                  node.expanded = expandedKeySet.has(value);
                  // 隐藏没有在线设备的部门和群组
                  if (showOnlineState) {
                      if (!children || children.length === 0 && rawNode.dataType !== 3) {
                          hiddenNodeKeySet.add(node.key);
                      }
                  }
                  if (children && children.length) {
                      const { list, count: childCount, total: childTotal, businessList: list2 } = traverse(children, level + 1, node);
                      // 过滤没有设备的部门和群组 步骤二
                      if (!showOnlineState && clearEmptyBusiness && childTotal === 0) {
                          continue;
                      }
                      // 保存下层业务数据
                      if (integratedBusiness) {
                          for (const target of list2) {
                              businessList.push(target);
                              deepBusinessList.push(target);
                          }
                          node.data.childrenDeviceList = businessList;
                      }
                      node.children = list;
                      node.count = childCount ;
                      node.total = childTotal ;
                      count += childCount;
                      total += childTotal;
                      // 仅显示在线设备时，隐藏没有在线设备的部门和群组
                      if (showOnlineState && !childCount) {
                          hiddenNodeKeySet.add(node.key);
                      }
                  }
                  else {
                      node.count = 0;
                      node.total = 0;
                      // 统计
                      if (!showOnlineState || !hiddenNodeKeySet.has(node.key)) {
                          {
                              count += countFilter(rawNode) ? 1 : 0;
                          }
                          {
                              total += totalFilter(rawNode) ? 1 : 0;
                          }
                      }
                  }
                  siblings.push(node);
                  treeNodeMap.set(value, node);
                  if (!levelTreeNodeMap.has(level)) {
                      levelTreeNodeMap.set(level, []);
                  }
                  if (levelTreeNodeMap.has(level)) {
                      levelTreeNodeMap.get(level).push(node);
                  }
                  // 设备
                  if (rawNode.dataType === 3) {
                      const { deviceId } = node.data;
                      const deviceInfo = deviceMap.get(deviceId) || [];
                      deviceInfo.push(node);
                      deviceMap.set(deviceId, deviceInfo);
                  }
              }
              if (level > maxLevel) {
                  maxLevel = level;
              }
              return { list: siblings, count, total, businessList: deepBusinessList };
          };
          const { list } = traverse(data || []);
          const treeNodes = list;
          return {
              treeNodeMap,
              deviceMap,
              levelTreeNodeMap,
              maxLevel,
              treeNodes,
              hiddenNodeKeySet
          };
      }
      return createDeviceTree(data);
  }
  // 群组树结构
  function generateGroupTree(data, config) {
      const { expandedKeySet } = config;
      const { clearEmptyBusiness, integratedBusiness } = config.businessConfig;
      const { getKey, getLabel, getChildren} = useHandleFun(config);
      /** 群组树 */
      function createGroupTree(data) {
          let maxLevel = 1;
          const treeNodeMap = new Map();
          const levelTreeNodeMap = new Map();
          const traverse = (nodes, level = 1, parent = undefined) => {
              const siblings = [];
              const deepBusinessList = [];
              let count = 0;
              let total = 0;
              for (let rawNode of nodes) {
                  const businessList = [];
                  let deviceCount = 0;
                  let deviceTotal = 0;
                  // 业务逻辑
                  let children = getChildren(rawNode);
                  // 群组
                  if (rawNode.children?.length ||
                      rawNode.groupList?.length ||
                      ![3, 4].includes(rawNode.dataType)) {
                      const groupList = [];
                      children = children ? children : [];
                      if (rawNode.groupList?.length) {
                          rawNode.groupList.forEach((v) => {
                              const target = {
                                  ...v,
                                  onlyId: rawNode.id + '' + v.id,
                                  label: v.groupName || v.id,
                                  dataType: 4 // 代表群组
                              };
                              groupList.push(target);
                          });
                          children = [...children, ...groupList];
                      }
                      rawNode = {
                          ...rawNode,
                          children,
                          onlyId: rawNode.id,
                          dataType: 1, // 部门
                          label: rawNode.orgName || rawNode.companyName
                      };
                  }
                  // 设备
                  if (rawNode.deviceList?.length) {
                      deviceCount = rawNode.deviceList.reduce((value, v) => {
                          if (integratedBusiness) {
                              businessList.push(v);
                              deepBusinessList.push(v);
                          }
                          return value + (v.onlineState === 1 ? 1 : 0);
                      }, deviceCount);
                      deviceTotal = rawNode.deviceList.length || 0;
                      count += deviceCount;
                      total += deviceTotal;
                  }
                  // 过滤没有设备和群组的部门 步骤一
                  if (clearEmptyBusiness) {
                      if (!children || children.length === 0 && ![3, 4].includes(rawNode.dataType)) {
                          continue;
                      }
                  }
                  // 处理逻辑
                  const value = getKey(rawNode);
                  const node = {
                      level,
                      key: value,
                      data: rawNode
                  };
                  node.label = getLabel(rawNode);
                  node.parent = parent;
                  node.isLeaf = !children || children.length === 0;
                  node.expanded = expandedKeySet.has(value);
                  if (children && children.length) {
                      const { list, count: childCount, total: childTotal, businessList: list2 } = traverse(children, level + 1, node);
                      // 过滤没有设备的部门和群组 步骤二
                      if (clearEmptyBusiness && childTotal === 0) {
                          continue;
                      }
                      // 保存下层业务数据
                      if (integratedBusiness) {
                          for (const target of list2) {
                              businessList.push(target);
                              deepBusinessList.push(target);
                          }
                          node.data.childrenDeviceList = businessList;
                      }
                      node.children = list;
                      node.count = childCount ;
                      node.total = childTotal ;
                      count += childCount;
                      total += childTotal;
                  }
                  else if (rawNode.dataType !== 3) {
                      node.count = deviceCount;
                      node.total = deviceTotal;
                  }
                  siblings.push(node);
                  treeNodeMap.set(value, node);
                  if (!levelTreeNodeMap.has(level)) {
                      levelTreeNodeMap.set(level, []);
                  }
                  if (levelTreeNodeMap.has(level)) {
                      levelTreeNodeMap.get(level).push(node);
                  }
              }
              if (level > maxLevel) {
                  maxLevel = level;
              }
              return { list: siblings, count, total, businessList: deepBusinessList };
          };
          const { list } = traverse(data || []);
          const treeNodes = list;
          return {
              treeNodeMap,
              levelTreeNodeMap,
              maxLevel,
              treeNodes,
              hiddenNodeKeySet: new Set()
          };
      }
      return createGroupTree(data);
  }
  // 用户树结构
  function generateUserTree(data, config) {
      const { expandedKeySet } = config;
      const { clearEmptyBusiness, integratedBusiness } = config.businessConfig;
      const { getKey, getLabel, getChildren, countFilter, totalFilter } = useHandleFun(config);
      const filterList = handleFilterConfig(config.businessConfig?.filterConfig);
      /** 用户树 */
      function createUserTree(data) {
          let maxLevel = 1;
          const treeNodeMap = new Map();
          const levelTreeNodeMap = new Map();
          const userMap = new Map();
          const traverse = (nodes, level = 1, parent = undefined) => {
              const siblings = [];
              const deepBusinessList = [];
              let count = 0;
              let total = 0;
              for (let rawNode of nodes) {
                  // 业务逻辑
                  const businessList = [];
                  let children = getChildren(rawNode);
                  if (rawNode.dataType !== 5) {
                      children = children ? children : [];
                      if (rawNode.deviceUserList) {
                          rawNode.deviceUserList.forEach((v) => {
                              const target = {
                                  ...v,
                                  onlyId: rawNode.id + '' + v.id,
                                  label: v.name || v.id,
                                  dataType: 5, // 代表用户
                              };
                              if (useFilterConfig(target, filterList)) {
                                  children.push(target);
                                  if (integratedBusiness) {
                                      businessList.push(target);
                                      deepBusinessList.push(target);
                                  }
                              }
                          });
                      }
                      rawNode = {
                          ...rawNode,
                          children,
                          onlyId: rawNode.id,
                          dataType: 1, // 部门
                          label: rawNode.orgName || rawNode.companyName
                      };
                  }
                  // 过滤没有用户的部门 步骤一
                  if (clearEmptyBusiness) {
                      if (!children || children.length === 0 && rawNode.dataType !== 5) {
                          continue;
                      }
                  }
                  // 通用逻辑
                  const value = getKey(rawNode);
                  const node = {
                      level,
                      key: value,
                      data: rawNode
                  };
                  node.label = getLabel(rawNode);
                  node.parent = parent;
                  node.isLeaf = !children || children.length === 0;
                  node.expanded = expandedKeySet.has(value);
                  if (children && children.length) {
                      const { list, count: childCount, total: childTotal, businessList: list2 } = traverse(children, level + 1, node);
                      // 过滤没有用户的部门 步骤二
                      if (clearEmptyBusiness && childTotal === 0) {
                          continue;
                      }
                      // 保存下层业务数据
                      if (integratedBusiness) {
                          for (const target of list2) {
                              businessList.push(target);
                              deepBusinessList.push(target);
                          }
                          node.data.childrenDeviceList = businessList;
                      }
                      node.children = list;
                      node.count = childCount ;
                      node.total = childTotal ;
                      count += childCount;
                      total += childTotal;
                  }
                  else {
                      node.count = 0;
                      node.total = 0;
                      // 统计
                      {
                          count += countFilter(rawNode) ? 1 : 0;
                      }
                      {
                          total += totalFilter(rawNode) ? 1 : 0;
                      }
                  }
                  siblings.push(node);
                  treeNodeMap.set(value, node);
                  if (!levelTreeNodeMap.has(level)) {
                      levelTreeNodeMap.set(level, []);
                  }
                  if (levelTreeNodeMap.has(level)) {
                      levelTreeNodeMap.get(level).push(node);
                  }
                  // 用户
                  if (rawNode.dataType === 5) {
                      const { id } = node.data;
                      const userList = userMap.get(id) || [];
                      userList.push(node);
                      userMap.set(id, userList);
                  }
              }
              if (level > maxLevel) {
                  maxLevel = level;
              }
              return { list: siblings, count, total, businessList: deepBusinessList };
          };
          const { list } = traverse(data || []);
          const treeNodes = list;
          return {
              treeNodeMap,
              userMap,
              levelTreeNodeMap,
              maxLevel,
              treeNodes,
              hiddenNodeKeySet: new Set()
          };
      }
      return createUserTree(data);
  }
  // 采集站树结构
  function generateCsTree(data, config) {
      const { expandedKeySet } = config;
      const { clearEmptyBusiness, integratedBusiness } = config.businessConfig;
      const { getKey, getLabel, getChildren, countFilter, totalFilter } = useHandleFun(config);
      const filterList = handleFilterConfig(config.businessConfig?.filterConfig);
      /** 采集站树 */
      function createCsTree(data) {
          let maxLevel = 1;
          const treeNodeMap = new Map();
          const levelTreeNodeMap = new Map();
          const csMap = new Map();
          const traverse = (nodes, level = 1, parent = undefined) => {
              const siblings = [];
              const deepBusinessList = [];
              let count = 0;
              let total = 0;
              for (let rawNode of nodes) {
                  // 业务逻辑
                  const businessList = [];
                  let children = getChildren(rawNode);
                  if (rawNode.dataType !== 8) {
                      children = children ? children : [];
                      if (rawNode.csList) {
                          rawNode.csList.forEach((v) => {
                              const target = {
                                  ...v,
                                  onlyId: rawNode.id + '' + v.id,
                                  label: v.sname || v.scode,
                                  dataType: 8, // 代表采集站
                              };
                              if (useFilterConfig(target, filterList)) {
                                  children.push(target);
                                  if (integratedBusiness) {
                                      businessList.push(target);
                                      deepBusinessList.push(target);
                                  }
                              }
                          });
                      }
                      rawNode = {
                          ...rawNode,
                          children,
                          onlyId: rawNode.id,
                          dataType: 1, // 部门
                          label: rawNode.orgName || rawNode.companyName
                      };
                  }
                  // 过滤没有采集器的部门 步骤一
                  if (clearEmptyBusiness) {
                      if (!children || children.length === 0 && rawNode.dataType !== 8) {
                          continue;
                      }
                  }
                  // 通用逻辑
                  const value = getKey(rawNode);
                  const node = {
                      level,
                      key: value,
                      data: rawNode
                  };
                  node.label = getLabel(rawNode);
                  node.parent = parent;
                  node.isLeaf = !children || children.length === 0;
                  node.expanded = expandedKeySet.has(value);
                  if (children && children.length) {
                      const { list, count: childCount, total: childTotal, businessList: list2 } = traverse(children, level + 1, node);
                      // 过滤没有采集器的部门 步骤二
                      if (clearEmptyBusiness && childTotal === 0) {
                          continue;
                      }
                      // 保存下层业务数据
                      if (integratedBusiness) {
                          for (const target of list2) {
                              businessList.push(target);
                              deepBusinessList.push(target);
                          }
                          node.data.childrenDeviceList = businessList;
                      }
                      node.children = list;
                      node.count = childCount ;
                      node.total = childTotal ;
                      count += childCount;
                      total += childTotal;
                  }
                  else {
                      node.count = 0;
                      node.total = 0;
                      // 统计
                      {
                          count += countFilter(rawNode) ? 1 : 0;
                      }
                      {
                          total += totalFilter(rawNode) ? 1 : 0;
                      }
                  }
                  siblings.push(node);
                  treeNodeMap.set(value, node);
                  if (!levelTreeNodeMap.has(level)) {
                      levelTreeNodeMap.set(level, []);
                  }
                  if (levelTreeNodeMap.has(level)) {
                      levelTreeNodeMap.get(level).push(node);
                  }
                  // 采集站
                  if (rawNode.dataType === 8) {
                      const { id } = node.data;
                      const userList = csMap.get(id) || [];
                      userList.push(node);
                      csMap.set(id, userList);
                  }
              }
              if (level > maxLevel) {
                  maxLevel = level;
              }
              return { list: siblings, count, total, businessList: deepBusinessList };
          };
          const { list } = traverse(data || []);
          const treeNodes = list;
          return {
              treeNodeMap,
              csMap,
              levelTreeNodeMap,
              maxLevel,
              treeNodes,
              hiddenNodeKeySet: new Set()
          };
      }
      return createCsTree(data);
  }
  const generateMap = {
      // 设备树
      device: generateDeviceTree,
      // 群组设备树
      groupDevice: generateGroupDeviceTree,
      // 群组树
      group: generateGroupTree,
      // 用户树
      user: generateUserTree,
      // 采集站
      cs: generateCsTree
  };

})();
//# sourceMappingURL=generateTree.js.map

');
|
|
1356
1393
|
/* eslint-enable */
|
|
1357
1394
|
|
|
1358
1395
|
// 设备树
|
|
1359
1396
|
function updateDeviceTree(tree, data, config) {
|
|
1360
1397
|
const deviceMap = tree.deviceMap || new Map();
|
|
1361
1398
|
const { countFilter, totalFilter, setDeviceStatus } = useHandleFun(config);
|
|
1399
|
+
const { showOnlineState, integratedBusiness } = config.businessConfig;
|
|
1362
1400
|
// 更新父节点统计
|
|
1363
1401
|
const updateParnetCount = (keySet) => {
|
|
1364
1402
|
const isCountFiler = countFilter && isFunction(countFilter);
|
|
@@ -1372,15 +1410,16 @@ function updateDeviceTree(tree, data, config) {
|
|
|
1372
1410
|
let total = isTotalFiler ? 0 : target.data.total;
|
|
1373
1411
|
const deviceList = [[], []];
|
|
1374
1412
|
if (isCountFiler || isTotalFiler) {
|
|
1413
|
+
const businessList = [];
|
|
1375
1414
|
let children = target.children || [];
|
|
1376
1415
|
for (let i = 0; i < children.length; i++) {
|
|
1377
1416
|
const item = target.children[i];
|
|
1378
1417
|
count =
|
|
1379
|
-
isCountFiler && countFilter
|
|
1418
|
+
isCountFiler && !tree.hiddenNodeKeySet.has(item.key) && countFilter
|
|
1380
1419
|
? count + (item.children ? item.count : countFilter(item.data))
|
|
1381
1420
|
: count;
|
|
1382
1421
|
total =
|
|
1383
|
-
isTotalFiler && totalFilter
|
|
1422
|
+
isTotalFiler && !tree.hiddenNodeKeySet.has(item.key) && totalFilter
|
|
1384
1423
|
? total + (item.children ? item.total : totalFilter(item.data))
|
|
1385
1424
|
: total;
|
|
1386
1425
|
if (item.data.deviceStatus === 0) {
|
|
@@ -1389,7 +1428,21 @@ function updateDeviceTree(tree, data, config) {
|
|
|
1389
1428
|
else {
|
|
1390
1429
|
deviceList[0].push(item);
|
|
1391
1430
|
}
|
|
1431
|
+
// 更新下级设备列表
|
|
1432
|
+
if (integratedBusiness && !tree.hiddenNodeKeySet.has(item.key)) {
|
|
1433
|
+
if (/^(1|4)$/.test(item.data.dataType)) {
|
|
1434
|
+
businessList.push(...(item.data.childrenDeviceList || []));
|
|
1435
|
+
}
|
|
1436
|
+
else {
|
|
1437
|
+
businessList.push(item.data);
|
|
1438
|
+
}
|
|
1439
|
+
}
|
|
1392
1440
|
}
|
|
1441
|
+
target.data.childrenDeviceList = businessList;
|
|
1442
|
+
}
|
|
1443
|
+
// 在仅显示设备时,切换显隐状态
|
|
1444
|
+
if (showOnlineState) {
|
|
1445
|
+
tree.hiddenNodeKeySet[count === 0 ? 'add' : 'delete'](target.key);
|
|
1393
1446
|
}
|
|
1394
1447
|
target.count = count;
|
|
1395
1448
|
target.total = total;
|
|
@@ -1418,6 +1471,10 @@ function updateDeviceTree(tree, data, config) {
|
|
|
1418
1471
|
deviceStatus: setDeviceStatus(v) // 设备状态
|
|
1419
1472
|
})
|
|
1420
1473
|
});
|
|
1474
|
+
// 在仅显示设备时,切换显隐状态
|
|
1475
|
+
if (showOnlineState) {
|
|
1476
|
+
tree.hiddenNodeKeySet[target.data.deviceStatus === 0 ? 'add' : 'delete'](target.key);
|
|
1477
|
+
}
|
|
1421
1478
|
target.parent && parentKeySet.add(target.parent.key);
|
|
1422
1479
|
});
|
|
1423
1480
|
});
|
|
@@ -1532,7 +1589,8 @@ class VirtualTree {
|
|
|
1532
1589
|
deviceMap: new Map(),
|
|
1533
1590
|
levelTreeNodeMap: new Map(),
|
|
1534
1591
|
treeNodes: [],
|
|
1535
|
-
maxLevel: 0
|
|
1592
|
+
maxLevel: 0,
|
|
1593
|
+
hiddenNodeKeySet: new Set()
|
|
1536
1594
|
};
|
|
1537
1595
|
_business;
|
|
1538
1596
|
_expandedKeySet = new Set(); // 展开的key
|
|
@@ -1602,8 +1660,7 @@ class VirtualTree {
|
|
|
1602
1660
|
label: this._props.label,
|
|
1603
1661
|
children: this._props.children,
|
|
1604
1662
|
count: this._props.count,
|
|
1605
|
-
total: this._props.total
|
|
1606
|
-
clearEmptyBusiness: this._props.clearEmptyBusiness
|
|
1663
|
+
total: this._props.total
|
|
1607
1664
|
},
|
|
1608
1665
|
expandedKeySet: this._expandedKeySet,
|
|
1609
1666
|
businessConfig: this._businessConfig
|
|
@@ -1675,11 +1732,13 @@ class VirtualTree {
|
|
|
1675
1732
|
treeNodeMap,
|
|
1676
1733
|
levelTreeNodeMap,
|
|
1677
1734
|
maxLevel,
|
|
1678
|
-
treeNodes: list
|
|
1735
|
+
treeNodes: list,
|
|
1736
|
+
hiddenNodeKeySet: new Set()
|
|
1679
1737
|
});
|
|
1680
1738
|
});
|
|
1681
1739
|
};
|
|
1682
1740
|
})();
|
|
1741
|
+
/** 更新树数据 */
|
|
1683
1742
|
_updateTree = (() => {
|
|
1684
1743
|
// 更新父节点统计
|
|
1685
1744
|
const updateParnetCount = (keySet) => {
|
|
@@ -1729,7 +1788,8 @@ class VirtualTree {
|
|
|
1729
1788
|
children: this._props.children,
|
|
1730
1789
|
count: this._props.count,
|
|
1731
1790
|
total: this._props.total
|
|
1732
|
-
}
|
|
1791
|
+
},
|
|
1792
|
+
businessConfig: this._businessConfig
|
|
1733
1793
|
});
|
|
1734
1794
|
Object.assign(this._tree, value);
|
|
1735
1795
|
resolve({});
|
|
@@ -1765,7 +1825,7 @@ class VirtualTree {
|
|
|
1765
1825
|
}
|
|
1766
1826
|
while (stack.length) {
|
|
1767
1827
|
const node = stack.pop();
|
|
1768
|
-
if (hiddenKeys.has(node.key))
|
|
1828
|
+
if (hiddenKeys.has(node.key) || this._tree.hiddenNodeKeySet.has(node.key))
|
|
1769
1829
|
continue;
|
|
1770
1830
|
flattenNodes.push(node);
|
|
1771
1831
|
if (node.children && expandedKeys.has(node.key)) {
|
|
@@ -2011,7 +2071,7 @@ class VirtualTree {
|
|
|
2011
2071
|
content.style.setProperty('padding-left', `${(item.level - 1) * (config.indent || 0)}px`);
|
|
2012
2072
|
// 设备离线 - 字体颜色
|
|
2013
2073
|
if (['device', 'groupDevice'].includes(config.business)
|
|
2014
|
-
&&
|
|
2074
|
+
&& this._props.showStatus
|
|
2015
2075
|
&& item.data.dataType === 3
|
|
2016
2076
|
&& item.data.deviceStatus === 0) {
|
|
2017
2077
|
content.style.color = config.placeholderColor;
|
|
@@ -2071,28 +2131,33 @@ class VirtualTree {
|
|
|
2071
2131
|
let nodeClickCount = 0;
|
|
2072
2132
|
let isSelecting = false;
|
|
2073
2133
|
let isMouseDown = false;
|
|
2074
|
-
const nodeClickHandle = (e) => {
|
|
2075
|
-
|
|
2076
|
-
|
|
2077
|
-
|
|
2078
|
-
if (config.checkOnClickNode) {
|
|
2079
|
-
toggleCheckbox(item, !(isChecked(item) || isIndeterminate(item)), true, true);
|
|
2080
|
-
if (!config.expandOnClickNode || item.isLeaf) {
|
|
2081
|
-
this.refresh();
|
|
2082
|
-
}
|
|
2134
|
+
const nodeClickHandle = async (e) => {
|
|
2135
|
+
try {
|
|
2136
|
+
if (config.onNodeClick) {
|
|
2137
|
+
await config.onNodeClick(item.data, item, e);
|
|
2083
2138
|
}
|
|
2084
|
-
|
|
2085
|
-
|
|
2086
|
-
|
|
2087
|
-
|
|
2139
|
+
if (!getDisabled(config, item) && (isBoolean(showSelect)
|
|
2140
|
+
? showSelect
|
|
2141
|
+
: isFunction(showSelect) && showSelect(item.data, item))) {
|
|
2142
|
+
if (config.checkOnClickNode) {
|
|
2143
|
+
toggleCheckbox(item, !(isChecked(item) || isIndeterminate(item)), true, true);
|
|
2144
|
+
if (!config.expandOnClickNode || item.isLeaf) {
|
|
2145
|
+
this.refresh();
|
|
2146
|
+
}
|
|
2147
|
+
}
|
|
2148
|
+
else if (item.isLeaf && config.checkOnClickLeaf) {
|
|
2149
|
+
toggleCheckbox(item, !isChecked(item), true, true);
|
|
2150
|
+
if (!config.expandOnClickNode || item.isLeaf) {
|
|
2151
|
+
this.refresh();
|
|
2152
|
+
}
|
|
2088
2153
|
}
|
|
2089
2154
|
}
|
|
2155
|
+
if (config.expandOnClickNode && !item.isLeaf) {
|
|
2156
|
+
this._expandedHandle(item);
|
|
2157
|
+
this._refreshVirtualScroll();
|
|
2158
|
+
}
|
|
2090
2159
|
}
|
|
2091
|
-
|
|
2092
|
-
this._expandedHandle(item);
|
|
2093
|
-
this._refreshVirtualScroll();
|
|
2094
|
-
}
|
|
2095
|
-
config.onNodeClick && config.onNodeClick(item.data, item, e);
|
|
2160
|
+
catch { }
|
|
2096
2161
|
};
|
|
2097
2162
|
nodeContainer.addEventListener('mousedown', (e) => {
|
|
2098
2163
|
isSelecting = false;
|
|
@@ -2108,9 +2173,10 @@ class VirtualTree {
|
|
|
2108
2173
|
if (isSelecting)
|
|
2109
2174
|
return;
|
|
2110
2175
|
e.stopPropagation();
|
|
2111
|
-
if (getDisabled(config, item) ||
|
|
2176
|
+
if ((getDisabled(config, item) ||
|
|
2112
2177
|
item.isLeaf ||
|
|
2113
|
-
!config.checkOnDblclickParentNode)
|
|
2178
|
+
!config.checkOnDblclickParentNode) &&
|
|
2179
|
+
!config.onNodeDblClick) {
|
|
2114
2180
|
nodeClickHandle(e);
|
|
2115
2181
|
}
|
|
2116
2182
|
else {
|
|
@@ -2127,21 +2193,29 @@ class VirtualTree {
|
|
|
2127
2193
|
}
|
|
2128
2194
|
});
|
|
2129
2195
|
// 鼠标左键双击事件
|
|
2130
|
-
nodeContainer.addEventListener('dblclick', (e) => {
|
|
2196
|
+
nodeContainer.addEventListener('dblclick', async (e) => {
|
|
2131
2197
|
if (isSelecting)
|
|
2132
2198
|
return;
|
|
2133
2199
|
e.stopPropagation();
|
|
2134
|
-
|
|
2135
|
-
|
|
2136
|
-
!config.
|
|
2137
|
-
|
|
2138
|
-
|
|
2139
|
-
|
|
2140
|
-
|
|
2200
|
+
try {
|
|
2201
|
+
// 双击回调
|
|
2202
|
+
if (!getDisabled(config, item) && config.onNodeDblClick) {
|
|
2203
|
+
await config.onNodeDblClick(item.data, item, e);
|
|
2204
|
+
}
|
|
2205
|
+
if (getDisabled(config, item) ||
|
|
2206
|
+
item.isLeaf ||
|
|
2207
|
+
!config.checkOnDblclickParentNode ||
|
|
2208
|
+
!(isBoolean(showSelect)
|
|
2209
|
+
? showSelect
|
|
2210
|
+
: isFunction(showSelect) && showSelect(item.data, item))) {
|
|
2211
|
+
return;
|
|
2212
|
+
}
|
|
2213
|
+
nodeClickCount = 0;
|
|
2214
|
+
toggleCheckbox(item, !(isChecked(item) || isIndeterminate(item)), true, true, true);
|
|
2215
|
+
this.refresh();
|
|
2216
|
+
}
|
|
2217
|
+
catch {
|
|
2141
2218
|
}
|
|
2142
|
-
nodeClickCount = 0;
|
|
2143
|
-
toggleCheckbox(item, !(isChecked(item) || isIndeterminate(item)), true, true, true);
|
|
2144
|
-
this.refresh();
|
|
2145
2219
|
});
|
|
2146
2220
|
// 鼠标右键点击事件
|
|
2147
2221
|
nodeContainer.addEventListener('contextmenu', (e) => {
|
|
@@ -2192,6 +2266,7 @@ class VirtualTree {
|
|
|
2192
2266
|
let data;
|
|
2193
2267
|
if (!Array.isArray(config)) {
|
|
2194
2268
|
data = config.data;
|
|
2269
|
+
Object.assign(this._props, (config.props || {}));
|
|
2195
2270
|
Object.assign(this._businessConfig, config.businessConfig || {});
|
|
2196
2271
|
}
|
|
2197
2272
|
else {
|
|
@@ -2298,7 +2373,8 @@ class VirtualTree {
|
|
|
2298
2373
|
filter = (params, filterAll = true) => {
|
|
2299
2374
|
const { doFilter, hiddenExpandIconKeySet, hiddenNodeKeySet, isForceHiddenExpandIcon } = useFilter({
|
|
2300
2375
|
props: this._props,
|
|
2301
|
-
business: this._business
|
|
2376
|
+
business: this._business,
|
|
2377
|
+
businessConfig: this._businessConfig
|
|
2302
2378
|
}, this._filterMethod, this._tree);
|
|
2303
2379
|
const keys = doFilter(params, filterAll);
|
|
2304
2380
|
if (keys) {
|