annotate src/main.ts @ 9:9f427d8073c3

redo data model; add ui colors
author drewp@bigasterisk.com
date Sun, 28 Jan 2024 16:53:08 -0800
parents c04563fc8616
children 028ed39aa78f
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
drewp@bigasterisk.com
parents:
diff changeset
1 import { LitElement, css, html } from "lit";
drewp@bigasterisk.com
parents:
diff changeset
2 import { customElement, state } from "lit/decorators.js";
drewp@bigasterisk.com
parents:
diff changeset
3
drewp@bigasterisk.com
parents:
diff changeset
4 @customElement("lb-page")
drewp@bigasterisk.com
parents:
diff changeset
5 export class LbPage extends LitElement {
drewp@bigasterisk.com
parents:
diff changeset
6 static styles = [
drewp@bigasterisk.com
parents:
diff changeset
7 css`
drewp@bigasterisk.com
parents:
diff changeset
8 :host {
drewp@bigasterisk.com
parents:
diff changeset
9 display: flex;
drewp@bigasterisk.com
parents:
diff changeset
10 flex-direction: column;
drewp@bigasterisk.com
parents:
diff changeset
11 height: 100vh;
drewp@bigasterisk.com
parents:
diff changeset
12 }
drewp@bigasterisk.com
parents:
diff changeset
13 table {
drewp@bigasterisk.com
parents:
diff changeset
14 border-collapse: collapse;
drewp@bigasterisk.com
parents:
diff changeset
15 }
drewp@bigasterisk.com
parents:
diff changeset
16 td,
drewp@bigasterisk.com
parents:
diff changeset
17 th {
drewp@bigasterisk.com
parents:
diff changeset
18 border: 1px solid #aaa;
drewp@bigasterisk.com
parents:
diff changeset
19 text-align: center;
drewp@bigasterisk.com
parents:
diff changeset
20 }
drewp@bigasterisk.com
parents:
diff changeset
21 .color {
drewp@bigasterisk.com
parents:
diff changeset
22 display: inline-block;
drewp@bigasterisk.com
parents:
diff changeset
23 width: 30px;
drewp@bigasterisk.com
parents:
diff changeset
24 height: 30px;
drewp@bigasterisk.com
parents:
diff changeset
25 border-radius: 50%;
drewp@bigasterisk.com
parents:
diff changeset
26 margin: 3px;
drewp@bigasterisk.com
parents:
diff changeset
27 vertical-align: middle;
drewp@bigasterisk.com
parents:
diff changeset
28 }
9
9f427d8073c3 redo data model; add ui colors
drewp@bigasterisk.com
parents: 3
diff changeset
29 .col-group-1 {
9f427d8073c3 redo data model; add ui colors
drewp@bigasterisk.com
parents: 3
diff changeset
30 background: #e0ecf4;
9f427d8073c3 redo data model; add ui colors
drewp@bigasterisk.com
parents: 3
diff changeset
31 }
9f427d8073c3 redo data model; add ui colors
drewp@bigasterisk.com
parents: 3
diff changeset
32 .col-group-2 {
9f427d8073c3 redo data model; add ui colors
drewp@bigasterisk.com
parents: 3
diff changeset
33 background: #e0f3db;
9f427d8073c3 redo data model; add ui colors
drewp@bigasterisk.com
parents: 3
diff changeset
34 }
9f427d8073c3 redo data model; add ui colors
drewp@bigasterisk.com
parents: 3
diff changeset
35 .col-group-3 {
9f427d8073c3 redo data model; add ui colors
drewp@bigasterisk.com
parents: 3
diff changeset
36 background: #fee8c8;
9f427d8073c3 redo data model; add ui colors
drewp@bigasterisk.com
parents: 3
diff changeset
37 }
0
drewp@bigasterisk.com
parents:
diff changeset
38 `,
drewp@bigasterisk.com
parents:
diff changeset
39 ];
3
c04563fc8616 quiet some ts warnings
drewp@bigasterisk.com
parents: 1
diff changeset
40
c04563fc8616 quiet some ts warnings
drewp@bigasterisk.com
parents: 1
diff changeset
41 // bug https://github.com/lit/lit/issues/4305
9
9f427d8073c3 redo data model; add ui colors
drewp@bigasterisk.com
parents: 3
diff changeset
42 @((state as any)()) lights: object[] = [];
9f427d8073c3 redo data model; add ui colors
drewp@bigasterisk.com
parents: 3
diff changeset
43 @((state as any)()) reportTime: Date = new Date(0);
0
drewp@bigasterisk.com
parents:
diff changeset
44
drewp@bigasterisk.com
parents:
diff changeset
45 connectedCallback(): void {
drewp@bigasterisk.com
parents:
diff changeset
46 super.connectedCallback();
drewp@bigasterisk.com
parents:
diff changeset
47 const es = new EventSource("api/table");
drewp@bigasterisk.com
parents:
diff changeset
48 es.onmessage = (ev) => {
1
42a494b8ee1a show report time
drewp@bigasterisk.com
parents: 0
diff changeset
49 const body = JSON.parse(ev.data);
42a494b8ee1a show report time
drewp@bigasterisk.com
parents: 0
diff changeset
50 this.lights = body.lights;
42a494b8ee1a show report time
drewp@bigasterisk.com
parents: 0
diff changeset
51 this.reportTime = new Date(body.now * 1000);
0
drewp@bigasterisk.com
parents:
diff changeset
52 };
drewp@bigasterisk.com
parents:
diff changeset
53 }
drewp@bigasterisk.com
parents:
diff changeset
54 render() {
drewp@bigasterisk.com
parents:
diff changeset
55 return html`
drewp@bigasterisk.com
parents:
diff changeset
56 <h1>Light-bridge</h1>
drewp@bigasterisk.com
parents:
diff changeset
57
drewp@bigasterisk.com
parents:
diff changeset
58 <table>
drewp@bigasterisk.com
parents:
diff changeset
59 <tr>
9
9f427d8073c3 redo data model; add ui colors
drewp@bigasterisk.com
parents: 3
diff changeset
60 <th class="col-group-1">light</th>
9f427d8073c3 redo data model; add ui colors
drewp@bigasterisk.com
parents: 3
diff changeset
61 <th class="col-group-1">address</th>
9f427d8073c3 redo data model; add ui colors
drewp@bigasterisk.com
parents: 3
diff changeset
62 <th class="col-group-2">requested color</th>
9f427d8073c3 redo data model; add ui colors
drewp@bigasterisk.com
parents: 3
diff changeset
63 <th class="col-group-2">requested device color</th>
9f427d8073c3 redo data model; add ui colors
drewp@bigasterisk.com
parents: 3
diff changeset
64 <th class="col-group-3">emitting color</th>
9f427d8073c3 redo data model; add ui colors
drewp@bigasterisk.com
parents: 3
diff changeset
65 <th class="col-group-3">online</th>
9f427d8073c3 redo data model; add ui colors
drewp@bigasterisk.com
parents: 3
diff changeset
66 <th class="col-group-3">latency</th>
0
drewp@bigasterisk.com
parents:
diff changeset
67 </tr>
drewp@bigasterisk.com
parents:
diff changeset
68 ${this.lights.map(
drewp@bigasterisk.com
parents:
diff changeset
69 (d: any) => html`
drewp@bigasterisk.com
parents:
diff changeset
70 <tr>
9
9f427d8073c3 redo data model; add ui colors
drewp@bigasterisk.com
parents: 3
diff changeset
71 <td class="col-group-1">${d.light.name}</td>
9f427d8073c3 redo data model; add ui colors
drewp@bigasterisk.com
parents: 3
diff changeset
72 <td class="col-group-1"><code>${d.light.address}</code></td>
9f427d8073c3 redo data model; add ui colors
drewp@bigasterisk.com
parents: 3
diff changeset
73 <td class="col-group-2">
9f427d8073c3 redo data model; add ui colors
drewp@bigasterisk.com
parents: 3
diff changeset
74 <code>${d.light.requestingColor}</code>
9f427d8073c3 redo data model; add ui colors
drewp@bigasterisk.com
parents: 3
diff changeset
75 <input type="color" @input=${this.onRequestingColor.bind(this, d.light.name)} .value="${d.light.requestingColor}" />
0
drewp@bigasterisk.com
parents:
diff changeset
76 </td>
9
9f427d8073c3 redo data model; add ui colors
drewp@bigasterisk.com
parents: 3
diff changeset
77 <td class="col-group-2"><code>${JSON.stringify(d.light.requestingDeviceColor)}</code></td>
9f427d8073c3 redo data model; add ui colors
drewp@bigasterisk.com
parents: 3
diff changeset
78 <td class="col-group-3">${d.light.emittingColor} <span class="color" style="background: ${d.light.emittingColor}"></span></td>
9f427d8073c3 redo data model; add ui colors
drewp@bigasterisk.com
parents: 3
diff changeset
79 <td class="col-group-3">${d.light.online ? "✔" : ""}</td>
9f427d8073c3 redo data model; add ui colors
drewp@bigasterisk.com
parents: 3
diff changeset
80 <td class="col-group-3">${d.light.latencyMs} ms</td>
0
drewp@bigasterisk.com
parents:
diff changeset
81 </tr>
drewp@bigasterisk.com
parents:
diff changeset
82 `
drewp@bigasterisk.com
parents:
diff changeset
83 )}
drewp@bigasterisk.com
parents:
diff changeset
84 </table>
1
42a494b8ee1a show report time
drewp@bigasterisk.com
parents: 0
diff changeset
85 <p>Updated ${this.reportTime.toLocaleString("sv")}</p>
0
drewp@bigasterisk.com
parents:
diff changeset
86 <p>
drewp@bigasterisk.com
parents:
diff changeset
87 <a href="metrics">metrics</a> |
drewp@bigasterisk.com
parents:
diff changeset
88 <a href="api/graph">graph</a>
drewp@bigasterisk.com
parents:
diff changeset
89 </p>
drewp@bigasterisk.com
parents:
diff changeset
90 <bigast-loginbar></bigast-loginbar>
drewp@bigasterisk.com
parents:
diff changeset
91 `;
drewp@bigasterisk.com
parents:
diff changeset
92 }
9
9f427d8073c3 redo data model; add ui colors
drewp@bigasterisk.com
parents: 3
diff changeset
93 onRequestingColor(lightName: string, ev: InputEvent) {
0
drewp@bigasterisk.com
parents:
diff changeset
94 const value = (ev.target as HTMLInputElement).value;
drewp@bigasterisk.com
parents:
diff changeset
95 const url = new URL("api/output", location as any);
drewp@bigasterisk.com
parents:
diff changeset
96 url.searchParams.append("light", lightName);
drewp@bigasterisk.com
parents:
diff changeset
97 fetch(url, { method: "PUT", body: value }); // todo: only run one fetch at a time, per light
drewp@bigasterisk.com
parents:
diff changeset
98 }
drewp@bigasterisk.com
parents:
diff changeset
99 }