annotate web/TiledHome.ts @ 2400:9a4bc2ea264e

ui tweaks and link fix
author drewp@bigasterisk.com
date Fri, 17 May 2024 13:25:46 -0700
parents 40d5a54dec99
children 1d3594ffd14b
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
2374
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
1 import * as React from "react";
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
2 import { createRoot } from "react-dom/client";
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
3 import * as FlexLayout from "flexlayout-react";
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
4 export { Light9DeviceSettings } from "./live/Light9DeviceSettings";
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
5 export { Light9CollectorUi } from "./collector/Light9CollectorUi";
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
6
2382
40d5a54dec99 ts warnings
drewp@bigasterisk.com
parents: 2376
diff changeset
7 const config: FlexLayout.IJsonModel = {
2374
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
8 global: {},
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
9 borders: [],
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
10 layout: {
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
11 type: "row",
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
12 weight: 100,
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
13 children: [
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
14 {
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
15 type: "tabset",
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
16 weight: 50,
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
17 children: [{ type: "tab", name: "devsettings", component: "light9-device-settings" }],
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
18 },
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
19 {
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
20 type: "tabset",
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
21 weight: 50,
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
22 children: [{ type: "tab", name: "collector", component: "light9-collector-ui" }],
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
23 },
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
24 ],
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
25 },
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
26 };
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
27
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
28 const e = React.createElement;
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
29
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
30 // see https://github.com/lit/lit/tree/main/packages/labs/react
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
31
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
32 class Main extends React.Component {
2382
40d5a54dec99 ts warnings
drewp@bigasterisk.com
parents: 2376
diff changeset
33 state: { model: FlexLayout.Model };
40d5a54dec99 ts warnings
drewp@bigasterisk.com
parents: 2376
diff changeset
34 constructor(props: any) {
2374
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
35 super(props);
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
36 this.state = { model: FlexLayout.Model.fromJson(config) };
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
37 }
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
38
2382
40d5a54dec99 ts warnings
drewp@bigasterisk.com
parents: 2376
diff changeset
39 factory = (node: any) => {
2374
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
40 var component = node.getComponent();
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
41 return e(component, null, "");
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
42 };
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
43
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
44 render() {
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
45 return e(FlexLayout.Layout, { model: this.state.model, factory: this.factory });
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
46 }
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
47 }
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
48
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
49 const root = createRoot(document.getElementById("container")!);
9d47c44d4ae4 experimental tiled-layout home page
drewp@bigasterisk.com
parents:
diff changeset
50 root.render(React.createElement(Main));