import { createFormControl, createFormGroup } from "solid-forms"; import { Trans, useLingui } from "@lingui-solid/solid/macro"; import { useNavigate } from "@revolt/routing"; import { Column, Dialog, DialogProps, Form2, Radio2 } from "@revolt/ui"; import { useModals } from ".."; import { Modals } from "../types"; /** * Modal to create a new server channel */ export function CreateChannelModal( props: DialogProps & Modals & { type: "create_channel" }, ) { const { t } = useLingui(); const navigate = useNavigate(); const { showError } = useModals(); const group = createFormGroup({ name: createFormControl("", { required: true }), type: createFormControl("Text"), }); async function onSubmit() { try { const channel = await props.server.createChannel({ type: group.controls.type.value as "Text" | "Voice", name: group.controls.name.value, }); if (props.cb) { props.cb(channel); } else { navigate(`/server/${props.server.id}/channel/${channel.id}`); } props.onClose(); } catch (error) { showError(error); } } const submit = Form2.useSubmitHandler(group, onSubmit); return ( Create channel} actions={[ { text: Close }, { text: Create, onClick: () => { onSubmit(); return false; }, isDisabled: !Form2.canSubmit(group), }, ]} isDisabled={group.isPending} >
Text Channel Voice Channel
); }