From 48199035bfa9d17b4fa9f90a42dc289019563e26 Mon Sep 17 00:00:00 2001 From: Dominik Guzei Date: Thu, 10 Oct 2024 13:41:07 +0200 Subject: [PATCH] feat: improve simple asset input [LW-9231] --- .../asset-input/amount-input.component.tsx | 5 ++++- src/design-system/asset-input/index.ts | 2 +- .../simple-asset-input.component.tsx | 3 +++ .../bundle-input/bundle-input.component.tsx | 17 ++++++----------- src/design-system/index.ts | 2 +- 5 files changed, 15 insertions(+), 14 deletions(-) diff --git a/src/design-system/asset-input/amount-input.component.tsx b/src/design-system/asset-input/amount-input.component.tsx index 3a898af..5ef049f 100644 --- a/src/design-system/asset-input/amount-input.component.tsx +++ b/src/design-system/asset-input/amount-input.component.tsx @@ -10,6 +10,7 @@ interface Props { onChange?: (value: string) => void; value?: string; id: string; + 'data-testid'?: string; } export const AmountInput = ({ @@ -17,7 +18,9 @@ export const AmountInput = ({ onChange, value, id, + ...rest }: Readonly): JSX.Element => { + const dataTestId = rest['data-testid']; return ( onChange?.(target.value)} placeholder="0.0" - data-testid={`asset-input-amount-input-${id}`} + data-testid={dataTestId ? dataTestId : `asset-input-amount-input-${id}`} /> ); diff --git a/src/design-system/asset-input/index.ts b/src/design-system/asset-input/index.ts index 6a30b10..280cba5 100644 --- a/src/design-system/asset-input/index.ts +++ b/src/design-system/asset-input/index.ts @@ -1,3 +1,3 @@ export { AssetInput } from './asset-input.component'; export { SimpleAssetInput } from './simple-asset-input.component'; -export * as Data from './asset-input.data'; +export * from './asset-input.data'; diff --git a/src/design-system/asset-input/simple-asset-input.component.tsx b/src/design-system/asset-input/simple-asset-input.component.tsx index a39e80d..94abad5 100644 --- a/src/design-system/asset-input/simple-asset-input.component.tsx +++ b/src/design-system/asset-input/simple-asset-input.component.tsx @@ -12,12 +12,14 @@ interface Props { state: AssetState; balanceLabel: string; onAmountChange?: (asset: Readonly, amount: string) => void; + 'data-testid'?: string; } export const SimpleAssetInput = ({ state, balanceLabel, onAmountChange, + ...rest }: Readonly): JSX.Element => (
@@ -28,6 +30,7 @@ export const SimpleAssetInput = ({ onChange={(value): void => { onAmountChange?.(state.asset, value); }} + data-testid={rest['data-testid']} /> diff --git a/src/design-system/bundle-input/bundle-input.component.tsx b/src/design-system/bundle-input/bundle-input.component.tsx index b694956..56220dd 100644 --- a/src/design-system/bundle-input/bundle-input.component.tsx +++ b/src/design-system/bundle-input/bundle-input.component.tsx @@ -3,7 +3,7 @@ import type { PropsWithChildren } from 'react'; import PlusSmall from '@icons/PlusSmallComponent'; -import { AssetInput } from '../asset-input'; +import { AssetInput, AssetState, AssetWithFiat } from '../asset-input'; import { Box } from '../box'; import * as ControlButtons from '../control-buttons'; import { Divider } from '../divider'; @@ -11,18 +11,13 @@ import { Divider } from '../divider'; import * as cx from './bundle-input.css'; import { RemoveButton } from './remove-button.component'; -import type { Data } from '../asset-input'; - export type Props = PropsWithChildren<{ - state?: Data.AssetState[]; + state?: AssetState[]; onAddAsset?: () => void; - onRemoveAsset?: (asset: Readonly) => void; - onAmountChange?: ( - asset: Readonly, - amount: string, - ) => void; - onTickerClick?: (asset: Readonly) => void; - onMaxClick?: (asset: Readonly) => void; + onRemoveAsset?: (asset: Readonly) => void; + onAmountChange?: (asset: Readonly, amount: string) => void; + onTickerClick?: (asset: Readonly) => void; + onMaxClick?: (asset: Readonly) => void; }>; export const BundleInput = ({ diff --git a/src/design-system/index.ts b/src/design-system/index.ts index 198ecd1..a2d0826 100644 --- a/src/design-system/index.ts +++ b/src/design-system/index.ts @@ -6,7 +6,7 @@ export { Divider } from './divider'; export { Flex } from './flex'; export { Grid, Cell } from './grid'; export { Text } from './text'; -export { AssetInput, SimpleAssetInput } from './asset-input'; +export * from './asset-input'; export { BundleInput } from './bundle-input'; export * as SubNavigation from './sub-navigation'; export * as NavigationButton from './navigation-buttons';