import { FormGroup, Switch } from "@patternfly/react-core"; import { useTranslation } from "react-i18next"; import React, { useEffect } from "react"; import { HelpItem } from "../../components/help-enabler/HelpItem"; import { useForm, Controller } from "react-hook-form"; import { convertToFormValues } from "../../util"; import ComponentRepresentation from "keycloak-admin/lib/defs/componentRepresentation"; import { FormAccess } from "../../components/form-access/FormAccess"; import { useAdminClient, useFetch } from "../../context/auth/AdminClient"; import { useParams } from "react-router-dom"; export const LdapSettingsAdvanced = () => { const { t } = useTranslation("user-federation"); const helpText = useTranslation("user-federation-help").t; const adminClient = useAdminClient(); const { control, setValue } = useForm(); const { id } = useParams<{ id: string }>(); const setupForm = (component: ComponentRepresentation) => { Object.entries(component).map((entry) => { if (entry[0] === "config") { convertToFormValues(entry[1], "config", setValue); } else { setValue(entry[0], entry[1]); } }); }; useEffect(() => { return useFetch( () => adminClient.components.findOne({ id }), (fetchedComponent) => setupForm(fetchedComponent) ); }, []); return ( <> } fieldId="kc-enable-ldapv3-password" hasNoPaddingTop > ( )} > } fieldId="kc-validate-password-policy" hasNoPaddingTop > ( )} > } fieldId="kc-trust-email" hasNoPaddingTop > ( )} > ); };