hy-virtual-tree 1.1.67 → 1.1.69

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -1,5 +1,22 @@
1
1
  ## Changelog
2
2
 
3
+ ### 1.1.69
4
+
5
+ _2026-01-29_
6
+
7
+ - 扩展[VirtualTree] 功能
8
+ (1)修复 channel业务 下,设备在线,而设备下全部通道离线,而设备无法选中问题
9
+ (2)完善 channel业务 下,设备在线,而设备下全部通道离线,选中设备后,此时通道上线,会将通道也选中,并且触发选中事件
10
+ (3)新增 tooltip.props 全局配置项
11
+
12
+ ### 1.1.68
13
+
14
+ _2026-01-23_
15
+
16
+ - 扩展[VirtualTree] 功能
17
+ (1)新增 setGlobalTreeConfig、getGlobalTreeConfig 全局配置项
18
+ (2)优化 tooltip 的性能
19
+
3
20
  ### 1.1.67
4
21
 
5
22
  _2026-01-23_
package/dist/index.css CHANGED
@@ -1,21 +1,33 @@
1
1
  .hy-tooltip {
2
+ --hy-tooltip-max-width: 600px;
3
+ --hy-tooltip-color: #fff;
4
+ --hy-tooltip-size: 12px;
5
+ --hy-tooltip-weight: 400;
6
+ --hy-tooltip-leading: 20px;
2
7
  --hy-tooltip-bg: #1C324B;
8
+ --hy-tooltip-border-width: 1px;
9
+ --hy-tooltip-border-color: #375C86;
10
+ --hy-tooltip-border-radius: 4px;
11
+ --hy-tooltip-padding: 7px 9px;
12
+ --hy-tooltip-z-index: 3200;
3
13
  position: absolute;
4
- border-radius: 4px;
5
- padding: 7px 9px;
6
- z-index: 3200;
7
- font-size: 12px;
8
- line-height: 20px;
9
14
  min-width: 10px;
15
+ max-width: var(--hy-tooltip-max-width);
16
+ font-size: var(--hy-tooltip-size);
17
+ font-weight: var(--hy-tooltip-weight);
18
+ line-height: var(--hy-tooltip-leading);
19
+ border-radius: var(--hy-tooltip-border-radius);
10
20
  overflow-wrap: break-word;
11
21
  word-break: normal;
12
22
  visibility: visible;
13
- color: #fff;
23
+ color: var(--hy-tooltip-color);
14
24
  background: var(--hy-tooltip-bg);
15
- border: 1px solid #375C86;
16
- transform: translateX(-50%) translateY(calc(-100% - 10px));
25
+ border: var(--hy-tooltip-border-width) solid var(--hy-tooltip-border-color);
26
+ z-index: var(--hy-tooltip-z-index);
27
+ padding: var(--hy-tooltip-padding);
17
28
  opacity: 0;
18
29
  transition: opacity 0.2s linear;
30
+ transform: translateX(-50%) translateY(calc(-100% - 10px));
19
31
  }
20
32
  .hy-tooltip.hy-tooltip-show {
21
33
  opacity: 1;
@@ -23,11 +35,11 @@
23
35
  .hy-tooltip.top .hy-popper__arrow {
24
36
  left: 50%;
25
37
  bottom: 0;
26
- transform: translateY(50%) translateX(-50%);
27
38
  }
28
39
  .hy-tooltip.top .hy-popper__arrow::before {
29
- border-right: 1px solid #375C86;
30
- border-bottom: 1px solid #375C86;
40
+ border-right: var(--hy-tooltip-border-width) solid var(--hy-tooltip-border-color);
41
+ border-bottom: var(--hy-tooltip-border-width) solid var(--hy-tooltip-border-color);
42
+ transform: rotate(45deg) translate(-50%, 0);
31
43
  }
32
44
  .hy-tooltip.bottom {
33
45
  transform: translateX(-50%) translateY(10px);
@@ -35,11 +47,11 @@
35
47
  .hy-tooltip.bottom .hy-popper__arrow {
36
48
  top: 0;
37
49
  left: 50%;
38
- transform: translateY(-50%) translateX(-50%);
39
50
  }
40
51
  .hy-tooltip.bottom .hy-popper__arrow::before {
41
- border-top: 1px solid #375C86;
42
- border-left: 1px solid #375C86;
52
+ border-top: var(--hy-tooltip-border-width) solid var(--hy-tooltip-border-color);
53
+ border-left: var(--hy-tooltip-border-width) solid var(--hy-tooltip-border-color);
54
+ transform: rotate(45deg) translate(-50%, -45%);
43
55
  }
44
56
  .hy-tooltip.left {
45
57
  transform: translateX(calc(-100% - 10px)) translateY(-50%);
@@ -47,11 +59,11 @@
47
59
  .hy-tooltip.left .hy-popper__arrow {
48
60
  top: 50%;
49
61
  right: 0;
50
- transform: translateY(-50%) translateX(50%);
51
62
  }
52
63
  .hy-tooltip.left .hy-popper__arrow::before {
53
- border-right: 1px solid #375C86;
54
- border-top: 1px solid #375C86;
64
+ border-right: var(--hy-tooltip-border-width) solid var(--hy-tooltip-border-color);
65
+ border-top: var(--hy-tooltip-border-width) solid var(--hy-tooltip-border-color);
66
+ transform: rotate(45deg) translate(-50%, 0%);
55
67
  }
56
68
  .hy-tooltip.right {
57
69
  transform: translateX(10px) translateY(-50%);
@@ -59,23 +71,23 @@
59
71
  .hy-tooltip.right .hy-popper__arrow {
60
72
  top: 50%;
61
73
  left: 0;
62
- transform: translateY(-50%) translateX(-50%);
63
74
  }
64
75
  .hy-tooltip.right .hy-popper__arrow::before {
65
- border-left: 1px solid #375C86;
66
- border-bottom: 1px solid #375C86;
76
+ border-left: var(--hy-tooltip-border-width) solid var(--hy-tooltip-border-color);
77
+ border-bottom: var(--hy-tooltip-border-width) solid var(--hy-tooltip-border-color);
78
+ transform: rotate(45deg) translate(-85%, 0%);
67
79
  }
68
80
  .hy-tooltip .hy-popper__arrow {
69
81
  position: absolute;
70
- width: 10px;
71
- height: 10px;
72
82
  z-index: -1;
73
83
  }
74
84
  .hy-tooltip .hy-popper__arrow::before {
85
+ --width: calc(var(--hy-tooltip-border-width) * 2 + 8px);
75
86
  position: absolute;
76
- width: 10px;
77
- height: 10px;
87
+ width: var(--width);
88
+ height: var(--width);
78
89
  z-index: -1;
90
+ display: block;
79
91
  content: " ";
80
92
  transform: rotate(45deg);
81
93
  background: var(--hy-tooltip-bg);
package/dist/index.js CHANGED
@@ -156,6 +156,94 @@ const setElementFocus = (config) => {
156
156
  };
157
157
  };
158
158
 
159
+ // 设备配置
160
+ let deviceConfig = {
161
+ status: {
162
+ 0: '离线',
163
+ 1: '在线',
164
+ 2: '监控中',
165
+ 3: '通话中',
166
+ 4: '录像中',
167
+ 5: '录音中',
168
+ 6: '广播中',
169
+ 7: 'SOS',
170
+ 8: '音频中',
171
+ }
172
+ };
173
+ // 获取全局设备状态
174
+ const getGlobalDeviceConfig = () => {
175
+ return deviceConfig;
176
+ };
177
+ // 设置全局设备状态
178
+ const setGlobalDeviceConfig = (config) => {
179
+ if (config?.status) {
180
+ deviceConfig.status = {
181
+ ...deviceConfig.status,
182
+ ...config.status
183
+ };
184
+ }
185
+ };
186
+ // tooltip配置
187
+ let tooltipConfig = {
188
+ style: {
189
+ maxWidth: '600px',
190
+ color: '#fff',
191
+ fontSize: '12px',
192
+ fontWeight: '400',
193
+ lineHeight: '20px',
194
+ background: '#1C324B',
195
+ borderWidth: '2px',
196
+ borderColor: '#375C86',
197
+ borderRadius: '4px',
198
+ padding: '7px 9px',
199
+ zIndex: 3200
200
+ },
201
+ props: {
202
+ // 偏移距离
203
+ offset: 0,
204
+ }
205
+ };
206
+ // 获取tooltip配置
207
+ const getGlobalTooltipConfig = () => {
208
+ return tooltipConfig;
209
+ };
210
+ // 设置tooltip配置
211
+ const setGlobalTooltipConfig = (config) => {
212
+ if (config?.style) {
213
+ tooltipConfig.style = {
214
+ ...tooltipConfig.style,
215
+ ...config.style
216
+ };
217
+ }
218
+ if (config?.props) {
219
+ const { offset } = config.props;
220
+ if (typeof offset === 'number') {
221
+ tooltipConfig.props.offset = offset;
222
+ }
223
+ }
224
+ };
225
+ // 获取全局的配置
226
+ const getGlobalTreeConfig = () => {
227
+ return {
228
+ deviceConfig: getGlobalDeviceConfig(),
229
+ tooltipConfig: getGlobalTooltipConfig()
230
+ };
231
+ };
232
+ /**
233
+ * 设置全局的配置
234
+ * @param config { device, tooltip }
235
+ */
236
+ const setGlobalTreeConfig = (config) => {
237
+ if (!config)
238
+ return;
239
+ if (isObject(config.device?.status)) {
240
+ setGlobalDeviceConfig(config.device);
241
+ }
242
+ if (isObject(config.tooltip)) {
243
+ setGlobalTooltipConfig(config.tooltip);
244
+ }
245
+ };
246
+
159
247
  let container;
160
248
  let closeActiveTooltip;
161
249
  const getContainer$1 = () => {
@@ -165,6 +253,19 @@ const getContainer$1 = () => {
165
253
  document.body.appendChild(container);
166
254
  return container;
167
255
  };
256
+ const styleVar = {
257
+ maxWidth: '--hy-tooltip-max-width',
258
+ color: '--hy-tooltip-color',
259
+ fontSize: '--hy-tooltip-size',
260
+ fontWeight: '--hy-tooltip-weight',
261
+ lineHeight: '--hy-tooltip-leading',
262
+ background: '--hy-tooltip-bg',
263
+ borderWidth: '--hy-tooltip-border-width',
264
+ borderColor: '--hy-tooltip-border-color',
265
+ borderRadius: '--hy-tooltip-border-radius',
266
+ padding: '--hy-tooltip-padding',
267
+ zIndex: '--hy-tooltip-z-index',
268
+ };
168
269
  class Tooltip {
169
270
  _el;
170
271
  _config;
@@ -172,6 +273,7 @@ class Tooltip {
172
273
  _timer;
173
274
  _openTimer;
174
275
  _closeTimer;
276
+ _style = getGlobalTooltipConfig().style;
175
277
  constructor(props) {
176
278
  if (!props.bind || !isElement(props.bind))
177
279
  throw Error('【bind参数错误】:请传入元素节点');
@@ -193,27 +295,38 @@ class Tooltip {
193
295
  return;
194
296
  const { bind, content } = this._config;
195
297
  const el = document.createElement('div');
298
+ this._setTooltipStyle(el);
196
299
  el.classList.add('hy-tooltip');
300
+ const span = document.createElement('span');
301
+ el.appendChild(span);
197
302
  if (isElement(content)) {
198
- el.appendChild(content);
303
+ span.appendChild(content);
199
304
  }
200
305
  else {
201
- el.innerHTML = `${content}`;
306
+ span.innerHTML = `${content}`;
202
307
  }
203
- const arrow = document.createElement('span');
308
+ const arrow = document.createElement('div');
204
309
  arrow.classList.add('hy-popper__arrow');
205
310
  el.appendChild(arrow);
206
311
  this._el = el;
207
- el.addEventListener('mouseenter', () => {
208
- this._focus && this._focus.focus();
312
+ let isHover = false;
313
+ el.addEventListener('mouseenter', (e) => {
314
+ if (isHover)
315
+ return;
316
+ isHover = true;
317
+ this._closeTimer && clearTimeout(this._closeTimer);
318
+ this.setPopper();
209
319
  });
210
- el.addEventListener('mouseleave', () => {
211
- this._focus && this._focus.blur();
320
+ el.addEventListener('mouseleave', (e) => {
321
+ isHover = false;
322
+ this.hide();
212
323
  });
213
324
  this._focus = setElementFocus({
214
325
  container: bind,
215
326
  trigger: this._config.trigger === 'click' ? 'click' : 'hover',
216
327
  onFocus: () => {
328
+ if (isHover)
329
+ return;
217
330
  closeActiveTooltip && closeActiveTooltip();
218
331
  if (!this._el || !this._config)
219
332
  return;
@@ -241,6 +354,8 @@ class Tooltip {
241
354
  }, this._config.openDelay || 0);
242
355
  },
243
356
  onBlur: () => {
357
+ if (isHover)
358
+ return;
244
359
  this._openTimer && clearTimeout(this._openTimer);
245
360
  this._closeTimer && clearTimeout(this._closeTimer);
246
361
  this._timer && clearTimeout(this._timer);
@@ -248,6 +363,17 @@ class Tooltip {
248
363
  }
249
364
  });
250
365
  }
366
+ _setTooltipStyle(el) {
367
+ if (!el || !this._style)
368
+ return;
369
+ Object.keys(this._style).forEach((styleKey) => {
370
+ // @ts-ignore
371
+ const value = this._style[styleKey];
372
+ // @ts-ignore
373
+ const key = styleVar[styleKey];
374
+ el.style.setProperty(key, value);
375
+ });
376
+ }
251
377
  setPopper() {
252
378
  if (!this._config || !this._el)
253
379
  return;
@@ -817,28 +943,6 @@ class Radio {
817
943
  }
818
944
  }
819
945
 
820
- // 设备状态列表
821
- let globalDeviceStatus = {
822
- 0: '离线',
823
- 1: '在线',
824
- 2: '监控中',
825
- 3: '通话中',
826
- 4: '录像中',
827
- 5: '录音中',
828
- 6: '广播中',
829
- 7: 'SOS',
830
- 8: '音频中',
831
- };
832
- const setGlobalDeviceStatus = (status = {}) => {
833
- globalDeviceStatus = {
834
- ...globalDeviceStatus,
835
- ...status,
836
- };
837
- };
838
- const getGlobalDeviceStatus = () => {
839
- return globalDeviceStatus;
840
- };
841
-
842
946
  // 业务类型(config.business) device-设备 channel-通道设备 groupDevice-群组设备 group-群组 user-用户 cs-采集站
843
947
  var Business;
844
948
  (function (Business) {
@@ -913,7 +1017,7 @@ const useConfig = (config) => {
913
1017
  // 设备树
914
1018
  if ([Business.DEVICE, Business.CHANNEL, Business.GROUP_DEVICE].includes(config.business)) {
915
1019
  businessConfig = {
916
- deviceStatusMap: getGlobalDeviceStatus(),
1020
+ deviceStatusMap: getGlobalDeviceConfig().status,
917
1021
  filterConfig: [],
918
1022
  sortByStatus: true,
919
1023
  clearEmptyBusiness: false,
@@ -1170,9 +1274,18 @@ const isShowSelect = (config, node = null) => {
1170
1274
  return !!(isFunction(showSelect) && showSelect(node.data, node));
1171
1275
  };
1172
1276
  const isCheckLeaf = (config, node) => {
1173
- if (config.business !== Business.CHANNEL || config.businessConfig.isShowChannelSelect)
1277
+ // 非通道业务
1278
+ if (config.business !== Business.CHANNEL)
1174
1279
  return node.isLeaf;
1175
- return node.data.dataType === 3 ? true : node.isLeaf;
1280
+ // 未开启通道可选中
1281
+ if (!config.businessConfig.isShowChannelSelect) {
1282
+ return node.data.dataType === 3 ? true : node.isLeaf;
1283
+ }
1284
+ // 仅显示在线数据
1285
+ if (config.businessConfig?.showOnlineState) {
1286
+ return node.data.dataType === 3 && !node.count ? true : node.isLeaf;
1287
+ }
1288
+ return node.isLeaf;
1176
1289
  };
1177
1290
  function useCheck(props, instance) {
1178
1291
  const tree = instance._tree;
@@ -1971,7 +2084,7 @@ const useIcon = (config, data, node) => {
1971
2084
  }
1972
2085
  // 通道
1973
2086
  else if (config.business === Business.CHANNEL && data.dataType === 9) {
1974
- const globalDeviceStatus = getGlobalDeviceStatus();
2087
+ const { status: globalDeviceStatus } = getGlobalDeviceConfig();
1975
2088
  // 在线
1976
2089
  let extendName = '', tip = globalDeviceStatus[1];
1977
2090
  // 离线
@@ -2032,7 +2145,7 @@ function createBase64WorkerFactory(base64, sourcemapArg, enableUnicodeArg) {
2032
2145
  };
2033
2146
  }
2034
2147
 
2035
- var WorkerFactory = /*#__PURE__*/createBase64WorkerFactory('/* rollup-plugin-web-worker-loader */
(function () {
  'use strict';

  // 业务类型(config.business) device-设备 channel-通道设备 groupDevice-群组设备 group-群组 user-用户 cs-采集站
  var Business;
  (function (Business) {
      Business["DEVICE"] = "device";
      Business["CHANNEL"] = "channel";
      Business["GROUP_DEVICE"] = "groupDevice";
      Business["GROUP"] = "group";
      Business["USER"] = "user";
      Business["TEAM_USER"] = "teamUser";
      Business["CS"] = "cs";
  })(Business || (Business = {}));
  // 设备状态(data.deviceStatus) 0-离线 1-在线 2-监控中 3-通话中 4-录像中 5-录音中 6-广播中 7-SOS 8-音频中
  var DeviceStatus;
  (function (DeviceStatus) {
      DeviceStatus[DeviceStatus["OFF_LINE"] = 0] = "OFF_LINE";
      DeviceStatus[DeviceStatus["ON_LINE"] = 1] = "ON_LINE";
      DeviceStatus[DeviceStatus["BE_MONITOR"] = 2] = "BE_MONITOR";
      DeviceStatus[DeviceStatus["IN_CALL"] = 3] = "IN_CALL";
      DeviceStatus[DeviceStatus["IN_VIDEO_RECORD"] = 4] = "IN_VIDEO_RECORD";
      DeviceStatus[DeviceStatus["IN_AUDIO_RECORD"] = 5] = "IN_AUDIO_RECORD";
      DeviceStatus[DeviceStatus["IN_BROADCASE"] = 6] = "IN_BROADCASE";
      DeviceStatus[DeviceStatus["SOS"] = 7] = "SOS";
      DeviceStatus[DeviceStatus["INTERCOM_CALL"] = 8] = "INTERCOM_CALL";
  })(DeviceStatus || (DeviceStatus = {}));
  // 业务数据类型(data.dataType) 1-部门 3-设备 4-群组 5-用户 6-考勤 7-水源点 8-采集站 9-设备通道 10-队伍
  var DataType;
  (function (DataType) {
      DataType[DataType["UNKNOW_1"] = 0] = "UNKNOW_1";
      DataType[DataType["DEPT"] = 1] = "DEPT";
      DataType[DataType["UNKNOW_2"] = 2] = "UNKNOW_2";
      DataType[DataType["DEVICE"] = 3] = "DEVICE";
      DataType[DataType["GROUP"] = 4] = "GROUP";
      DataType[DataType["USER"] = 5] = "USER";
      DataType[DataType["ATTENDANCE"] = 6] = "ATTENDANCE";
      DataType[DataType["WATER_SOURCE"] = 7] = "WATER_SOURCE";
      DataType[DataType["CS"] = 8] = "CS";
      DataType[DataType["CHANNEL"] = 9] = "CHANNEL";
      DataType[DataType["TEAM"] = 10] = "TEAM";
  })(DataType || (DataType = {}));

  /** 生成处理函数 */
  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 (node.dataType) {
                  case DataType.DEPT: // 部门
                  case DataType.GROUP: // 群组
                  case DataType.TEAM: // 队伍
                  case DataType.USER: // 用户
                  case DataType.CS: // 采集站
                      return node.id;
                  case DataType.DEVICE: // 设备
                      return node.deviceId;
                  case DataType.CHANNEL: // 设备通道
                      return node.channelId;
              }
          }
          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 (business && [Business.DEVICE, Business.CHANNEL, Business.GROUP_DEVICE].includes(business)) {
          countFilter = (data) => {
              return data.dataType === DataType.DEVICE && data.onlineState === 1;
          };
          totalFilter = (data) => {
              return data.dataType === DataType.DEVICE;
          };
      }
      else if (business && [Business.USER, Business.TEAM_USER].includes(business)) {
          countFilter = totalFilter = (data) => {
              return data.dataType === DataType.USER;
          };
      }
      else if (business === Business.CS) {
          countFilter = totalFilter = (data) => {
              return data.dataType === DataType.CS;
          };
      }
      return {
          getKey,
          getLabel,
          getChildren,
          getCount,
          getTotal,
          countFilter,
          totalFilter,
          getNodeData,
          // 设置设备状态
          setDeviceStatus: (data) => {
              // 通道状态
              if (data.dataType === DataType.CHANNEL) {
                  if (data.onlineState === 1) {
                      // 监控中
                      if (data.beMonitor === 1) {
                          return DeviceStatus.BE_MONITOR;
                      }
                      // 在线
                      return DeviceStatus.ON_LINE;
                  }
                  // 离线
                  return DeviceStatus.OFF_LINE;
              }
              // 设备状态
              if (data.onlineState === 1) {
                  if (data.intercomGroupTem === 1 || data.intercomCall === 1) {
                      // 音频中
                      return DeviceStatus.INTERCOM_CALL;
                  }
                  // 监控中
                  if (data.monitor === 1 || data.beMonitor === 1) {
                      return DeviceStatus.BE_MONITOR;
                  }
                  // 通话中
                  if (data.videoCall === 1) {
                      return DeviceStatus.IN_CALL;
                  }
                  // 录像中
                  if (data.videoRecording === 1) {
                      return DeviceStatus.IN_VIDEO_RECORD;
                  }
                  // 录音中
                  if (data.audioRecording === 1) {
                      return DeviceStatus.IN_AUDIO_RECORD;
                  }
                  // 广播中
                  if (data.broadcast === 1) {
                      return DeviceStatus.IN_BROADCASE;
                  }
                  // SOS
                  if (data.sos === 1) {
                      return DeviceStatus.SOS;
                  }
                  // 在线
                  return DeviceStatus.ON_LINE;
              }
              // 离线
              return DeviceStatus.OFF_LINE;
          }
      };
  };
  /** 获取节点数据 */
  const getNodeData = (node) => {
      if (node.data.dataType === DataType.CHANNEL) {
          return {
              ...node.parent.data,
              ...node.data
          };
      }
      return node.data;
  };

  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 } = 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 = [];
              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[sortByStatus ? 1 : 0].push(target);
                                      if (showOnlineState) {
                                          hiddenNodeKeySet.add(getKey(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 (showOnlineState) {
                      if (!children || children.length === 0 && rawNode.dataType !== 3) {
                          hiddenNodeKeySet.add(node.key);
                      }
                  }
                  if (children && children.length) {
                      const { list, count: childCount, total: childTotal } = traverse(children, level + 1, node);
                      // 过滤没有用户的部门 步骤二
                      if (!showOnlineState && clearEmptyBusiness && childTotal === 0) {
                          continue;
                      }
                      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 };
          };
          const { list } = traverse(data || []);
          const treeNodes = list;
          return {
              treeNodeMap,
              deviceMap,
              levelTreeNodeMap,
              maxLevel,
              treeNodes,
              hiddenNodeKeySet
          };
      }
      return createDeviceTree(data);
  }
  // 通道设备树结构
  function generateChannelDeviceTree(data, config) {
      const { expandedKeySet } = config;
      const { sortByStatus, showOnlineState, clearEmptyBusiness } = 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 channelMap = new Map();
          const hiddenNodeKeySet = new Set();
          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 !== DataType.DEVICE) {
                      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: DataType.DEVICE, // 代表设备
                                  deviceStatus: setDeviceStatus(v) // 设备状态
                              };
                              if (useFilterConfig(target, filterList)) {
                                  if (target.deviceStatus === DeviceStatus.OFF_LINE) {
                                      deviceList[sortByStatus ? 1 : 0].push(target);
                                      if (showOnlineState) {
                                          hiddenNodeKeySet.add(getKey(target));
                                      }
                                  }
                                  else {
                                      deviceList[0].push(target);
                                  }
                              }
                          });
                          children = [...children, ...deviceList[0], ...deviceList[1]];
                      }
                      rawNode = {
                          ...rawNode,
                          children,
                          onlyId: rawNode.id,
                          dataType: DataType.DEPT, // 部门
                          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,
                      label: getLabel(rawNode),
                      parent,
                      expanded: expandedKeySet.has(value)
                  };
                  // 隐藏没有在线设备的部门和群组
                  if (showOnlineState) {
                      if (!children || children.length === 0 && rawNode.dataType !== DataType.DEVICE) {
                          hiddenNodeKeySet.add(node.key);
                      }
                  }
                  // 非设备类型数据
                  if (rawNode.dataType !== DataType.DEVICE && children && children.length) {
                      const { list, count: childCount, total: childTotal } = traverse(children, level + 1, node);
                      // 过滤没有用户的部门 步骤二
                      if (!showOnlineState && clearEmptyBusiness && childTotal === 0) {
                          continue;
                      }
                      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;
                          }
                      }
                  }
                  // 设备类型数据，且有通道数据处理
                  if (rawNode.dataType === DataType.DEVICE && rawNode.videoChannelList?.length) {
                      const channelLevel = level + 1;
                      if (!levelTreeNodeMap.has(channelLevel)) {
                          levelTreeNodeMap.set(channelLevel, []);
                      }
                      const channelList = [[], []];
                      let channelOnlineCount = 0;
                      let hasBeMonitor = false;
                      rawNode.videoChannelList.forEach((c) => {
                          const channel = {
                              key: rawNode.onlyId + '-' + c.channelId,
                              label: c.channelName || c.channelId,
                              level: level + 1,
                              count: 0,
                              total: 0,
                              expanded: false,
                              isLeaf: true,
                              data: {
                                  ...c,
                                  deviceId: rawNode.deviceId,
                                  devName: rawNode.devName || rawNode.deviceId,
                                  onlyId: rawNode.onlyId + '-' + c.channelId,
                                  label: c.channelName || c.channelId,
                                  dataType: DataType.CHANNEL, // 代表通道
                                  deviceStatus: setDeviceStatus(c) // 设备通道状态
                              },
                              parent: node,
                          };
                          hasBeMonitor = hasBeMonitor || channel.data.deviceStatus === DeviceStatus.BE_MONITOR;
                          if (channel.data.deviceStatus === DeviceStatus.OFF_LINE) {
                              channelList[sortByStatus ? 1 : 0].push(channel);
                              if (showOnlineState) {
                                  hiddenNodeKeySet.add(channel.key);
                              }
                          }
                          else {
                              channelOnlineCount++;
                              channelList[0].push(channel);
                          }
                          channelMap.set(c.channelId, channel);
                          treeNodeMap.set(channel.key, channel);
                          levelTreeNodeMap.get(channelLevel).push(channel);
                      });
                      children = [...channelList[0], ...channelList[1]];
                      node.count = channelOnlineCount;
                      node.total = showOnlineState ? node.count : children.length;
                      node.children = children;
                      maxLevel = Math.max(channelLevel, maxLevel);
                      // 通道状态为监控中，设备状态为在线，将设备状态更改为监控中
                      if (hasBeMonitor && node.data.deviceStatus === DeviceStatus.ON_LINE) {
                          node.data.deviceStatus = DeviceStatus.BE_MONITOR;
                      }
                  }
                  node.isLeaf = !children || children.length === 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 === DataType.DEVICE) {
                      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 {
              channelMap,
              treeNodeMap,
              deviceMap,
              levelTreeNodeMap,
              maxLevel,
              treeNodes,
              hiddenNodeKeySet
          };
      }
      return createDeviceTree(data);
  }
  // 群组设备树结构
  function generateGroupDeviceTree(data, config) {
      const { expandedKeySet } = config;
      const { sortByStatus, showOnlineState, clearEmptyBusiness } = 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 = [];
              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[sortByStatus ? 1 : 0].push(target);
                                  if (showOnlineState) {
                                      hiddenNodeKeySet.add(getKey(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 (showOnlineState) {
                      if (!children || children.length === 0 && rawNode.dataType !== 3) {
                          hiddenNodeKeySet.add(node.key);
                      }
                  }
                  if (children && children.length) {
                      const { list, count: childCount, total: childTotal } = traverse(children, level + 1, node);
                      // 过滤没有设备的部门和群组 步骤二
                      if (!showOnlineState && clearEmptyBusiness && childTotal === 0) {
                          continue;
                      }
                      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 };
          };
          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 } = 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 = [];
              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,
              hiddenNodeKeySet: new Set()
          };
      }
      return createGroupTree(data);
  }
  // 用户树结构
  function generateUserTree(data, config) {
      const { expandedKeySet } = config;
      const { clearEmptyBusiness } = 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 = [];
              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,
              hiddenNodeKeySet: new Set()
          };
      }
      return createUserTree(data);
  }
  // 队伍用户树结构
  function generateTeamUserTree(data, config) {
      const { expandedKeySet } = config;
      const { clearEmptyBusiness } = 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 teamMap = 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.taskTeamList?.length ||
                      ![DataType.USER, DataType.TEAM].includes(rawNode.dataType)) {
                      children = children ? children : [];
                      if (rawNode.taskTeamList?.length) {
                          rawNode.taskTeamList.forEach((v) => {
                              children.push({
                                  ...v,
                                  onlyId: rawNode.id + '-' + v.id,
                                  label: v.teamName || v.id,
                                  dataType: DataType.TEAM, // 队伍
                              });
                          });
                      }
                      rawNode = {
                          ...rawNode,
                          children,
                          onlyId: rawNode.id,
                          dataType: DataType.DEPT, // 部门
                          label: rawNode.orgName || rawNode.companyName
                      };
                  }
                  // 用户
                  if (rawNode.memberList?.length) {
                      children = children ? children : [];
                      rawNode.memberList.forEach((v) => {
                          const target = {
                              ...v,
                              onlyId: rawNode.id + '-' + v.userId,
                              label: v.name || v.userId,
                              dataType: DataType.USER, // 代表用户
                          };
                          if (useFilterConfig(target, filterList)) {
                              children.push(target);
                          }
                      });
                  }
                  // 过滤没有用户的部门或队伍 步骤一
                  if (clearEmptyBusiness) {
                      if (!children || children.length === 0 && rawNode.dataType !== DataType.USER) {
                          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 === DataType.TEAM) {
                      const { id } = node.data;
                      const teamList = teamMap.get(id) || [];
                      teamList.push(node);
                      teamMap.set(id, teamList);
                  }
                  // 用户
                  if (rawNode.dataType === DataType.USER) {
                      const { userId } = node.data;
                      const userList = userMap.get(userId) || [];
                      userList.push(node);
                      userMap.set(userId, userList);
                  }
              }
              if (level > maxLevel) {
                  maxLevel = level;
              }
              return { list: siblings, count, total };
          };
          const { list } = traverse(data || []);
          const treeNodes = list;
          return {
              treeNodeMap,
              teamMap,
              userMap,
              levelTreeNodeMap,
              maxLevel,
              treeNodes,
              hiddenNodeKeySet: new Set()
          };
      }
      return createUserTree(data);
  }
  // 采集站树结构
  function generateCsTree(data, config) {
      const { expandedKeySet } = config;
      const { clearEmptyBusiness } = 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 = [];
              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,
              hiddenNodeKeySet: new Set()
          };
      }
      return createCsTree(data);
  }
  const generateMap = {
      // 设备树
      [Business.DEVICE]: generateDeviceTree,
      // 通道设备树
      [Business.CHANNEL]: generateChannelDeviceTree,
      // 群组设备树
      [Business.GROUP_DEVICE]: generateGroupDeviceTree,
      // 群组树
      [Business.GROUP]: generateGroupTree,
      // 用户树
      [Business.USER]: generateUserTree,
      // 队伍用户树
      [Business.TEAM_USER]: generateTeamUserTree,
      // 采集站
      [Business.CS]: generateCsTree
  };

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

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

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

  // 业务类型(config.business) device-设备 channel-通道设备 groupDevice-群组设备 group-群组 user-用户 cs-采集站
  var Business;
  (function (Business) {
      Business["DEVICE"] = "device";
      Business["CHANNEL"] = "channel";
      Business["GROUP_DEVICE"] = "groupDevice";
      Business["GROUP"] = "group";
      Business["USER"] = "user";
      Business["TEAM_USER"] = "teamUser";
      Business["CS"] = "cs";
  })(Business || (Business = {}));
  // 设备状态(data.deviceStatus) 0-离线 1-在线 2-监控中 3-通话中 4-录像中 5-录音中 6-广播中 7-SOS 8-音频中
  var DeviceStatus;
  (function (DeviceStatus) {
      DeviceStatus[DeviceStatus["OFF_LINE"] = 0] = "OFF_LINE";
      DeviceStatus[DeviceStatus["ON_LINE"] = 1] = "ON_LINE";
      DeviceStatus[DeviceStatus["BE_MONITOR"] = 2] = "BE_MONITOR";
      DeviceStatus[DeviceStatus["IN_CALL"] = 3] = "IN_CALL";
      DeviceStatus[DeviceStatus["IN_VIDEO_RECORD"] = 4] = "IN_VIDEO_RECORD";
      DeviceStatus[DeviceStatus["IN_AUDIO_RECORD"] = 5] = "IN_AUDIO_RECORD";
      DeviceStatus[DeviceStatus["IN_BROADCASE"] = 6] = "IN_BROADCASE";
      DeviceStatus[DeviceStatus["SOS"] = 7] = "SOS";
      DeviceStatus[DeviceStatus["INTERCOM_CALL"] = 8] = "INTERCOM_CALL";
  })(DeviceStatus || (DeviceStatus = {}));
  // 业务数据类型(data.dataType) 1-部门 3-设备 4-群组 5-用户 6-考勤 7-水源点 8-采集站 9-设备通道 10-队伍
  var DataType;
  (function (DataType) {
      DataType[DataType["UNKNOW_1"] = 0] = "UNKNOW_1";
      DataType[DataType["DEPT"] = 1] = "DEPT";
      DataType[DataType["UNKNOW_2"] = 2] = "UNKNOW_2";
      DataType[DataType["DEVICE"] = 3] = "DEVICE";
      DataType[DataType["GROUP"] = 4] = "GROUP";
      DataType[DataType["USER"] = 5] = "USER";
      DataType[DataType["ATTENDANCE"] = 6] = "ATTENDANCE";
      DataType[DataType["WATER_SOURCE"] = 7] = "WATER_SOURCE";
      DataType[DataType["CS"] = 8] = "CS";
      DataType[DataType["CHANNEL"] = 9] = "CHANNEL";
      DataType[DataType["TEAM"] = 10] = "TEAM";
  })(DataType || (DataType = {}));

  /** 生成处理函数 */
  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 (node.dataType) {
                  case DataType.DEPT: // 部门
                  case DataType.GROUP: // 群组
                  case DataType.TEAM: // 队伍
                  case DataType.USER: // 用户
                  case DataType.CS: // 采集站
                      return node.id;
                  case DataType.DEVICE: // 设备
                      return node.deviceId;
                  case DataType.CHANNEL: // 设备通道
                      return node.channelId;
              }
          }
          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 (business && [Business.DEVICE, Business.CHANNEL, Business.GROUP_DEVICE].includes(business)) {
          countFilter = (data) => {
              return data.dataType === DataType.DEVICE && data.onlineState === 1;
          };
          totalFilter = (data) => {
              return data.dataType === DataType.DEVICE;
          };
      }
      else if (business && [Business.USER, Business.TEAM_USER].includes(business)) {
          countFilter = totalFilter = (data) => {
              return data.dataType === DataType.USER;
          };
      }
      else if (business === Business.CS) {
          countFilter = totalFilter = (data) => {
              return data.dataType === DataType.CS;
          };
      }
      return {
          getKey,
          getLabel,
          getChildren,
          getCount,
          getTotal,
          countFilter,
          totalFilter,
          getNodeData,
          // 设置设备状态
          setDeviceStatus: (data) => {
              // 通道状态
              if (data.dataType === DataType.CHANNEL) {
                  if (data.onlineState === 1) {
                      // 监控中
                      if (data.beMonitor === 1) {
                          return DeviceStatus.BE_MONITOR;
                      }
                      // 在线
                      return DeviceStatus.ON_LINE;
                  }
                  // 离线
                  return DeviceStatus.OFF_LINE;
              }
              // 设备状态
              if (data.onlineState === 1) {
                  if (data.intercomGroupTem === 1 || data.intercomCall === 1) {
                      // 音频中
                      return DeviceStatus.INTERCOM_CALL;
                  }
                  // 监控中
                  if (data.monitor === 1 || data.beMonitor === 1) {
                      return DeviceStatus.BE_MONITOR;
                  }
                  // 通话中
                  if (data.videoCall === 1) {
                      return DeviceStatus.IN_CALL;
                  }
                  // 录像中
                  if (data.videoRecording === 1) {
                      return DeviceStatus.IN_VIDEO_RECORD;
                  }
                  // 录音中
                  if (data.audioRecording === 1) {
                      return DeviceStatus.IN_AUDIO_RECORD;
                  }
                  // 广播中
                  if (data.broadcast === 1) {
                      return DeviceStatus.IN_BROADCASE;
                  }
                  // SOS
                  if (data.sos === 1) {
                      return DeviceStatus.SOS;
                  }
                  // 在线
                  return DeviceStatus.ON_LINE;
              }
              // 离线
              return DeviceStatus.OFF_LINE;
          }
      };
  };
  /** 获取节点数据 */
  const getNodeData = (node) => {
      if (node.data.dataType === DataType.CHANNEL) {
          return {
              ...node.parent.data,
              ...node.data
          };
      }
      return node.data;
  };

  // 处理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 } = 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 = [];
              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[sortByStatus ? 1 : 0].push(target);
                                      if (showOnlineState) {
                                          hiddenNodeKeySet.add(getKey(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 (showOnlineState) {
                      if (!children || children.length === 0 && rawNode.dataType !== 3) {
                          hiddenNodeKeySet.add(node.key);
                      }
                  }
                  if (children && children.length) {
                      const { list, count: childCount, total: childTotal } = traverse(children, level + 1, node);
                      // 过滤没有用户的部门 步骤二
                      if (!showOnlineState && clearEmptyBusiness && childTotal === 0) {
                          continue;
                      }
                      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 };
          };
          const { list } = traverse(data || []);
          const treeNodes = list;
          return {
              treeNodeMap,
              deviceMap,
              levelTreeNodeMap,
              maxLevel,
              treeNodes,
              hiddenNodeKeySet
          };
      }
      return createDeviceTree(data);
  }
  // 通道设备树结构
  function generateChannelDeviceTree(data, config) {
      const { expandedKeySet } = config;
      const { sortByStatus, showOnlineState, clearEmptyBusiness } = 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 channelMap = new Map();
          const hiddenNodeKeySet = new Set();
          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 !== DataType.DEVICE) {
                      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: DataType.DEVICE, // 代表设备
                                  deviceStatus: setDeviceStatus(v) // 设备状态
                              };
                              if (useFilterConfig(target, filterList)) {
                                  if (target.deviceStatus === DeviceStatus.OFF_LINE) {
                                      deviceList[sortByStatus ? 1 : 0].push(target);
                                      if (showOnlineState) {
                                          hiddenNodeKeySet.add(getKey(target));
                                      }
                                  }
                                  else {
                                      deviceList[0].push(target);
                                  }
                              }
                          });
                          children = [...children, ...deviceList[0], ...deviceList[1]];
                      }
                      rawNode = {
                          ...rawNode,
                          children,
                          onlyId: rawNode.id,
                          dataType: DataType.DEPT, // 部门
                          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,
                      label: getLabel(rawNode),
                      parent,
                      expanded: expandedKeySet.has(value)
                  };
                  // 隐藏没有在线设备的部门和群组
                  if (showOnlineState) {
                      if (!children || children.length === 0 && rawNode.dataType !== DataType.DEVICE) {
                          hiddenNodeKeySet.add(node.key);
                      }
                  }
                  // 非设备类型数据
                  if (rawNode.dataType !== DataType.DEVICE && children && children.length) {
                      const { list, count: childCount, total: childTotal } = traverse(children, level + 1, node);
                      // 过滤没有用户的部门 步骤二
                      if (!showOnlineState && clearEmptyBusiness && childTotal === 0) {
                          continue;
                      }
                      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;
                          }
                      }
                  }
                  // 设备类型数据，且有通道数据处理
                  if (rawNode.dataType === DataType.DEVICE && rawNode.videoChannelList?.length) {
                      const channelLevel = level + 1;
                      if (!levelTreeNodeMap.has(channelLevel)) {
                          levelTreeNodeMap.set(channelLevel, []);
                      }
                      const channelList = [[], []];
                      let channelOnlineCount = 0;
                      let hasBeMonitor = false;
                      rawNode.videoChannelList.forEach((c) => {
                          const channel = {
                              key: rawNode.onlyId + '-' + c.channelId,
                              label: c.channelName || c.channelId,
                              level: level + 1,
                              count: 0,
                              total: 0,
                              expanded: false,
                              isLeaf: true,
                              data: {
                                  ...c,
                                  deviceId: rawNode.deviceId,
                                  devName: rawNode.devName || rawNode.deviceId,
                                  onlyId: rawNode.onlyId + '-' + c.channelId,
                                  label: c.channelName || c.channelId,
                                  dataType: DataType.CHANNEL, // 代表通道
                                  deviceStatus: setDeviceStatus(c) // 设备通道状态
                              },
                              parent: node,
                          };
                          hasBeMonitor = hasBeMonitor || channel.data.deviceStatus === DeviceStatus.BE_MONITOR;
                          if (channel.data.deviceStatus === DeviceStatus.OFF_LINE) {
                              channelList[sortByStatus ? 1 : 0].push(channel);
                              if (showOnlineState) {
                                  hiddenNodeKeySet.add(channel.key);
                              }
                          }
                          else {
                              channelOnlineCount++;
                              channelList[0].push(channel);
                          }
                          channelMap.set(c.channelId, channel);
                          treeNodeMap.set(channel.key, channel);
                          levelTreeNodeMap.get(channelLevel).push(channel);
                      });
                      children = [...channelList[0], ...channelList[1]];
                      node.count = channelOnlineCount;
                      node.total = showOnlineState ? node.count : children.length;
                      node.children = children;
                      maxLevel = Math.max(channelLevel, maxLevel);
                      // 通道状态为监控中，设备状态为在线，将设备状态更改为监控中
                      if (hasBeMonitor && node.data.deviceStatus === DeviceStatus.ON_LINE) {
                          node.data.deviceStatus = DeviceStatus.BE_MONITOR;
                      }
                  }
                  node.isLeaf = !children || children.length === 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 === DataType.DEVICE) {
                      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 {
              channelMap,
              treeNodeMap,
              deviceMap,
              levelTreeNodeMap,
              maxLevel,
              treeNodes,
              hiddenNodeKeySet
          };
      }
      return createDeviceTree(data);
  }
  // 群组设备树结构
  function generateGroupDeviceTree(data, config) {
      const { expandedKeySet } = config;
      const { sortByStatus, showOnlineState, clearEmptyBusiness } = 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 = [];
              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[sortByStatus ? 1 : 0].push(target);
                                  if (showOnlineState) {
                                      hiddenNodeKeySet.add(getKey(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 (showOnlineState) {
                      if (!children || children.length === 0 && rawNode.dataType !== 3) {
                          hiddenNodeKeySet.add(node.key);
                      }
                  }
                  if (children && children.length) {
                      const { list, count: childCount, total: childTotal } = traverse(children, level + 1, node);
                      // 过滤没有设备的部门和群组 步骤二
                      if (!showOnlineState && clearEmptyBusiness && childTotal === 0) {
                          continue;
                      }
                      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 };
          };
          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 } = 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 = [];
              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,
              hiddenNodeKeySet: new Set()
          };
      }
      return createGroupTree(data);
  }
  // 用户树结构
  function generateUserTree(data, config) {
      const { expandedKeySet } = config;
      const { clearEmptyBusiness } = 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 = [];
              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,
              hiddenNodeKeySet: new Set()
          };
      }
      return createUserTree(data);
  }
  // 队伍用户树结构
  function generateTeamUserTree(data, config) {
      const { expandedKeySet } = config;
      const { clearEmptyBusiness } = 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 teamMap = 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.taskTeamList?.length ||
                      ![DataType.USER, DataType.TEAM].includes(rawNode.dataType)) {
                      children = children ? children : [];
                      if (rawNode.taskTeamList?.length) {
                          rawNode.taskTeamList.forEach((v) => {
                              children.push({
                                  ...v,
                                  onlyId: rawNode.id + '-' + v.id,
                                  label: v.teamName || v.id,
                                  dataType: DataType.TEAM, // 队伍
                              });
                          });
                      }
                      rawNode = {
                          ...rawNode,
                          children,
                          onlyId: rawNode.id,
                          dataType: DataType.DEPT, // 部门
                          label: rawNode.orgName || rawNode.companyName
                      };
                  }
                  // 用户
                  if (rawNode.memberList?.length) {
                      children = children ? children : [];
                      rawNode.memberList.forEach((v) => {
                          const target = {
                              ...v,
                              onlyId: rawNode.id + '-' + v.userId,
                              label: v.name || v.userId,
                              dataType: DataType.USER, // 代表用户
                          };
                          if (useFilterConfig(target, filterList)) {
                              children.push(target);
                          }
                      });
                  }
                  // 过滤没有用户的部门或队伍 步骤一
                  if (clearEmptyBusiness) {
                      if (!children || children.length === 0 && rawNode.dataType !== DataType.USER) {
                          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 === DataType.TEAM) {
                      const { id } = node.data;
                      const teamList = teamMap.get(id) || [];
                      teamList.push(node);
                      teamMap.set(id, teamList);
                  }
                  // 用户
                  if (rawNode.dataType === DataType.USER) {
                      const { userId } = node.data;
                      const userList = userMap.get(userId) || [];
                      userList.push(node);
                      userMap.set(userId, userList);
                  }
              }
              if (level > maxLevel) {
                  maxLevel = level;
              }
              return { list: siblings, count, total };
          };
          const { list } = traverse(data || []);
          const treeNodes = list;
          return {
              treeNodeMap,
              teamMap,
              userMap,
              levelTreeNodeMap,
              maxLevel,
              treeNodes,
              hiddenNodeKeySet: new Set()
          };
      }
      return createUserTree(data);
  }
  // 采集站树结构
  function generateCsTree(data, config) {
      const { expandedKeySet } = config;
      const { clearEmptyBusiness } = 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 = [];
              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,
              hiddenNodeKeySet: new Set()
          };
      }
      return createCsTree(data);
  }
  const generateMap = {
      // 设备树
      [Business.DEVICE]: generateDeviceTree,
      // 通道设备树
      [Business.CHANNEL]: generateChannelDeviceTree,
      // 群组设备树
      [Business.GROUP_DEVICE]: generateGroupDeviceTree,
      // 群组树
      [Business.GROUP]: generateGroupTree,
      // 用户树
      [Business.USER]: generateUserTree,
      // 队伍用户树
      [Business.TEAM_USER]: generateTeamUserTree,
      // 采集站
      [Business.CS]: generateCsTree
  };

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

');
2036
2149
  /* eslint-enable */
2037
2150
 
2038
2151
  // 设备树
@@ -2128,7 +2241,10 @@ function updateDeviceChannelTree(tree, data, config) {
2128
2241
  const deviceMap = tree.deviceMap || new Map();
2129
2242
  const channelMap = tree.channelMap || new Map();
2130
2243
  let beOnlineList = [], beOfflineList = [];
2131
- const { businessConfig, hiddenNodeKeySet } = config;
2244
+ // 是否触发选中事件
2245
+ let checkedChangeNode = undefined;
2246
+ let isCheckedChange = false;
2247
+ const { businessConfig, hiddenNodeKeySet, isChecked, isIndeterminate, toggleCheckbox } = config;
2132
2248
  const { countFilter, totalFilter, setDeviceStatus } = useHandleFun(config);
2133
2249
  const { sortByStatus, showOnlineState } = businessConfig;
2134
2250
  // 是否参与统计
@@ -2198,7 +2314,8 @@ function updateDeviceChannelTree(tree, data, config) {
2198
2314
  // 通道
2199
2315
  if (v.channelId) {
2200
2316
  const channel = channelMap.get(v.channelId);
2201
- if (!channel)
2317
+ const channelParent = channel.parent;
2318
+ if (!channel || !parent)
2202
2319
  return;
2203
2320
  Object.assign(channel, {
2204
2321
  data: {
@@ -2217,9 +2334,15 @@ function updateDeviceChannelTree(tree, data, config) {
2217
2334
  else {
2218
2335
  tree.hiddenNodeKeySet.delete(channel.key);
2219
2336
  beOnlineList.push(channel);
2337
+ // 设备在线,而设备下通道全部离线,且此时通道上线,自动勾选通道
2338
+ if (config.businessConfig.isShowChannelSelect && !channelParent.count && isChecked(channelParent)) {
2339
+ toggleCheckbox(channel, true, false, true, false);
2340
+ checkedChangeNode = channel;
2341
+ isCheckedChange = true;
2342
+ }
2220
2343
  }
2221
2344
  }
2222
- channel.parent && parentMap.set(channel.parent.key, channel.parent);
2345
+ parentMap.set(channelParent.key, channelParent);
2223
2346
  }
2224
2347
  // 设备
2225
2348
  else {
@@ -2259,7 +2382,7 @@ function updateDeviceChannelTree(tree, data, config) {
2259
2382
  }
2260
2383
  });
2261
2384
  updateParnetCount(parentMap);
2262
- return { tree, beOnlineList, beOfflineList };
2385
+ return { tree, beOnlineList, beOfflineList, checkedChangeNode, isCheckedChange };
2263
2386
  }
2264
2387
  // 用户树
2265
2388
  function updateUserTree(tree, data, config) {
@@ -9250,9 +9373,7 @@ class VirtualTree {
9250
9373
  return;
9251
9374
  this._tree = await this._createTree(config.data);
9252
9375
  this._flattenTree = this._genereateFlattenTree();
9253
- const { checkedKeys, updateCheckedKeys, isIndeterminate, isChecked, toggleCheckbox, getChecked,
9254
- // afterNodeCheck,
9255
- getCheckedKeys, getCheckedNodes, getCheckedBusinessNodes,
9376
+ const { checkedKeys, updateCheckedKeys, isIndeterminate, isChecked, toggleCheckbox, getChecked, afterNodeCheck, getCheckedKeys, getCheckedNodes, getCheckedBusinessNodes,
9256
9377
  // getHalfCheckedKeys,
9257
9378
  // getHalfCheckedNodes,
9258
9379
  setChecked, setCheckedKeys, setCheckedNodes, getSwitchCheckedValue, } = useCheck(config, this);
@@ -9300,10 +9421,7 @@ class VirtualTree {
9300
9421
  const icon = document.createElement('div');
9301
9422
  icon.classList.add('hy-tree-node__expand-icon');
9302
9423
  el.appendChild(icon);
9303
- const isHideIcon = config.business !== Business.CHANNEL || item.data.dataType !== DataType.DEVICE
9304
- ? item.isLeaf
9305
- : this._businessConfig?.showOnlineState ? !item.count : !item.total;
9306
- if (isHideIcon || this._hiddenExpandIconKeySet.has(item.key)) {
9424
+ if (isCheckLeaf(config, item) || this._hiddenExpandIconKeySet.has(item.key)) {
9307
9425
  el.style.setProperty('visibility', 'hidden');
9308
9426
  }
9309
9427
  else {
@@ -9472,21 +9590,22 @@ class VirtualTree {
9472
9590
  if (config.onNodeClick) {
9473
9591
  await config.onNodeClick(getNodeData(item), item, e);
9474
9592
  }
9593
+ const isLeaf = isCheckLeaf(config, item);
9475
9594
  if (!getDisabled(config, item) && isShowSelect(config, item)) {
9476
9595
  if (config.checkOnClickNode) {
9477
9596
  toggleCheckbox(item, !(isChecked(item) || isIndeterminate(item)), true, true);
9478
- if (!config.expandOnClickNode || item.isLeaf) {
9597
+ if (!config.expandOnClickNode || isLeaf) {
9479
9598
  this.refresh();
9480
9599
  }
9481
9600
  }
9482
- else if (item.isLeaf && config.checkOnClickLeaf) {
9601
+ else if (isLeaf && config.checkOnClickLeaf) {
9483
9602
  toggleCheckbox(item, !isChecked(item), true, true);
9484
- if (!config.expandOnClickNode || item.isLeaf) {
9603
+ if (!config.expandOnClickNode || isLeaf) {
9485
9604
  this.refresh();
9486
9605
  }
9487
9606
  }
9488
9607
  }
9489
- if (config.expandOnClickNode && !item.isLeaf) {
9608
+ if (config.expandOnClickNode && !isLeaf) {
9490
9609
  this._expandedHandle(item);
9491
9610
  this._refreshVirtualScroll();
9492
9611
  }
@@ -9510,7 +9629,7 @@ class VirtualTree {
9510
9629
  return;
9511
9630
  e.stopPropagation();
9512
9631
  if ((getDisabled(config, item) ||
9513
- item.isLeaf ||
9632
+ isCheckLeaf(config, item) ||
9514
9633
  !config.checkOnDblclickParentNode) &&
9515
9634
  !config.onNodeDblClick) {
9516
9635
  nodeClickHandle(e);
@@ -9539,7 +9658,7 @@ class VirtualTree {
9539
9658
  await config.onNodeDblClick(getNodeData(item), item, e);
9540
9659
  }
9541
9660
  if (getDisabled(config, item) ||
9542
- item.isLeaf ||
9661
+ isCheckLeaf(config, item) ||
9543
9662
  !config.checkOnDblclickParentNode ||
9544
9663
  !isShowSelect(config, item)) {
9545
9664
  return;
@@ -9632,7 +9751,7 @@ class VirtualTree {
9632
9751
  reject({});
9633
9752
  return;
9634
9753
  }
9635
- const { tree } = updateMethod(this._tree, data, {
9754
+ const { tree, checkedChangeNode, isCheckedChange } = updateMethod(this._tree, data, {
9636
9755
  business: this._business,
9637
9756
  props: {
9638
9757
  value: this._props.value,
@@ -9642,21 +9761,17 @@ class VirtualTree {
9642
9761
  total: this._props.total
9643
9762
  },
9644
9763
  businessConfig: this._businessConfig,
9645
- hiddenNodeKeySet: this._hiddenNodeKeySet
9764
+ hiddenNodeKeySet: this._hiddenNodeKeySet,
9765
+ isChecked,
9766
+ isIndeterminate,
9767
+ toggleCheckbox
9646
9768
  });
9647
9769
  Object.assign(this._tree, tree);
9648
- // 设备离线时取消勾选状态
9649
- // let updateNode = null
9650
- // for (const node of (beOfflineList || [])) {
9651
- // if (checkedKeys.has(node.key)) {
9652
- // checkedKeys.delete(node.key)
9653
- // updateNode = node
9654
- // }
9655
- // }
9656
9770
  updateCheckedKeys();
9657
- // if (updateNode) {
9658
- // afterNodeCheck(updateNode, false)
9659
- // }
9771
+ // 选中数据更新,触发选中事件
9772
+ if (checkedChangeNode && isCheckedChange) {
9773
+ afterNodeCheck(checkedChangeNode, true);
9774
+ }
9660
9775
  resolve({});
9661
9776
  return;
9662
9777
  }
@@ -9916,4 +10031,4 @@ class VirtualTree {
9916
10031
  };
9917
10032
  }
9918
10033
 
9919
- export { Business, DataType, DeviceStatus, VirtualScroll, VirtualTree, getGlobalDeviceStatus, isArray, isBoolean, isElement, isEmpty, isFunction, isNull, isNumber, isObject, isOverflowing, isString, isUndefined, setGlobalDeviceStatus };
10034
+ export { Business, DataType, DeviceStatus, VirtualScroll, VirtualTree, getGlobalDeviceConfig, getGlobalTooltipConfig, getGlobalTreeConfig, isArray, isBoolean, isElement, isEmpty, isFunction, isNull, isNumber, isObject, isOverflowing, isString, isUndefined, setGlobalDeviceConfig, setGlobalTooltipConfig, setGlobalTreeConfig };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "hy-virtual-tree",
3
- "version": "1.1.67",
3
+ "version": "1.1.69",
4
4
  "type": "module",
5
5
  "scripts": {
6
6
  "dev": "vite",