@matter-server/dashboard 0.3.2 → 0.3.3

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 (104) hide show
  1. package/dist/esm/pages/cluster-commands/base-cluster-commands.d.ts +2 -2
  2. package/dist/esm/pages/cluster-commands/base-cluster-commands.d.ts.map +1 -1
  3. package/dist/esm/pages/cluster-commands/base-cluster-commands.js.map +1 -1
  4. package/dist/esm/pages/cluster-commands/clusters/basic-information-commands.d.ts +36 -0
  5. package/dist/esm/pages/cluster-commands/clusters/basic-information-commands.d.ts.map +1 -0
  6. package/dist/esm/pages/cluster-commands/clusters/basic-information-commands.js +159 -0
  7. package/dist/esm/pages/cluster-commands/clusters/basic-information-commands.js.map +6 -0
  8. package/dist/esm/pages/cluster-commands/index.d.ts +1 -0
  9. package/dist/esm/pages/cluster-commands/index.d.ts.map +1 -1
  10. package/dist/esm/pages/cluster-commands/index.js +1 -0
  11. package/dist/esm/pages/cluster-commands/index.js.map +1 -1
  12. package/dist/esm/pages/components/footer.d.ts.map +1 -1
  13. package/dist/esm/pages/components/footer.js +4 -7
  14. package/dist/esm/pages/components/footer.js.map +1 -1
  15. package/dist/esm/pages/components/header.d.ts +5 -0
  16. package/dist/esm/pages/components/header.d.ts.map +1 -1
  17. package/dist/esm/pages/components/header.js +75 -0
  18. package/dist/esm/pages/components/header.js.map +1 -1
  19. package/dist/esm/pages/components/node-details.js +1 -1
  20. package/dist/esm/pages/components/node-details.js.map +1 -1
  21. package/dist/esm/pages/components/server-details.d.ts.map +1 -1
  22. package/dist/esm/pages/components/server-details.js +0 -1
  23. package/dist/esm/pages/components/server-details.js.map +1 -1
  24. package/dist/esm/pages/matter-dashboard-app.d.ts +12 -0
  25. package/dist/esm/pages/matter-dashboard-app.d.ts.map +1 -1
  26. package/dist/esm/pages/matter-dashboard-app.js +84 -4
  27. package/dist/esm/pages/matter-dashboard-app.js.map +1 -1
  28. package/dist/esm/pages/matter-network-view.d.ts +52 -0
  29. package/dist/esm/pages/matter-network-view.d.ts.map +1 -0
  30. package/dist/esm/pages/matter-network-view.js +309 -0
  31. package/dist/esm/pages/matter-network-view.js.map +6 -0
  32. package/dist/esm/pages/matter-node-view.d.ts.map +1 -1
  33. package/dist/esm/pages/matter-node-view.js +70 -1
  34. package/dist/esm/pages/matter-node-view.js.map +1 -1
  35. package/dist/esm/pages/matter-server-view.d.ts +4 -0
  36. package/dist/esm/pages/matter-server-view.d.ts.map +1 -1
  37. package/dist/esm/pages/matter-server-view.js +16 -1
  38. package/dist/esm/pages/matter-server-view.js.map +1 -1
  39. package/dist/esm/pages/network/base-network-graph.d.ts +74 -0
  40. package/dist/esm/pages/network/base-network-graph.d.ts.map +1 -0
  41. package/dist/esm/pages/network/base-network-graph.js +403 -0
  42. package/dist/esm/pages/network/base-network-graph.js.map +6 -0
  43. package/dist/esm/pages/network/device-icons.d.ts +52 -0
  44. package/dist/esm/pages/network/device-icons.d.ts.map +1 -0
  45. package/dist/esm/pages/network/device-icons.js +197 -0
  46. package/dist/esm/pages/network/device-icons.js.map +6 -0
  47. package/dist/esm/pages/network/device-panel.d.ts +31 -0
  48. package/dist/esm/pages/network/device-panel.d.ts.map +1 -0
  49. package/dist/esm/pages/network/device-panel.js +183 -0
  50. package/dist/esm/pages/network/device-panel.js.map +6 -0
  51. package/dist/esm/pages/network/network-details.d.ts +47 -0
  52. package/dist/esm/pages/network/network-details.d.ts.map +1 -0
  53. package/dist/esm/pages/network/network-details.js +686 -0
  54. package/dist/esm/pages/network/network-details.js.map +6 -0
  55. package/dist/esm/pages/network/network-types.d.ts +153 -0
  56. package/dist/esm/pages/network/network-types.d.ts.map +1 -0
  57. package/dist/esm/pages/network/network-types.js +19 -0
  58. package/dist/esm/pages/network/network-types.js.map +6 -0
  59. package/dist/esm/pages/network/network-utils.d.ts +170 -0
  60. package/dist/esm/pages/network/network-utils.d.ts.map +1 -0
  61. package/dist/esm/pages/network/network-utils.js +472 -0
  62. package/dist/esm/pages/network/network-utils.js.map +6 -0
  63. package/dist/esm/pages/network/thread-graph.d.ts +27 -0
  64. package/dist/esm/pages/network/thread-graph.d.ts.map +1 -0
  65. package/dist/esm/pages/network/thread-graph.js +134 -0
  66. package/dist/esm/pages/network/thread-graph.js.map +6 -0
  67. package/dist/esm/pages/network/wifi-graph.d.ts +27 -0
  68. package/dist/esm/pages/network/wifi-graph.d.ts.map +1 -0
  69. package/dist/esm/pages/network/wifi-graph.js +167 -0
  70. package/dist/esm/pages/network/wifi-graph.js.map +6 -0
  71. package/dist/web/js/{commission-node-dialog-CBSDiqRW.js → commission-node-dialog-B1_khzZb.js} +5 -5
  72. package/dist/web/js/{commission-node-existing-TP6s8Tez.js → commission-node-existing-RpdajrwF.js} +2 -5
  73. package/dist/web/js/{commission-node-thread-DOB8pu6x.js → commission-node-thread-5f2itkTG.js} +2 -5
  74. package/dist/web/js/{commission-node-wifi-tzavmk1j.js → commission-node-wifi-DZ_pWqsa.js} +2 -5
  75. package/dist/web/js/{dialog-box-Dknil_Be.js → dialog-box-DEUxM4B1.js} +2 -2
  76. package/dist/web/js/{fire_event-DRpOSjJR.js → fire_event-BczBMT8E.js} +1 -1
  77. package/dist/web/js/{log-level-dialog-TXkma-7Z.js → log-level-dialog-Cr3PfX1X.js} +2 -3
  78. package/dist/web/js/main.js +1 -1
  79. package/dist/web/js/matter-dashboard-app-BuCe_Jxf.js +29990 -0
  80. package/dist/web/js/{node-binding-dialog-D52FCBFP.js → node-binding-dialog-DMiHNDLA.js} +2 -4
  81. package/dist/web/js/{prevent_default-BPgSQsuY.js → prevent_default-D4FX_PIh.js} +2 -42
  82. package/package.json +5 -4
  83. package/src/pages/cluster-commands/base-cluster-commands.ts +2 -2
  84. package/src/pages/cluster-commands/clusters/basic-information-commands.ts +171 -0
  85. package/src/pages/cluster-commands/index.ts +1 -0
  86. package/src/pages/components/footer.ts +4 -7
  87. package/src/pages/components/header.ts +81 -0
  88. package/src/pages/components/node-details.ts +2 -2
  89. package/src/pages/components/server-details.ts +0 -1
  90. package/src/pages/matter-dashboard-app.ts +105 -5
  91. package/src/pages/matter-network-view.ts +325 -0
  92. package/src/pages/matter-node-view.ts +75 -1
  93. package/src/pages/matter-server-view.ts +17 -1
  94. package/src/pages/network/base-network-graph.ts +463 -0
  95. package/src/pages/network/device-icons.ts +283 -0
  96. package/src/pages/network/device-panel.ts +180 -0
  97. package/src/pages/network/network-details.ts +750 -0
  98. package/src/pages/network/network-types.ts +161 -0
  99. package/src/pages/network/network-utils.ts +752 -0
  100. package/src/pages/network/thread-graph.ts +164 -0
  101. package/src/pages/network/wifi-graph.ts +192 -0
  102. package/dist/web/js/matter-dashboard-app-B7GUghkC.js +0 -17254
  103. package/dist/web/js/outlined-text-field-D1DyKQY-.js +0 -968
  104. package/dist/web/js/validator-C735j770.js +0 -1122
@@ -23,8 +23,10 @@ import { clone } from "../util/clone_class.js";
23
23
  import "./components/header";
24
24
  import "./matter-cluster-view";
25
25
  import "./matter-endpoint-view";
26
+ import "./matter-network-view";
26
27
  import "./matter-node-view";
27
28
  import "./matter-server-view";
29
+ import { categorizeDevices } from "./network/network-utils.js";
28
30
  let MatterDashboardApp = class extends LitElement {
29
31
  constructor() {
30
32
  super(...arguments);
@@ -32,7 +34,11 @@ let MatterDashboardApp = class extends LitElement {
32
34
  prefix: "",
33
35
  path: []
34
36
  };
37
+ this._activeView = "nodes";
38
+ this._initialSelectedNodeId = null;
35
39
  this._state = "connecting";
40
+ /** Track whether nodes have been loaded at least once (to avoid redirecting before data arrives) */
41
+ this._nodesLoaded = false;
36
42
  this.provider = new ContextProvider(this, { context: clientContext, initialValue: this.client });
37
43
  this._reconnect = () => {
38
44
  this._state = "connecting";
@@ -42,15 +48,39 @@ let MatterDashboardApp = class extends LitElement {
42
48
  firstUpdated(_changedProperties) {
43
49
  super.firstUpdated(_changedProperties);
44
50
  this._connect();
45
- const updateRoute = () => {
46
- const pathParts = location.hash.substring(1).split("/");
51
+ this._updateRoute = () => {
52
+ const hash = location.hash.substring(1);
53
+ const pathParts = hash.split("/");
54
+ this._initialSelectedNodeId = null;
55
+ const { hasThreadDevices, hasWifiDevices } = this._getDeviceCounts();
56
+ if (pathParts[0] === "thread") {
57
+ if (this._nodesLoaded && !hasThreadDevices) {
58
+ location.hash = "#nodes";
59
+ return;
60
+ }
61
+ this._activeView = "thread";
62
+ if (pathParts.length > 1 && pathParts[1]) {
63
+ this._initialSelectedNodeId = pathParts[1];
64
+ }
65
+ } else if (pathParts[0] === "wifi") {
66
+ if (this._nodesLoaded && !hasWifiDevices) {
67
+ location.hash = "#nodes";
68
+ return;
69
+ }
70
+ this._activeView = "wifi";
71
+ if (pathParts.length > 1 && pathParts[1]) {
72
+ this._initialSelectedNodeId = pathParts[1];
73
+ }
74
+ } else if (hash === "nodes" || hash === "" || pathParts[0] === "node") {
75
+ this._activeView = "nodes";
76
+ }
47
77
  this._route = {
48
78
  prefix: pathParts.length == 1 ? "" : pathParts[0],
49
79
  path: pathParts.length == 1 ? pathParts : pathParts.slice(1)
50
80
  };
51
81
  };
52
- window.addEventListener("hashchange", updateRoute);
53
- updateRoute();
82
+ window.addEventListener("hashchange", this._updateRoute);
83
+ this._updateRoute();
54
84
  }
55
85
  _connect() {
56
86
  this.client.startListening().then(
@@ -65,6 +95,11 @@ let MatterDashboardApp = class extends LitElement {
65
95
  }
66
96
  _setupEventListeners() {
67
97
  this.client.addEventListener("nodes_changed", () => {
98
+ const wasFirstLoad = !this._nodesLoaded;
99
+ this._nodesLoaded = true;
100
+ if (wasFirstLoad && this._updateRoute) {
101
+ this._updateRoute();
102
+ }
68
103
  this.requestUpdate();
69
104
  this.provider.setValue(clone(this.client));
70
105
  });
@@ -75,6 +110,19 @@ let MatterDashboardApp = class extends LitElement {
75
110
  this._state = "disconnected";
76
111
  });
77
112
  }
113
+ /**
114
+ * Get device counts for Thread and WiFi networks.
115
+ */
116
+ _getDeviceCounts() {
117
+ if (!this.client?.nodes) {
118
+ return { hasThreadDevices: false, hasWifiDevices: false };
119
+ }
120
+ const categorized = categorizeDevices(this.client.nodes);
121
+ return {
122
+ hasThreadDevices: categorized.thread.length > 0,
123
+ hasWifiDevices: categorized.wifi.length > 0 || categorized.ethernet.length > 0
124
+ };
125
+ }
78
126
  render() {
79
127
  if (this._state === "connecting") {
80
128
  return html`
@@ -141,10 +189,36 @@ let MatterDashboardApp = class extends LitElement {
141
189
  ></matter-node-view>
142
190
  `;
143
191
  }
192
+ const { hasThreadDevices, hasWifiDevices } = this._getDeviceCounts();
193
+ if (this._route.prefix === "thread" || this._route.path[0] === "thread") {
194
+ return html`<matter-network-view
195
+ .client=${this.client}
196
+ .nodes=${this.client.nodes}
197
+ .activeView=${this._activeView}
198
+ .initialSelectedNodeId=${this._initialSelectedNodeId}
199
+ .hasThreadDevices=${hasThreadDevices}
200
+ .hasWifiDevices=${hasWifiDevices}
201
+ networkType="thread"
202
+ ></matter-network-view>`;
203
+ }
204
+ if (this._route.prefix === "wifi" || this._route.path[0] === "wifi") {
205
+ return html`<matter-network-view
206
+ .client=${this.client}
207
+ .nodes=${this.client.nodes}
208
+ .activeView=${this._activeView}
209
+ .initialSelectedNodeId=${this._initialSelectedNodeId}
210
+ .hasThreadDevices=${hasThreadDevices}
211
+ .hasWifiDevices=${hasWifiDevices}
212
+ networkType="wifi"
213
+ ></matter-network-view>`;
214
+ }
144
215
  return html`<matter-server-view
145
216
  .client=${this.client}
146
217
  .nodes=${this.client.nodes}
147
218
  .route=${this._route}
219
+ .activeView=${this._activeView}
220
+ .hasThreadDevices=${hasThreadDevices}
221
+ .hasWifiDevices=${hasWifiDevices}
148
222
  ></matter-server-view>`;
149
223
  }
150
224
  };
@@ -208,6 +282,12 @@ MatterDashboardApp.styles = css`
208
282
  __decorateClass([
209
283
  state()
210
284
  ], MatterDashboardApp.prototype, "_route", 2);
285
+ __decorateClass([
286
+ state()
287
+ ], MatterDashboardApp.prototype, "_activeView", 2);
288
+ __decorateClass([
289
+ state()
290
+ ], MatterDashboardApp.prototype, "_initialSelectedNodeId", 2);
211
291
  __decorateClass([
212
292
  state()
213
293
  ], MatterDashboardApp.prototype, "_state", 2);
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../src/pages/matter-dashboard-app.ts"],
4
- "mappings": "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",
4
+ "mappings": "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",
5
5
  "names": []
6
6
  }
@@ -0,0 +1,52 @@
1
+ /**
2
+ * @license
3
+ * Copyright 2025-2026 Open Home Foundation
4
+ * SPDX-License-Identifier: Apache-2.0
5
+ */
6
+ import type { MatterClient, MatterNode } from "@matter-server/ws-client";
7
+ import { LitElement } from "lit";
8
+ import "../components/ha-svg-icon";
9
+ import "./components/footer";
10
+ import "./components/header";
11
+ import type { ActiveView } from "./components/header.js";
12
+ import "./network/device-panel";
13
+ import "./network/network-details";
14
+ import "./network/thread-graph";
15
+ import "./network/wifi-graph";
16
+ declare global {
17
+ interface HTMLElementTagNameMap {
18
+ "matter-network-view": MatterNetworkView;
19
+ }
20
+ }
21
+ declare class MatterNetworkView extends LitElement {
22
+ client: MatterClient;
23
+ nodes: Record<string, MatterNode>;
24
+ activeView?: ActiveView;
25
+ networkType: "thread" | "wifi";
26
+ /** Initial selected node ID from URL (string to avoid BigInt precision loss) */
27
+ initialSelectedNodeId: string | null;
28
+ hasThreadDevices?: boolean;
29
+ hasWifiDevices?: boolean;
30
+ private _selectedNodeId;
31
+ private _initialSelectionApplied;
32
+ private _selectRetryTimer?;
33
+ private _threadGraph?;
34
+ private _wifiGraph?;
35
+ willUpdate(changedProperties: Map<string, unknown>): void;
36
+ updated(changedProperties: Map<string, unknown>): void;
37
+ disconnectedCallback(): void;
38
+ /**
39
+ * Tries to select a node in the graph, retrying until the graph is ready.
40
+ */
41
+ private _selectNodeWhenReady;
42
+ private _handleNodeSelected;
43
+ private _handleDetailsClose;
44
+ private _handleSelectNode;
45
+ private _handleFitToScreen;
46
+ private _renderThreadView;
47
+ private _renderWifiView;
48
+ render(): import("lit-html").TemplateResult<1>;
49
+ static styles: import("lit").CSSResult;
50
+ }
51
+ export {};
52
+ //# sourceMappingURL=matter-network-view.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"matter-network-view.d.ts","sourceRoot":"","sources":["../../../src/pages/matter-network-view.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AAEzE,OAAO,EAAa,UAAU,EAAE,MAAM,KAAK,CAAC;AAE5C,OAAO,2BAA2B,CAAC;AACnC,OAAO,qBAAqB,CAAC;AAC7B,OAAO,qBAAqB,CAAC;AAC7B,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AACzD,OAAO,wBAAwB,CAAC;AAChC,OAAO,2BAA2B,CAAC;AACnC,OAAO,wBAAwB,CAAC;AAEhC,OAAO,sBAAsB,CAAC;AAG9B,OAAO,CAAC,MAAM,CAAC;IACX,UAAU,qBAAqB;QAC3B,qBAAqB,EAAE,iBAAiB,CAAC;KAC5C;CACJ;AAED,cACM,iBAAkB,SAAQ,UAAU;IAC/B,MAAM,EAAG,YAAY,CAAC;IAGtB,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,UAAU,CAAC,CAAM;IAGvC,UAAU,CAAC,EAAE,UAAU,CAAC;IAGxB,WAAW,EAAE,QAAQ,GAAG,MAAM,CAAY;IAEjD,gFAAgF;IAEzE,qBAAqB,EAAE,MAAM,GAAG,IAAI,CAAQ;IAG5C,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAG3B,cAAc,CAAC,EAAE,OAAO,CAAC;IAGhC,OAAO,CAAC,eAAe,CAAgC;IAEvD,OAAO,CAAC,wBAAwB,CAAS;IACzC,OAAO,CAAC,iBAAiB,CAAC,CAAgC;IAG1D,OAAO,CAAC,YAAY,CAAC,CAAc;IAGnC,OAAO,CAAC,UAAU,CAAC,CAAY;IAEtB,UAAU,CAAC,iBAAiB,EAAE,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAQzD,OAAO,CAAC,iBAAiB,EAAE,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAWtD,oBAAoB,IAAI,IAAI;IAOrC;;OAEG;IACH,OAAO,CAAC,oBAAoB;IAW5B,OAAO,CAAC,mBAAmB;IAI3B,OAAO,CAAC,mBAAmB;IAI3B,OAAO,CAAC,iBAAiB;IAWzB,OAAO,CAAC,kBAAkB;IAQ1B,OAAO,CAAC,iBAAiB;IAczB,OAAO,CAAC,eAAe;IAcd,MAAM;IAmCf,OAAgB,MAAM,0BAmIpB;CACL"}
@@ -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,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;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;IAuEf,OAAO,CAAC,OAAO;IAIf,OAAgB,MAAM,0BAkFpB;CACL"}
@@ -17,7 +17,7 @@ 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";
20
+ import { mdiChevronRight, mdiGraphOutline } from "@mdi/js";
21
21
  import { LitElement, css, html } from "lit";
22
22
  import { customElement, property } from "lit/decorators.js";
23
23
  import { guard } from "lit/directives/guard.js";
@@ -25,6 +25,7 @@ import "../components/ha-svg-icon";
25
25
  import "./components/header";
26
26
  import "./components/node-details";
27
27
  import { getEndpointDeviceTypes } from "./matter-endpoint-view.js";
28
+ import { getNetworkType } from "./network/network-utils.js";
28
29
  function getUniqueEndpoints(node) {
29
30
  return Array.from(new Set(Object.keys(node.attributes).map((key) => Number(key.split("/")[0])))).sort((a, b) => {
30
31
  return a - b;
@@ -38,6 +39,10 @@ let MatterNodeView = class extends LitElement {
38
39
  <button @click=${this._goBack}>Back</button>
39
40
  `;
40
41
  }
42
+ const networkType = getNetworkType(this.node);
43
+ const showGraphButton = networkType === "thread" || networkType === "wifi" || networkType === "ethernet";
44
+ const graphViewType = networkType === "ethernet" ? "wifi" : networkType;
45
+ const graphUrl = showGraphButton ? `#${graphViewType}/${this.node.node_id}` : null;
41
46
  return html`
42
47
  <dashboard-header
43
48
  .title=${"Node " + this.node.node_id}
@@ -47,6 +52,15 @@ let MatterNodeView = class extends LitElement {
47
52
 
48
53
  <!-- node details section -->
49
54
  <div class="container">
55
+ <div class="node-title-bar">
56
+ <h2>Node ${this.node.node_id}</h2>
57
+ ${showGraphButton ? html`
58
+ <a href=${graphUrl} class="show-in-graph-button" title="Show in ${graphViewType} graph">
59
+ <ha-svg-icon .path=${mdiGraphOutline}></ha-svg-icon>
60
+ <span class="button-text">Show in graph</span>
61
+ </a>
62
+ ` : ""}
63
+ </div>
50
64
  <node-details .node=${this.node} .client=${this.client}></node-details>
51
65
  </div>
52
66
 
@@ -112,6 +126,61 @@ MatterNodeView.styles = css`
112
126
  font-weight: bold;
113
127
  font-size: 0.8em;
114
128
  }
129
+
130
+ .node-title-bar {
131
+ display: flex;
132
+ align-items: center;
133
+ gap: 16px;
134
+ margin-bottom: 16px;
135
+ }
136
+
137
+ .node-title-bar h2 {
138
+ margin: 0;
139
+ font-size: 1.25rem;
140
+ font-weight: 500;
141
+ color: var(--md-sys-color-on-background, #333);
142
+ }
143
+
144
+ .show-in-graph-button {
145
+ display: inline-flex;
146
+ align-items: center;
147
+ gap: 6px;
148
+ padding: 6px 12px;
149
+ background-color: var(--md-sys-color-primary);
150
+ color: var(--md-sys-color-on-primary);
151
+ text-decoration: none;
152
+ border-radius: 4px;
153
+ font-size: 0.8rem;
154
+ font-weight: 500;
155
+ transition: opacity 0.2s;
156
+ white-space: nowrap;
157
+ }
158
+
159
+ .show-in-graph-button:hover {
160
+ opacity: 0.9;
161
+ }
162
+
163
+ .show-in-graph-button ha-svg-icon {
164
+ --icon-primary-color: var(--md-sys-color-on-primary);
165
+ width: 16px;
166
+ height: 16px;
167
+ }
168
+
169
+ @media (max-width: 768px) {
170
+ .show-in-graph-button {
171
+ display: none;
172
+ }
173
+ }
174
+
175
+ @media (max-width: 480px) {
176
+ .show-in-graph-button .button-text {
177
+ display: none;
178
+ }
179
+
180
+ .show-in-graph-button {
181
+ padding: 6px;
182
+ }
183
+ }
115
184
  `;
116
185
  __decorateClass([
117
186
  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": ";;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAMA,OAAO;AACP,OAAO;AACP,OAAO;AACP,OAAO;AAEP,SAAS,iBAAiB,uBAAuB;AACjD,SAAS,YAAY,KAAK,YAAY;AACtC,SAAS,eAAe,gBAAgB;AACxC,SAAS,aAAa;AACtB,OAAO;AACP,OAAO;AACP,OAAO;AACP,SAAS,8BAA8B;AACvC,SAAS,sBAAsB;AAQ/B,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,UAAM,cAAc,eAAe,KAAK,IAAI;AAE5C,UAAM,kBAAkB,gBAAgB,YAAY,gBAAgB,UAAU,gBAAgB;AAE9F,UAAM,gBAAgB,gBAAgB,aAAa,SAAS;AAC5D,UAAM,WAAW,kBAAkB,IAAI,aAAa,IAAI,KAAK,KAAK,OAAO,KAAK;AAE9E,WAAO;AAAA;AAAA,yBAEU,UAAU,KAAK,KAAK,OAAO;AAAA,0BAC1B,KAAK,MAAM;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,+BAON,KAAK,KAAK,OAAO;AAAA,sBAC1B,kBACI;AAAA,wCACc,QAAQ,gDAAgD,aAAa;AAAA,uDACtD,eAAe;AAAA;AAAA;AAAA,8BAI5C,EAAE;AAAA;AAAA,sCAEU,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;AAqFJ;AApKM,eAiFc,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;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,eAIK;AAJL,iBAAN;AAAA,EADC,cAAc,kBAAkB;AAAA,GAC3B;",
5
5
  "names": []
6
6
  }