diff --git a/packages/insomnia/src/ui/components/editors/request-parameters-editor.tsx b/packages/insomnia/src/ui/components/editors/request-parameters-editor.tsx index bfca8cfd9ec..a027693326c 100644 --- a/packages/insomnia/src/ui/components/editors/request-parameters-editor.tsx +++ b/packages/insomnia/src/ui/components/editors/request-parameters-editor.tsx @@ -74,11 +74,8 @@ export const RequestParametersEditor: FC = ({ ); } - const pairsIds = activeRequest.parameters.map((param, index) => param.id || index).join(','); - return ( = ({ }) => { const [showDescription, setShowDescription] = React.useState(false); const { enabled: nunjucksEnabled } = useNunjucksEnabled(); - let pairsListItems = pairs.length > 0 ? pairs.map(pair => ({ ...pair, id: pair.id || generateId('pair') })) : [createEmptyPair()]; + let pairsListItems = useMemo( + () => pairs.length > 0 ? pairs.map(pair => ({ ...pair, id: pair.id || generateId('pair') })) : [createEmptyPair()], + // Ensure same array data will not generate different kvPairs to avoid flash issue + // eslint-disable-next-line react-hooks/exhaustive-deps + [JSON.stringify(pairs)] + ); const initialReadOnlyItems = readOnlyPairs?.map(pair => ({ ...pair, id: pair.id || generateId('pair') })) || []; const upsertPair = useCallback(function upsertPair(pairsListItems: Pair[], pair: Pair) { if (pairsListItems.find(item => item.id === pair.id)) { - pairsListItems = pairsListItems.map(item => (item.id === pair.id ? pair : item)); - onChange(pairsListItems); + onChange(pairsListItems.map(item => (item.id === pair.id ? pair : item))); } else { - const id = pair.id === 'pair-empty' ? generateId('pair') : pair.id; - pairsListItems = pairsListItems.concat({ ...pair, id }); - onChange(pairsListItems); + onChange([...pairsListItems, pair]); } }, [onChange]); @@ -305,7 +307,6 @@ export const KeyValueEditor: FC = ({