From 50ba699ab80ae8d040fa09719a8cb382a2c9e4c1 Mon Sep 17 00:00:00 2001 From: Erik Jan de Wit Date: Wed, 20 Apr 2022 21:10:30 +0200 Subject: [PATCH] fixed error when data not found (#2449) * fixed error when data not found fixes: #2447 * change to useMemo --- .../authorization/KeyBasedAttributeInput.tsx | 27 ++++++++++--------- 1 file changed, 15 insertions(+), 12 deletions(-) diff --git a/src/clients/authorization/KeyBasedAttributeInput.tsx b/src/clients/authorization/KeyBasedAttributeInput.tsx index 519d33810e..b6375a66fc 100644 --- a/src/clients/authorization/KeyBasedAttributeInput.tsx +++ b/src/clients/authorization/KeyBasedAttributeInput.tsx @@ -1,4 +1,4 @@ -import React, { useEffect, useState } from "react"; +import React, { useEffect, useMemo, useState } from "react"; import { useTranslation } from "react-i18next"; import { Controller, useFieldArray, useFormContext } from "react-hook-form"; import { @@ -56,7 +56,6 @@ const ValueInput = ({ }: ValueInputProps) => { const { t } = useTranslation("common"); const { control, register, getValues } = useFormContext(); - const [isValueOpenArray, setIsValueOpenArray] = useState([false]); const toggleValueSelect = (rowIndex: number, open: boolean) => { @@ -65,19 +64,23 @@ const ValueInput = ({ setIsValueOpenArray(arr); }; - let attributeValues: { key: string; name: string }[] | undefined = []; + const attributeValues = useMemo(() => { + let values: AttributeType[] | undefined = []; - const scopeValues = resources?.find( - (resource) => resource.name === getValues().resources[rowIndex]?.key - )?.scopes; + if (selectableValues) { + values = defaultContextAttributes.find( + (attr) => attr.key === getValues().context?.[rowIndex]?.key + )?.values; + } - if (selectableValues) { - attributeValues = defaultContextAttributes.find( - (attr) => attr.key === getValues().context[rowIndex]?.key - )?.values; - } + return values; + }, [getValues]); const renderSelectOptionType = () => { + const scopeValues = resources?.find( + (resource) => resource.name === getValues().resources?.[rowIndex]?.key + )?.scopes; + if (attributeValues?.length && !resources) { return attributeValues.map((attr) => ( @@ -165,7 +168,7 @@ export const KeyBasedAttributeInput = ({ useEffect(() => { if (!fields.length) { - append({ key: "", value: "" }); + append({ key: "", value: "" }, false); } }, [fields]);