@riil-frontend/component-topology 12.1.0-dev.8 → 12.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (64) hide show
  1. package/build/1.js +1 -1
  2. package/build/index.css +1 -1
  3. package/build/index.js +14 -14
  4. package/es/components/ResourceSelectDrawer/ResourceSelectDrawer.js +1 -1
  5. package/es/core/components/AlarmListPanel/components/AlarmListItem.js +2 -2
  6. package/es/core/components/TopoView/topoView.js +7 -4
  7. package/es/core/editor/components/Sidebar/views/ImagePanel/ImagePanel.js +11 -3
  8. package/es/core/editor/components/Toolbar/widgets/Layout/index.js +2 -2
  9. package/es/core/editor/components/settings/core/updateElementProperty.js +3 -2
  10. package/es/core/editor/components/settings/propertyViews/view/GlobalEdgeToggle.js +2 -2
  11. package/es/core/editor/hooks/useKeyboardShortcut.js +4 -0
  12. package/es/core/editor/hooks/useNewElementTheme.js +20 -16
  13. package/es/core/hooks/useGraphAlarmDisplay.js +4 -0
  14. package/es/core/hooks/usePolling.js +2 -1
  15. package/es/core/hooks/useTopoEdit.js +208 -243
  16. package/es/core/models/Alarm.js +14 -15
  17. package/es/core/models/AttributeMetricDisplay.js +4 -3
  18. package/es/core/models/HistoryManager.js +11 -9
  19. package/es/core/models/TopoApp.js +17 -15
  20. package/es/core/models/topoData.js +7 -14
  21. package/es/core/models/utils/linkUtils.js +2 -2
  22. package/es/core/store/models/topoConfig.js +7 -11
  23. package/es/core/utils/edgeUtil.js +7 -11
  24. package/es/core/viewer/components/plugins/ResourceDetail/components/ResourceOverview/EventsCard.js +51 -13
  25. package/es/core/viewer/components/plugins/ResourceDetail/components/ResourceOverview/components/LinkTopo/LinkTopo.module.scss +1 -1
  26. package/es/core/viewer/components/plugins/ResourceDetail/components/ResourceOverview/index.module.scss +8 -0
  27. package/es/networkTopo/models/LinkDynamicStyleExecutor.js +7 -63
  28. package/es/networkTopo/utils/exitLinkUtil.js +23 -11
  29. package/es/style.js +1 -1
  30. package/es/utils/clusterUtil.js +3 -3
  31. package/es/utils/htElementUtils.js +8 -108
  32. package/es/utils/topoData.js +1 -1
  33. package/lib/components/ResourceSelectDrawer/ResourceSelectDrawer.js +1 -1
  34. package/lib/core/components/AlarmListPanel/components/AlarmListItem.js +2 -2
  35. package/lib/core/components/TopoView/topoView.js +15 -19
  36. package/lib/core/editor/components/Sidebar/views/ImagePanel/ImagePanel.js +12 -3
  37. package/lib/core/editor/components/Toolbar/widgets/Layout/index.js +1 -1
  38. package/lib/core/editor/components/settings/core/updateElementProperty.js +7 -2
  39. package/lib/core/editor/components/settings/propertyViews/view/GlobalEdgeToggle.js +2 -2
  40. package/lib/core/editor/hooks/useKeyboardShortcut.js +4 -0
  41. package/lib/core/editor/hooks/useNewElementTheme.js +20 -16
  42. package/lib/core/hooks/useGraphAlarmDisplay.js +4 -0
  43. package/lib/core/hooks/usePolling.js +6 -5
  44. package/lib/core/hooks/useTopoEdit.js +214 -267
  45. package/lib/core/models/Alarm.js +14 -15
  46. package/lib/core/models/AttributeMetricDisplay.js +6 -6
  47. package/lib/core/models/HistoryManager.js +13 -17
  48. package/lib/core/models/TopoApp.js +18 -15
  49. package/lib/core/models/topoData.js +7 -14
  50. package/lib/core/models/utils/linkUtils.js +1 -1
  51. package/lib/core/store/models/topoConfig.js +13 -25
  52. package/lib/core/utils/edgeUtil.js +6 -10
  53. package/lib/core/viewer/components/plugins/ResourceDetail/components/ResourceOverview/EventsCard.js +52 -13
  54. package/lib/core/viewer/components/plugins/ResourceDetail/components/ResourceOverview/components/LinkTopo/LinkTopo.module.scss +1 -1
  55. package/lib/core/viewer/components/plugins/ResourceDetail/components/ResourceOverview/index.module.scss +8 -0
  56. package/lib/networkTopo/models/LinkDynamicStyleExecutor.js +6 -64
  57. package/lib/networkTopo/utils/exitLinkUtil.js +23 -11
  58. package/lib/style.js +1 -1
  59. package/lib/utils/clusterUtil.js +2 -2
  60. package/lib/utils/htElementUtils.js +9 -119
  61. package/lib/utils/topoData.js +1 -1
  62. package/package.json +2 -2
  63. package/es/networkTopo/models/LinkTagsTipsBuilder.js +0 -235
  64. package/lib/networkTopo/models/LinkTagsTipsBuilder.js +0 -245
@@ -3,14 +3,10 @@
3
3
  exports.__esModule = true;
4
4
  exports["default"] = void 0;
5
5
 
6
- var _componentTopologyUtils = require("@riil-frontend/component-topology-utils");
7
-
8
6
  var _clusterUtil = require("../../utils/clusterUtil");
9
7
 
10
8
  var _htElementUtils = require("../../utils/htElementUtils");
11
9
 
12
- var _linkUtil = require("../utils/linkUtil");
13
-
14
10
  // network_link.actual_bandwidth
15
11
  function calcEdgeWidth(actualBandwidth) {
16
12
  if (!actualBandwidth) {
@@ -61,16 +57,17 @@ var LinkDynamicStyleExecutor = /*#__PURE__*/function () {
61
57
  var _proto = LinkDynamicStyleExecutor.prototype;
62
58
 
63
59
  _proto.execute = function execute() {
64
- var _this = this;
60
+ var _topo$historyManager,
61
+ _this = this,
62
+ _topo$historyManager2;
65
63
 
66
64
  var topo = this.topo;
67
65
 
68
66
  var _topo$dataModel$getDa = topo.dataModel.getData(),
69
- links = _topo$dataModel$getDa.links,
70
- linkGroups = _topo$dataModel$getDa.linkGroups;
67
+ links = _topo$dataModel$getDa.links;
71
68
 
72
69
  var dataModel = this.topo.getDataModel();
73
- topo.historyManager && topo.historyManager.setDisabled(true, '链路动态样式'); // 1、如果连线可见,设置线宽
70
+ (_topo$historyManager = topo.historyManager) === null || _topo$historyManager === void 0 ? void 0 : _topo$historyManager.setDisabled(true, '链路动态粗细'); // 1、如果连线可见,设置线宽
74
71
 
75
72
  links.forEach(function (link) {
76
73
  var edge = dataModel.getDataByTag(link.id);
@@ -78,63 +75,8 @@ var LinkDynamicStyleExecutor = /*#__PURE__*/function () {
78
75
  if (edge) {
79
76
  edge.s('edge.width', _this.calcLinkEdgeWidth(link));
80
77
  }
81
- }); // 2、如果连线组关联链路并可见,设置线宽
82
-
83
- linkGroups.forEach(function (link) {
84
- // 聚合链路是连线/连线组,并可以查询到
85
- var edge = topo.getDataModel().getDataByTag(link.id);
86
-
87
- if (edge) {
88
- edge.s('edge.width', _this.calcLinkEdgeWidth(link));
89
- return;
90
- } // 聚合链路是连线组(编辑模式还未关联业务信息)
91
-
92
-
93
- var edgeGroup = (0, _htElementUtils.getEdgeGroupByNodeTags)(dataModel, link.source, link.target);
94
-
95
- if (edgeGroup) {
96
- var edgeGroupAgent = edgeGroup.getEdgeGroupAgent(); // 判断是显示的连线组元素
97
-
98
- if (edgeGroupAgent) {
99
- edgeGroup.getEdgeGroupAgent().s('edge.width', _this.calcLinkEdgeWidth(link));
100
- }
101
- } else {
102
- _componentTopologyUtils.rlog.warn('动态链路样式执行:未找到聚合链路的ht元素', link);
103
- }
104
- }); // 3、如果连线组未关联链路并可见,设置线宽。
105
-
106
- var edges = (0, _htElementUtils.getEdges)(dataModel);
107
- edges.forEach(function (edge) {
108
- try {
109
- // 获取两端代理节点
110
- var sourceAgent = edge.getSourceAgent();
111
- var targetAgent = edge.getTargetAgent();
112
- var sourceId = sourceAgent.getTag();
113
- var targetId = targetAgent.getTag(); // 查询是否有聚合链路
114
-
115
- var aggLink = linkGroups.find(function (link) {
116
- return link.source === sourceId && link.target === targetId || link.target === sourceId && link.source === targetId;
117
- }); // 如果连线组未关联链路并可见
118
-
119
- if (!aggLink && edge.isEdgeGroupAgent()) {
120
- // 查询两端代理节点(包含子节点)间的子链路列表
121
- var sourceCiIds = getChildrenNodeCiIds([sourceAgent]);
122
- var targetCiIds = getChildrenNodeCiIds([targetAgent]);
123
- var aggLinks = (0, _linkUtil.getLinksBetweenNodes)(linkGroups, sourceCiIds, targetCiIds);
124
- var phyLinks = (0, _linkUtil.getLinksBetweenNodes)(links, sourceCiIds, targetCiIds);
125
- var linkBetweenNodes = aggLinks.length ? aggLinks : phyLinks; // 如果有子链路,计算线宽并设置
126
-
127
- if (linkBetweenNodes.length) {
128
- var edgeWidth = _this.calcEdgeGroupEdgeWidth(linkBetweenNodes);
129
-
130
- edge.s('edge.width', edgeWidth);
131
- }
132
- }
133
- } catch (error) {
134
- _componentTopologyUtils.rlog.error('连线组未关联链路并可见,设置线宽:异常', edge, error);
135
- }
136
78
  });
137
- topo.historyManager && topo.historyManager.setDisabled(false, '链路动态样式');
79
+ (_topo$historyManager2 = topo.historyManager) === null || _topo$historyManager2 === void 0 ? void 0 : _topo$historyManager2.setDisabled(false, '链路动态粗细');
138
80
  }
139
81
  /**
140
82
  * 处理单个连线组切换。有链路时设置
@@ -251,9 +251,10 @@ function updateLinkTarget(links, nodes) {
251
251
 
252
252
 
253
253
  function processByConditionResult(topoData, groupConfigs) {
254
- var nodes = topoData.nodes,
254
+ var groups = topoData.groups,
255
+ nodes = topoData.nodes,
255
256
  links = topoData.links;
256
- var ipNodes = getIpNodes(groupConfigs, nodes); // 出口链路目的端设置为IP节点或者ping资源节点id
257
+ var ipNodes = getIpNodes(groupConfigs, topoData); // 出口链路目的端设置为IP节点或者ping资源节点id
257
258
 
258
259
  var newLinks = updateLinkTarget(links, nodes);
259
260
  return (0, _extends2["default"])({}, topoData, {
@@ -261,15 +262,26 @@ function processByConditionResult(topoData, groupConfigs) {
261
262
  links: newLinks
262
263
  });
263
264
 
264
- function getIpNodes(groupConfigs, nodes) {
265
- var ips = groupConfigs.map(function (g) {
266
- return g.condition.linkIps;
267
- }).reduce(function (result, groupIps) {
268
- return [].concat(result, groupIps);
269
- }, []) // 过滤ping资源对应的ip节点
270
- .filter(function (ip) {
271
- return !findPingNode(nodes, ip);
265
+ function getIpNodes(groupConfigs, _ref) {
266
+ var groups = _ref.groups,
267
+ nodes = _ref.nodes;
268
+ var ipNodes = [];
269
+ groupConfigs.forEach(function (g) {
270
+ g.condition.linkIps // 过滤ping资源对应的ip节点
271
+ .filter(function (ip) {
272
+ return !findPingNode(nodes, ip);
273
+ }).map(function (ip) {
274
+ var topoGroup = g.topoGroup;
275
+ var group = groups.find(function (item) {
276
+ return item.id === topoGroup.id || item.tag === topoGroup.tag;
277
+ });
278
+ ipNodes.push((0, _extends2["default"])({}, buildIpNode(ip), {
279
+ // 解决区域里有ip添加资源ip消失的问题
280
+ 'groupId': group === null || group === void 0 ? void 0 : group.id,
281
+ 'groupTag': group === null || group === void 0 ? void 0 : group.tag
282
+ }));
283
+ });
272
284
  });
273
- return ips.map(buildIpNode);
285
+ return ipNodes;
274
286
  }
275
287
  }
package/lib/style.js CHANGED
@@ -1,7 +1,7 @@
1
1
  require('@riil-frontend/component-topology-graph/lib/style');
2
2
  require('@alifd/next/lib/box/style');
3
- require('@riil-frontend/component-topology-utils/lib/style');
4
3
  require('@alifd/next/lib/message/style');
4
+ require('@riil-frontend/component-topology-utils/lib/style');
5
5
  require('@riil-frontend/utils/lib/style');
6
6
  require('@riil-frontend/component-riil-event-emitter/lib/style');
7
7
  require('@alifd/next/lib/menu-button/style');
@@ -103,7 +103,7 @@ function isClusterHtElement(element) {
103
103
  }
104
104
 
105
105
  function isClusterMemberHtElement(element) {
106
- return element && element.getParent() && isClusterHtElement(element.getParent());
106
+ return (element === null || element === void 0 ? void 0 : element.getParent()) && isClusterHtElement(element.getParent());
107
107
  }
108
108
  /**
109
109
  * 集群无权限时收起
@@ -140,7 +140,7 @@ function upgradeV103GraphClusterNode(topo, topoData) {
140
140
  var topoDataTrans = (0, _utils.transformTopoElements)(topoData);
141
141
  var dm = topo.getDataModel();
142
142
  var unExistedList = topoDataTrans.filter(function (data) {
143
- return !(0, _htElementUtils.isExistedElement)(topo.getHtTopo(), dm, data);
143
+ return !(0, _htElementUtils.containsElement)(dm, data);
144
144
  });
145
145
 
146
146
  if (!unExistedList.length) {
@@ -3,11 +3,9 @@
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
4
 
5
5
  exports.__esModule = true;
6
+ exports.containsElement = containsElement;
6
7
  exports.getEdgeDatas = getEdgeDatas;
7
8
  exports.getEdgeGroupAgents = getEdgeGroupAgents;
8
- exports.getEdgeGroupByNodeTags = getEdgeGroupByNodeTags;
9
- exports.getEdgeGroupByNodes = getEdgeGroupByNodes;
10
- exports.getEdgeGroups = getEdgeGroups;
11
9
  exports.getEdges = getEdges;
12
10
  exports.getEdgesBetweenNodes = getEdgesBetweenNodes;
13
11
  exports.getElements = getElements;
@@ -26,11 +24,8 @@ exports.getNodeDatas = getNodeDatas;
26
24
  exports.getNodes = getNodes;
27
25
  exports.getNodesByGroupIdOrTag = getNodesByGroupIdOrTag;
28
26
  exports.isEdge = isEdge;
29
- exports.isEdgeGroup = isEdgeGroup;
30
27
  exports.isEdgeGroupAgent = isEdgeGroupAgent;
31
- exports.isEdgeGroupExpanded = isEdgeGroupExpanded;
32
28
  exports.isEdgeVisible = isEdgeVisible;
33
- exports.isExistedElement = isExistedElement;
34
29
  exports.isGroup = isGroup;
35
30
  exports.isLayer = isLayer;
36
31
  exports.isNode = isNode;
@@ -174,16 +169,6 @@ function getNodeData(element) {
174
169
  function getEdges(dataModel) {
175
170
  return getElements(dataModel).filter(isValidEdge);
176
171
  }
177
- /**
178
- * 是否连线组
179
- * @param {ht.Edge} edge
180
- * @returns
181
- */
182
-
183
-
184
- function isEdgeGroup(edge) {
185
- return isEdge(edge) && edge.a('x.edgegroup.isEdgeGroup');
186
- }
187
172
  /**
188
173
  * 是否连线组代理
189
174
  * @param {*} edge
@@ -192,17 +177,7 @@ function isEdgeGroup(edge) {
192
177
 
193
178
 
194
179
  function isEdgeGroupAgent(edge) {
195
- return isEdgeGroup(edge);
196
- }
197
- /**
198
- * TODO
199
- * @param {*} edge
200
- * @returns
201
- */
202
-
203
-
204
- function isEdgeGroupExpanded(edge) {
205
- return isEdge(edge) && edge.getEdgeGroup() && !!edge.s("edge.expanded");
180
+ return isEdge(edge) && edge.a('x.edgegroup.isEdgeGroup');
206
181
  }
207
182
 
208
183
  function isEdgeVisible(edge) {
@@ -233,66 +208,6 @@ function getEdgesBetweenNodes(node1, node2) {
233
208
  });
234
209
  return edges;
235
210
  }
236
- /**
237
- * 获得节点间的连线组,连线<=1时返回null
238
- * @returns
239
- */
240
-
241
-
242
- function getEdgeGroupByNodes(node1, node2) {
243
- var htEdgeGroup = null;
244
- getEdgesBetweenNodes(node1, node2).forEach(function (edge) {
245
- if (!htEdgeGroup) {
246
- htEdgeGroup = edge.getEdgeGroup();
247
- }
248
- });
249
-
250
- if (!htEdgeGroup) {
251
- return null;
252
- }
253
-
254
- return new _EdgeGroup["default"](htEdgeGroup);
255
- }
256
- /**
257
- * 获得节点间的连线组,连线<=1时返回null
258
- * @returns
259
- */
260
-
261
-
262
- function getEdgeGroupByNodeTags(dataModel, nodeTag1, nodeTag2) {
263
- var node1 = dataModel.getDataByTag(nodeTag1);
264
- var node2 = dataModel.getDataByTag(nodeTag2);
265
-
266
- if (!node1 || !node2) {
267
- console.warn("getEdgeGroupByNodes 未找到节点", {
268
- node1: node1,
269
- node2: node2,
270
- nodeTag1: nodeTag1,
271
- nodeTag2: nodeTag2
272
- });
273
- return null;
274
- }
275
-
276
- return getEdgeGroupByNodes(node1, node2);
277
- }
278
- /**
279
- * 获得连线组连线列表
280
- * @param {*} dataModel
281
- * @returns
282
- */
283
-
284
-
285
- function getEdgeGroups(dataModel) {
286
- var edgeGroups = [];
287
- getEdges(dataModel).forEach(function (edge) {
288
- var group = edge.getEdgeGroup();
289
-
290
- if (group && !edgeGroups.includes(group)) {
291
- edgeGroups.push(group);
292
- }
293
- });
294
- return edgeGroups;
295
- }
296
211
  /**
297
212
  * 获得连线组连线列表
298
213
  * @param {*} dataModel
@@ -306,7 +221,7 @@ function getEdgeGroupAgents(dataModel) {
306
221
 
307
222
  function getEdgeDatas(dataModel) {
308
223
  return getEdges(dataModel).filter(function (edge) {
309
- return !isEdgeGroup(edge);
224
+ return !isEdgeGroupAgent(edge);
310
225
  }).map(function (element) {
311
226
  var _element$getSource, _element$getTarget;
312
227
 
@@ -415,10 +330,14 @@ function setElementRuntimeStyle(element, name, value) {
415
330
  }
416
331
  /**
417
332
  * 判断拓扑图是否存在元素
333
+ *
334
+ * @param {*} dataModel
335
+ * @param {{id?: string, tag?: string}} data
336
+ * @returns
418
337
  */
419
338
 
420
339
 
421
- function isExistedElement(htTopo, dataModel, data) {
340
+ function containsElement(dataModel, data) {
422
341
  if (dataModel.getDataByTag(data.id)) {
423
342
  return true;
424
343
  } // 识别区域
@@ -427,34 +346,5 @@ function isExistedElement(htTopo, dataModel, data) {
427
346
  var element = getElements(dataModel).find(function (item) {
428
347
  return data.tag && item.a("tag") === data.tag;
429
348
  });
430
-
431
- if (element) {
432
- return true;
433
- } // 连线/连线组
434
-
435
-
436
- var edges = getEdges(dataModel);
437
-
438
- for (var i = 0; i < edges.length; i++) {
439
- var edge = edges[i]; // 如果连线组折叠,判断子连线
440
-
441
- var edgeData = htTopo.getEdgeData(edge);
442
-
443
- if (edgeData) {
444
- // eslint-disable-next-line no-underscore-dangle
445
- var id = edgeData._attrObject.id;
446
-
447
- if (id === data.id) {
448
- return true;
449
- }
450
- } // 如果连线组展开,判断连线组
451
- // eslint-disable-next-line no-underscore-dangle
452
-
453
-
454
- if (edge.__edgeGroup && edge.__edgeGroup._tag === data.id) {
455
- return true;
456
- }
457
- }
458
-
459
- return false;
349
+ return !!element;
460
350
  }
@@ -231,7 +231,7 @@ function buildGlobal(_ref2) {
231
231
  // 是否可编辑----控制[编辑]按钮
232
232
  moveable: true,
233
233
  // 节点是否可移动
234
- toggleGroupByDblClick: true
234
+ toggleGroupByDblClick: false
235
235
  }, (result === null || result === void 0 ? void 0 : (_result$global2 = result.global) === null || _result$global2 === void 0 ? void 0 : _result$global2.control) || {}, (result === null || result === void 0 ? void 0 : (_result$customGlobal = result.customGlobal) === null || _result$customGlobal === void 0 ? void 0 : _result$customGlobal.control) || {}),
236
236
  topoDisplayConfig: (0, _extends2["default"])({
237
237
  // alarmSwitch: (result.global || {}).alarmSwitch ?? true,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@riil-frontend/component-topology",
3
- "version": "12.1.0-dev.8",
3
+ "version": "12.1.1",
4
4
  "description": "拓扑",
5
5
  "scripts": {
6
6
  "start": "build-scripts start",
@@ -123,6 +123,6 @@
123
123
  "access": "public"
124
124
  },
125
125
  "license": "MIT",
126
- "homepage": "https://unpkg.com/@riil-frontend/component-topology@12.1.0-dev.8/build/index.html",
126
+ "homepage": "https://unpkg.com/@riil-frontend/component-topology@12.1.1/build/index.html",
127
127
  "gitHead": "2da19ffccbb7ca60a8acf396e39f542c68bb33f5"
128
128
  }
@@ -1,235 +0,0 @@
1
- import _extends from "@babel/runtime/helpers/extends";
2
-
3
- /**
4
- * 连线组标注、悬浮框数据构建
5
- */
6
- import { rlog } from '@riil-frontend/component-topology-utils';
7
- import { getEdgeGroups } from "../../utils/htElementUtils";
8
- import AttributeFormatter from "../../core/models/attributeFormatter"; // 参与计算的链路指标
9
-
10
- var metrics = [// 总流速
11
- {
12
- code: 'interface_totalbps',
13
- calcType: 'sum'
14
- }, // 带宽利用率
15
- {
16
- code: 'bandwidth_utilization',
17
- calcType: 'avg'
18
- }, // 发送带宽利用率
19
- {
20
- code: 'out_bandwidth_utilization',
21
- calcType: 'avg',
22
- showWhenSameSource: true
23
- }, // 接收带宽利用率
24
- {
25
- code: 'in_bandwidth_utilization',
26
- calcType: 'avg',
27
- showWhenSameSource: true
28
- }, {
29
- code: 'out_rate',
30
- calcType: 'sum',
31
- showWhenSameSource: true
32
- }, {
33
- code: 'in_rate',
34
- calcType: 'sum',
35
- showWhenSameSource: true
36
- }];
37
- var calcFnMap = {
38
- sum: function sum(values) {
39
- return values.reduce(function (total, val) {
40
- return total + parseInt(val || 0, 10);
41
- }, 0);
42
- },
43
- avg: function avg(values) {
44
- return values.reduce(function (total, val) {
45
- return total + parseFloat(val || 0, 10);
46
- }, 0) / values.length;
47
- }
48
- };
49
-
50
- var LinkTagsTipsBuilder = /*#__PURE__*/function () {
51
- function LinkTagsTipsBuilder(amDisplay) {
52
- this.amDisplay = void 0;
53
- this.topo = void 0;
54
- this.amDisplay = amDisplay;
55
- this.topo = amDisplay.topo;
56
- }
57
-
58
- var _proto = LinkTagsTipsBuilder.prototype;
59
-
60
- _proto.getExtElementTagsAndTips = function getExtElementTagsAndTips() {
61
- return this.getEdgeGroupTagsAndTips();
62
- }
63
- /**
64
- * 获得未关联聚合链路的连线组标注和悬浮框数据
65
- * @param {*} ciTagsAndTips
66
- * @returns
67
- */
68
- ;
69
-
70
- _proto.getEdgeGroupTagsAndTips = function getEdgeGroupTagsAndTips() {
71
- var _this = this;
72
-
73
- var ciConfigs = this.amDisplay.getResourceTagTipConfig();
74
- var data = this.amDisplay.getData();
75
- var topo = this.topo;
76
- var dm = this.topo.getDataModel(); // 获取所有连线组,排除关联聚合链路,排除无子链路
77
-
78
- var groups = getEdgeGroups(dm).map(getGroupInfo).filter(function (item) {
79
- return !!item;
80
- }); // 计算标注和指标
81
-
82
- var edgeGroupsTagsTips = groups.map(function (_ref) {
83
- var groupId = _ref.groupId,
84
- linkChildren = _ref.children;
85
- var config = ciConfigs.find(function (item) {
86
- return item.id === linkChildren[0].id;
87
- });
88
- return _this.buildEdgeGroupTagTagsAndTips({
89
- groupId: groupId,
90
- config: config,
91
- linkChildren: linkChildren,
92
- data: data
93
- });
94
- }); // 获得连线组及子链路
95
- // 关联聚合链路、无子链路 时返回null
96
-
97
- function getGroupInfo(group) {
98
- var edges = group.getEdges().toArray();
99
- var edge = edges[0];
100
- var edgeGroupData = topo.getHtTopo().getEdgeGroupData(edge.getSource(), edge.getTarget()); // eslint-disable-next-line no-underscore-dangle
101
-
102
- var linkId = edgeGroupData.data._attrObject.id;
103
-
104
- if (linkId) {
105
- return null;
106
- }
107
-
108
- var linkChildren = getLinkChildren(edges);
109
-
110
- if (!linkChildren.length) {
111
- return null;
112
- }
113
-
114
- return {
115
- groupId: [edge.getSource().getId(), edge.getTarget().getId()].sort().join('-'),
116
- children: linkChildren
117
- };
118
- }
119
-
120
- function getLinkChildren(edges) {
121
- return edges.map(function (edge) {
122
- var edgeData = topo.getHtTopo().getEdgeData(edge); // eslint-disable-next-line no-underscore-dangle
123
-
124
- var childLinkId = edgeData._tag;
125
-
126
- if (childLinkId) {
127
- return topo.dataModel.getDataById(childLinkId);
128
- }
129
-
130
- return null;
131
- }).filter(function (item) {
132
- return !!item;
133
- }).filter(function (link) {
134
- return link.ciType === 'network_link';
135
- });
136
- }
137
-
138
- return edgeGroupsTagsTips;
139
- };
140
-
141
- _proto.buildEdgeGroupTagTagsAndTips = function buildEdgeGroupTagTagsAndTips(_ref2) {
142
- var _this2 = this;
143
-
144
- var groupId = _ref2.groupId,
145
- config = _ref2.config,
146
- linkChildren = _ref2.linkChildren,
147
- data = _ref2.data;
148
-
149
- // 查询配置,过滤不在范围内的属性
150
- var finalConfig = _extends({}, config, {
151
- tags: config.tags.filter(function (item) {
152
- return _this2.filterField(item, linkChildren);
153
- }),
154
- tips: config.tips.filter(function (item) {
155
- return _this2.filterField(item, linkChildren);
156
- })
157
- }); // 构造数据,计算指标值
158
-
159
-
160
- var mergeData = this.buildData(data, linkChildren);
161
- rlog.debug('buildEdgeGroupTagTagsAndTips', {
162
- groupId: groupId,
163
- config: config,
164
- linkChildren: linkChildren,
165
- data: data,
166
- finalConfig: finalConfig,
167
- mergeData: mergeData
168
- }); // 构造标注、悬浮框数据
169
-
170
- var formatter = new AttributeFormatter(this.topo);
171
- return {
172
- type: 'edgeGroup',
173
- edgeGroupId: groupId,
174
- tags: formatter.formatAttrs(finalConfig.tags, mergeData),
175
- tips: formatter.formatAttrs(finalConfig.tips, mergeData)
176
- };
177
- } // eslint-disable-next-line class-methods-use-this
178
- ;
179
-
180
- _proto.filterField = function filterField(item, linkChildren) {
181
- var fieldConfig = metrics.find(function (m) {
182
- return item.code === m.code;
183
- });
184
-
185
- if (item.type !== 'metric' || !fieldConfig) {
186
- return false;
187
- } // 如果需要校验取值接口,如果取值接口为不同设备的接口,则不显示这四个指标
188
-
189
-
190
- if (fieldConfig.showWhenSameSource) {
191
- var sources = [];
192
- linkChildren.forEach(function (link) {
193
- if (sources.indexOf(link.source) === -1) {
194
- sources.push(link.source);
195
- }
196
- });
197
-
198
- if (sources.length > 1) {
199
- return false;
200
- }
201
- }
202
-
203
- return true;
204
- } // eslint-disable-next-line class-methods-use-this
205
- ;
206
-
207
- _proto.buildData = function buildData(data, linkChildren) {
208
- var linkChildrenData = linkChildren.map(function (link) {
209
- return data.find(function (item) {
210
- return item.id === link.id;
211
- });
212
- });
213
- var mergeData = {
214
- ciType: 'network_link',
215
- metricMap: {}
216
- };
217
- metrics.forEach(function (m) {
218
- try {
219
- var values = linkChildrenData.map(function (linkData) {
220
- return linkData.metricMap[m.code];
221
- });
222
- mergeData.metricMap[m.code] = calcFnMap[m.calcType](values);
223
- } catch (error) {
224
- rlog.warn('连线组指标计算异常', error);
225
- }
226
- }); // console.error(groupId, {config, linkChildrenData, mergeData})
227
-
228
- return mergeData;
229
- };
230
-
231
- return LinkTagsTipsBuilder;
232
- }();
233
-
234
- export { LinkTagsTipsBuilder as default };
235
- ;