annotate src/main.ts @ 0:5a77696c6dab

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