@matter-server/dashboard 0.3.2 → 0.3.4
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/README.md +76 -0
- package/dist/esm/pages/cluster-commands/base-cluster-commands.d.ts +2 -2
- package/dist/esm/pages/cluster-commands/base-cluster-commands.d.ts.map +1 -1
- package/dist/esm/pages/cluster-commands/base-cluster-commands.js.map +1 -1
- package/dist/esm/pages/cluster-commands/clusters/basic-information-commands.d.ts +36 -0
- package/dist/esm/pages/cluster-commands/clusters/basic-information-commands.d.ts.map +1 -0
- package/dist/esm/pages/cluster-commands/clusters/basic-information-commands.js +159 -0
- package/dist/esm/pages/cluster-commands/clusters/basic-information-commands.js.map +6 -0
- package/dist/esm/pages/cluster-commands/index.d.ts +1 -0
- package/dist/esm/pages/cluster-commands/index.d.ts.map +1 -1
- package/dist/esm/pages/cluster-commands/index.js +1 -0
- package/dist/esm/pages/cluster-commands/index.js.map +1 -1
- package/dist/esm/pages/components/footer.d.ts.map +1 -1
- package/dist/esm/pages/components/footer.js +4 -7
- package/dist/esm/pages/components/footer.js.map +1 -1
- package/dist/esm/pages/components/header.d.ts +5 -0
- package/dist/esm/pages/components/header.d.ts.map +1 -1
- package/dist/esm/pages/components/header.js +75 -0
- package/dist/esm/pages/components/header.js.map +1 -1
- package/dist/esm/pages/components/node-details.js +2 -2
- package/dist/esm/pages/components/node-details.js.map +1 -1
- package/dist/esm/pages/components/server-details.d.ts.map +1 -1
- package/dist/esm/pages/components/server-details.js +0 -1
- package/dist/esm/pages/components/server-details.js.map +1 -1
- package/dist/esm/pages/matter-cluster-view.d.ts.map +1 -1
- package/dist/esm/pages/matter-cluster-view.js +9 -4
- package/dist/esm/pages/matter-cluster-view.js.map +1 -1
- package/dist/esm/pages/matter-dashboard-app.d.ts +12 -0
- package/dist/esm/pages/matter-dashboard-app.d.ts.map +1 -1
- package/dist/esm/pages/matter-dashboard-app.js +84 -4
- package/dist/esm/pages/matter-dashboard-app.js.map +1 -1
- package/dist/esm/pages/matter-endpoint-view.d.ts.map +1 -1
- package/dist/esm/pages/matter-endpoint-view.js +8 -2
- package/dist/esm/pages/matter-endpoint-view.js.map +1 -1
- package/dist/esm/pages/matter-network-view.d.ts +52 -0
- package/dist/esm/pages/matter-network-view.d.ts.map +1 -0
- package/dist/esm/pages/matter-network-view.js +309 -0
- package/dist/esm/pages/matter-network-view.js.map +6 -0
- package/dist/esm/pages/matter-node-view.d.ts.map +1 -1
- package/dist/esm/pages/matter-node-view.js +86 -3
- package/dist/esm/pages/matter-node-view.js.map +1 -1
- package/dist/esm/pages/matter-server-view.d.ts +4 -0
- package/dist/esm/pages/matter-server-view.d.ts.map +1 -1
- package/dist/esm/pages/matter-server-view.js +16 -1
- package/dist/esm/pages/matter-server-view.js.map +1 -1
- package/dist/esm/pages/network/base-network-graph.d.ts +74 -0
- package/dist/esm/pages/network/base-network-graph.d.ts.map +1 -0
- package/dist/esm/pages/network/base-network-graph.js +411 -0
- package/dist/esm/pages/network/base-network-graph.js.map +6 -0
- package/dist/esm/pages/network/device-icons.d.ts +52 -0
- package/dist/esm/pages/network/device-icons.d.ts.map +1 -0
- package/dist/esm/pages/network/device-icons.js +197 -0
- package/dist/esm/pages/network/device-icons.js.map +6 -0
- package/dist/esm/pages/network/device-panel.d.ts +31 -0
- package/dist/esm/pages/network/device-panel.d.ts.map +1 -0
- package/dist/esm/pages/network/device-panel.js +183 -0
- package/dist/esm/pages/network/device-panel.js.map +6 -0
- package/dist/esm/pages/network/network-details.d.ts +77 -0
- package/dist/esm/pages/network/network-details.d.ts.map +1 -0
- package/dist/esm/pages/network/network-details.js +904 -0
- package/dist/esm/pages/network/network-details.js.map +6 -0
- package/dist/esm/pages/network/network-types.d.ts +159 -0
- package/dist/esm/pages/network/network-types.d.ts.map +1 -0
- package/dist/esm/pages/network/network-types.js +19 -0
- package/dist/esm/pages/network/network-types.js.map +6 -0
- package/dist/esm/pages/network/network-utils.d.ts +196 -0
- package/dist/esm/pages/network/network-utils.d.ts.map +1 -0
- package/dist/esm/pages/network/network-utils.js +540 -0
- package/dist/esm/pages/network/network-utils.js.map +6 -0
- package/dist/esm/pages/network/thread-graph.d.ts +27 -0
- package/dist/esm/pages/network/thread-graph.d.ts.map +1 -0
- package/dist/esm/pages/network/thread-graph.js +137 -0
- package/dist/esm/pages/network/thread-graph.js.map +6 -0
- package/dist/esm/pages/network/update-connections-dialog.d.ts +55 -0
- package/dist/esm/pages/network/update-connections-dialog.d.ts.map +1 -0
- package/dist/esm/pages/network/update-connections-dialog.js +284 -0
- package/dist/esm/pages/network/update-connections-dialog.js.map +6 -0
- package/dist/esm/pages/network/wifi-graph.d.ts +27 -0
- package/dist/esm/pages/network/wifi-graph.d.ts.map +1 -0
- package/dist/esm/pages/network/wifi-graph.js +169 -0
- package/dist/esm/pages/network/wifi-graph.js.map +6 -0
- package/dist/esm/util/format_hex.d.ts +18 -0
- package/dist/esm/util/format_hex.d.ts.map +1 -1
- package/dist/esm/util/format_hex.js +21 -1
- package/dist/esm/util/format_hex.js.map +1 -1
- package/dist/web/js/{commission-node-dialog-CBSDiqRW.js → commission-node-dialog-CcMuttYO.js} +5 -5
- package/dist/web/js/{commission-node-existing-TP6s8Tez.js → commission-node-existing-CqTRDMAr.js} +2 -5
- package/dist/web/js/{commission-node-thread-DOB8pu6x.js → commission-node-thread-DgwtTVwK.js} +2 -5
- package/dist/web/js/{commission-node-wifi-tzavmk1j.js → commission-node-wifi-XaN2SEnE.js} +2 -5
- package/dist/web/js/{dialog-box-Dknil_Be.js → dialog-box-COpDD8i7.js} +2 -2
- package/dist/web/js/{fire_event-DRpOSjJR.js → fire_event-mDYWi2sw.js} +1 -1
- package/dist/web/js/{log-level-dialog-TXkma-7Z.js → log-level-dialog-Bc32kZVw.js} +2 -3
- package/dist/web/js/main.js +1 -1
- package/dist/web/js/matter-dashboard-app-CrBHT4fT.js +31606 -0
- package/dist/web/js/{node-binding-dialog-D52FCBFP.js → node-binding-dialog-C8fqOJiB.js} +2 -4
- package/dist/web/js/prevent_default-D-ohDGsN.js +8 -0
- package/package.json +6 -5
- package/src/pages/cluster-commands/base-cluster-commands.ts +2 -2
- package/src/pages/cluster-commands/clusters/basic-information-commands.ts +171 -0
- package/src/pages/cluster-commands/index.ts +1 -0
- package/src/pages/components/footer.ts +4 -7
- package/src/pages/components/header.ts +81 -0
- package/src/pages/components/node-details.ts +3 -3
- package/src/pages/components/server-details.ts +0 -1
- package/src/pages/matter-cluster-view.ts +11 -4
- package/src/pages/matter-dashboard-app.ts +105 -5
- package/src/pages/matter-endpoint-view.ts +10 -3
- package/src/pages/matter-network-view.ts +325 -0
- package/src/pages/matter-node-view.ts +93 -4
- package/src/pages/matter-server-view.ts +17 -1
- package/src/pages/network/base-network-graph.ts +477 -0
- package/src/pages/network/device-icons.ts +283 -0
- package/src/pages/network/device-panel.ts +180 -0
- package/src/pages/network/network-details.ts +1015 -0
- package/src/pages/network/network-types.ts +167 -0
- package/src/pages/network/network-utils.ts +861 -0
- package/src/pages/network/thread-graph.ts +170 -0
- package/src/pages/network/update-connections-dialog.ts +327 -0
- package/src/pages/network/wifi-graph.ts +193 -0
- package/src/util/format_hex.ts +39 -0
- package/dist/web/js/matter-dashboard-app-B7GUghkC.js +0 -17254
- package/dist/web/js/outlined-text-field-D1DyKQY-.js +0 -968
- package/dist/web/js/prevent_default-BPgSQsuY.js +0 -814
- package/dist/web/js/validator-C735j770.js +0 -1122
|
@@ -0,0 +1,309 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
3
|
+
var __decorateClass = (decorators, target, key, kind) => {
|
|
4
|
+
var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;
|
|
5
|
+
for (var i = decorators.length - 1, decorator; i >= 0; i--)
|
|
6
|
+
if (decorator = decorators[i])
|
|
7
|
+
result = (kind ? decorator(target, key, result) : decorator(result)) || result;
|
|
8
|
+
if (kind && result) __defProp(target, key, result);
|
|
9
|
+
return result;
|
|
10
|
+
};
|
|
11
|
+
/**
|
|
12
|
+
* @license
|
|
13
|
+
* Copyright 2025-2026 Open Home Foundation
|
|
14
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
15
|
+
*/
|
|
16
|
+
import { mdiFitToScreen } from "@mdi/js";
|
|
17
|
+
import { css, html, LitElement } from "lit";
|
|
18
|
+
import { customElement, property, query, state } from "lit/decorators.js";
|
|
19
|
+
import "../components/ha-svg-icon";
|
|
20
|
+
import "./components/footer";
|
|
21
|
+
import "./components/header";
|
|
22
|
+
import "./network/device-panel";
|
|
23
|
+
import "./network/network-details";
|
|
24
|
+
import "./network/thread-graph";
|
|
25
|
+
import "./network/wifi-graph";
|
|
26
|
+
let MatterNetworkView = class extends LitElement {
|
|
27
|
+
constructor() {
|
|
28
|
+
super(...arguments);
|
|
29
|
+
this.nodes = {};
|
|
30
|
+
this.networkType = "thread";
|
|
31
|
+
this.initialSelectedNodeId = null;
|
|
32
|
+
this._selectedNodeId = null;
|
|
33
|
+
this._initialSelectionApplied = false;
|
|
34
|
+
}
|
|
35
|
+
willUpdate(changedProperties) {
|
|
36
|
+
if (changedProperties.has("initialSelectedNodeId") && this.initialSelectedNodeId !== null) {
|
|
37
|
+
this._selectedNodeId = this.initialSelectedNodeId;
|
|
38
|
+
this._initialSelectionApplied = false;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
updated(changedProperties) {
|
|
42
|
+
super.updated(changedProperties);
|
|
43
|
+
if (!this._initialSelectionApplied && this.initialSelectedNodeId !== null) {
|
|
44
|
+
this._initialSelectionApplied = true;
|
|
45
|
+
this._selectNodeWhenReady(this.initialSelectedNodeId);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
disconnectedCallback() {
|
|
49
|
+
super.disconnectedCallback();
|
|
50
|
+
if (this._selectRetryTimer) {
|
|
51
|
+
clearTimeout(this._selectRetryTimer);
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
/**
|
|
55
|
+
* Tries to select a node in the graph, retrying until the graph is ready.
|
|
56
|
+
*/
|
|
57
|
+
_selectNodeWhenReady(nodeId, retries = 10) {
|
|
58
|
+
const graph = this.networkType === "thread" ? this._threadGraph : this._wifiGraph;
|
|
59
|
+
if (graph?.isReady()) {
|
|
60
|
+
graph.selectNode(nodeId);
|
|
61
|
+
} else if (retries > 0) {
|
|
62
|
+
this._selectRetryTimer = setTimeout(() => this._selectNodeWhenReady(nodeId, retries - 1), 100);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
_handleNodeSelected(event) {
|
|
66
|
+
this._selectedNodeId = event.detail.nodeId;
|
|
67
|
+
}
|
|
68
|
+
_handleDetailsClose() {
|
|
69
|
+
this._selectedNodeId = null;
|
|
70
|
+
}
|
|
71
|
+
_handleSelectNode(event) {
|
|
72
|
+
const nodeId = event.detail.nodeId;
|
|
73
|
+
this._selectedNodeId = nodeId;
|
|
74
|
+
if (this.networkType === "thread") {
|
|
75
|
+
this._threadGraph?.selectNode(nodeId);
|
|
76
|
+
} else {
|
|
77
|
+
this._wifiGraph?.selectNode(nodeId);
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
_handleFitToScreen() {
|
|
81
|
+
if (this.networkType === "thread") {
|
|
82
|
+
this._threadGraph?.fit();
|
|
83
|
+
} else {
|
|
84
|
+
this._wifiGraph?.fit();
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
_renderThreadView() {
|
|
88
|
+
return html`
|
|
89
|
+
<div class="graph-section">
|
|
90
|
+
<div class="graph-header">
|
|
91
|
+
<h2>Thread Network Mesh</h2>
|
|
92
|
+
<button class="fit-button" @click=${this._handleFitToScreen} title="Fit to screen">
|
|
93
|
+
<ha-svg-icon .path=${mdiFitToScreen}></ha-svg-icon>
|
|
94
|
+
</button>
|
|
95
|
+
</div>
|
|
96
|
+
<thread-graph .nodes=${this.nodes} @node-selected=${this._handleNodeSelected}></thread-graph>
|
|
97
|
+
</div>
|
|
98
|
+
`;
|
|
99
|
+
}
|
|
100
|
+
_renderWifiView() {
|
|
101
|
+
return html`
|
|
102
|
+
<div class="graph-section">
|
|
103
|
+
<div class="graph-header">
|
|
104
|
+
<h2>WiFi Network</h2>
|
|
105
|
+
<button class="fit-button" @click=${this._handleFitToScreen} title="Fit to screen">
|
|
106
|
+
<ha-svg-icon .path=${mdiFitToScreen}></ha-svg-icon>
|
|
107
|
+
</button>
|
|
108
|
+
</div>
|
|
109
|
+
<wifi-graph .nodes=${this.nodes} @node-selected=${this._handleNodeSelected}></wifi-graph>
|
|
110
|
+
</div>
|
|
111
|
+
`;
|
|
112
|
+
}
|
|
113
|
+
render() {
|
|
114
|
+
const showSidebar = this._selectedNodeId !== null;
|
|
115
|
+
const unknownDevices = this._threadGraph?.unknownDevicesMap ?? /* @__PURE__ */ new Map();
|
|
116
|
+
const wifiAccessPoints = this._wifiGraph?.wifiAccessPointsMap ?? /* @__PURE__ */ new Map();
|
|
117
|
+
return html`
|
|
118
|
+
<dashboard-header
|
|
119
|
+
title="Open Home Foundation Matter Server"
|
|
120
|
+
.client=${this.client}
|
|
121
|
+
.activeView=${this.activeView}
|
|
122
|
+
.hasThreadDevices=${this.hasThreadDevices}
|
|
123
|
+
.hasWifiDevices=${this.hasWifiDevices}
|
|
124
|
+
></dashboard-header>
|
|
125
|
+
|
|
126
|
+
<div class="content">
|
|
127
|
+
<div class="main-area">
|
|
128
|
+
${this.networkType === "thread" ? this._renderThreadView() : this._renderWifiView()}
|
|
129
|
+
</div>
|
|
130
|
+
|
|
131
|
+
<aside class="details-sidebar ${showSidebar ? "visible" : ""}">
|
|
132
|
+
<network-details
|
|
133
|
+
.selectedNodeId=${this._selectedNodeId}
|
|
134
|
+
.nodes=${this.nodes}
|
|
135
|
+
.unknownDevices=${unknownDevices}
|
|
136
|
+
.wifiAccessPoints=${wifiAccessPoints}
|
|
137
|
+
@close=${this._handleDetailsClose}
|
|
138
|
+
@select-node=${this._handleSelectNode}
|
|
139
|
+
></network-details>
|
|
140
|
+
</aside>
|
|
141
|
+
</div>
|
|
142
|
+
|
|
143
|
+
<dashboard-footer></dashboard-footer>
|
|
144
|
+
`;
|
|
145
|
+
}
|
|
146
|
+
};
|
|
147
|
+
MatterNetworkView.styles = css`
|
|
148
|
+
:host {
|
|
149
|
+
display: flex;
|
|
150
|
+
flex-direction: column;
|
|
151
|
+
height: 100vh;
|
|
152
|
+
height: 100dvh; /* dynamic viewport height - fallback above for older browsers */
|
|
153
|
+
overflow: hidden;
|
|
154
|
+
background-color: var(--md-sys-color-background, #fafafa);
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
.content {
|
|
158
|
+
display: flex;
|
|
159
|
+
flex: 1 1 0;
|
|
160
|
+
padding: 8px 16px;
|
|
161
|
+
gap: 8px;
|
|
162
|
+
max-width: 1600px;
|
|
163
|
+
margin: 0 auto;
|
|
164
|
+
width: 100%;
|
|
165
|
+
box-sizing: border-box;
|
|
166
|
+
min-height: 0;
|
|
167
|
+
overflow: hidden;
|
|
168
|
+
}
|
|
169
|
+
|
|
170
|
+
.main-area {
|
|
171
|
+
flex: 1 1 0;
|
|
172
|
+
display: flex;
|
|
173
|
+
flex-direction: column;
|
|
174
|
+
min-width: 0;
|
|
175
|
+
min-height: 0;
|
|
176
|
+
overflow: hidden;
|
|
177
|
+
}
|
|
178
|
+
|
|
179
|
+
.graph-section {
|
|
180
|
+
flex: 1 1 0;
|
|
181
|
+
min-height: 0;
|
|
182
|
+
display: flex;
|
|
183
|
+
flex-direction: column;
|
|
184
|
+
overflow: hidden;
|
|
185
|
+
}
|
|
186
|
+
|
|
187
|
+
.graph-header {
|
|
188
|
+
display: flex;
|
|
189
|
+
align-items: center;
|
|
190
|
+
justify-content: space-between;
|
|
191
|
+
margin-bottom: 4px;
|
|
192
|
+
flex-shrink: 0;
|
|
193
|
+
}
|
|
194
|
+
|
|
195
|
+
.graph-header h2 {
|
|
196
|
+
margin: 0;
|
|
197
|
+
font-size: 1.1rem;
|
|
198
|
+
font-weight: 500;
|
|
199
|
+
color: var(--md-sys-color-on-background, #333);
|
|
200
|
+
}
|
|
201
|
+
|
|
202
|
+
.fit-button {
|
|
203
|
+
background: none;
|
|
204
|
+
border: 1px solid var(--md-sys-color-outline-variant, #ccc);
|
|
205
|
+
border-radius: 4px;
|
|
206
|
+
padding: 6px;
|
|
207
|
+
cursor: pointer;
|
|
208
|
+
display: flex;
|
|
209
|
+
align-items: center;
|
|
210
|
+
justify-content: center;
|
|
211
|
+
transition: background-color 0.2s;
|
|
212
|
+
}
|
|
213
|
+
|
|
214
|
+
.fit-button:hover {
|
|
215
|
+
background-color: var(--md-sys-color-surface-container-high, #e8e8e8);
|
|
216
|
+
}
|
|
217
|
+
|
|
218
|
+
.fit-button ha-svg-icon {
|
|
219
|
+
--icon-primary-color: var(--md-sys-color-on-surface-variant, #666);
|
|
220
|
+
}
|
|
221
|
+
|
|
222
|
+
.graph-section thread-graph,
|
|
223
|
+
.graph-section wifi-graph {
|
|
224
|
+
flex: 1 1 0;
|
|
225
|
+
min-height: 0;
|
|
226
|
+
}
|
|
227
|
+
|
|
228
|
+
.wifi-section {
|
|
229
|
+
display: flex;
|
|
230
|
+
flex-direction: column;
|
|
231
|
+
gap: 16px;
|
|
232
|
+
overflow-y: auto;
|
|
233
|
+
}
|
|
234
|
+
|
|
235
|
+
.wifi-section h2 {
|
|
236
|
+
margin: 0;
|
|
237
|
+
font-size: 1.25rem;
|
|
238
|
+
font-weight: 500;
|
|
239
|
+
color: var(--md-sys-color-on-background, #333);
|
|
240
|
+
}
|
|
241
|
+
|
|
242
|
+
.wifi-section device-panel {
|
|
243
|
+
flex-shrink: 0;
|
|
244
|
+
}
|
|
245
|
+
|
|
246
|
+
.details-sidebar {
|
|
247
|
+
width: 320px;
|
|
248
|
+
flex-shrink: 0;
|
|
249
|
+
display: none;
|
|
250
|
+
min-height: 0;
|
|
251
|
+
overflow-y: auto;
|
|
252
|
+
}
|
|
253
|
+
|
|
254
|
+
.details-sidebar.visible {
|
|
255
|
+
display: block;
|
|
256
|
+
}
|
|
257
|
+
|
|
258
|
+
@media (max-width: 1024px) {
|
|
259
|
+
.content {
|
|
260
|
+
flex-direction: column;
|
|
261
|
+
}
|
|
262
|
+
|
|
263
|
+
.details-sidebar {
|
|
264
|
+
width: 100%;
|
|
265
|
+
max-height: 300px;
|
|
266
|
+
}
|
|
267
|
+
|
|
268
|
+
.details-sidebar.visible {
|
|
269
|
+
display: block;
|
|
270
|
+
}
|
|
271
|
+
}
|
|
272
|
+
|
|
273
|
+
@media (max-width: 600px) {
|
|
274
|
+
.content {
|
|
275
|
+
padding: 8px;
|
|
276
|
+
}
|
|
277
|
+
}
|
|
278
|
+
`;
|
|
279
|
+
__decorateClass([
|
|
280
|
+
property({ type: Object })
|
|
281
|
+
], MatterNetworkView.prototype, "nodes", 2);
|
|
282
|
+
__decorateClass([
|
|
283
|
+
property()
|
|
284
|
+
], MatterNetworkView.prototype, "activeView", 2);
|
|
285
|
+
__decorateClass([
|
|
286
|
+
property()
|
|
287
|
+
], MatterNetworkView.prototype, "networkType", 2);
|
|
288
|
+
__decorateClass([
|
|
289
|
+
property()
|
|
290
|
+
], MatterNetworkView.prototype, "initialSelectedNodeId", 2);
|
|
291
|
+
__decorateClass([
|
|
292
|
+
property({ type: Boolean })
|
|
293
|
+
], MatterNetworkView.prototype, "hasThreadDevices", 2);
|
|
294
|
+
__decorateClass([
|
|
295
|
+
property({ type: Boolean })
|
|
296
|
+
], MatterNetworkView.prototype, "hasWifiDevices", 2);
|
|
297
|
+
__decorateClass([
|
|
298
|
+
state()
|
|
299
|
+
], MatterNetworkView.prototype, "_selectedNodeId", 2);
|
|
300
|
+
__decorateClass([
|
|
301
|
+
query("thread-graph")
|
|
302
|
+
], MatterNetworkView.prototype, "_threadGraph", 2);
|
|
303
|
+
__decorateClass([
|
|
304
|
+
query("wifi-graph")
|
|
305
|
+
], MatterNetworkView.prototype, "_wifiGraph", 2);
|
|
306
|
+
MatterNetworkView = __decorateClass([
|
|
307
|
+
customElement("matter-network-view")
|
|
308
|
+
], MatterNetworkView);
|
|
309
|
+
//# sourceMappingURL=matter-network-view.js.map
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/pages/matter-network-view.ts"],
|
|
4
|
+
"mappings": "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",
|
|
5
|
+
"names": []
|
|
6
|
+
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"matter-node-view.d.ts","sourceRoot":"","sources":["../../../src/pages/matter-node-view.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,+BAA+B,CAAC;AACvC,OAAO,sCAAsC,CAAC;AAC9C,OAAO,yBAAyB,CAAC;AACjC,OAAO,8BAA8B,CAAC;AACtC,OAAO,
|
|
1
|
+
{"version":3,"file":"matter-node-view.d.ts","sourceRoot":"","sources":["../../../src/pages/matter-node-view.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,+BAA+B,CAAC;AACvC,OAAO,sCAAsC,CAAC;AAC9C,OAAO,yBAAyB,CAAC;AACjC,OAAO,8BAA8B,CAAC;AACtC,OAAO,EAAgB,YAAY,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AAElF,OAAO,EAAa,UAAU,EAAE,MAAM,KAAK,CAAC;AAG5C,OAAO,2BAA2B,CAAC;AAEnC,OAAO,qBAAqB,CAAC;AAC7B,OAAO,2BAA2B,CAAC;AAInC,OAAO,CAAC,MAAM,CAAC;IACX,UAAU,qBAAqB;QAC3B,kBAAkB,EAAE,cAAc,CAAC;KACtC;CACJ;AASD,cACM,cAAe,SAAQ,UAAU;IAC5B,MAAM,EAAG,YAAY,CAAC;IAGtB,IAAI,CAAC,EAAE,UAAU,CAAC;IAEhB,MAAM;IA8Ef,OAAO,CAAC,OAAO;IAIf,OAAgB,MAAM,0BAyFpB;CACL"}
|
|
@@ -17,14 +17,17 @@ import "@material/web/divider/divider";
|
|
|
17
17
|
import "@material/web/iconbutton/icon-button";
|
|
18
18
|
import "@material/web/list/list";
|
|
19
19
|
import "@material/web/list/list-item";
|
|
20
|
-
import {
|
|
21
|
-
import {
|
|
20
|
+
import { isTestNodeId } from "@matter-server/ws-client";
|
|
21
|
+
import { mdiChevronRight, mdiGraphOutline } from "@mdi/js";
|
|
22
|
+
import { css, html, LitElement } from "lit";
|
|
22
23
|
import { customElement, property } from "lit/decorators.js";
|
|
23
24
|
import { guard } from "lit/directives/guard.js";
|
|
24
25
|
import "../components/ha-svg-icon";
|
|
26
|
+
import { formatNodeAddress, getEffectiveFabricIndex } from "../util/format_hex.js";
|
|
25
27
|
import "./components/header";
|
|
26
28
|
import "./components/node-details";
|
|
27
29
|
import { getEndpointDeviceTypes } from "./matter-endpoint-view.js";
|
|
30
|
+
import { getNetworkType } from "./network/network-utils.js";
|
|
28
31
|
function getUniqueEndpoints(node) {
|
|
29
32
|
return Array.from(new Set(Object.keys(node.attributes).map((key) => Number(key.split("/")[0])))).sort((a, b) => {
|
|
30
33
|
return a - b;
|
|
@@ -38,15 +41,33 @@ let MatterNodeView = class extends LitElement {
|
|
|
38
41
|
<button @click=${this._goBack}>Back</button>
|
|
39
42
|
`;
|
|
40
43
|
}
|
|
44
|
+
const networkType = getNetworkType(this.node);
|
|
45
|
+
const showGraphButton = networkType === "thread" || networkType === "wifi" || networkType === "ethernet";
|
|
46
|
+
const graphViewType = networkType === "ethernet" ? "wifi" : networkType;
|
|
47
|
+
const graphUrl = showGraphButton ? `#${graphViewType}/${this.node.node_id}` : null;
|
|
48
|
+
const fabricIndex = getEffectiveFabricIndex(
|
|
49
|
+
this.client.serverInfo.fabric_index,
|
|
50
|
+
isTestNodeId(this.node.node_id)
|
|
51
|
+
);
|
|
52
|
+
const nodeHex = formatNodeAddress(fabricIndex, this.node.node_id);
|
|
41
53
|
return html`
|
|
42
54
|
<dashboard-header
|
|
43
|
-
.title=${
|
|
55
|
+
.title=${`Node ${this.node.node_id} ${nodeHex}`}
|
|
44
56
|
.client=${this.client}
|
|
45
57
|
backButton="#"
|
|
46
58
|
></dashboard-header>
|
|
47
59
|
|
|
48
60
|
<!-- node details section -->
|
|
49
61
|
<div class="container">
|
|
62
|
+
<div class="node-title-bar">
|
|
63
|
+
<h2>Node ${this.node.node_id} <span class="node-id-hex">${nodeHex}</span></h2>
|
|
64
|
+
${showGraphButton ? html`
|
|
65
|
+
<a href=${graphUrl} class="show-in-graph-button" title="Show in ${graphViewType} graph">
|
|
66
|
+
<ha-svg-icon .path=${mdiGraphOutline}></ha-svg-icon>
|
|
67
|
+
<span class="button-text">Show in graph</span>
|
|
68
|
+
</a>
|
|
69
|
+
` : ""}
|
|
70
|
+
</div>
|
|
50
71
|
<node-details .node=${this.node} .client=${this.client}></node-details>
|
|
51
72
|
</div>
|
|
52
73
|
|
|
@@ -112,6 +133,68 @@ MatterNodeView.styles = css`
|
|
|
112
133
|
font-weight: bold;
|
|
113
134
|
font-size: 0.8em;
|
|
114
135
|
}
|
|
136
|
+
|
|
137
|
+
.node-title-bar {
|
|
138
|
+
display: flex;
|
|
139
|
+
align-items: center;
|
|
140
|
+
gap: 16px;
|
|
141
|
+
margin-bottom: 16px;
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
.node-title-bar h2 {
|
|
145
|
+
margin: 0;
|
|
146
|
+
font-size: 1.25rem;
|
|
147
|
+
font-weight: 500;
|
|
148
|
+
color: var(--md-sys-color-on-background, #333);
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
.node-id-hex {
|
|
152
|
+
font-size: 0.75em;
|
|
153
|
+
font-weight: 400;
|
|
154
|
+
color: var(--md-sys-color-on-surface-variant, #666);
|
|
155
|
+
font-family: monospace;
|
|
156
|
+
}
|
|
157
|
+
|
|
158
|
+
.show-in-graph-button {
|
|
159
|
+
display: inline-flex;
|
|
160
|
+
align-items: center;
|
|
161
|
+
gap: 6px;
|
|
162
|
+
padding: 6px 12px;
|
|
163
|
+
background-color: var(--md-sys-color-primary);
|
|
164
|
+
color: var(--md-sys-color-on-primary);
|
|
165
|
+
text-decoration: none;
|
|
166
|
+
border-radius: 4px;
|
|
167
|
+
font-size: 0.8rem;
|
|
168
|
+
font-weight: 500;
|
|
169
|
+
transition: opacity 0.2s;
|
|
170
|
+
white-space: nowrap;
|
|
171
|
+
}
|
|
172
|
+
|
|
173
|
+
.show-in-graph-button:hover {
|
|
174
|
+
opacity: 0.9;
|
|
175
|
+
}
|
|
176
|
+
|
|
177
|
+
.show-in-graph-button ha-svg-icon {
|
|
178
|
+
--icon-primary-color: var(--md-sys-color-on-primary);
|
|
179
|
+
width: 16px;
|
|
180
|
+
height: 16px;
|
|
181
|
+
}
|
|
182
|
+
|
|
183
|
+
@media (max-width: 768px) {
|
|
184
|
+
.show-in-graph-button {
|
|
185
|
+
display: none;
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
@media (max-width: 480px) {
|
|
190
|
+
.show-in-graph-button .button-text {
|
|
191
|
+
display: none;
|
|
192
|
+
}
|
|
193
|
+
|
|
194
|
+
.show-in-graph-button {
|
|
195
|
+
padding: 6px;
|
|
196
|
+
}
|
|
197
|
+
}
|
|
115
198
|
`;
|
|
116
199
|
__decorateClass([
|
|
117
200
|
property()
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../src/pages/matter-node-view.ts"],
|
|
4
|
-
"mappings": ";;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAMA,OAAO;AACP,OAAO;AACP,OAAO;AACP,OAAO;
|
|
4
|
+
"mappings": "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",
|
|
5
5
|
"names": []
|
|
6
6
|
}
|
|
@@ -12,6 +12,7 @@ import { LitElement } from "lit";
|
|
|
12
12
|
import "../components/ha-svg-icon";
|
|
13
13
|
import "./components/footer";
|
|
14
14
|
import "./components/header";
|
|
15
|
+
import type { ActiveView } from "./components/header.js";
|
|
15
16
|
import "./components/server-details";
|
|
16
17
|
declare global {
|
|
17
18
|
interface HTMLElementTagNameMap {
|
|
@@ -21,6 +22,9 @@ declare global {
|
|
|
21
22
|
declare class MatterServerView extends LitElement {
|
|
22
23
|
client: MatterClient;
|
|
23
24
|
nodes: MatterClient["nodes"];
|
|
25
|
+
activeView?: ActiveView;
|
|
26
|
+
hasThreadDevices?: boolean;
|
|
27
|
+
hasWifiDevices?: boolean;
|
|
24
28
|
private _cachedNodes?;
|
|
25
29
|
private _cachedNodeEntries?;
|
|
26
30
|
private getNodeEntries;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"matter-server-view.d.ts","sourceRoot":"","sources":["../../../src/pages/matter-server-view.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,+BAA+B,CAAC;AACvC,OAAO,sCAAsC,CAAC;AAC9C,OAAO,yBAAyB,CAAC;AACjC,OAAO,8BAA8B,CAAC;AACtC,OAAO,EAAgB,YAAY,EAAc,MAAM,0BAA0B,CAAC;AAElF,OAAO,EAAa,UAAU,EAAW,MAAM,KAAK,CAAC;AAErD,OAAO,2BAA2B,CAAC;AAEnC,OAAO,qBAAqB,CAAC;AAC7B,OAAO,qBAAqB,CAAC;AAC7B,OAAO,6BAA6B,CAAC;AAErC,OAAO,CAAC,MAAM,CAAC;IACX,UAAU,qBAAqB;QAC3B,oBAAoB,EAAE,gBAAgB,CAAC;KAC1C;CACJ;AAED,cACM,gBAAiB,SAAQ,UAAU;IAC9B,MAAM,EAAG,YAAY,CAAC;IAGtB,KAAK,EAAG,YAAY,CAAC,OAAO,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"matter-server-view.d.ts","sourceRoot":"","sources":["../../../src/pages/matter-server-view.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,+BAA+B,CAAC;AACvC,OAAO,sCAAsC,CAAC;AAC9C,OAAO,yBAAyB,CAAC;AACjC,OAAO,8BAA8B,CAAC;AACtC,OAAO,EAAgB,YAAY,EAAc,MAAM,0BAA0B,CAAC;AAElF,OAAO,EAAa,UAAU,EAAW,MAAM,KAAK,CAAC;AAErD,OAAO,2BAA2B,CAAC;AAEnC,OAAO,qBAAqB,CAAC;AAC7B,OAAO,qBAAqB,CAAC;AAC7B,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AACzD,OAAO,6BAA6B,CAAC;AAErC,OAAO,CAAC,MAAM,CAAC;IACX,UAAU,qBAAqB;QAC3B,oBAAoB,EAAE,gBAAgB,CAAC;KAC1C;CACJ;AAED,cACM,gBAAiB,SAAQ,UAAU;IAC9B,MAAM,EAAG,YAAY,CAAC;IAGtB,KAAK,EAAG,YAAY,CAAC,OAAO,CAAC,CAAC;IAG9B,UAAU,CAAC,EAAE,UAAU,CAAC;IAGxB,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAG3B,cAAc,CAAC,EAAE,OAAO,CAAC;IAEhC,OAAO,CAAC,YAAY,CAAC,CAAwB;IAC7C,OAAO,CAAC,kBAAkB,CAAC,CAAyB;IAEpD,OAAO,CAAC,cAAc;IAQb,MAAM;IAuDf,OAAgB,MAAM,0BA8CpB;CACL"}
|
|
@@ -37,7 +37,13 @@ let MatterServerView = class extends LitElement {
|
|
|
37
37
|
render() {
|
|
38
38
|
const nodes = this.getNodeEntries(this.nodes);
|
|
39
39
|
return html`
|
|
40
|
-
<dashboard-header
|
|
40
|
+
<dashboard-header
|
|
41
|
+
title="Open Home Foundation Matter Server"
|
|
42
|
+
.client=${this.client}
|
|
43
|
+
.activeView=${this.activeView}
|
|
44
|
+
.hasThreadDevices=${this.hasThreadDevices}
|
|
45
|
+
.hasWifiDevices=${this.hasWifiDevices}
|
|
46
|
+
></dashboard-header>
|
|
41
47
|
|
|
42
48
|
<!-- server details section -->
|
|
43
49
|
<div class="container">
|
|
@@ -129,6 +135,15 @@ MatterServerView.styles = css`
|
|
|
129
135
|
__decorateClass([
|
|
130
136
|
property()
|
|
131
137
|
], MatterServerView.prototype, "nodes", 2);
|
|
138
|
+
__decorateClass([
|
|
139
|
+
property()
|
|
140
|
+
], MatterServerView.prototype, "activeView", 2);
|
|
141
|
+
__decorateClass([
|
|
142
|
+
property({ type: Boolean })
|
|
143
|
+
], MatterServerView.prototype, "hasThreadDevices", 2);
|
|
144
|
+
__decorateClass([
|
|
145
|
+
property({ type: Boolean })
|
|
146
|
+
], MatterServerView.prototype, "hasWifiDevices", 2);
|
|
132
147
|
MatterServerView = __decorateClass([
|
|
133
148
|
customElement("matter-server-view")
|
|
134
149
|
], MatterServerView);
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../src/pages/matter-server-view.ts"],
|
|
4
|
-
"mappings": ";;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAMA,OAAO;AACP,OAAO;AACP,OAAO;AACP,OAAO;AACP,SAAS,oBAA8C;AACvD,SAAS,uBAAuB;AAChC,SAAS,KAAK,MAAM,YAAY,eAAe;AAC/C,SAAS,eAAe,gBAAgB;AACxC,OAAO;AACP,SAAS,yBAAyB;AAClC,OAAO;AACP,OAAO;
|
|
4
|
+
"mappings": ";;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAMA,OAAO;AACP,OAAO;AACP,OAAO;AACP,OAAO;AACP,SAAS,oBAA8C;AACvD,SAAS,uBAAuB;AAChC,SAAS,KAAK,MAAM,YAAY,eAAe;AAC/C,SAAS,eAAe,gBAAgB;AACxC,OAAO;AACP,SAAS,yBAAyB;AAClC,OAAO;AACP,OAAO;AAEP,OAAO;AASP,IAAM,mBAAN,cAA+B,WAAW;AAAA,EAkB9B,eAAe,OAAsD;AACzE,QAAI,UAAU,KAAK,cAAc;AAC7B,WAAK,eAAe;AACpB,WAAK,qBAAqB,OAAO,QAAQ,KAAK;AAAA,IAClD;AACA,WAAO,KAAK;AAAA,EAChB;AAAA,EAES,SAAS;AACd,UAAM,QAAQ,KAAK,eAAe,KAAK,KAAK;AAE5C,WAAO;AAAA;AAAA;AAAA,0BAGW,KAAK,MAAM;AAAA,8BACP,KAAK,UAAU;AAAA,oCACT,KAAK,gBAAgB;AAAA,kCACvB,KAAK,cAAc;AAAA;AAAA;AAAA;AAAA;AAAA,0CAKX,KAAK,MAAM;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,sBAW/B,MAAM,IAAI,CAAC,CAAC,KAAK,IAAI,MAAM;AACzB,aAAO;AAAA,6DAC8B,SAAS,KAAK,OAAO,EAAE;AAAA;AAAA,2CAEzC,KAAK,OAAO;AAAA;AAAA,4CAEX;AAAA,QACA,aAAa,KAAK,OAAO,KACrB,KAAK,OAAO,WAAW,iBAAiB,SACtC,SACA,KAAK,OAAO,WAAW;AAAA,QAC7B,KAAK;AAAA,MACT,CAAC;AAAA;AAAA,sCAEH,KAAK,YAAY,KAAK,yCAAyC;AAAA;AAAA;AAAA,sCAG/D,KAAK,YAAY,GAAG,KAAK,SAAS,QAAQ,OAAO,IAAI,KAAK,UAAU;AAAA,sCACpE,KAAK,WAAW;AAAA;AAAA,gEAEU,eAAe;AAAA;AAAA;AAAA,IAG3D,CAAC,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,EAKlB;AAiDJ;AAhIM,iBAiFc,SAAS;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AA7ElB;AAAA,EADN,SAAS;AAAA,GAHR,iBAIK;AAGA;AAAA,EADN,SAAS;AAAA,GANR,iBAOK;AAGA;AAAA,EADN,SAAS,EAAE,MAAM,QAAQ,CAAC;AAAA,GATzB,iBAUK;AAGA;AAAA,EADN,SAAS,EAAE,MAAM,QAAQ,CAAC;AAAA,GAZzB,iBAaK;AAbL,mBAAN;AAAA,EADC,cAAc,oBAAoB;AAAA,GAC7B;",
|
|
5
5
|
"names": []
|
|
6
6
|
}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2025-2026 Open Home Foundation
|
|
4
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
+
*/
|
|
6
|
+
import type { MatterNode } from "@matter-server/ws-client";
|
|
7
|
+
import { LitElement } from "lit";
|
|
8
|
+
import { DataSet, Network } from "vis-network/standalone";
|
|
9
|
+
import type { NetworkGraphEdge, NetworkGraphNode } from "./network-types.js";
|
|
10
|
+
/**
|
|
11
|
+
* Base class for network graph components (Thread and WiFi).
|
|
12
|
+
* Provides shared vis.js network initialization, highlighting, and theme support.
|
|
13
|
+
*/
|
|
14
|
+
export declare abstract class BaseNetworkGraph extends LitElement {
|
|
15
|
+
nodes: Record<string, MatterNode>;
|
|
16
|
+
protected _selectedNodeId: number | string | null;
|
|
17
|
+
protected _network?: Network;
|
|
18
|
+
protected _nodesDataSet?: DataSet<NetworkGraphNode>;
|
|
19
|
+
protected _edgesDataSet?: DataSet<NetworkGraphEdge>;
|
|
20
|
+
protected _container?: HTMLDivElement;
|
|
21
|
+
protected _resizeObserver?: ResizeObserver;
|
|
22
|
+
protected _themeUnsubscribe?: () => void;
|
|
23
|
+
protected _updateDebounceTimer?: ReturnType<typeof setTimeout>;
|
|
24
|
+
/** Store original edge colors for restoration after highlighting */
|
|
25
|
+
private _originalEdgeColors;
|
|
26
|
+
protected _getFontColor(): string;
|
|
27
|
+
protected _getDimmedEdgeColor(): string;
|
|
28
|
+
/**
|
|
29
|
+
* Returns physics options for the network. Override in subclasses for different behavior.
|
|
30
|
+
*/
|
|
31
|
+
protected _getPhysicsOptions(): any;
|
|
32
|
+
updated(changedProperties: Map<string, unknown>): void;
|
|
33
|
+
/**
|
|
34
|
+
* Try to find and attach the graph container if it wasn't available before.
|
|
35
|
+
* This handles the case where empty state was rendered initially.
|
|
36
|
+
*/
|
|
37
|
+
private _tryAttachContainer;
|
|
38
|
+
/** Debounced graph update to avoid excessive redraws */
|
|
39
|
+
protected _debouncedUpdateGraph(): void;
|
|
40
|
+
firstUpdated(): void;
|
|
41
|
+
disconnectedCallback(): void;
|
|
42
|
+
protected _initializeNetwork(): void;
|
|
43
|
+
/**
|
|
44
|
+
* Returns true if the graph is initialized and ready for interaction.
|
|
45
|
+
*/
|
|
46
|
+
isReady(): boolean;
|
|
47
|
+
/**
|
|
48
|
+
* Fits all nodes into view.
|
|
49
|
+
*/
|
|
50
|
+
fit(): void;
|
|
51
|
+
/**
|
|
52
|
+
* Selects a node by ID and focuses on it.
|
|
53
|
+
*/
|
|
54
|
+
selectNode(nodeId: number | string): void;
|
|
55
|
+
protected _dispatchNodeSelected(nodeId: number | string | null): void;
|
|
56
|
+
/**
|
|
57
|
+
* Highlights edges connected to the selected node and makes neighbor nodes more prominent.
|
|
58
|
+
*/
|
|
59
|
+
protected _highlightConnections(nodeId: number | string): void;
|
|
60
|
+
/**
|
|
61
|
+
* Clears all highlights and restores default styling.
|
|
62
|
+
*/
|
|
63
|
+
protected _clearHighlights(): void;
|
|
64
|
+
/**
|
|
65
|
+
* Clear stored edge colors when graph is updated (edges are recreated).
|
|
66
|
+
*/
|
|
67
|
+
protected _clearOriginalEdgeColors(): void;
|
|
68
|
+
/**
|
|
69
|
+
* Abstract method to be implemented by subclasses for graph-specific updates.
|
|
70
|
+
*/
|
|
71
|
+
protected abstract _updateGraph(): void;
|
|
72
|
+
static styles: import("lit").CSSResult;
|
|
73
|
+
}
|
|
74
|
+
//# sourceMappingURL=base-network-graph.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"base-network-graph.d.ts","sourceRoot":"","sources":["../../../../src/pages/network/base-network-graph.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,UAAU,EAAO,MAAM,KAAK,CAAC;AAGtC,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAE1D,OAAO,KAAK,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAE7E;;;GAGG;AACH,8BAAsB,gBAAiB,SAAQ,UAAU;IAE9C,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,UAAU,CAAC,CAAM;IAG9C,SAAS,CAAC,eAAe,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CAAQ;IAEzD,SAAS,CAAC,QAAQ,CAAC,EAAE,OAAO,CAAC;IAC7B,SAAS,CAAC,aAAa,CAAC,EAAE,OAAO,CAAC,gBAAgB,CAAC,CAAC;IACpD,SAAS,CAAC,aAAa,CAAC,EAAE,OAAO,CAAC,gBAAgB,CAAC,CAAC;IACpD,SAAS,CAAC,UAAU,CAAC,EAAE,cAAc,CAAC;IACtC,SAAS,CAAC,eAAe,CAAC,EAAE,cAAc,CAAC;IAC3C,SAAS,CAAC,iBAAiB,CAAC,EAAE,MAAM,IAAI,CAAC;IACzC,SAAS,CAAC,oBAAoB,CAAC,EAAE,UAAU,CAAC,OAAO,UAAU,CAAC,CAAC;IAE/D,oEAAoE;IACpE,OAAO,CAAC,mBAAmB,CAAgE;IAE3F,SAAS,CAAC,aAAa,IAAI,MAAM;IAIjC,SAAS,CAAC,mBAAmB,IAAI,MAAM;IAIvC;;OAEG;IACH,SAAS,CAAC,kBAAkB,IAAI,GAAG;IAoB1B,OAAO,CAAC,iBAAiB,EAAE,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAc/D;;;OAGG;IACH,OAAO,CAAC,mBAAmB;IAmB3B,wDAAwD;IACxD,SAAS,CAAC,qBAAqB,IAAI,IAAI;IAS9B,YAAY,IAAI,IAAI;IAkDpB,oBAAoB,IAAI,IAAI;IAgBrC,SAAS,CAAC,kBAAkB,IAAI,IAAI;IAyFpC;;OAEG;IACI,OAAO,IAAI,OAAO;IAIzB;;OAEG;IACI,GAAG,IAAI,IAAI;IASlB;;OAEG;IACI,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;IAkBhD,SAAS,CAAC,qBAAqB,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,GAAG,IAAI;IAUrE;;OAEG;IACH,SAAS,CAAC,qBAAqB,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;IAqE9D;;OAEG;IACH,SAAS,CAAC,gBAAgB,IAAI,IAAI;IA8BlC;;OAEG;IACH,SAAS,CAAC,wBAAwB,IAAI,IAAI;IAI1C;;OAEG;IACH,SAAS,CAAC,QAAQ,CAAC,YAAY,IAAI,IAAI;IAEvC,OAAgB,MAAM,0BAuCpB;CACL"}
|