import { useForm } from "react-hook-form"; import { useTranslation } from "react-i18next"; import { AlertVariant, Button, ButtonVariant, Form, FormGroup, Modal, } from "@patternfly/react-core"; import { useAdminClient } from "../../context/auth/AdminClient"; import { useAlerts } from "../../components/alert/Alerts"; import { KeycloakTextInput } from "../../components/keycloak-text-input/KeycloakTextInput"; type Host = { node: string; }; type AddHostDialogProps = { clientId: string; isOpen: boolean; onAdded: (host: string) => void; onClose: () => void; }; export const AddHostDialog = ({ clientId: id, isOpen, onAdded, onClose, }: AddHostDialogProps) => { const { t } = useTranslation("clients"); const { register, getValues } = useForm(); const { adminClient } = useAdminClient(); const { addAlert, addError } = useAlerts(); return ( { try { const node = getValues("node"); await adminClient.clients.addClusterNode({ id, node, }); onAdded(node); addAlert(t("addedNodeSuccess"), AlertVariant.success); } catch (error) { addError("clients:addedNodeFail", error); } onClose(); }} > {t("common:save")} , , ]} >
); };