diff --git a/website/src/components/app/-app.tsx b/website/src/components/app/-app.tsx index a71d70a..be237fe 100644 --- a/website/src/components/app/-app.tsx +++ b/website/src/components/app/-app.tsx @@ -1,10 +1,13 @@ import { Card, CardBody, CardHeader } from '@nextui-org/card'; +import { Chip } from '@nextui-org/chip'; import { Listbox, ListboxItem, ListboxSection } from '@nextui-org/listbox'; import { Table, TableBody, TableCell, TableColumn, TableHeader, TableRow } from '@nextui-org/table'; import Image from 'next/image'; +import Link from 'next/link'; import { Just, Maybe, Nothing } from 'purify-ts/Maybe'; import { useState } from 'react'; import { LhpData } from './-data'; +import { KVBox } from './-ui'; export function App({ data, onFlushRequest }: { data: LhpData[]; onFlushRequest: () => void }) { const [host, setHost] = useState>(Nothing); @@ -54,17 +57,17 @@ export function Sidebar({ data, onHostSelect, onTabulateRequest, onFlushRequest onHostSelect(host)}>
{`logo {`logo {host.host.name} @@ -107,9 +110,9 @@ export function TabulateHosts({ hosts, onHostSelect }: { hosts: LhpData[]; onHos > Hostname - Architecture - Distribution Cloud + Distribution + Arch CPU @@ -122,6 +125,7 @@ export function TabulateHosts({ hosts, onHostSelect }: { hosts: LhpData[]; onHos Docker + Tags {(host) => ( @@ -129,27 +133,35 @@ export function TabulateHosts({ hosts, onHostSelect }: { hosts: LhpData[]; onHos
{`logo {`logo onHostSelect(host)}> {host.host.name} + {host.host.url && ( + + 🔗 + + )}
- {host.kernel.machine} + + {host.cloud.name} + {host.cloud.hostRegion && {host.cloud.hostRegion}} + {host.distribution.description} - {host.cloud.name} + {host.kernel.machine} {host.hardware.cpuCount} {host.hardware.ramTotal} {host.hardware.diskRoot} @@ -158,6 +170,13 @@ export function TabulateHosts({ hosts, onHostSelect }: { hosts: LhpData[]; onHos ? '❌' : `${host.dockerContainers.filter((x) => x.running).length} / ${host.dockerContainers.length}`} + + {(host.host.tags || []).map((x) => ( + + {x} + + ))} + )}
@@ -167,73 +186,105 @@ export function TabulateHosts({ hosts, onHostSelect }: { hosts: LhpData[]; onHos } export function HostDetails({ host }: { host: LhpData }) { - const kvs = [ - { key: 'Hostname', value: host.host.name }, - { key: 'Kernel Name', value: host.kernel.name }, - { key: 'Kernel Architecture', value: host.kernel.machine }, - { key: 'Kernel Release', value: host.kernel.release }, - { key: 'Operating System', value: host.kernel.os }, - { key: 'Distribution ID', value: host.distribution.id }, - { key: 'Distribution Name', value: host.distribution.name }, - { key: 'Distribution Version ID', value: host.distribution.id }, - { key: 'Distribution Version', value: host.distribution.version }, - { key: 'Distribution Version Code', value: host.distribution.codename }, - { key: 'Distribution Full Name', value: host.distribution.description }, - { key: 'Cloud', value: host.cloud.name }, - { key: 'Type', value: host.cloud.hostType }, - { key: 'Region', value: host.cloud.hostRegion }, - { key: 'CPU', value: `${host.hardware.cpuCount} cores` }, - { key: 'RAM', value: `${host.hardware.ramTotal} GB` }, - { key: 'DISK', value: `${host.hardware.diskRoot} GB` }, - ]; - return (
-

{host.host.name}

- -
-
- - Host Information - - - - {({ key, value }) => ( - - {key} - - )} - - - +

+
+ {host.host.name} + {host.host.url && ( + + 🔗 + + )}
-
- - Docker Containers - - - {host.dockerContainers ? ( - (a.running ? 0 : 1) - (b.running ? 0 : 1) || a.name.localeCompare(b.name) - ), - ]} - emptyContent={Docker service has no containers.} - > - {({ id, image, name, running }) => ( - 🟢 : <>🔴}> - {name} - - )} - - ) : ( - Docker service is not found. - )} - - +
+ {(host.host.tags || []).map((x) => ( + + {x} + + ))}
+

+ +
+ +
+ +
+ + + +
+ +
+ + Docker Containers + + + {host.dockerContainers ? ( + (a.running ? 0 : 1) - (b.running ? 0 : 1) || a.name.localeCompare(b.name) + ), + ]} + emptyContent={Docker service has no containers.} + > + {({ id, image, name, running, created }) => ( + 🟢 : <>🔴} + endContent={ + + {created} + + } + > + {name} + + )} + + ) : ( + Docker service is not found. + )} + +
); diff --git a/website/src/components/app/-data.tsx b/website/src/components/app/-data.tsx index d83dc6b..7404f90 100644 --- a/website/src/components/app/-data.tsx +++ b/website/src/components/app/-data.tsx @@ -52,9 +52,7 @@ export interface LhpData { dockerContainers: | null | { - created: { - [k: string]: unknown; - }; + created: string; id: string; image: string; name: string; diff --git a/website/src/components/app/-ui.tsx b/website/src/components/app/-ui.tsx index 23c0130..638e77e 100644 --- a/website/src/components/app/-ui.tsx +++ b/website/src/components/app/-ui.tsx @@ -1,3 +1,5 @@ +import { Card, CardBody, CardHeader } from '@nextui-org/card'; +import { Listbox, ListboxItem } from '@nextui-org/listbox'; import { Spinner } from '@nextui-org/react'; export function Centered({ children }: { children: React.ReactNode }) { @@ -11,3 +13,27 @@ export function BigSpinner({ label }: { label?: string }) { ); } + +export function KVBox({ + title, + kvs, +}: { + title: string; + kvs: { key: string; value: React.ReactNode | string | number | null | undefined }[]; +}) { + return ( + + {title} + + + + {({ key, value }) => ( + + {key} + + )} + + + + ); +}