hy-virtual-tree 1.1.27 → 1.1.29

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (3) hide show
  1. package/CHANGELOG.md +20 -0
  2. package/dist/index.js +205 -111
  3. package/package.json +1 -1
package/CHANGELOG.md CHANGED
@@ -1,5 +1,25 @@
1
1
  ## Changelog
2
2
 
3
+ ### 1.1.29
4
+
5
+ _2025-09-17_
6
+
7
+ - 扩展[VirtualTree] 功能
8
+ (1)修复开启 businessConfig.showOnlineState 时,隐藏的节点仍可被选中
9
+ (2)修复开启 businessConfig.showOnlineState 时,设备上下线不会同步更新勾选状态
10
+ (3)添加 businessConfig.sortByStatus,对设备在线和离线状态进行排序
11
+
12
+ ### 1.1.28
13
+
14
+ _2025-09-16_
15
+
16
+ - 扩展[VirtualTree] 功能
17
+ (1)添加 businessConfig.integratedBusiness,部门和群组会集成所有下级业务数据到 childrenDeviceList 字段
18
+ (2)添加 businessConfig.showOnlineState,仅显示在线设备,更新数据时也会同时更新展示列表
19
+ (3)setData方法添加 config.props 传参
20
+ (4)修改props.clearEmptyBusiness为businessConfig.clearEmptyBusiness
21
+ (5)修复异步渲染节点导致缓存节点判断错误问题
22
+
3
23
  ### 1.1.27
4
24
 
5
25
  _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
- cacheNodeMap = new Map();
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
- // this.contentContainer.innerHTML = ''
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 (this.cacheNodeMap.has(innerHTML)) {
138
- const target = this.cacheNodeMap.get(innerHTML);
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.cacheNodeMap.delete(innerHTML);
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
- for (const [key, value] of this.cacheNodeMap) {
164
- this.contentContainer.removeChild(value);
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,11 @@ const useConfig = (config) => {
408
422
  // 业务配置
409
423
  let businessConfig = {
410
424
  statusTextList: [],
411
- filterConfig: []
425
+ filterConfig: [],
426
+ sortByStatus: true,
427
+ clearEmptyBusiness: false,
428
+ integratedBusiness: false,
429
+ ...(config.businessConfig || {})
412
430
  };
413
431
  // 设备树
414
432
  if (['device', 'groupDevice'].includes(`${config.business}`)) {
@@ -424,6 +442,9 @@ const useConfig = (config) => {
424
442
  'SOS'
425
443
  ],
426
444
  filterConfig: [],
445
+ sortByStatus: true,
446
+ clearEmptyBusiness: false,
447
+ integratedBusiness: false,
427
448
  ...(config.businessConfig || {})
428
449
  };
429
450
  props = {
@@ -431,7 +452,6 @@ const useConfig = (config) => {
431
452
  disabled: 'disabled',
432
453
  showStatus: false,
433
454
  showCount: (data) => data.dataType !== 3,
434
- clearEmptyBusiness: false,
435
455
  ...(config.props || {}),
436
456
  value: 'onlyId',
437
457
  label: 'label',
@@ -455,7 +475,6 @@ const useConfig = (config) => {
455
475
  disabled: 'disabled',
456
476
  showStatus: false,
457
477
  showCount: false,
458
- clearEmptyBusiness: false,
459
478
  ...(config.props || {}),
460
479
  value: 'onlyId',
461
480
  label: 'label',
@@ -471,7 +490,6 @@ const useConfig = (config) => {
471
490
  disabled: 'disabled',
472
491
  showStatus: false,
473
492
  showCount: (data) => data.dataType !== 5,
474
- clearEmptyBusiness: false,
475
493
  ...(config.props || {}),
476
494
  value: 'onlyId',
477
495
  label: 'label',
@@ -487,7 +505,6 @@ const useConfig = (config) => {
487
505
  disabled: 'disabled',
488
506
  showStatus: false,
489
507
  showCount: false,
490
- clearEmptyBusiness: false,
491
508
  ...(config.props || {}),
492
509
  value: 'onlyId',
493
510
  label: 'label',
@@ -649,11 +666,15 @@ function useCheck(props, tree) {
649
666
  continue;
650
667
  nodes.forEach((node) => {
651
668
  const children = node.children;
669
+ if (tree.hiddenNodeKeySet.has(node.key))
670
+ return;
652
671
  if (children) {
653
672
  let allChecked = true;
654
673
  let hasChecked = false;
655
674
  for (const childNode of children) {
656
675
  const key = childNode.key;
676
+ if (tree.hiddenNodeKeySet.has(key))
677
+ continue;
657
678
  if (checkedKeySet.has(key)) {
658
679
  hasChecked = true;
659
680
  }
@@ -701,7 +722,7 @@ function useCheck(props, tree) {
701
722
  // 多选
702
723
  const toggle = (node, checked) => {
703
724
  // 对隐藏的节点不做处理
704
- if (hiddenNodeKeySet.has(node.key))
725
+ if (hiddenNodeKeySet.has(node.key) || tree.hiddenNodeKeySet.has(node.key))
705
726
  return;
706
727
  checkedKeySet[checked ? 'add' : 'delete'](node.key);
707
728
  const children = node.children;
@@ -950,6 +971,7 @@ function useCheck(props, tree) {
950
971
  isIndeterminate,
951
972
  // expose
952
973
  getChecked,
974
+ afterNodeCheck,
953
975
  getCheckedKeys,
954
976
  getCheckedNodes,
955
977
  getHalfCheckedKeys,
@@ -964,7 +986,8 @@ function useFilter(config, filterMethod, tree = {
964
986
  treeNodeMap: new Map(),
965
987
  levelTreeNodeMap: new Map(),
966
988
  treeNodes: [],
967
- maxLevel: 0
989
+ maxLevel: 0,
990
+ hiddenNodeKeySet: new Set()
968
991
  }) {
969
992
  const hiddenNodeKeySet = new Set([]);
970
993
  const hiddenExpandIconKeySet = new Set([]);
@@ -974,6 +997,7 @@ function useFilter(config, filterMethod, tree = {
974
997
  if (!isFunction(filterMethod)) {
975
998
  return;
976
999
  }
1000
+ const { integratedBusiness } = config.businessConfig;
977
1001
  const { getCount, getTotal, countFilter, totalFilter } = useHandleFun(config);
978
1002
  const isCountFiler = countFilter && isFunction(countFilter);
979
1003
  const isTotalFiler = totalFilter && isFunction(totalFilter);
@@ -984,21 +1008,39 @@ function useFilter(config, filterMethod, tree = {
984
1008
  const nodes = tree.treeNodes || [];
985
1009
  hiddenKeys.clear();
986
1010
  function traverse(nodes, isShow = false) {
1011
+ const deepBusinessList = [];
987
1012
  let count = 0;
988
1013
  let total = 0;
989
1014
  nodes.forEach((node) => {
1015
+ const businessList = [];
990
1016
  family.push(node);
1017
+ if (tree.hiddenNodeKeySet.has(node.key))
1018
+ return;
991
1019
  if (isShow || (filterMethod && filterMethod(params, node.data, node))) {
992
1020
  family.forEach((member) => {
993
1021
  expandKeySet.add(member.key);
994
1022
  });
1023
+ if (integratedBusiness && !/^1|4$/.test(node.data.dataType)) {
1024
+ businessList.push(node.data);
1025
+ deepBusinessList.push(node.data);
1026
+ }
995
1027
  }
996
1028
  else if (node.isLeaf) {
997
1029
  hiddenKeys.add(node.key);
998
1030
  }
999
1031
  const children = node.children;
1000
1032
  if (children) {
1001
- const { count: childCount, total: childTotal } = traverse(children, filterAll ? false : expandKeySet.has(node.key));
1033
+ const { count: childCount, total: childTotal, businessList: list2 } = traverse(children, filterAll ? false : expandKeySet.has(node.key));
1034
+ // 保存下层业务数据
1035
+ if (integratedBusiness) {
1036
+ for (const target of list2) {
1037
+ if (!/^1|4$/.test(target.dataType)) {
1038
+ businessList.push(target);
1039
+ deepBusinessList.push(target);
1040
+ }
1041
+ }
1042
+ node.data.childrenDeviceList = businessList;
1043
+ }
1002
1044
  node.count = isCountFiler ? childCount : getCount(node);
1003
1045
  node.total = isTotalFiler ? childTotal : getTotal(node);
1004
1046
  count += childCount;
@@ -1037,7 +1079,7 @@ function useFilter(config, filterMethod, tree = {
1037
1079
  }
1038
1080
  family.pop();
1039
1081
  });
1040
- return { count, total };
1082
+ return { count, total, businessList: deepBusinessList };
1041
1083
  }
1042
1084
  traverse(nodes);
1043
1085
  return expandKeySet;
@@ -1059,6 +1101,8 @@ function useFilter(config, filterMethod, tree = {
1059
1101
  let total = 0;
1060
1102
  nodes.forEach((node) => {
1061
1103
  family.push(node);
1104
+ if (tree.hiddenNodeKeySet.has(node.key))
1105
+ return;
1062
1106
  if (isShow || (filterMethod && filterMethod(params, node.data, node))) {
1063
1107
  family.forEach((member) => {
1064
1108
  expandKeySet.add(member.key);
@@ -1352,13 +1396,15 @@ function createBase64WorkerFactory(base64, sourcemapArg, enableUnicodeArg) {
1352
1396
  };
1353
1397
  }
1354
1398
 
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

');
1399
+ 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 { sortByStatus, 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[sortByStatus ? 1 : 0].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 { sortByStatus, 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[sortByStatus ? 1 : 0].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
1400
  /* eslint-enable */
1357
1401
 
1358
1402
  // 设备树
1359
1403
  function updateDeviceTree(tree, data, config) {
1360
1404
  const deviceMap = tree.deviceMap || new Map();
1405
+ let beOnlineList = [], beOfflineList = [];
1361
1406
  const { countFilter, totalFilter, setDeviceStatus } = useHandleFun(config);
1407
+ const { sortByStatus, showOnlineState, integratedBusiness } = config.businessConfig;
1362
1408
  // 更新父节点统计
1363
1409
  const updateParnetCount = (keySet) => {
1364
1410
  const isCountFiler = countFilter && isFunction(countFilter);
@@ -1372,24 +1418,39 @@ function updateDeviceTree(tree, data, config) {
1372
1418
  let total = isTotalFiler ? 0 : target.data.total;
1373
1419
  const deviceList = [[], []];
1374
1420
  if (isCountFiler || isTotalFiler) {
1421
+ const businessList = [];
1375
1422
  let children = target.children || [];
1376
1423
  for (let i = 0; i < children.length; i++) {
1377
1424
  const item = target.children[i];
1378
1425
  count =
1379
- isCountFiler && countFilter
1426
+ isCountFiler && !tree.hiddenNodeKeySet.has(item.key) && countFilter
1380
1427
  ? count + (item.children ? item.count : countFilter(item.data))
1381
1428
  : count;
1382
1429
  total =
1383
- isTotalFiler && totalFilter
1430
+ isTotalFiler && !tree.hiddenNodeKeySet.has(item.key) && totalFilter
1384
1431
  ? total + (item.children ? item.total : totalFilter(item.data))
1385
1432
  : total;
1386
1433
  if (item.data.deviceStatus === 0) {
1387
- deviceList[1].push(item);
1434
+ deviceList[sortByStatus ? 1 : 0].push(item);
1388
1435
  }
1389
1436
  else {
1390
1437
  deviceList[0].push(item);
1391
1438
  }
1439
+ // 更新下级设备列表
1440
+ if (integratedBusiness && !tree.hiddenNodeKeySet.has(item.key)) {
1441
+ if (/^(1|4)$/.test(item.data.dataType)) {
1442
+ businessList.push(...(item.data.childrenDeviceList || []));
1443
+ }
1444
+ else {
1445
+ businessList.push(item.data);
1446
+ }
1447
+ }
1392
1448
  }
1449
+ target.data.childrenDeviceList = businessList;
1450
+ }
1451
+ // 在仅显示设备时,切换显隐状态
1452
+ if (showOnlineState) {
1453
+ tree.hiddenNodeKeySet[count === 0 ? 'add' : 'delete'](target.key);
1393
1454
  }
1394
1455
  target.count = count;
1395
1456
  target.total = total;
@@ -1418,11 +1479,22 @@ function updateDeviceTree(tree, data, config) {
1418
1479
  deviceStatus: setDeviceStatus(v) // 设备状态
1419
1480
  })
1420
1481
  });
1482
+ // 在仅显示设备时,切换显隐状态
1483
+ if (showOnlineState) {
1484
+ if (target.data.deviceStatus === 0) {
1485
+ tree.hiddenNodeKeySet.add(target.key);
1486
+ beOfflineList.push(target);
1487
+ }
1488
+ else {
1489
+ tree.hiddenNodeKeySet.delete(target.key);
1490
+ beOnlineList.push(target);
1491
+ }
1492
+ }
1421
1493
  target.parent && parentKeySet.add(target.parent.key);
1422
1494
  });
1423
1495
  });
1424
1496
  updateParnetCount(parentKeySet);
1425
- return tree;
1497
+ return { tree, beOnlineList, beOfflineList };
1426
1498
  }
1427
1499
  // 用户树
1428
1500
  function updateUserTree(tree, data, config) {
@@ -1447,7 +1519,7 @@ function updateUserTree(tree, data, config) {
1447
1519
  });
1448
1520
  });
1449
1521
  });
1450
- return tree;
1522
+ return { tree };
1451
1523
  }
1452
1524
  // 采集站
1453
1525
  function updateCsTree(tree, data, config) {
@@ -1472,7 +1544,7 @@ function updateCsTree(tree, data, config) {
1472
1544
  });
1473
1545
  });
1474
1546
  });
1475
- return tree;
1547
+ return { tree };
1476
1548
  }
1477
1549
  const updateTreeMap = {
1478
1550
  // 设备树
@@ -1532,7 +1604,8 @@ class VirtualTree {
1532
1604
  deviceMap: new Map(),
1533
1605
  levelTreeNodeMap: new Map(),
1534
1606
  treeNodes: [],
1535
- maxLevel: 0
1607
+ maxLevel: 0,
1608
+ hiddenNodeKeySet: new Set()
1536
1609
  };
1537
1610
  _business;
1538
1611
  _expandedKeySet = new Set(); // 展开的key
@@ -1546,6 +1619,7 @@ class VirtualTree {
1546
1619
  _onNodeExpand;
1547
1620
  _onNodeCollapse;
1548
1621
  _getKey;
1622
+ _updateTree;
1549
1623
  _businessConfig = {};
1550
1624
  _isDestroy = false;
1551
1625
  getChecked;
@@ -1602,8 +1676,7 @@ class VirtualTree {
1602
1676
  label: this._props.label,
1603
1677
  children: this._props.children,
1604
1678
  count: this._props.count,
1605
- total: this._props.total,
1606
- clearEmptyBusiness: this._props.clearEmptyBusiness
1679
+ total: this._props.total
1607
1680
  },
1608
1681
  expandedKeySet: this._expandedKeySet,
1609
1682
  businessConfig: this._businessConfig
@@ -1675,84 +1748,12 @@ class VirtualTree {
1675
1748
  treeNodeMap,
1676
1749
  levelTreeNodeMap,
1677
1750
  maxLevel,
1678
- treeNodes: list
1751
+ treeNodes: list,
1752
+ hiddenNodeKeySet: new Set()
1679
1753
  });
1680
1754
  });
1681
1755
  };
1682
1756
  })();
1683
- _updateTree = (() => {
1684
- // 更新父节点统计
1685
- const updateParnetCount = (keySet) => {
1686
- if (!this._tree)
1687
- return;
1688
- const { countFilter, totalFilter } = useHandleFun({
1689
- props: this._props
1690
- });
1691
- const isCountFiler = countFilter && isFunction(countFilter);
1692
- const isTotalFiler = totalFilter && isFunction(totalFilter);
1693
- const parentKeySet = new Set();
1694
- for (const key of keySet) {
1695
- const target = this._tree.treeNodeMap.get(key);
1696
- if (!target)
1697
- continue;
1698
- let count = isCountFiler ? 0 : target.data.count;
1699
- let total = isTotalFiler ? 0 : target.data.total;
1700
- if (isCountFiler || isTotalFiler) {
1701
- for (let i = 0; i < target.children.length; i++) {
1702
- const item = target.children[i];
1703
- count =
1704
- isCountFiler && countFilter
1705
- ? count + (item.children ? item.count : countFilter(item.data))
1706
- : count;
1707
- total =
1708
- isTotalFiler && totalFilter
1709
- ? total + (item.children ? item.total : totalFilter(item.data))
1710
- : total;
1711
- }
1712
- }
1713
- target.count = count;
1714
- target.total = total;
1715
- target.parent && parentKeySet.add(target.parent.key);
1716
- }
1717
- parentKeySet.size && updateParnetCount(parentKeySet);
1718
- };
1719
- return (data) => {
1720
- return new Promise(async (resolve) => {
1721
- // 业务树更新
1722
- if (this._business) {
1723
- const updateMethod = updateTreeMap[this._business];
1724
- const value = updateMethod(this._tree, data, {
1725
- business: this._business,
1726
- props: {
1727
- value: this._props.value,
1728
- label: this._props.label,
1729
- children: this._props.children,
1730
- count: this._props.count,
1731
- total: this._props.total
1732
- }
1733
- });
1734
- Object.assign(this._tree, value);
1735
- resolve({});
1736
- return;
1737
- }
1738
- // 通用树更新
1739
- const { treeNodeMap } = await this._createTree(data);
1740
- const parentKeySet = new Set();
1741
- for (const [key, value] of treeNodeMap) {
1742
- const target = this._tree.treeNodeMap.get(key);
1743
- if (!target)
1744
- continue;
1745
- this._tree.treeNodeMap.set(key, Object.assign(target, {
1746
- data: value.data,
1747
- label: value.label
1748
- }));
1749
- target.parent && parentKeySet.add(target.parent.key);
1750
- }
1751
- updateParnetCount(parentKeySet);
1752
- resolve({});
1753
- });
1754
- };
1755
- })();
1756
1757
  /** 生成平铺树列表 */
1757
1758
  _genereateFlattenTree() {
1758
1759
  const expandedKeys = this._expandedKeySet;
@@ -1765,7 +1766,7 @@ class VirtualTree {
1765
1766
  }
1766
1767
  while (stack.length) {
1767
1768
  const node = stack.pop();
1768
- if (hiddenKeys.has(node.key))
1769
+ if (hiddenKeys.has(node.key) || this._tree.hiddenNodeKeySet.has(node.key))
1769
1770
  continue;
1770
1771
  flattenNodes.push(node);
1771
1772
  if (node.children && expandedKeys.has(node.key)) {
@@ -1870,7 +1871,7 @@ class VirtualTree {
1870
1871
  return;
1871
1872
  this._tree = await this._createTree(config.data);
1872
1873
  this._flattenTree = this._genereateFlattenTree();
1873
- const { checkedKeys, isIndeterminate, isChecked, toggleCheckbox, getChecked, getCheckedKeys, getCheckedNodes,
1874
+ const { checkedKeys, updateCheckedKeys, isIndeterminate, isChecked, toggleCheckbox, getChecked, afterNodeCheck, getCheckedKeys, getCheckedNodes,
1874
1875
  // getHalfCheckedKeys,
1875
1876
  // getHalfCheckedNodes,
1876
1877
  setChecked, setCheckedKeys, setCheckedNodes } = useCheck(config, this._tree);
@@ -2011,7 +2012,7 @@ class VirtualTree {
2011
2012
  content.style.setProperty('padding-left', `${(item.level - 1) * (config.indent || 0)}px`);
2012
2013
  // 设备离线 - 字体颜色
2013
2014
  if (['device', 'groupDevice'].includes(config.business)
2014
- && config.props.showStatus
2015
+ && this._props.showStatus
2015
2016
  && item.data.dataType === 3
2016
2017
  && item.data.deviceStatus === 0) {
2017
2018
  content.style.color = config.placeholderColor;
@@ -2139,7 +2140,7 @@ class VirtualTree {
2139
2140
  e.stopPropagation();
2140
2141
  try {
2141
2142
  // 双击回调
2142
- if (config.onNodeDblClick) {
2143
+ if (!getDisabled(config, item) && config.onNodeDblClick) {
2143
2144
  await config.onNodeDblClick(item.data, item, e);
2144
2145
  }
2145
2146
  if (getDisabled(config, item) ||
@@ -2188,6 +2189,97 @@ class VirtualTree {
2188
2189
  }
2189
2190
  });
2190
2191
  config.onLoad && config.onLoad();
2192
+ // @ts-ignore
2193
+ // 更新函数
2194
+ this._updateTree = (() => {
2195
+ // 更新父节点统计
2196
+ const updateParnetCount = (keySet) => {
2197
+ if (!this._tree)
2198
+ return;
2199
+ const { countFilter, totalFilter } = useHandleFun({
2200
+ props: this._props
2201
+ });
2202
+ const isCountFiler = countFilter && isFunction(countFilter);
2203
+ const isTotalFiler = totalFilter && isFunction(totalFilter);
2204
+ const parentKeySet = new Set();
2205
+ for (const key of keySet) {
2206
+ const target = this._tree.treeNodeMap.get(key);
2207
+ if (!target)
2208
+ continue;
2209
+ let count = isCountFiler ? 0 : target.data.count;
2210
+ let total = isTotalFiler ? 0 : target.data.total;
2211
+ if (isCountFiler || isTotalFiler) {
2212
+ for (let i = 0; i < target.children.length; i++) {
2213
+ const item = target.children[i];
2214
+ count =
2215
+ isCountFiler && countFilter
2216
+ ? count + (item.children ? item.count : countFilter(item.data))
2217
+ : count;
2218
+ total =
2219
+ isTotalFiler && totalFilter
2220
+ ? total + (item.children ? item.total : totalFilter(item.data))
2221
+ : total;
2222
+ }
2223
+ }
2224
+ target.count = count;
2225
+ target.total = total;
2226
+ target.parent && parentKeySet.add(target.parent.key);
2227
+ }
2228
+ parentKeySet.size && updateParnetCount(parentKeySet);
2229
+ };
2230
+ return (data) => {
2231
+ return new Promise(async (resolve, reject) => {
2232
+ // 业务树更新
2233
+ if (this._business) {
2234
+ const updateMethod = updateTreeMap[this._business];
2235
+ if (!updateMethod) {
2236
+ reject({});
2237
+ return;
2238
+ }
2239
+ const { tree, beOfflineList } = updateMethod(this._tree, data, {
2240
+ business: this._business,
2241
+ props: {
2242
+ value: this._props.value,
2243
+ label: this._props.label,
2244
+ children: this._props.children,
2245
+ count: this._props.count,
2246
+ total: this._props.total
2247
+ },
2248
+ businessConfig: this._businessConfig
2249
+ });
2250
+ Object.assign(this._tree, tree);
2251
+ let updateNode = null;
2252
+ for (const node of (beOfflineList || [])) {
2253
+ if (checkedKeys.has(node.key)) {
2254
+ checkedKeys.delete(node.key);
2255
+ updateNode = node;
2256
+ }
2257
+ }
2258
+ updateCheckedKeys();
2259
+ if (updateNode) {
2260
+ afterNodeCheck(updateNode, false);
2261
+ }
2262
+ resolve({});
2263
+ return;
2264
+ }
2265
+ // 通用树更新
2266
+ const { treeNodeMap } = await this._createTree(data);
2267
+ const parentKeySet = new Set();
2268
+ for (const [key, value] of treeNodeMap) {
2269
+ const target = this._tree.treeNodeMap.get(key);
2270
+ if (!target)
2271
+ continue;
2272
+ this._tree.treeNodeMap.set(key, Object.assign(target, {
2273
+ data: value.data,
2274
+ label: value.label
2275
+ }));
2276
+ target.parent && parentKeySet.add(target.parent.key);
2277
+ }
2278
+ updateParnetCount(parentKeySet);
2279
+ resolve({});
2280
+ });
2281
+ };
2282
+ })();
2191
2283
  }
2192
2284
  /** 全量更新数据 */
2193
2285
  setData = (() => {
@@ -2206,6 +2298,7 @@ class VirtualTree {
2206
2298
  let data;
2207
2299
  if (!Array.isArray(config)) {
2208
2300
  data = config.data;
2301
+ Object.assign(this._props, (config.props || {}));
2209
2302
  Object.assign(this._businessConfig, config.businessConfig || {});
2210
2303
  }
2211
2304
  else {
@@ -2228,7 +2321,7 @@ class VirtualTree {
2228
2321
  const cacheInterval = 500;
2229
2322
  let cacheData = [];
2230
2323
  return async (data, callback) => {
2231
- if (!this._tree)
2324
+ if (!this._tree || !this._updateTree)
2232
2325
  return;
2233
2326
  cacheTimer && clearTimeout(cacheTimer);
2234
2327
  if (Array.isArray(data)) {
@@ -2242,7 +2335,7 @@ class VirtualTree {
2242
2335
  // cacheInterval毫秒仅更新一次数据
2243
2336
  if (Date.now() - cacheTime >= cacheInterval) {
2244
2337
  cacheTime = Date.now();
2245
- this._updateTree([...cacheData]);
2338
+ await this._updateTree([...cacheData]);
2246
2339
  cacheData = [];
2247
2340
  this._refreshVirtualScroll();
2248
2341
  callback && callback();
@@ -2312,7 +2405,8 @@ class VirtualTree {
2312
2405
  filter = (params, filterAll = true) => {
2313
2406
  const { doFilter, hiddenExpandIconKeySet, hiddenNodeKeySet, isForceHiddenExpandIcon } = useFilter({
2314
2407
  props: this._props,
2315
- business: this._business
2408
+ business: this._business,
2409
+ businessConfig: this._businessConfig
2316
2410
  }, this._filterMethod, this._tree);
2317
2411
  const keys = doFilter(params, filterAll);
2318
2412
  if (keys) {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "hy-virtual-tree",
3
- "version": "1.1.27",
3
+ "version": "1.1.29",
4
4
  "type": "module",
5
5
  "scripts": {
6
6
  "dev": "vite",