From 96ccc24b8b8ebd62e4f05b3f620066a60ca09bc2 Mon Sep 17 00:00:00 2001 From: olav Date: Fri, 29 Apr 2022 13:51:25 +0200 Subject: [PATCH] refactor: fix override field selection (#925) --- .../AddFeatureVariant/AddFeatureVariant.tsx | 28 +++++++------------ .../OverrideConfig/OverrideConfig.jsx | 2 +- 2 files changed, 11 insertions(+), 19 deletions(-) diff --git a/frontend/src/component/feature/FeatureView/FeatureVariants/FeatureVariantsList/AddFeatureVariant/AddFeatureVariant.tsx b/frontend/src/component/feature/FeatureView/FeatureVariants/FeatureVariantsList/AddFeatureVariant/AddFeatureVariant.tsx index 528317b4f6..87d76c6d73 100644 --- a/frontend/src/component/feature/FeatureView/FeatureVariants/FeatureVariantsList/AddFeatureVariant/AddFeatureVariant.tsx +++ b/frontend/src/component/feature/FeatureView/FeatureVariants/FeatureVariantsList/AddFeatureVariant/AddFeatureVariant.tsx @@ -25,6 +25,7 @@ import Input from 'component/common/Input/Input'; import { formatUnknownError } from 'utils/formatUnknownError'; import useUnleashContext from 'hooks/api/getters/useUnleashContext/useUnleashContext'; import { HelpIcon } from 'component/common/HelpIcon/HelpIcon'; +import produce from 'immer'; const payloadOptions = [ { key: 'string', label: 'string' }, @@ -199,27 +200,18 @@ export const AddVariant = ({ closeDialog(); }; - const updateOverrideType = - (index: number, contextName: string) => (value: string) => { - setOverrides( - overrides.map((o, i) => { - if (i === index) { - // @ts-expect-error - o[contextName] = value; - } - - return o; - }) - ); - }; + const updateOverrideType = (index: number) => (value: string) => { + setOverrides( + produce(draft => { + draft[index].contextName = value; + }) + ); + }; const updateOverrideValues = (index: number, values: string[]) => { setOverrides( - overrides.map((o, i) => { - if (i === index) { - o.values = values; - } - return o; + produce(draft => { + draft[index].values = values; }) ); }; diff --git a/frontend/src/component/feature/FeatureView/FeatureVariants/FeatureVariantsList/AddFeatureVariant/OverrideConfig/OverrideConfig.jsx b/frontend/src/component/feature/FeatureView/FeatureVariants/FeatureVariantsList/AddFeatureVariant/OverrideConfig/OverrideConfig.jsx index 5432949435..31b2d7bbad 100644 --- a/frontend/src/component/feature/FeatureView/FeatureVariants/FeatureVariantsList/AddFeatureVariant/OverrideConfig/OverrideConfig.jsx +++ b/frontend/src/component/feature/FeatureView/FeatureVariants/FeatureVariantsList/AddFeatureVariant/OverrideConfig/OverrideConfig.jsx @@ -54,7 +54,7 @@ export const OverrideConfig = ({ classes={{ root: classnames(commonStyles.fullWidth), }} - onChange={updateOverrideType(i, o.contextName)} + onChange={updateOverrideType(i)} />