/* eslint-disable unicorn/filename-case */ import { ClipboardIcon } from '@heroicons/react/24/outline' import { type LoaderFunctionArgs } from '@remix-run/node' import { Link, useLoaderData } from '@remix-run/react' import clsx from 'clsx' import { toast } from 'react-hot-toast/headless' import StatusCircle from '~/components/StatusCircle' import { type Machine } from '~/types' import { pull } from '~/utils/headscale' import { getSession } from '~/utils/sessions' import { useLiveData } from '~/utils/useLiveData' export async function loader({ request }: LoaderFunctionArgs) { const session = await getSession(request.headers.get('Cookie')) // eslint-disable-next-line @typescript-eslint/no-non-null-assertion const data = await pull<{ nodes: Machine[] }>('v1/node', session.get('hsApiKey')!) return data.nodes } export default function Page() { const data = useLoaderData() useLiveData({ interval: 3000 }) return ( {data.map(machine => { const tags = [...machine.forcedTags, ...machine.validTags] return ( ) })}
Name IP Addresses Last Seen

{machine.givenName}

{machine.name}
{tags.map(tag => ( {tag} ))}
{machine.ipAddresses.map((ip, index) => ( ))}

{machine.online ? 'Connected' : new Date( machine.lastSeen ).toLocaleString()}

) }