import { useState } from "react"; import { Controller, useFormContext } from "react-hook-form"; import { SelectOption, FormGroup, Select, SelectVariant, } from "@patternfly/react-core"; import type { ClientQuery } from "@keycloak/keycloak-admin-client/lib/resources/clients"; import type ClientRepresentation from "@keycloak/keycloak-admin-client/lib/defs/clientRepresentation"; import { HelpItem } from "../../../components/help-enabler/HelpItem"; import { useAdminClient, useFetch } from "../../../context/auth/AdminClient"; import { useTranslation } from "react-i18next"; export const Client = () => { const { t } = useTranslation("clients"); const { control, getValues, formState: { errors }, } = useFormContext(); const values: string[] | undefined = getValues("clients"); const [open, setOpen] = useState(false); const [clients, setClients] = useState([]); const [search, setSearch] = useState(""); const { adminClient } = useAdminClient(); useFetch( async () => { const params: ClientQuery = { max: 20, }; if (search) { params.clientId = search; params.search = true; } if (values?.length && !search) { return await Promise.all( values.map( (id: string) => adminClient.clients.findOne({ id }) as ClientRepresentation ) ); } return await adminClient.clients.find(params); }, setClients, [search] ); const convert = (clients: ClientRepresentation[]) => clients.map((option) => ( {option.clientId} )); return ( } fieldId="clients" helperTextInvalid={t("requiredClient")} validated={errors.clients ? "error" : "default"} isRequired > value.length > 0, }} render={({ onChange, value }) => ( )} /> ); };