@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.
Files changed (124) hide show
  1. package/README.md +76 -0
  2. package/dist/esm/pages/cluster-commands/base-cluster-commands.d.ts +2 -2
  3. package/dist/esm/pages/cluster-commands/base-cluster-commands.d.ts.map +1 -1
  4. package/dist/esm/pages/cluster-commands/base-cluster-commands.js.map +1 -1
  5. package/dist/esm/pages/cluster-commands/clusters/basic-information-commands.d.ts +36 -0
  6. package/dist/esm/pages/cluster-commands/clusters/basic-information-commands.d.ts.map +1 -0
  7. package/dist/esm/pages/cluster-commands/clusters/basic-information-commands.js +159 -0
  8. package/dist/esm/pages/cluster-commands/clusters/basic-information-commands.js.map +6 -0
  9. package/dist/esm/pages/cluster-commands/index.d.ts +1 -0
  10. package/dist/esm/pages/cluster-commands/index.d.ts.map +1 -1
  11. package/dist/esm/pages/cluster-commands/index.js +1 -0
  12. package/dist/esm/pages/cluster-commands/index.js.map +1 -1
  13. package/dist/esm/pages/components/footer.d.ts.map +1 -1
  14. package/dist/esm/pages/components/footer.js +4 -7
  15. package/dist/esm/pages/components/footer.js.map +1 -1
  16. package/dist/esm/pages/components/header.d.ts +5 -0
  17. package/dist/esm/pages/components/header.d.ts.map +1 -1
  18. package/dist/esm/pages/components/header.js +75 -0
  19. package/dist/esm/pages/components/header.js.map +1 -1
  20. package/dist/esm/pages/components/node-details.js +2 -2
  21. package/dist/esm/pages/components/node-details.js.map +1 -1
  22. package/dist/esm/pages/components/server-details.d.ts.map +1 -1
  23. package/dist/esm/pages/components/server-details.js +0 -1
  24. package/dist/esm/pages/components/server-details.js.map +1 -1
  25. package/dist/esm/pages/matter-cluster-view.d.ts.map +1 -1
  26. package/dist/esm/pages/matter-cluster-view.js +9 -4
  27. package/dist/esm/pages/matter-cluster-view.js.map +1 -1
  28. package/dist/esm/pages/matter-dashboard-app.d.ts +12 -0
  29. package/dist/esm/pages/matter-dashboard-app.d.ts.map +1 -1
  30. package/dist/esm/pages/matter-dashboard-app.js +84 -4
  31. package/dist/esm/pages/matter-dashboard-app.js.map +1 -1
  32. package/dist/esm/pages/matter-endpoint-view.d.ts.map +1 -1
  33. package/dist/esm/pages/matter-endpoint-view.js +8 -2
  34. package/dist/esm/pages/matter-endpoint-view.js.map +1 -1
  35. package/dist/esm/pages/matter-network-view.d.ts +52 -0
  36. package/dist/esm/pages/matter-network-view.d.ts.map +1 -0
  37. package/dist/esm/pages/matter-network-view.js +309 -0
  38. package/dist/esm/pages/matter-network-view.js.map +6 -0
  39. package/dist/esm/pages/matter-node-view.d.ts.map +1 -1
  40. package/dist/esm/pages/matter-node-view.js +86 -3
  41. package/dist/esm/pages/matter-node-view.js.map +1 -1
  42. package/dist/esm/pages/matter-server-view.d.ts +4 -0
  43. package/dist/esm/pages/matter-server-view.d.ts.map +1 -1
  44. package/dist/esm/pages/matter-server-view.js +16 -1
  45. package/dist/esm/pages/matter-server-view.js.map +1 -1
  46. package/dist/esm/pages/network/base-network-graph.d.ts +74 -0
  47. package/dist/esm/pages/network/base-network-graph.d.ts.map +1 -0
  48. package/dist/esm/pages/network/base-network-graph.js +411 -0
  49. package/dist/esm/pages/network/base-network-graph.js.map +6 -0
  50. package/dist/esm/pages/network/device-icons.d.ts +52 -0
  51. package/dist/esm/pages/network/device-icons.d.ts.map +1 -0
  52. package/dist/esm/pages/network/device-icons.js +197 -0
  53. package/dist/esm/pages/network/device-icons.js.map +6 -0
  54. package/dist/esm/pages/network/device-panel.d.ts +31 -0
  55. package/dist/esm/pages/network/device-panel.d.ts.map +1 -0
  56. package/dist/esm/pages/network/device-panel.js +183 -0
  57. package/dist/esm/pages/network/device-panel.js.map +6 -0
  58. package/dist/esm/pages/network/network-details.d.ts +77 -0
  59. package/dist/esm/pages/network/network-details.d.ts.map +1 -0
  60. package/dist/esm/pages/network/network-details.js +904 -0
  61. package/dist/esm/pages/network/network-details.js.map +6 -0
  62. package/dist/esm/pages/network/network-types.d.ts +159 -0
  63. package/dist/esm/pages/network/network-types.d.ts.map +1 -0
  64. package/dist/esm/pages/network/network-types.js +19 -0
  65. package/dist/esm/pages/network/network-types.js.map +6 -0
  66. package/dist/esm/pages/network/network-utils.d.ts +196 -0
  67. package/dist/esm/pages/network/network-utils.d.ts.map +1 -0
  68. package/dist/esm/pages/network/network-utils.js +540 -0
  69. package/dist/esm/pages/network/network-utils.js.map +6 -0
  70. package/dist/esm/pages/network/thread-graph.d.ts +27 -0
  71. package/dist/esm/pages/network/thread-graph.d.ts.map +1 -0
  72. package/dist/esm/pages/network/thread-graph.js +137 -0
  73. package/dist/esm/pages/network/thread-graph.js.map +6 -0
  74. package/dist/esm/pages/network/update-connections-dialog.d.ts +55 -0
  75. package/dist/esm/pages/network/update-connections-dialog.d.ts.map +1 -0
  76. package/dist/esm/pages/network/update-connections-dialog.js +284 -0
  77. package/dist/esm/pages/network/update-connections-dialog.js.map +6 -0
  78. package/dist/esm/pages/network/wifi-graph.d.ts +27 -0
  79. package/dist/esm/pages/network/wifi-graph.d.ts.map +1 -0
  80. package/dist/esm/pages/network/wifi-graph.js +169 -0
  81. package/dist/esm/pages/network/wifi-graph.js.map +6 -0
  82. package/dist/esm/util/format_hex.d.ts +18 -0
  83. package/dist/esm/util/format_hex.d.ts.map +1 -1
  84. package/dist/esm/util/format_hex.js +21 -1
  85. package/dist/esm/util/format_hex.js.map +1 -1
  86. package/dist/web/js/{commission-node-dialog-CBSDiqRW.js → commission-node-dialog-CcMuttYO.js} +5 -5
  87. package/dist/web/js/{commission-node-existing-TP6s8Tez.js → commission-node-existing-CqTRDMAr.js} +2 -5
  88. package/dist/web/js/{commission-node-thread-DOB8pu6x.js → commission-node-thread-DgwtTVwK.js} +2 -5
  89. package/dist/web/js/{commission-node-wifi-tzavmk1j.js → commission-node-wifi-XaN2SEnE.js} +2 -5
  90. package/dist/web/js/{dialog-box-Dknil_Be.js → dialog-box-COpDD8i7.js} +2 -2
  91. package/dist/web/js/{fire_event-DRpOSjJR.js → fire_event-mDYWi2sw.js} +1 -1
  92. package/dist/web/js/{log-level-dialog-TXkma-7Z.js → log-level-dialog-Bc32kZVw.js} +2 -3
  93. package/dist/web/js/main.js +1 -1
  94. package/dist/web/js/matter-dashboard-app-CrBHT4fT.js +31606 -0
  95. package/dist/web/js/{node-binding-dialog-D52FCBFP.js → node-binding-dialog-C8fqOJiB.js} +2 -4
  96. package/dist/web/js/prevent_default-D-ohDGsN.js +8 -0
  97. package/package.json +6 -5
  98. package/src/pages/cluster-commands/base-cluster-commands.ts +2 -2
  99. package/src/pages/cluster-commands/clusters/basic-information-commands.ts +171 -0
  100. package/src/pages/cluster-commands/index.ts +1 -0
  101. package/src/pages/components/footer.ts +4 -7
  102. package/src/pages/components/header.ts +81 -0
  103. package/src/pages/components/node-details.ts +3 -3
  104. package/src/pages/components/server-details.ts +0 -1
  105. package/src/pages/matter-cluster-view.ts +11 -4
  106. package/src/pages/matter-dashboard-app.ts +105 -5
  107. package/src/pages/matter-endpoint-view.ts +10 -3
  108. package/src/pages/matter-network-view.ts +325 -0
  109. package/src/pages/matter-node-view.ts +93 -4
  110. package/src/pages/matter-server-view.ts +17 -1
  111. package/src/pages/network/base-network-graph.ts +477 -0
  112. package/src/pages/network/device-icons.ts +283 -0
  113. package/src/pages/network/device-panel.ts +180 -0
  114. package/src/pages/network/network-details.ts +1015 -0
  115. package/src/pages/network/network-types.ts +167 -0
  116. package/src/pages/network/network-utils.ts +861 -0
  117. package/src/pages/network/thread-graph.ts +170 -0
  118. package/src/pages/network/update-connections-dialog.ts +327 -0
  119. package/src/pages/network/wifi-graph.ts +193 -0
  120. package/src/util/format_hex.ts +39 -0
  121. package/dist/web/js/matter-dashboard-app-B7GUghkC.js +0 -17254
  122. package/dist/web/js/outlined-text-field-D1DyKQY-.js +0 -968
  123. package/dist/web/js/prevent_default-BPgSQsuY.js +0 -814
  124. 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,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AAEpE,OAAO,EAAE,UAAU,EAAa,MAAM,KAAK,CAAC;AAG5C,OAAO,2BAA2B,CAAC;AACnC,OAAO,qBAAqB,CAAC;AAC7B,OAAO,2BAA2B,CAAC;AAGnC,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;IAqDf,OAAO,CAAC,OAAO;IAIf,OAAgB,MAAM,0BA2BpB;CACL"}
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 { mdiChevronRight } from "@mdi/js";
21
- import { LitElement, css, html } from "lit";
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=${"Node " + this.node.node_id}
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;AAEP,SAAS,uBAAuB;AAChC,SAAS,YAAY,KAAK,YAAY;AACtC,SAAS,eAAe,gBAAgB;AACxC,SAAS,aAAa;AACtB,OAAO;AACP,OAAO;AACP,OAAO;AACP,SAAS,8BAA8B;AAQvC,SAAS,mBAAmB,MAAkB;AAE1C,SAAO,MAAM,KAAK,IAAI,IAAI,OAAO,KAAK,KAAK,UAAU,EAAE,IAAI,SAAO,OAAO,IAAI,MAAM,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,GAAG,MAAM;AAC1G,WAAO,IAAI;AAAA,EACf,CAAC;AACL;AAGA,IAAM,iBAAN,cAA6B,WAAW;AAAA,EAM3B,SAAS;AACd,QAAI,CAAC,KAAK,MAAM;AACZ,aAAO;AAAA;AAAA,iCAEc,KAAK,OAAO;AAAA;AAAA,IAErC;AAEA,WAAO;AAAA;AAAA,yBAEU,UAAU,KAAK,KAAK,OAAO;AAAA,0BAC1B,KAAK,MAAM;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,sCAMC,KAAK,IAAI,YAAY,KAAK,MAAM;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,sBAWhD;AAAA,MAAM,CAAC,KAAK,MAAM,WAAW,MAAM;AAAA,MAAG,MACpC,mBAAmB,KAAK,IAAK,EAAE,IAAI,gBAAc;AAC7C,eAAO;AAAA,iEAC8B,SAAS,KAAK,KAAM,OAAO,IAAI,UAAU,EAAE;AAAA,oEACxC,UAAU;AAAA;AAAA;AAAA,0CAGpC,uBAAuB,KAAK,MAAO,UAAU,EAC1C,IAAI,gBAAc;AACf,iBAAO,WAAW;AAAA,QACtB,CAAC,EACA,KAAK,KAAK,CAAC;AAAA;AAAA,oEAEY,eAAe;AAAA;AAAA;AAAA,MAG3D,CAAC;AAAA,IACL,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAMjB;AAAA,EAEQ,UAAU;AACd,YAAQ,KAAK;AAAA,EACjB;AA8BJ;AA3FM,eA+Dc,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;AA3DlB;AAAA,EADN,SAAS;AAAA,GAHR,eAIK;AAJL,iBAAN;AAAA,EADC,cAAc,kBAAkB;AAAA,GAC3B;",
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;IAErC,OAAO,CAAC,YAAY,CAAC,CAAwB;IAC7C,OAAO,CAAC,kBAAkB,CAAC,CAAyB;IAEpD,OAAO,CAAC,cAAc;IAQb,MAAM;IAiDf,OAAgB,MAAM,0BA8CpB;CACL"}
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 title="Open Home Foundation Matter Server" .client=${this.client}></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;AACP,OAAO;AASP,IAAM,mBAAN,cAA+B,WAAW;AAAA,EAS9B,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,mFACoE,KAAK,MAAM;AAAA;AAAA;AAAA;AAAA,0CAIpD,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;AAjHM,iBAkEc,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;AA9DlB;AAAA,EADN,SAAS;AAAA,GAHR,iBAIK;AAJL,mBAAN;AAAA,EADC,cAAc,oBAAoB;AAAA,GAC7B;",
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"}