Files
caravel/frontend/src/pages/relays/RelayEdit.tsx
T
2026-03-27 14:52:00 -07:00

45 lines
1.7 KiB
TypeScript

import { useNavigate, useParams } from "@solidjs/router"
import { Show } from "solid-js"
import RelayForm, { type RelayFormValues } from "@/components/RelayForm"
import { slugify } from "@/lib/slugify"
import BackLink from "@/components/BackLink"
import PageContainer from "@/components/PageContainer"
import ResourceState from "@/components/ResourceState"
import useMinLoading from "@/components/useMinLoading"
import { updateRelayById, useRelay } from "@/lib/hooks"
export default function RelayEdit(props: { basePath?: string; title?: string }) {
const basePath = () => props.basePath ?? "/relays"
const navigate = useNavigate()
const params = useParams()
const relayId = () => params.id ?? ""
const [relay] = useRelay(relayId)
const loading = useMinLoading(() => relay.loading)
async function handleSubmit(values: RelayFormValues) {
await updateRelayById(relayId(), {
subdomain: slugify(values.subdomain),
info_name: values.info_name.trim(),
info_icon: values.info_icon.trim(),
info_description: values.info_description.trim(),
})
navigate(`${basePath()}/${relayId()}`)
}
return (
<PageContainer size="narrow">
<BackLink href={`${basePath()}/${params.id}`} label="Back" />
<h1 class="text-2xl font-bold text-gray-900 mb-6 py-2">{props.title ?? "Edit Relay"}</h1>
<ResourceState loading={loading()} error={relay.error} loadingText="Loading relay..." errorText="Failed to load relay." />
<Show when={relay() && !loading()}>
<RelayForm
initialValues={relay()!}
onSubmit={handleSubmit}
submitLabel="Save Changes"
submittingLabel="Saving..."
/>
</Show>
</PageContainer>
)
}