import type AuthenticationFlowRepresentation from "@keycloak/keycloak-admin-client/lib/defs/authenticationFlowRepresentation"; import { AlertVariant, Button, ButtonVariant, Form, Modal, ModalVariant, } from "@patternfly/react-core"; import { useEffect } from "react"; import { FormProvider, useForm } from "react-hook-form-v7"; import { useTranslation } from "react-i18next"; import { useAlerts } from "../components/alert/Alerts"; import { useAdminClient } from "../context/auth/AdminClient"; import { NameDescription } from "./form/NameDescription"; type EditFlowModalProps = { flow: AuthenticationFlowRepresentation; toggleDialog: () => void; }; export const EditFlowModal = ({ flow, toggleDialog }: EditFlowModalProps) => { const { t } = useTranslation("authentication"); const { adminClient } = useAdminClient(); const { addAlert, addError } = useAlerts(); const form = useForm({ mode: "onChange" }); const { reset, handleSubmit } = form; useEffect(() => reset(flow), [flow]); const onSubmit = async (formValues: AuthenticationFlowRepresentation) => { try { await adminClient.authenticationManagement.updateFlow( { flowId: flow.id! }, { ...flow, ...formValues } ); addAlert(t("updateFlowSuccess"), AlertVariant.success); } catch (error) { addError("authentication:updateFlowError", error); } toggleDialog(); }; return ( {t("edit")} , , ]} isOpen >
); };