Since we have at least three trade widgets we need to unify their logic and avoid code duplication (DRY). To do this, we need to define what is specific and what is common. At the same time, strike a balance between code cohesion and solution scalability.
TradeWidget
- Widget to create CoW orders. Its configuration can create many different ways to create orders, for example Swap, Limit Orders and Advanced orders will be instances of itTradeRawState
- DTO derived from URL (/1/USDT/WETH?recipient=0x000
) and persisted into localStorage (ref)TradeDerivedState
- a model that containsCurrencyAmount
andCurrency
instances. This state is derived from TradeRawState (ref)
- Each trade widget: SwapWidget, LimitOrdersWidget, AdvancedOrdersWidget uses TradeWidget as a skeleton to get out of the box:
- State persistence with URL
- Tokens selection and
setMax
functionality - Recipient input
- Token importing
- Token approving
- Simultaneously,
TradeWidget
allows customizing a widget layout usingTradeWidgetSlots
(ref) and other parameters. useTradeState()
hook serves to generalize trade states. It returns the current trade widgets raw state depending on what widget is open now. We take as a fact that we can have only one trade widget on the page at one point in time.- This hook is supposed to be a base for shared trade services (by service I mean component, hook, updater, atom, etc.)
Shared trade services
- these are tools that allow you to work with any trade widgets without requiring you to know the type of this widget- Example:
useIsWrapOrUnwrap()
- the hook returns true when a trade state is ETH/WETH or WETH/ETH. And you can call it from everywhere in the App and it will give the result relative to the current widget (swap/limit orders/advanced orders)
- Example: