annotate src/main.ts @ 3:c04563fc8616

quiet some ts warnings
author drewp@bigasterisk.com
date Sun, 28 Jan 2024 16:00:43 -0800
parents 42a494b8ee1a
children 9f427d8073c3
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 }
drewp@bigasterisk.com
parents:
diff changeset
29 `,
drewp@bigasterisk.com
parents:
diff changeset
30 ];
3
c04563fc8616 quiet some ts warnings
drewp@bigasterisk.com
parents: 1
diff changeset
31
c04563fc8616 quiet some ts warnings
drewp@bigasterisk.com
parents: 1
diff changeset
32 // bug https://github.com/lit/lit/issues/4305
c04563fc8616 quiet some ts warnings
drewp@bigasterisk.com
parents: 1
diff changeset
33 @(state as any)() lights: object[] = [];
c04563fc8616 quiet some ts warnings
drewp@bigasterisk.com
parents: 1
diff changeset
34 @(state as any)() reportTime: Date = new Date(0);
0
drewp@bigasterisk.com
parents:
diff changeset
35
drewp@bigasterisk.com
parents:
diff changeset
36 connectedCallback(): void {
drewp@bigasterisk.com
parents:
diff changeset
37 super.connectedCallback();
drewp@bigasterisk.com
parents:
diff changeset
38 const es = new EventSource("api/table");
drewp@bigasterisk.com
parents:
diff changeset
39 es.onmessage = (ev) => {
1
42a494b8ee1a show report time
drewp@bigasterisk.com
parents: 0
diff changeset
40 const body = JSON.parse(ev.data);
42a494b8ee1a show report time
drewp@bigasterisk.com
parents: 0
diff changeset
41 this.lights = body.lights;
42a494b8ee1a show report time
drewp@bigasterisk.com
parents: 0
diff changeset
42 this.reportTime = new Date(body.now * 1000);
0
drewp@bigasterisk.com
parents:
diff changeset
43 };
drewp@bigasterisk.com
parents:
diff changeset
44 }
drewp@bigasterisk.com
parents:
diff changeset
45 render() {
drewp@bigasterisk.com
parents:
diff changeset
46 return html`
drewp@bigasterisk.com
parents:
diff changeset
47 <h1>Light-bridge</h1>
drewp@bigasterisk.com
parents:
diff changeset
48
drewp@bigasterisk.com
parents:
diff changeset
49 <table>
drewp@bigasterisk.com
parents:
diff changeset
50 <tr>
drewp@bigasterisk.com
parents:
diff changeset
51 <th>light</th>
drewp@bigasterisk.com
parents:
diff changeset
52 <th>address</th>
drewp@bigasterisk.com
parents:
diff changeset
53 <th>online</th>
drewp@bigasterisk.com
parents:
diff changeset
54 <th>color request</th>
drewp@bigasterisk.com
parents:
diff changeset
55 <th>color message</th>
drewp@bigasterisk.com
parents:
diff changeset
56 <th>color current</th>
drewp@bigasterisk.com
parents:
diff changeset
57 <th>latency</th>
drewp@bigasterisk.com
parents:
diff changeset
58 </tr>
drewp@bigasterisk.com
parents:
diff changeset
59 ${this.lights.map(
drewp@bigasterisk.com
parents:
diff changeset
60 (d: any) => html`
drewp@bigasterisk.com
parents:
diff changeset
61 <tr>
drewp@bigasterisk.com
parents:
diff changeset
62 <td>${d.light.name}</td>
drewp@bigasterisk.com
parents:
diff changeset
63 <td><code>${d.light.address}</code></td>
drewp@bigasterisk.com
parents:
diff changeset
64 <td>${d.light.online ? "✔" : ""}</td>
drewp@bigasterisk.com
parents:
diff changeset
65 <td>
drewp@bigasterisk.com
parents:
diff changeset
66 <code>${d.light.colorRequest}</code>
drewp@bigasterisk.com
parents:
diff changeset
67 <input type="color" @input=${this.onColorRequest.bind(this, d.light.name)} value="${d.light.colorRequest}" />
drewp@bigasterisk.com
parents:
diff changeset
68 </td>
drewp@bigasterisk.com
parents:
diff changeset
69 <td><code>${JSON.stringify(d.light.colorMessage)}</code></td>
drewp@bigasterisk.com
parents:
diff changeset
70 <td>${d.light.colorCurrent} <span class="color" style="background: ${d.light.colorCurrent}"></span></td>
drewp@bigasterisk.com
parents:
diff changeset
71 <td>${d.light.latencyMs} ms</td>
drewp@bigasterisk.com
parents:
diff changeset
72 </tr>
drewp@bigasterisk.com
parents:
diff changeset
73 `
drewp@bigasterisk.com
parents:
diff changeset
74 )}
drewp@bigasterisk.com
parents:
diff changeset
75 </table>
1
42a494b8ee1a show report time
drewp@bigasterisk.com
parents: 0
diff changeset
76 <p>Updated ${this.reportTime.toLocaleString("sv")}</p>
0
drewp@bigasterisk.com
parents:
diff changeset
77 <p>
drewp@bigasterisk.com
parents:
diff changeset
78 <a href="metrics">metrics</a> |
drewp@bigasterisk.com
parents:
diff changeset
79 <a href="api/graph">graph</a>
drewp@bigasterisk.com
parents:
diff changeset
80 </p>
drewp@bigasterisk.com
parents:
diff changeset
81 <bigast-loginbar></bigast-loginbar>
drewp@bigasterisk.com
parents:
diff changeset
82 `;
drewp@bigasterisk.com
parents:
diff changeset
83 }
drewp@bigasterisk.com
parents:
diff changeset
84 onColorRequest(lightName: string, ev: InputEvent) {
drewp@bigasterisk.com
parents:
diff changeset
85 const value = (ev.target as HTMLInputElement).value;
drewp@bigasterisk.com
parents:
diff changeset
86 const url = new URL("api/output", location as any);
drewp@bigasterisk.com
parents:
diff changeset
87 url.searchParams.append("light", lightName);
drewp@bigasterisk.com
parents:
diff changeset
88 fetch(url, { method: "PUT", body: value }); // todo: only run one fetch at a time, per light
drewp@bigasterisk.com
parents:
diff changeset
89 }
drewp@bigasterisk.com
parents:
diff changeset
90 }