import { useEffect, useState } from "react"; import { useTranslation } from "react-i18next"; import { useForm } from "react-hook-form"; import { AlertVariant, PageSection, PageSectionVariants, } from "@patternfly/react-core"; import type UserRepresentation from "@keycloak/keycloak-admin-client/lib/defs/userRepresentation"; import { useAlerts } from "../components/alert/Alerts"; import { AttributeForm, AttributesForm, } from "../components/key-value-form/AttributeForm"; import { arrayToKeyValue, keyValueToArray, } from "../components/key-value-form/key-value-convert"; import { useAdminClient } from "../context/auth/AdminClient"; import { useUserProfile } from "../realm-settings/user-profile/UserProfileContext"; type UserAttributesProps = { user: UserRepresentation; }; export const UserAttributes = ({ user: defaultUser }: UserAttributesProps) => { const { t } = useTranslation("users"); const { adminClient } = useAdminClient(); const { addAlert, addError } = useAlerts(); const [user, setUser] = useState(defaultUser); const form = useForm({ mode: "onChange" }); const { config } = useUserProfile(); const convertAttributes = () => { return arrayToKeyValue(user.attributes!).filter( (a) => !config?.attributes?.some((attribute) => attribute.name === a.key) ); }; useEffect(() => { form.setValue("attributes", convertAttributes()); }, [user]); const save = async (attributeForm: AttributeForm) => { try { const attributes = Object.assign( {}, user.attributes || {}, keyValueToArray(attributeForm.attributes!) ); await adminClient.users.update({ id: user.id! }, { ...user, attributes }); setUser({ ...user, attributes }); addAlert(t("userSaved"), AlertVariant.success); } catch (error) { addError("groups:groupUpdateError", error); } }; return ( form.reset({ attributes: convertAttributes(), }) } /> ); };