@velora-dex/widget 0.8.2 → 0.8.3-dev.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/components/widget/BridgeList/hooks.d.ts +2 -2
- package/dist/components/widget/BridgeList/hooks.d.ts.map +1 -1
- package/dist/components/widget/BridgeList/hooks.js +79 -73
- package/dist/components/widget/BridgeList/hooks.js.map +1 -1
- package/dist/components/widget/BridgeSelectorExpandable/BridgeSelectorExpandable.d.ts +2 -2
- package/dist/components/widget/BridgeSelectorExpandable/BridgeSelectorExpandable.d.ts.map +1 -1
- package/dist/components/widget/BridgeSelectorExpandable/BridgeSelectorExpandable.js.map +1 -1
- package/dist/components/widget/TradeOverview/DeltaOrderTradeOverview.d.ts +2 -2
- package/dist/components/widget/TradeOverview/DeltaOrderTradeOverview.d.ts.map +1 -1
- package/dist/components/widget/TradeOverview/DeltaOrderTradeOverview.js +2 -2
- package/dist/components/widget/TradeOverview/DeltaOrderTradeOverview.js.map +1 -1
- package/dist/components/widget/TradeOverview/TwapOrderTradeOverview.d.ts +2 -2
- package/dist/components/widget/TradeOverview/TwapOrderTradeOverview.d.ts.map +1 -1
- package/dist/components/widget/TradeOverview/TwapOrderTradeOverview.js.map +1 -1
- package/dist/components/widget/TradeOverview/utils/useSwapAmountsWithSlippage.d.ts +4 -1
- package/dist/components/widget/TradeOverview/utils/useSwapAmountsWithSlippage.d.ts.map +1 -1
- package/dist/components/widget/TradeOverview/utils/useSwapAmountsWithSlippage.js +1 -1
- package/dist/components/widget/TradeOverview/utils/useSwapAmountsWithSlippage.js.map +1 -1
- package/dist/core/LimitOrderButton.d.ts.map +1 -1
- package/dist/core/LimitOrderButton.js +46 -52
- package/dist/core/LimitOrderButton.js.map +1 -1
- package/dist/core/TradeFlowScreenButton.d.ts +3 -4
- package/dist/core/TradeFlowScreenButton.d.ts.map +1 -1
- package/dist/core/TradeFlowScreenButton.js.map +1 -1
- package/dist/core/button/hooks/useWidgetButtonExtraProps.d.ts.map +1 -1
- package/dist/core/button/hooks/useWidgetButtonExtraProps.js +1 -4
- package/dist/core/button/hooks/useWidgetButtonExtraProps.js.map +1 -1
- package/dist/core/index.js.map +1 -1
- package/dist/core/inputs/hooks/useTokenFromInputProps.d.ts.map +1 -1
- package/dist/core/inputs/hooks/useTokenFromInputProps.js +2 -2
- package/dist/core/inputs/hooks/useTokenFromInputProps.js.map +1 -1
- package/dist/core/inputs/hooks/useTokenToInputProps.d.ts.map +1 -1
- package/dist/core/inputs/hooks/useTokenToInputProps.js +2 -2
- package/dist/core/inputs/hooks/useTokenToInputProps.js.map +1 -1
- package/dist/core/inputs/hooks/utils.d.ts.map +1 -1
- package/dist/core/inputs/hooks/utils.js +7 -5
- package/dist/core/inputs/hooks/utils.js.map +1 -1
- package/dist/core/limit/useLimitRate.d.ts +2 -3
- package/dist/core/limit/useLimitRate.d.ts.map +1 -1
- package/dist/core/limit/useLimitRate.js +54 -110
- package/dist/core/limit/useLimitRate.js.map +1 -1
- package/dist/core/limit/useLimitTokenToInputProps.d.ts.map +1 -1
- package/dist/core/limit/useLimitTokenToInputProps.js +1 -4
- package/dist/core/limit/useLimitTokenToInputProps.js.map +1 -1
- package/dist/core/swapDetails/fees.d.ts.map +1 -1
- package/dist/core/swapDetails/fees.js +16 -11
- package/dist/core/swapDetails/fees.js.map +1 -1
- package/dist/core/swapDetails/maxToPay.d.ts.map +1 -1
- package/dist/core/swapDetails/maxToPay.js +18 -17
- package/dist/core/swapDetails/maxToPay.js.map +1 -1
- package/dist/core/twap/twapDetails/minimumReceiveable.d.ts +2 -2
- package/dist/core/twap/twapDetails/minimumReceiveable.d.ts.map +1 -1
- package/dist/core/twap/twapDetails/minimumReceiveable.js.map +1 -1
- package/dist/events/hooks/useOnPriceUpdates.js.map +1 -1
- package/dist/events/types/priceChange.d.ts +2 -2
- package/dist/events/types/priceChange.d.ts.map +1 -1
- package/dist/events/types/swap.d.ts +2 -2
- package/dist/events/types/swap.d.ts.map +1 -1
- package/dist/events/types/twap.d.ts +2 -2
- package/dist/events/types/twap.d.ts.map +1 -1
- package/dist/hooks/swap/prices/delta/bridge/useSelectedBridgePrice.d.ts +3 -4
- package/dist/hooks/swap/prices/delta/bridge/useSelectedBridgePrice.d.ts.map +1 -1
- package/dist/hooks/swap/prices/delta/bridge/useSelectedBridgePrice.js.map +1 -1
- package/dist/hooks/swap/prices/delta/bridge/utils.d.ts +6 -3
- package/dist/hooks/swap/prices/delta/bridge/utils.d.ts.map +1 -1
- package/dist/hooks/swap/prices/delta/bridge/utils.js +20 -17
- package/dist/hooks/swap/prices/delta/bridge/utils.js.map +1 -1
- package/dist/hooks/swap/prices/delta/mutations/twap/useCreateTwapOrder.d.ts +2 -2
- package/dist/hooks/swap/prices/delta/mutations/twap/useCreateTwapOrder.d.ts.map +1 -1
- package/dist/hooks/swap/prices/delta/mutations/twap/useCreateTwapOrder.js +5 -5
- package/dist/hooks/swap/prices/delta/mutations/twap/useCreateTwapOrder.js.map +1 -1
- package/dist/hooks/swap/prices/delta/mutations/twap/usePostTwapOrder.d.ts +2 -2
- package/dist/hooks/swap/prices/delta/mutations/twap/usePostTwapOrder.d.ts.map +1 -1
- package/dist/hooks/swap/prices/delta/mutations/twap/usePostTwapOrder.js +2 -2
- package/dist/hooks/swap/prices/delta/mutations/twap/usePostTwapOrder.js.map +1 -1
- package/dist/hooks/swap/prices/delta/mutations/twap/useTwapOrderToPost.d.ts.map +1 -1
- package/dist/hooks/swap/prices/delta/mutations/twap/useTwapOrderToPost.js +27 -28
- package/dist/hooks/swap/prices/delta/mutations/twap/useTwapOrderToPost.js.map +1 -1
- package/dist/hooks/swap/prices/delta/mutations/types.d.ts +3 -3
- package/dist/hooks/swap/prices/delta/mutations/types.d.ts.map +1 -1
- package/dist/hooks/swap/prices/delta/mutations/useCancelDeltaOrders.js +2 -2
- package/dist/hooks/swap/prices/delta/mutations/useCancelDeltaOrders.js.map +1 -1
- package/dist/hooks/swap/prices/delta/mutations/useCancelOrWithdrawAndCancelDeltaOrder.d.ts.map +1 -1
- package/dist/hooks/swap/prices/delta/mutations/useCancelOrWithdrawAndCancelDeltaOrder.js +1 -1
- package/dist/hooks/swap/prices/delta/mutations/useCancelOrWithdrawAndCancelDeltaOrder.js.map +1 -1
- package/dist/hooks/swap/prices/delta/mutations/useCreateDeltaOrder.d.ts +2 -2
- package/dist/hooks/swap/prices/delta/mutations/useCreateDeltaOrder.d.ts.map +1 -1
- package/dist/hooks/swap/prices/delta/mutations/useCreateDeltaOrder.js +5 -5
- package/dist/hooks/swap/prices/delta/mutations/useCreateDeltaOrder.js.map +1 -1
- package/dist/hooks/swap/prices/delta/mutations/useDeltaOrderToPost.d.ts.map +1 -1
- package/dist/hooks/swap/prices/delta/mutations/useDeltaOrderToPost.js +27 -28
- package/dist/hooks/swap/prices/delta/mutations/useDeltaOrderToPost.js.map +1 -1
- package/dist/hooks/swap/prices/delta/mutations/usePostDeltaOrder.d.ts +2 -2
- package/dist/hooks/swap/prices/delta/mutations/usePostDeltaOrder.d.ts.map +1 -1
- package/dist/hooks/swap/prices/delta/mutations/usePostDeltaOrder.js +2 -2
- package/dist/hooks/swap/prices/delta/mutations/usePostDeltaOrder.js.map +1 -1
- package/dist/hooks/swap/prices/delta/mutations/useSendDepositPreSignDeltaOrderTx.js +1 -1
- package/dist/hooks/swap/prices/delta/mutations/useSendDepositPreSignDeltaOrderTx.js.map +1 -1
- package/dist/hooks/swap/prices/delta/mutations/useWithdrawAndCancelDeltaOrder.js +1 -1
- package/dist/hooks/swap/prices/delta/mutations/useWithdrawAndCancelDeltaOrder.js.map +1 -1
- package/dist/hooks/swap/prices/delta/mutations/utils.d.ts +5 -6
- package/dist/hooks/swap/prices/delta/mutations/utils.d.ts.map +1 -1
- package/dist/hooks/swap/prices/delta/mutations/utils.js +6 -6
- package/dist/hooks/swap/prices/delta/mutations/utils.js.map +1 -1
- package/dist/hooks/swap/prices/delta/orders/unposted/utils.d.ts +3 -3
- package/dist/hooks/swap/prices/delta/orders/unposted/utils.js +3 -3
- package/dist/hooks/swap/prices/delta/orders/unposted/utils.js.map +1 -1
- package/dist/hooks/swap/prices/delta/orders/utils.d.ts +3 -3
- package/dist/hooks/swap/prices/delta/orders/utils.d.ts.map +1 -1
- package/dist/hooks/swap/prices/delta/orders/utils.js +7 -4
- package/dist/hooks/swap/prices/delta/orders/utils.js.map +1 -1
- package/dist/hooks/swap/prices/delta/queries/errors.js.map +1 -1
- package/dist/hooks/swap/prices/delta/queries/useDeltaPriceQuery.d.ts +16 -33
- package/dist/hooks/swap/prices/delta/queries/useDeltaPriceQuery.d.ts.map +1 -1
- package/dist/hooks/swap/prices/delta/queries/useDeltaPriceQuery.js +6 -6
- package/dist/hooks/swap/prices/delta/queries/useDeltaPriceQuery.js.map +1 -1
- package/dist/hooks/swap/prices/factory.d.ts.map +1 -1
- package/dist/hooks/swap/prices/factory.js +1 -1
- package/dist/hooks/swap/prices/factory.js.map +1 -1
- package/dist/hooks/swap/prices/market/queries/useMarketPriceQuery.d.ts +1 -1
- package/dist/hooks/swap/prices/types.d.ts +2 -3
- package/dist/hooks/swap/prices/types.d.ts.map +1 -1
- package/dist/hooks/swap/prices/useSwapPrices.d.ts +3 -3
- package/dist/hooks/swap/prices/useSwapPrices.d.ts.map +1 -1
- package/dist/hooks/swap/prices/useSwapPrices.js.map +1 -1
- package/dist/hooks/swap/prices/useTokenInputsFromPrice.js +3 -3
- package/dist/hooks/swap/prices/useTokenInputsFromPrice.js.map +1 -1
- package/dist/hooks/swap/prices/useTokenInputsFromTwapPrice.d.ts +2 -2
- package/dist/hooks/swap/prices/useTokenInputsFromTwapPrice.d.ts.map +1 -1
- package/dist/hooks/swap/prices/useTokenInputsFromTwapPrice.js.map +1 -1
- package/dist/hooks/swap/prices/useTwapPrices.d.ts +4 -5
- package/dist/hooks/swap/prices/useTwapPrices.d.ts.map +1 -1
- package/dist/hooks/swap/prices/useTwapPrices.js.map +1 -1
- package/dist/hooks/swap/tradeFlow/common/factory/depositAndSubmitOrderFactory.d.ts +10 -17
- package/dist/hooks/swap/tradeFlow/common/factory/depositAndSubmitOrderFactory.d.ts.map +1 -1
- package/dist/hooks/swap/tradeFlow/common/factory/depositAndSubmitOrderFactory.js +6 -6
- package/dist/hooks/swap/tradeFlow/common/factory/depositAndSubmitOrderFactory.js.map +1 -1
- package/dist/hooks/swap/tradeFlow/useDeltaFlow.d.ts +5 -5
- package/dist/hooks/swap/tradeFlow/useDeltaFlow.d.ts.map +1 -1
- package/dist/hooks/swap/tradeFlow/useDeltaFlow.js +119 -124
- package/dist/hooks/swap/tradeFlow/useDeltaFlow.js.map +1 -1
- package/dist/hooks/swap/tradeFlow/useLimitOrderFlow.d.ts +2 -2
- package/dist/hooks/swap/tradeFlow/useLimitOrderFlow.d.ts.map +1 -1
- package/dist/hooks/swap/tradeFlow/useLimitOrderFlow.js +159 -196
- package/dist/hooks/swap/tradeFlow/useLimitOrderFlow.js.map +1 -1
- package/dist/hooks/swap/tradeFlow/useTwapFlow.d.ts +5 -5
- package/dist/hooks/swap/tradeFlow/useTwapFlow.d.ts.map +1 -1
- package/dist/hooks/swap/tradeFlow/useTwapFlow.js +217 -229
- package/dist/hooks/swap/tradeFlow/useTwapFlow.js.map +1 -1
- package/dist/hooks/useSDK.d.ts +19 -3
- package/dist/hooks/useSDK.d.ts.map +1 -1
- package/dist/hooks/useSDK.js +65 -35
- package/dist/hooks/useSDK.js.map +1 -1
- package/dist/lib/queryClient.js +1 -1
- package/dist/lib/queryClient.js.map +1 -1
- package/dist/lib/utils/price.d.ts +5 -2
- package/dist/lib/utils/price.d.ts.map +1 -1
- package/dist/lib/utils/price.js +8 -5
- package/dist/lib/utils/price.js.map +1 -1
- package/dist/lib/utils/twap.d.ts +2 -2
- package/dist/lib/utils/twap.d.ts.map +1 -1
- package/dist/lib/utils/twap.js +2 -2
- package/dist/lib/utils/twap.js.map +1 -1
- package/package.json +2 -2
- package/dist/hooks/swap/prices/delta/bridge/const.d.ts +0 -8
- package/dist/hooks/swap/prices/delta/bridge/const.d.ts.map +0 -1
- package/dist/hooks/swap/prices/delta/bridge/const.js +0 -13
- package/dist/hooks/swap/prices/delta/bridge/const.js.map +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useTwapFlow.js","names":["BridgePrice","DeltaPrice","useAccount","assert","useEnsureTxReceipt","Address","Hash","TransactionReceipt","ApprovalFlowResult","SignPermitFlowResult","SubmitTxResult","useMinViemClient","useWatchDeltaAuction","getOverallOrderStatus","useMutation","useRef","SupportedChainId","UserCancelledError","useTwapReceiverAddressValue","CallsSentObject","TxSentObject","useApproveOrPermit","useMarkPermit1Or2NonceAsUsed","SignedPermitResult","useLogger","isBridgePrice","useSubscribeToDeltaPrice","usePartner","useWidgetEvents","shouldApproveOrBatch","getSwapSideFromDeltaPrice","DeltaOrBridgePrice","isETHaddress","useCancelOrWithdrawAndCancelDeltaOrder","CancelDeltaOrdersReturn","useReferrer","useTwapPrices","useTwapSide","useTwapDuration","useTwapSlippage","useCreateAndSubmitTwapOrder","CreateAndSubmitTwapOrderInput","DeltaAuctionWithTwapOrder","BuildTWAPSellOrBuySpecificParams","getTwapAmountsFromPrice","produceTwapDeadlines","usePreSignAndSubmitTwapOrder","TwapOrderPreSignResult","useDepositAndSubmitTwapOrder","TwapOrderDepositResult","amountAfterSlippage","DEFAULT_DELTA_BRIDGE","CancelOrderStepKey","HALF_MINUTE_MS","twapOrderFlowType","UseTwapFlowInput","twapPrice","SubmitTwapOrderResult","tradeFlowType","approve","twapOrder","sentOrder","lastOrderState","account","receiverAddress","OnTxSent","txSent","RunTwapOrderOptions","onTxSent","TwapOrderSubmissionResult","order","isCreatingOrder","isPostingOrder","isOrderSent","isPending","isError","isSuccess","error","Error","TwapOrderExecutionResult","isOrderPending","isOrderExecuting","isOrderExecuted","TwapOrderCancelationResult","step","receipt","txHash","response","isCancelingOrder","isOrderCancellable","isOrderCanceled","result","UseTwapFlowResult","chainId","runTwapOrderFlow","options","Promise","reset","cancelFlow","retryFlow","cancelTwapOrder","approval","signPermit","twapOrderPreSign","twapOrderDeposit","twapOrderSubmission","twapOrderExecution","twapOrderCancelation","usedPrice","freshPrice","submittedTwapOrder","TWAP_ORDER_MUTATION_KEY","useTwapFlow","_twapPrice","logger","queryKey","price","refetch","totalSrcAmount","side","sideFromPrices","numSlices","priceParams","enabled","twapSideFromInput","twapSide","approveTxMut","signPermitMut","events","approveOrPermitEvents","srcToken","srcAmount","spenderContractType","swapSide","tradeMode","tryPermit2","address","minClient","createAndSubmitOrderMut","client","mutationOptions","onSuccess","log","onError","twapOrderCreateAndSubmit","canBatchTxs","isConnectedToSafe","preSignAndSubmitTwapOrder","resetPreSignAndSubmitTwapOrder","viemClient","resetDepositAndSubmitTwapOrder","depositAndSubmitTwapOrder","postingOrder","watchOrderExecution","orderId","id","refetchInterval","onAuctionSuccess","onAuctionFailure","onUpdatedAuction","orderStatus","data","isLoading","isRefetching","orderToCancel","cancelOrderMut","onMutate","cancelOrderResponse","ensureTxReceipt","currentAbortControllerRef","AbortController","usingPriceRef","current","abort","markNonceAsUsed","clearNonce","partner","partnerAddress","partnerFeeBps","partnerTakesSurplus","referrerAddress","subscribeToPrice","onTwapOrder","twapSlippage","twapDurationMin","submitTwapOrder","lastPrice","abortController","signal","orderDeadline","orderInterval","durationMin","orderSlippageBps","Math","floor","signedPermitResult","approveTxHash","approveTxReceipt","allowanceToSet","allowanceToPermit","amountToPermit","hmac","newPriceResult","cancelRefetch","throwIfAborted","unsubscribeFromPrice","shouldDepositAndPreSign","shouldDoApprovalTxOrPermit","tryPermit","shouldPreSignBatch","_queryKey","approvedAmount","onData","newPrice","aborted","undefined","BigInt","onApproveTx","request","approveAsync","allowanceData","sent","approveTxReceiptPromise","hash","onReplaced","action","transactionHash","receiptPromise","transactionSpecificData","tokenAddress","token","spenderAddress","spender","confirmed","txReceipt","onSignPermit","signPermitAsync","deadline","value","permit","permitEncodedArgs","failed","twapPriceToUse","destAmount","totalDestAmount","destChainId","bridge","destinationChainId","event","name","params","orderFromAPI","sellOrBuyParams","onChainOrderType","maxSrcAmount","createOrderInput","type","degenMode","orderInput","owner","beneficiary","destToken","deltaPrice","protocolSelector","slippage","interval","depositAmount","getDepositAmount","mutateAsync","signedPermitData","cancelDeltaOrder","twapOrderMut","mutationFn","mutationKey","onSettled","toFixed"],"sources":["../../../../src/hooks/swap/tradeFlow/useTwapFlow.ts"],"sourcesContent":["import { type BridgePrice, type DeltaPrice } from \"@velora-dex/sdk\";\nimport { useAccount } from \"wagmi\";\nimport { assert } from \"ts-essentials\";\nimport { useEnsureTxReceipt } from \"@/hooks/txs/queries/useAwaitTx\";\nimport { type Address, type Hash, type TransactionReceipt } from \"viem\";\nimport type {\n ApprovalFlowResult,\n SignPermitFlowResult,\n SubmitTxResult,\n} from \"./common/types\";\nimport { useMinViemClient } from \"@/hooks/useMinViemClient\";\nimport { useWatchDeltaAuction } from \"../prices/delta/queries/useWatchDeltaOrder\";\nimport { getOverallOrderStatus } from \"../prices/delta/orders/utils\";\nimport { useMutation } from \"@tanstack/react-query\";\nimport { useRef } from \"react\";\nimport type { SupportedChainId } from \"@/lib/web3/wagmi/types\";\nimport { UserCancelledError } from \"./common/errors\";\nimport { useTwapReceiverAddressValue } from \"@/core/twap/state/twapReceiverAddressAtom\";\nimport type {\n CallsSentObject,\n TxSentObject,\n} from \"@/lib/utils/transactionHandlers\";\nimport { useApproveOrPermit } from \"./common/useApproveOrPermit\";\nimport {\n useMarkPermit1Or2NonceAsUsed,\n type SignedPermitResult,\n} from \"./common/useSignPermit1Or2\";\nimport { useLogger } from \"@/core/logger\";\nimport {\n isBridgePrice,\n useSubscribeToDeltaPrice,\n} from \"../prices/delta/queries/useDeltaPriceQuery\";\nimport { usePartner } from \"@/hooks/usePartner\";\nimport { useWidgetEvents } from \"@/core/state/widgetEventsAtom\";\nimport { shouldApproveOrBatch } from \"./common/usePreSignAndSubmitDeltaOrder\";\nimport { getSwapSideFromDeltaPrice } from \"../prices/delta/orders/utils\";\nimport type { DeltaOrBridgePrice } from \"../prices/types\";\n\nimport { isETHaddress } from \"@/tokens/utils/eth\";\nimport { useCancelOrWithdrawAndCancelDeltaOrder } from \"../prices/delta/mutations/useCancelOrWithdrawAndCancelDeltaOrder\";\nimport type { CancelDeltaOrdersReturn } from \"../prices/delta/mutations/useCancelDeltaOrders\";\nimport { useReferrer } from \"@/hooks/useReferrer\";\n\nimport { useTwapPrices } from \"../prices/useTwapPrices\";\nimport { useTwapSide } from \"@/core/twap/state/twapSideAtom\";\nimport {\n useTwapDuration,\n useTwapSlippage,\n} from \"@/core/twap/state/twapParamsAtom\";\nimport {\n useCreateAndSubmitTwapOrder,\n type CreateAndSubmitTwapOrderInput,\n} from \"../prices/delta/mutations/twap/useCreateTwapOrder\";\nimport type { DeltaAuctionWithTwapOrder } from \"../prices/delta/orders/types\";\nimport type { BuildTWAPSellOrBuySpecificParams } from \"../prices/delta/mutations/types\";\nimport {\n getTwapAmountsFromPrice,\n produceTwapDeadlines,\n} from \"@/lib/utils/twap\";\nimport {\n usePreSignAndSubmitTwapOrder,\n type TwapOrderPreSignResult,\n} from \"../prices/delta/mutations/twap/usePreSignAndSubmitTwapOrder\";\nimport {\n useDepositAndSubmitTwapOrder,\n type TwapOrderDepositResult,\n} from \"../prices/delta/mutations/twap/useDepositAndSubmitTwapOrder\";\nimport { amountAfterSlippage } from \"@/lib/utils/slippage\";\nimport { DEFAULT_DELTA_BRIDGE } from \"../prices/delta/bridge/const\";\nimport type { CancelOrderStepKey } from \"@/components/widget/TradeOverview/steps\";\nimport { HALF_MINUTE_MS } from \"@/lib/constants/time\";\n\nconst twapOrderFlowType = \"twapOrder\";\n\nexport type UseTwapFlowInput = {\n twapPrice?: DeltaPrice | BridgePrice;\n};\n\nexport type SubmitTwapOrderResult = {\n tradeFlowType: typeof twapOrderFlowType;\n approve: SubmitTxResult;\n twapOrder: {\n sentOrder: DeltaAuctionWithTwapOrder;\n lastOrderState?: DeltaAuctionWithTwapOrder;\n };\n twapPrice: DeltaPrice | BridgePrice;\n account: Address;\n receiverAddress?: Address;\n};\n\ntype OnTxSent = (txSent: TxSentObject | CallsSentObject) => void;\n\ntype RunTwapOrderOptions = {\n onTxSent?: OnTxSent;\n};\n\ntype TwapOrderSubmissionResult = {\n order?: DeltaAuctionWithTwapOrder;\n isCreatingOrder: boolean;\n isPostingOrder: boolean;\n isOrderSent: boolean;\n isPending: boolean;\n isError: boolean;\n isSuccess: boolean;\n error: Error | null;\n};\n\ntype TwapOrderExecutionResult = {\n sentOrder?: DeltaAuctionWithTwapOrder;\n lastOrderState?: DeltaAuctionWithTwapOrder;\n isOrderPending: boolean;\n isOrderExecuting: boolean;\n isOrderExecuted: boolean;\n isPending: boolean;\n isError: boolean;\n isSuccess: boolean;\n error: Error | null;\n};\n\ntype TwapOrderCancelationResult = {\n step?: CancelOrderStepKey;\n receipt?: TransactionReceipt;\n txHash?: string;\n response?: CancelDeltaOrdersReturn;\n isCancelingOrder: boolean;\n isOrderCancellable: boolean;\n isOrderCanceled: boolean;\n isPending: boolean;\n isError: boolean;\n isSuccess: boolean;\n result?: TransactionReceipt | CancelDeltaOrdersReturn;\n error: Error | null;\n};\n\nexport type UseTwapFlowResult = {\n tradeFlowType: typeof twapOrderFlowType;\n chainId: SupportedChainId;\n runTwapOrderFlow: (\n options?: RunTwapOrderOptions\n ) => Promise<SubmitTwapOrderResult>;\n reset: () => void; // reset on Error to retry\n cancelFlow: () => void; // cancel flow\n retryFlow: (options?: RunTwapOrderOptions) => Promise<SubmitTwapOrderResult>; // reset and retry flow\n cancelTwapOrder: () => Promise<\n TransactionReceipt | CancelDeltaOrdersReturn | undefined\n >;\n approval: ApprovalFlowResult;\n signPermit: SignPermitFlowResult;\n twapOrderPreSign: TwapOrderPreSignResult;\n twapOrderDeposit: TwapOrderDepositResult;\n // submission represents either normal signing and POSTing of Order or pre-signing (in a tx) and POSTing\n twapOrderSubmission: TwapOrderSubmissionResult;\n twapOrderExecution: TwapOrderExecutionResult;\n twapOrderCancelation: TwapOrderCancelationResult;\n isPending: boolean;\n isSuccess: boolean;\n isError: boolean;\n error: Error | null;\n result?: SubmitTwapOrderResult;\n usedPrice?: DeltaPrice | BridgePrice;\n freshPrice?: DeltaPrice | BridgePrice;\n submittedTwapOrder?: DeltaAuctionWithTwapOrder;\n};\n\nconst TWAP_ORDER_MUTATION_KEY = \"runTwapOrderFlow\";\n\nexport function useTwapFlow({\n twapPrice: _twapPrice,\n}: UseTwapFlowInput): UseTwapFlowResult {\n const logger = useLogger(\"TwapFlow\");\n\n const {\n queryKey,\n price,\n chainId,\n refetch,\n totalSrcAmount,\n side: sideFromPrices,\n numSlices,\n priceParams,\n } = useTwapPrices({ enabled: false });\n\n const twapPrice: DeltaOrBridgePrice | undefined = price || _twapPrice;\n\n const twapSideFromInput = useTwapSide();\n\n const twapSide = sideFromPrices || twapSideFromInput;\n\n /* Inside useApproveOrPermit:\n 1. Get allowance for tokenFrom\n 2.1. submit Approve tx if necessary\n\n 2.2. sign Permit1\n\n 3. await Approve tx (if not using Permit)\n */\n\n const {\n approval,\n signPermit,\n approveTxMut,\n signPermitMut,\n events: approveOrPermitEvents,\n } = useApproveOrPermit({\n srcToken: twapPrice?.srcToken,\n srcAmount: totalSrcAmount,\n spenderContractType: \"ParaswapDelta\",\n swapSide: twapSide,\n tradeMode: \"twap\",\n chainId,\n tryPermit2: false,\n });\n\n /* 4.1. Build and Submit Twap Order */\n\n const { address: account } = useAccount();\n\n const { minClient } = useMinViemClient({\n chainId,\n account,\n });\n\n const createAndSubmitOrderMut = useCreateAndSubmitTwapOrder({\n chainId,\n account,\n client: minClient,\n mutationOptions: {\n onSuccess: (order) => {\n logger.log(\"Create Twap Order success\", order);\n },\n onError: (error) => {\n logger.error(\"Create Twap Order error\", error);\n },\n },\n });\n\n const twapOrderCreateAndSubmit: UseTwapFlowResult[\"twapOrderSubmission\"] = {\n order: createAndSubmitOrderMut.order,\n isCreatingOrder: createAndSubmitOrderMut.isCreatingOrder,\n isPostingOrder: createAndSubmitOrderMut.isPostingOrder,\n isOrderSent: createAndSubmitOrderMut.isOrderSent,\n isPending: createAndSubmitOrderMut.isPending,\n isError: createAndSubmitOrderMut.isError,\n isSuccess: createAndSubmitOrderMut.isSuccess,\n error: createAndSubmitOrderMut.error,\n };\n\n /* 4.2.\n 1. submit Batch tx (Approve + Twap pre-sign)\n 2. await Batch tx\n 3. post Pre-signed Order\n */\n\n const {\n twapOrderPreSign,\n canBatchTxs,\n isConnectedToSafe,\n preSignAndSubmitTwapOrder,\n reset: resetPreSignAndSubmitTwapOrder,\n } = usePreSignAndSubmitTwapOrder({\n chainId,\n account,\n logger,\n viemClient: minClient,\n });\n\n const {\n twapOrderDeposit,\n reset: resetDepositAndSubmitTwapOrder,\n depositAndSubmitTwapOrder,\n } = useDepositAndSubmitTwapOrder({\n chainId,\n account,\n logger,\n viemClient: minClient,\n });\n\n /* final Twap Order submission for step 4 */\n const twapOrderSubmission: UseTwapFlowResult[\"twapOrderSubmission\"] = {\n order:\n twapOrderCreateAndSubmit.order ||\n twapOrderPreSign.order ||\n twapOrderDeposit.order,\n isPostingOrder:\n twapOrderCreateAndSubmit.isPostingOrder ||\n twapOrderPreSign.postingOrder.isPostingOrder ||\n twapOrderDeposit.postingOrder.isPostingOrder,\n isCreatingOrder:\n twapOrderCreateAndSubmit.isCreatingOrder ||\n twapOrderPreSign.isCreatingOrder ||\n twapOrderDeposit.isCreatingOrder,\n isOrderSent:\n twapOrderCreateAndSubmit.isOrderSent ||\n twapOrderPreSign.isOrderSent ||\n twapOrderDeposit.isOrderSent,\n isPending:\n twapOrderCreateAndSubmit.isPending ||\n twapOrderPreSign.isPending ||\n twapOrderDeposit.isPending,\n isError:\n twapOrderCreateAndSubmit.isError ||\n twapOrderPreSign.isError ||\n twapOrderDeposit.isError,\n isSuccess:\n twapOrderCreateAndSubmit.isSuccess ||\n twapOrderPreSign.isSuccess ||\n twapOrderDeposit.isSuccess,\n error:\n twapOrderCreateAndSubmit.error ||\n twapOrderPreSign.error ||\n twapOrderDeposit.error,\n };\n\n /* 5. await Order execution */\n\n const watchOrderExecution = useWatchDeltaAuction<DeltaAuctionWithTwapOrder>({\n orderId: twapOrderSubmission.order?.id,\n refetchInterval: HALF_MINUTE_MS,\n onAuctionSuccess: (order) => {\n logger.log(\"Twap Order success\", order);\n },\n onAuctionFailure: (order) => {\n logger.log(\"Twap Order failure\", order);\n },\n onUpdatedAuction: (order) => {\n logger.log(\"Twap Order updated\", order);\n },\n });\n\n const orderStatus = watchOrderExecution.data\n ? getOverallOrderStatus(watchOrderExecution.data)\n : null;\n\n const twapOrderExecution: UseTwapFlowResult[\"twapOrderExecution\"] = {\n sentOrder: twapOrderSubmission.order,\n lastOrderState: watchOrderExecution.data,\n isOrderPending: orderStatus === \"pending\",\n isOrderExecuting: orderStatus === \"executing\",\n isOrderExecuted: orderStatus === \"confirmed\",\n isPending:\n watchOrderExecution.isLoading ||\n watchOrderExecution.isRefetching ||\n orderStatus === \"pending\" ||\n orderStatus === \"executing\",\n isError: watchOrderExecution.isError || orderStatus === \"failed\",\n isSuccess: orderStatus === \"confirmed\",\n error: watchOrderExecution.error,\n };\n\n const orderToCancel =\n twapOrderExecution.lastOrderState || twapOrderExecution.sentOrder;\n\n const cancelOrderMut = useCancelOrWithdrawAndCancelDeltaOrder({\n // supply the must up-to-date order for cancellation\n order: orderToCancel,\n chainId,\n account,\n client: minClient,\n logger,\n mutationOptions: {\n onMutate: () => {\n assert(orderToCancel, \"No order to cancel\");\n return orderToCancel;\n },\n },\n });\n\n const twapOrderCancelation: UseTwapFlowResult[\"twapOrderCancelation\"] = {\n receipt: cancelOrderMut.receipt,\n txHash: cancelOrderMut.txHash,\n response: cancelOrderMut.cancelOrderResponse,\n isCancelingOrder: cancelOrderMut.isPending,\n isOrderCancellable: cancelOrderMut.isOrderCancellable,\n isOrderCanceled: cancelOrderMut.isSuccess,\n isPending: cancelOrderMut.isPending,\n isError: cancelOrderMut.isError,\n isSuccess: cancelOrderMut.isSuccess,\n error: cancelOrderMut.error,\n result: cancelOrderMut.result,\n step: cancelOrderMut.step,\n };\n\n const ensureTxReceipt = useEnsureTxReceipt();\n\n const currentAbortControllerRef = useRef<AbortController | null>(null);\n const usingPriceRef = useRef<DeltaPrice | BridgePrice | null>(null);\n\n const cancelFlow = () => {\n currentAbortControllerRef.current?.abort(new UserCancelledError());\n currentAbortControllerRef.current = null;\n\n usingPriceRef.current = null;\n };\n\n const receiverAddress = useTwapReceiverAddressValue();\n\n const { markNonceAsUsed, clearNonce } = useMarkPermit1Or2NonceAsUsed({\n chainId,\n });\n\n const { partner, partnerAddress, partnerFeeBps, partnerTakesSurplus } =\n usePartner();\n const { referrerAddress } = useReferrer();\n\n const subscribeToPrice = useSubscribeToDeltaPrice();\n\n const { onTwapOrder } = useWidgetEvents();\n\n const twapSlippage = useTwapSlippage();\n const twapDurationMin = useTwapDuration();\n\n const submitTwapOrder = async ({\n onTxSent,\n lastPrice,\n }: RunTwapOrderOptions & {\n lastPrice?: DeltaPrice | BridgePrice | null;\n } = {}): Promise<SubmitTwapOrderResult> => {\n // reset all mutations except the current one,\n // otherwise we'll have previous data (txs) as mutation results\n approveTxMut.reset();\n signPermitMut.reset();\n createAndSubmitOrderMut.reset();\n cancelOrderMut.reset();\n resetPreSignAndSubmitTwapOrder();\n resetDepositAndSubmitTwapOrder();\n\n // no sense in starting flow without a price,\n // which may be unavailable only if we are retrying and twapPrice response now returns an error.\n // Otherwise this flow will be stopped by disabling Swap button in the first place\n assert(twapPrice, \"Twap price is not available\");\n\n const abortController = new AbortController();\n currentAbortControllerRef.current = abortController;\n\n const signal = abortController.signal;\n\n const { orderDeadline, orderInterval } = produceTwapDeadlines({\n durationMin: twapDurationMin,\n numSlices,\n });\n\n const orderSlippageBps = Math.floor(twapSlippage * 100);\n\n let signedPermitResult: SignedPermitResult | undefined;\n\n let approveTxHash: Hash | undefined;\n let approveTxReceipt: TransactionReceipt | undefined;\n\n // at this point this is the synchronously available price\n const allowanceToSet = approval.allowanceToSet;\n const allowanceToPermit = signPermit.amountToPermit;\n // we use this allowance as a max allowance we will accept new prices for\n\n // twapPrice here is the starting price, available before async code and waiting\n let freshPrice = twapPrice;\n if (freshPrice.hmac === lastPrice?.hmac) {\n // we are resubmitting the Twap order, because it failed the last time,\n // but the price hasn't updated yet, so force refetch,\n // comparing raw prices here before mutating to select by bridge preference\n const newPriceResult = await refetch({\n cancelRefetch: false,\n });\n // check if cancelled during refetch\n signal.throwIfAborted();\n\n if (newPriceResult.data) {\n freshPrice = newPriceResult.data;\n }\n }\n let unsubscribeFromPrice: (() => void) | undefined;\n // this also resets previous usingPriceRef\n usingPriceRef.current = freshPrice;\n\n const shouldDepositAndPreSign =\n // @TODO [depositNativeAndPreSign] ensureDeltaEthBalance and compare with price.srcAmount to skip the deposit,\n // or deposit the difference between user dETH balance and price.srcAmount to avoid unnecessary deposits\n isETHaddress(freshPrice.srcToken);\n\n /*\n if connected to Safe, or needs to approve a token with a tx, or needs to pre-wrap ETH\n and can batch txs, then pre-sign the batch;\n that way Safe does only one action (wrapETH?+Approve+setPreSignature batch tx)\n and a wallet that would otherwise potentially wrap ETH and then Approve Token (tx, not Permit),\n and then sign Order, basically has to make at least one tx, does only one action as well.\n */\n const { shouldDoApprovalTxOrPermit, tryPermit, shouldPreSignBatch } =\n shouldApproveOrBatch({\n approval,\n signPermit,\n canBatchTxs,\n isConnectedToSafe,\n });\n\n try {\n if (shouldDoApprovalTxOrPermit && allowanceToSet) {\n // queryKey used to fetch the current price,\n // it will be used for the subsequent price refetches as long as price params not changed\n const _queryKey = queryKey;\n\n // should always be available\n if (_queryKey) {\n // freeze allowanceToSet\n const approvedAmount = allowanceToSet;\n\n // subscribe to price updates to keep track of new prices for the same price params,\n // independently of the hook itself\n unsubscribeFromPrice = subscribeToPrice({\n queryKey: _queryKey,\n onData: (price) => {\n const newPrice: DeltaOrBridgePrice = price;\n\n if (signal.aborted) {\n // just in case unsubscribe in finally is not yet called\n // for the queued update with the price from an already cancelled flow\n unsubscribeFromPrice?.();\n unsubscribeFromPrice = undefined;\n return;\n }\n\n const { srcAmount: totalSrcAmount } = getTwapAmountsFromPrice({\n price: newPrice,\n numSlices,\n });\n\n // if new price fits into allowance, update it\n if (approvedAmount >= BigInt(totalSrcAmount)) {\n // add this check to resubmit flow\n logger.log(\"~ fresh price ~\", newPrice);\n freshPrice = newPrice;\n usingPriceRef.current = freshPrice;\n }\n },\n });\n }\n\n try {\n if (!tryPermit) {\n approveOrPermitEvents.onApproveTx.request({ allowanceToSet });\n\n approveTxHash = await approveTxMut.approveAsync({\n allowanceData: {\n allowanceToSet,\n },\n });\n\n approveOrPermitEvents.onApproveTx.sent({\n allowanceToSet,\n txHash: approveTxHash,\n });\n\n // if aborted by this point, throw an error\n signal.throwIfAborted();\n\n const approveTxReceiptPromise = ensureTxReceipt({\n hash: approveTxHash,\n chainId,\n onReplaced: (data) => {\n logger.log(\"onReplaced:approveTx\", approveTxHash, data);\n },\n });\n\n if (onTxSent) {\n onTxSent({\n chainId,\n action: \"approve\",\n transactionHash: approveTxHash,\n receiptPromise: approveTxReceiptPromise,\n transactionSpecificData: {\n action: \"approve\",\n approvedAmount: allowanceToSet,\n tokenAddress: approval.token as Address,\n spenderAddress: approval.spender as Address,\n },\n });\n }\n\n approveTxReceipt = await approveTxReceiptPromise;\n\n approveOrPermitEvents.onApproveTx.confirmed({\n allowanceToSet,\n txHash: approveTxHash,\n txReceipt: approveTxReceipt,\n });\n\n logger.log(\"~ approveTx ~ receipt:\", approveTxReceipt);\n } else {\n approveOrPermitEvents.onSignPermit.request({\n allowanceToSet: allowanceToPermit,\n });\n\n // sign Permit\n signedPermitResult = await signPermitMut.signPermitAsync({\n deadline: BigInt(orderDeadline),\n value: allowanceToPermit,\n });\n\n approveOrPermitEvents.onSignPermit.confirmed({\n allowanceToSet: allowanceToPermit,\n permit: signedPermitResult?.permitEncodedArgs,\n });\n }\n } catch (error) {\n if (!tryPermit) {\n approveOrPermitEvents.onApproveTx.failed({\n allowanceToSet,\n error: error as Error,\n txHash: approveTxHash, // won't necessarily be available\n });\n } else {\n approveOrPermitEvents.onSignPermit.failed({\n allowanceToSet: allowanceToPermit,\n error: error as Error,\n });\n }\n throw error;\n }\n }\n\n // if aborted by this point, throw an error\n signal.throwIfAborted();\n\n assert(account, \"Account is not connected\");\n\n // as long as we had set approvedAmount, we will only get new prices that satisfy the allowance\n const twapPriceToUse = freshPrice;\n usingPriceRef.current = twapPriceToUse;\n\n // no longer need updates, unsubscribe\n unsubscribeFromPrice?.();\n unsubscribeFromPrice = undefined;\n\n assert(twapPriceToUse, \"Twap price is not available\");\n const twapSide = getSwapSideFromDeltaPrice(twapPriceToUse);\n const { srcAmount: totalSrcAmount, destAmount: totalDestAmount } =\n getTwapAmountsFromPrice({ price: twapPriceToUse, numSlices });\n\n const permit = signedPermitResult?.permitEncodedArgs;\n\n const destChainId = isBridgePrice(twapPriceToUse)\n ? twapPriceToUse.bridge.destinationChainId\n : chainId;\n\n onTwapOrder?.({\n event: {\n name: \"TwapOrder:request\",\n params: {\n price: twapPriceToUse,\n },\n },\n });\n\n let orderFromAPI: DeltaAuctionWithTwapOrder;\n let sellOrBuyParams: BuildTWAPSellOrBuySpecificParams;\n\n if (twapSide === \"SELL\") {\n sellOrBuyParams = {\n onChainOrderType: \"TWAPOrder\",\n totalSrcAmount,\n // SDK adds destAmountPerSlice internally with slippage applied\n };\n } else {\n sellOrBuyParams = {\n onChainOrderType: \"TWAPBuyOrder\",\n totalDestAmount,\n // SDK applies slippage to maxSrcAmount internally\n maxSrcAmount: totalSrcAmount,\n };\n }\n\n const createOrderInput: CreateAndSubmitTwapOrderInput = {\n signal,\n type: \"MARKET\",\n degenMode: priceParams.degenMode,\n referrerAddress,\n orderInput: {\n owner: account,\n beneficiary: receiverAddress,\n srcToken: twapPriceToUse.srcToken,\n destToken: twapPriceToUse.destToken,\n permit,\n destChainId,\n deltaPrice: {\n ...twapPriceToUse,\n bridge: {\n ...twapPriceToUse.bridge,\n // TWAP: pass nullified protocolSelector\n protocolSelector: DEFAULT_DELTA_BRIDGE.protocolSelector,\n // SDK nullifies protocolData internally\n },\n partner,\n },\n\n partner,\n partnerAddress,\n partnerFeeBps,\n partnerTakesSurplus,\n\n deadline: orderDeadline,\n\n // twap specific params\n ...sellOrBuyParams,\n numSlices: numSlices,\n slippage: orderSlippageBps,\n interval: orderInterval,\n },\n };\n\n if (shouldDepositAndPreSign) {\n const depositAmount = getDepositAmount(sellOrBuyParams, twapSlippage);\n // deposit ETH + depositTx + POST order\n orderFromAPI = await depositAndSubmitTwapOrder({\n createOrderInput,\n depositAmount,\n onTxSent,\n });\n } else if (shouldPreSignBatch) {\n // prepare Order for pre-signing and POSTing:\n // 1. builds the order\n // 2. hashes the built order\n // 3. construct DeltaContract.setPreSignature(orderHash, true) tx calldata\n\n orderFromAPI = await preSignAndSubmitTwapOrder({\n createOrderInput,\n approval,\n onTxSent,\n });\n } else {\n // creating signing and POSTing the Order all together in one mutation\n orderFromAPI =\n await createAndSubmitOrderMut.mutateAsync(createOrderInput);\n }\n\n // Order is sent, consider Token nonce as used\n if (signedPermitResult) {\n markNonceAsUsed(signedPermitResult.signedPermitData);\n }\n\n onTwapOrder?.({\n event: {\n name: \"TwapOrder:sent\",\n params: {\n price: twapPriceToUse,\n order: orderFromAPI,\n },\n },\n });\n\n // no use aborting past this point, Order is already being processed\n\n return {\n tradeFlowType: twapOrderFlowType,\n approve: {\n txHash: approveTxHash,\n receipt: approveTxReceipt,\n },\n twapOrder: {\n sentOrder: orderFromAPI,\n },\n twapPrice: twapPriceToUse,\n account,\n receiverAddress,\n };\n } catch (error) {\n // Order failed, we can't be sure if nonce can be reused or it was incremented in a different Order\n if (signedPermitResult) {\n clearNonce(signedPermitResult.signedPermitData);\n }\n onTwapOrder?.({\n event: {\n name: \"TwapOrder:failed\",\n params: {\n error: error as Error,\n },\n },\n });\n\n throw error;\n } finally {\n // always unsubscribe if subscribed previously\n unsubscribeFromPrice?.();\n }\n };\n\n const cancelTwapOrder = async () => {\n try {\n return await cancelOrderMut.cancelDeltaOrder();\n } catch (error) {\n logger.error(\"Cancel Delta order error\", error);\n // allow to re-trigger cancellation after error (like UserCancelledError)\n cancelOrderMut.reset();\n }\n };\n\n const twapOrderMut = useMutation({\n mutationFn: submitTwapOrder,\n mutationKey: [TWAP_ORDER_MUTATION_KEY],\n onSuccess: (data) => {\n logger.log(\"Twap Order success\", data);\n },\n onError: (error) => {\n logger.error(\"Twap Order error\", error);\n },\n onSettled: () => {\n logger.log(\"Twap Order settled\");\n },\n });\n\n const runTwapOrderFlow = twapOrderMut.mutateAsync;\n\n const reset = () => {\n usingPriceRef.current = null;\n\n approveTxMut.reset();\n signPermitMut.reset();\n createAndSubmitOrderMut.reset();\n twapOrderMut.reset();\n cancelOrderMut.reset();\n resetPreSignAndSubmitTwapOrder();\n resetDepositAndSubmitTwapOrder();\n };\n\n const retryFlow = (\n options?: RunTwapOrderOptions\n ): Promise<SubmitTwapOrderResult> => {\n const lastPrice = usingPriceRef.current;\n reset();\n return runTwapOrderFlow({ ...options, lastPrice });\n };\n\n // finalPrice if we reached that point, or usable price (based on allowance given)\n const usedPrice: typeof twapPrice = usingPriceRef.current || twapPrice;\n\n let result: SubmitTwapOrderResult | undefined = twapOrderMut.data;\n if (result && twapOrderExecution.lastOrderState) {\n result = {\n ...result,\n twapOrder: {\n sentOrder: result.twapOrder.sentOrder,\n // lastOrderState may be CANCELLED here\n lastOrderState: twapOrderExecution.lastOrderState,\n },\n };\n }\n\n /**\n * priority:\n * 1. sentOrder = just sent Order from final result\n * 2. twapOrderExecution.lastOrderState = updated sent Order from watchOrderExecution (intermediate result)\n * 3. twapOrderExecution.sentOrder = just sent Order from watchOrderExecution (intermediate result)\n */\n const submittedTwapOrder: DeltaAuctionWithTwapOrder | undefined =\n result?.twapOrder.sentOrder ||\n twapOrderExecution.lastOrderState ||\n twapOrderExecution.sentOrder;\n\n /* 6. return result */\n return {\n tradeFlowType: twapOrderFlowType,\n chainId,\n runTwapOrderFlow,\n reset,\n cancelFlow,\n retryFlow,\n cancelTwapOrder,\n approval,\n signPermit,\n twapOrderPreSign: twapOrderPreSign,\n twapOrderDeposit: twapOrderDeposit,\n twapOrderSubmission,\n twapOrderExecution,\n twapOrderCancelation,\n // twapOrderMut includes all steps' queries and mutations and returns more precise errors (including cancellation)\n isPending: twapOrderMut.isPending,\n isSuccess: twapOrderSubmission.isSuccess && twapOrderExecution.isSuccess, // approval is an optional step\n isError: twapOrderMut.isError,\n error: twapOrderMut.error,\n result,\n usedPrice,\n freshPrice: twapPrice,\n submittedTwapOrder,\n };\n}\n\nfunction getDepositAmount(\n params: BuildTWAPSellOrBuySpecificParams,\n slippage: number\n) {\n if (\"totalSrcAmount\" in params) {\n return params.totalSrcAmount;\n }\n return amountAfterSlippage(params.maxSrcAmount, slippage, \"BUY\").toFixed(0);\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"useTwapFlow.js","names":["DeltaPriceV2","useAccount","assert","useEnsureTxReceipt","Address","Hash","TransactionReceipt","ApprovalFlowResult","SignPermitFlowResult","SubmitTxResult","useMinViemClient","useWatchDeltaAuction","getOverallOrderStatus","useMutation","useRef","SupportedChainId","UserCancelledError","useTwapReceiverAddressValue","CallsSentObject","TxSentObject","useApproveOrPermit","useMarkPermit1Or2NonceAsUsed","SignedPermitResult","useLogger","useSubscribeToDeltaPrice","usePartner","useWidgetEvents","shouldApproveOrBatch","getSwapSideFromDeltaPrice","isETHaddress","useCancelOrWithdrawAndCancelDeltaOrder","CancelDeltaOrdersReturn","useReferrer","useTwapPrices","useTwapSide","useTwapDuration","useTwapSlippage","useCreateAndSubmitTwapOrder","CreateAndSubmitTwapOrderInput","DeltaAuctionWithTwapOrder","BuildTWAPSellOrBuySpecificParams","getTwapAmountsFromPrice","produceTwapDeadlines","usePreSignAndSubmitTwapOrder","TwapOrderPreSignResult","useDepositAndSubmitTwapOrder","TwapOrderDepositResult","amountAfterSlippage","CancelOrderStepKey","HALF_MINUTE_MS","twapOrderFlowType","UseTwapFlowInput","twapPrice","SubmitTwapOrderResult","tradeFlowType","approve","twapOrder","sentOrder","lastOrderState","account","receiverAddress","OnTxSent","txSent","RunTwapOrderOptions","onTxSent","TwapOrderSubmissionResult","order","isCreatingOrder","isPostingOrder","isOrderSent","isPending","isError","isSuccess","error","Error","TwapOrderExecutionResult","isOrderPending","isOrderExecuting","isOrderExecuted","TwapOrderCancelationResult","step","receipt","txHash","response","isCancelingOrder","isOrderCancellable","isOrderCanceled","result","UseTwapFlowResult","chainId","runTwapOrderFlow","options","Promise","reset","cancelFlow","retryFlow","cancelTwapOrder","approval","signPermit","twapOrderPreSign","twapOrderDeposit","twapOrderSubmission","twapOrderExecution","twapOrderCancelation","usedPrice","freshPrice","submittedTwapOrder","TWAP_ORDER_MUTATION_KEY","useTwapFlow","_twapPrice","logger","queryKey","price","refetch","totalSrcAmount","side","sideFromPrices","numSlices","priceParams","enabled","twapSideFromInput","twapSide","approveTxMut","signPermitMut","events","approveOrPermitEvents","srcToken","inputToken","address","srcAmount","spenderContractType","swapSide","tradeMode","tryPermit2","minClient","createAndSubmitOrderMut","client","mutationOptions","onSuccess","log","onError","twapOrderCreateAndSubmit","canBatchTxs","isConnectedToSafe","preSignAndSubmitTwapOrder","resetPreSignAndSubmitTwapOrder","viemClient","resetDepositAndSubmitTwapOrder","depositAndSubmitTwapOrder","postingOrder","watchOrderExecution","orderId","id","refetchInterval","onAuctionSuccess","onAuctionFailure","onUpdatedAuction","orderStatus","data","isLoading","isRefetching","orderToCancel","cancelOrderMut","onMutate","cancelOrderResponse","ensureTxReceipt","currentAbortControllerRef","AbortController","usingPriceRef","current","abort","markNonceAsUsed","clearNonce","partner","partnerAddress","partnerFeeBps","partnerTakesSurplus","referrerAddress","subscribeToPrice","onTwapOrder","twapSlippage","twapDurationMin","submitTwapOrder","lastPrice","abortController","signal","orderDeadline","orderInterval","durationMin","orderSlippageBps","Math","floor","signedPermitResult","approveTxHash","approveTxReceipt","allowanceToSet","allowanceToPermit","amountToPermit","newPriceResult","cancelRefetch","throwIfAborted","unsubscribeFromPrice","shouldDepositAndPreSign","shouldDoApprovalTxOrPermit","tryPermit","shouldPreSignBatch","_queryKey","approvedAmount","onData","newPrice","aborted","undefined","BigInt","onApproveTx","request","approveAsync","allowanceData","sent","approveTxReceiptPromise","hash","onReplaced","action","transactionHash","receiptPromise","transactionSpecificData","tokenAddress","token","spenderAddress","spender","confirmed","txReceipt","onSignPermit","signPermitAsync","deadline","value","permit","permitEncodedArgs","failed","twapPriceToUse","destAmount","totalDestAmount","event","name","params","orderFromAPI","sellOrBuyParams","onChainOrderType","maxSrcAmount","createOrderInput","type","degenMode","orderInput","owner","beneficiary","route","slippage","interval","depositAmount","getDepositAmount","mutateAsync","signedPermitData","cancelDeltaOrder","twapOrderMut","mutationFn","mutationKey","onSettled","toFixed"],"sources":["../../../../src/hooks/swap/tradeFlow/useTwapFlow.ts"],"sourcesContent":["import type { DeltaPriceV2 } from \"@velora-dex/sdk\";\nimport { useAccount } from \"wagmi\";\nimport { assert } from \"ts-essentials\";\nimport { useEnsureTxReceipt } from \"@/hooks/txs/queries/useAwaitTx\";\nimport { type Address, type Hash, type TransactionReceipt } from \"viem\";\nimport type {\n ApprovalFlowResult,\n SignPermitFlowResult,\n SubmitTxResult,\n} from \"./common/types\";\nimport { useMinViemClient } from \"@/hooks/useMinViemClient\";\nimport { useWatchDeltaAuction } from \"../prices/delta/queries/useWatchDeltaOrder\";\nimport { getOverallOrderStatus } from \"../prices/delta/orders/utils\";\nimport { useMutation } from \"@tanstack/react-query\";\nimport { useRef } from \"react\";\nimport type { SupportedChainId } from \"@/lib/web3/wagmi/types\";\nimport { UserCancelledError } from \"./common/errors\";\nimport { useTwapReceiverAddressValue } from \"@/core/twap/state/twapReceiverAddressAtom\";\nimport type {\n CallsSentObject,\n TxSentObject,\n} from \"@/lib/utils/transactionHandlers\";\nimport { useApproveOrPermit } from \"./common/useApproveOrPermit\";\nimport {\n useMarkPermit1Or2NonceAsUsed,\n type SignedPermitResult,\n} from \"./common/useSignPermit1Or2\";\nimport { useLogger } from \"@/core/logger\";\nimport { useSubscribeToDeltaPrice } from \"../prices/delta/queries/useDeltaPriceQuery\";\nimport { usePartner } from \"@/hooks/usePartner\";\nimport { useWidgetEvents } from \"@/core/state/widgetEventsAtom\";\nimport { shouldApproveOrBatch } from \"./common/usePreSignAndSubmitDeltaOrder\";\nimport { getSwapSideFromDeltaPrice } from \"../prices/delta/orders/utils\";\n\nimport { isETHaddress } from \"@/tokens/utils/eth\";\nimport { useCancelOrWithdrawAndCancelDeltaOrder } from \"../prices/delta/mutations/useCancelOrWithdrawAndCancelDeltaOrder\";\nimport type { CancelDeltaOrdersReturn } from \"../prices/delta/mutations/useCancelDeltaOrders\";\nimport { useReferrer } from \"@/hooks/useReferrer\";\n\nimport { useTwapPrices } from \"../prices/useTwapPrices\";\nimport { useTwapSide } from \"@/core/twap/state/twapSideAtom\";\nimport {\n useTwapDuration,\n useTwapSlippage,\n} from \"@/core/twap/state/twapParamsAtom\";\nimport {\n useCreateAndSubmitTwapOrder,\n type CreateAndSubmitTwapOrderInput,\n} from \"../prices/delta/mutations/twap/useCreateTwapOrder\";\nimport type { DeltaAuctionWithTwapOrder } from \"../prices/delta/orders/types\";\nimport type { BuildTWAPSellOrBuySpecificParams } from \"../prices/delta/mutations/types\";\nimport {\n getTwapAmountsFromPrice,\n produceTwapDeadlines,\n} from \"@/lib/utils/twap\";\nimport {\n usePreSignAndSubmitTwapOrder,\n type TwapOrderPreSignResult,\n} from \"../prices/delta/mutations/twap/usePreSignAndSubmitTwapOrder\";\nimport {\n useDepositAndSubmitTwapOrder,\n type TwapOrderDepositResult,\n} from \"../prices/delta/mutations/twap/useDepositAndSubmitTwapOrder\";\nimport { amountAfterSlippage } from \"@/lib/utils/slippage\";\nimport type { CancelOrderStepKey } from \"@/components/widget/TradeOverview/steps\";\nimport { HALF_MINUTE_MS } from \"@/lib/constants/time\";\n\nconst twapOrderFlowType = \"twapOrder\";\n\nexport type UseTwapFlowInput = {\n twapPrice?: DeltaPriceV2;\n};\n\nexport type SubmitTwapOrderResult = {\n tradeFlowType: typeof twapOrderFlowType;\n approve: SubmitTxResult;\n twapOrder: {\n sentOrder: DeltaAuctionWithTwapOrder;\n lastOrderState?: DeltaAuctionWithTwapOrder;\n };\n twapPrice: DeltaPriceV2;\n account: Address;\n receiverAddress?: Address;\n};\n\ntype OnTxSent = (txSent: TxSentObject | CallsSentObject) => void;\n\ntype RunTwapOrderOptions = {\n onTxSent?: OnTxSent;\n};\n\ntype TwapOrderSubmissionResult = {\n order?: DeltaAuctionWithTwapOrder;\n isCreatingOrder: boolean;\n isPostingOrder: boolean;\n isOrderSent: boolean;\n isPending: boolean;\n isError: boolean;\n isSuccess: boolean;\n error: Error | null;\n};\n\ntype TwapOrderExecutionResult = {\n sentOrder?: DeltaAuctionWithTwapOrder;\n lastOrderState?: DeltaAuctionWithTwapOrder;\n isOrderPending: boolean;\n isOrderExecuting: boolean;\n isOrderExecuted: boolean;\n isPending: boolean;\n isError: boolean;\n isSuccess: boolean;\n error: Error | null;\n};\n\ntype TwapOrderCancelationResult = {\n step?: CancelOrderStepKey;\n receipt?: TransactionReceipt;\n txHash?: string;\n response?: CancelDeltaOrdersReturn;\n isCancelingOrder: boolean;\n isOrderCancellable: boolean;\n isOrderCanceled: boolean;\n isPending: boolean;\n isError: boolean;\n isSuccess: boolean;\n result?: TransactionReceipt | CancelDeltaOrdersReturn;\n error: Error | null;\n};\n\nexport type UseTwapFlowResult = {\n tradeFlowType: typeof twapOrderFlowType;\n chainId: SupportedChainId;\n runTwapOrderFlow: (\n options?: RunTwapOrderOptions\n ) => Promise<SubmitTwapOrderResult>;\n reset: () => void; // reset on Error to retry\n cancelFlow: () => void; // cancel flow\n retryFlow: (options?: RunTwapOrderOptions) => Promise<SubmitTwapOrderResult>; // reset and retry flow\n cancelTwapOrder: () => Promise<\n TransactionReceipt | CancelDeltaOrdersReturn | undefined\n >;\n approval: ApprovalFlowResult;\n signPermit: SignPermitFlowResult;\n twapOrderPreSign: TwapOrderPreSignResult;\n twapOrderDeposit: TwapOrderDepositResult;\n // submission represents either normal signing and POSTing of Order or pre-signing (in a tx) and POSTing\n twapOrderSubmission: TwapOrderSubmissionResult;\n twapOrderExecution: TwapOrderExecutionResult;\n twapOrderCancelation: TwapOrderCancelationResult;\n isPending: boolean;\n isSuccess: boolean;\n isError: boolean;\n error: Error | null;\n result?: SubmitTwapOrderResult;\n usedPrice?: DeltaPriceV2;\n freshPrice?: DeltaPriceV2;\n submittedTwapOrder?: DeltaAuctionWithTwapOrder;\n};\n\nconst TWAP_ORDER_MUTATION_KEY = \"runTwapOrderFlow\";\n\nexport function useTwapFlow({\n twapPrice: _twapPrice,\n}: UseTwapFlowInput): UseTwapFlowResult {\n const logger = useLogger(\"TwapFlow\");\n\n const {\n queryKey,\n price,\n chainId,\n refetch,\n totalSrcAmount,\n side: sideFromPrices,\n numSlices,\n priceParams,\n } = useTwapPrices({ enabled: false });\n\n const twapPrice: DeltaPriceV2 | undefined = price || _twapPrice;\n\n const twapSideFromInput = useTwapSide();\n\n const twapSide = sideFromPrices || twapSideFromInput;\n\n /* Inside useApproveOrPermit:\n 1. Get allowance for tokenFrom\n 2.1. submit Approve tx if necessary\n\n 2.2. sign Permit1\n\n 3. await Approve tx (if not using Permit)\n */\n\n const {\n approval,\n signPermit,\n approveTxMut,\n signPermitMut,\n events: approveOrPermitEvents,\n } = useApproveOrPermit({\n srcToken: twapPrice?.inputToken.address,\n srcAmount: totalSrcAmount,\n spenderContractType: \"ParaswapDelta\",\n swapSide: twapSide,\n tradeMode: \"twap\",\n chainId,\n tryPermit2: false,\n });\n\n /* 4.1. Build and Submit Twap Order */\n\n const { address: account } = useAccount();\n\n const { minClient } = useMinViemClient({\n chainId,\n account,\n });\n\n const createAndSubmitOrderMut = useCreateAndSubmitTwapOrder({\n chainId,\n account,\n client: minClient,\n mutationOptions: {\n onSuccess: (order) => {\n logger.log(\"Create Twap Order success\", order);\n },\n onError: (error) => {\n logger.error(\"Create Twap Order error\", error);\n },\n },\n });\n\n const twapOrderCreateAndSubmit: UseTwapFlowResult[\"twapOrderSubmission\"] = {\n order: createAndSubmitOrderMut.order,\n isCreatingOrder: createAndSubmitOrderMut.isCreatingOrder,\n isPostingOrder: createAndSubmitOrderMut.isPostingOrder,\n isOrderSent: createAndSubmitOrderMut.isOrderSent,\n isPending: createAndSubmitOrderMut.isPending,\n isError: createAndSubmitOrderMut.isError,\n isSuccess: createAndSubmitOrderMut.isSuccess,\n error: createAndSubmitOrderMut.error,\n };\n\n /* 4.2.\n 1. submit Batch tx (Approve + Twap pre-sign)\n 2. await Batch tx\n 3. post Pre-signed Order\n */\n\n const {\n twapOrderPreSign,\n canBatchTxs,\n isConnectedToSafe,\n preSignAndSubmitTwapOrder,\n reset: resetPreSignAndSubmitTwapOrder,\n } = usePreSignAndSubmitTwapOrder({\n chainId,\n account,\n logger,\n viemClient: minClient,\n });\n\n const {\n twapOrderDeposit,\n reset: resetDepositAndSubmitTwapOrder,\n depositAndSubmitTwapOrder,\n } = useDepositAndSubmitTwapOrder({\n chainId,\n account,\n logger,\n viemClient: minClient,\n });\n\n /* final Twap Order submission for step 4 */\n const twapOrderSubmission: UseTwapFlowResult[\"twapOrderSubmission\"] = {\n order:\n twapOrderCreateAndSubmit.order ||\n twapOrderPreSign.order ||\n twapOrderDeposit.order,\n isPostingOrder:\n twapOrderCreateAndSubmit.isPostingOrder ||\n twapOrderPreSign.postingOrder.isPostingOrder ||\n twapOrderDeposit.postingOrder.isPostingOrder,\n isCreatingOrder:\n twapOrderCreateAndSubmit.isCreatingOrder ||\n twapOrderPreSign.isCreatingOrder ||\n twapOrderDeposit.isCreatingOrder,\n isOrderSent:\n twapOrderCreateAndSubmit.isOrderSent ||\n twapOrderPreSign.isOrderSent ||\n twapOrderDeposit.isOrderSent,\n isPending:\n twapOrderCreateAndSubmit.isPending ||\n twapOrderPreSign.isPending ||\n twapOrderDeposit.isPending,\n isError:\n twapOrderCreateAndSubmit.isError ||\n twapOrderPreSign.isError ||\n twapOrderDeposit.isError,\n isSuccess:\n twapOrderCreateAndSubmit.isSuccess ||\n twapOrderPreSign.isSuccess ||\n twapOrderDeposit.isSuccess,\n error:\n twapOrderCreateAndSubmit.error ||\n twapOrderPreSign.error ||\n twapOrderDeposit.error,\n };\n\n /* 5. await Order execution */\n\n const watchOrderExecution = useWatchDeltaAuction<DeltaAuctionWithTwapOrder>({\n orderId: twapOrderSubmission.order?.id,\n refetchInterval: HALF_MINUTE_MS,\n onAuctionSuccess: (order) => {\n logger.log(\"Twap Order success\", order);\n },\n onAuctionFailure: (order) => {\n logger.log(\"Twap Order failure\", order);\n },\n onUpdatedAuction: (order) => {\n logger.log(\"Twap Order updated\", order);\n },\n });\n\n const orderStatus = watchOrderExecution.data\n ? getOverallOrderStatus(watchOrderExecution.data)\n : null;\n\n const twapOrderExecution: UseTwapFlowResult[\"twapOrderExecution\"] = {\n sentOrder: twapOrderSubmission.order,\n lastOrderState: watchOrderExecution.data,\n isOrderPending: orderStatus === \"pending\",\n isOrderExecuting: orderStatus === \"executing\",\n isOrderExecuted: orderStatus === \"confirmed\",\n isPending:\n watchOrderExecution.isLoading ||\n watchOrderExecution.isRefetching ||\n orderStatus === \"pending\" ||\n orderStatus === \"executing\",\n isError: watchOrderExecution.isError || orderStatus === \"failed\",\n isSuccess: orderStatus === \"confirmed\",\n error: watchOrderExecution.error,\n };\n\n const orderToCancel =\n twapOrderExecution.lastOrderState || twapOrderExecution.sentOrder;\n\n const cancelOrderMut = useCancelOrWithdrawAndCancelDeltaOrder({\n // supply the must up-to-date order for cancellation\n order: orderToCancel,\n chainId,\n account,\n client: minClient,\n logger,\n mutationOptions: {\n onMutate: () => {\n assert(orderToCancel, \"No order to cancel\");\n return orderToCancel;\n },\n },\n });\n\n const twapOrderCancelation: UseTwapFlowResult[\"twapOrderCancelation\"] = {\n receipt: cancelOrderMut.receipt,\n txHash: cancelOrderMut.txHash,\n response: cancelOrderMut.cancelOrderResponse,\n isCancelingOrder: cancelOrderMut.isPending,\n isOrderCancellable: cancelOrderMut.isOrderCancellable,\n isOrderCanceled: cancelOrderMut.isSuccess,\n isPending: cancelOrderMut.isPending,\n isError: cancelOrderMut.isError,\n isSuccess: cancelOrderMut.isSuccess,\n error: cancelOrderMut.error,\n result: cancelOrderMut.result,\n step: cancelOrderMut.step,\n };\n\n const ensureTxReceipt = useEnsureTxReceipt();\n\n const currentAbortControllerRef = useRef<AbortController | null>(null);\n const usingPriceRef = useRef<DeltaPriceV2 | null>(null);\n\n const cancelFlow = () => {\n currentAbortControllerRef.current?.abort(new UserCancelledError());\n currentAbortControllerRef.current = null;\n\n usingPriceRef.current = null;\n };\n\n const receiverAddress = useTwapReceiverAddressValue();\n\n const { markNonceAsUsed, clearNonce } = useMarkPermit1Or2NonceAsUsed({\n chainId,\n });\n\n const { partner, partnerAddress, partnerFeeBps, partnerTakesSurplus } =\n usePartner();\n const { referrerAddress } = useReferrer();\n\n const subscribeToPrice = useSubscribeToDeltaPrice();\n\n const { onTwapOrder } = useWidgetEvents();\n\n const twapSlippage = useTwapSlippage();\n const twapDurationMin = useTwapDuration();\n\n const submitTwapOrder = async ({\n onTxSent,\n lastPrice,\n }: RunTwapOrderOptions & {\n lastPrice?: DeltaPriceV2 | null;\n } = {}): Promise<SubmitTwapOrderResult> => {\n // reset all mutations except the current one,\n // otherwise we'll have previous data (txs) as mutation results\n approveTxMut.reset();\n signPermitMut.reset();\n createAndSubmitOrderMut.reset();\n cancelOrderMut.reset();\n resetPreSignAndSubmitTwapOrder();\n resetDepositAndSubmitTwapOrder();\n\n // no sense in starting flow without a price,\n // which may be unavailable only if we are retrying and twapPrice response now returns an error.\n // Otherwise this flow will be stopped by disabling Swap button in the first place\n assert(twapPrice, \"Twap price is not available\");\n\n const abortController = new AbortController();\n currentAbortControllerRef.current = abortController;\n\n const signal = abortController.signal;\n\n const { orderDeadline, orderInterval } = produceTwapDeadlines({\n durationMin: twapDurationMin,\n numSlices,\n });\n\n const orderSlippageBps = Math.floor(twapSlippage * 100);\n\n let signedPermitResult: SignedPermitResult | undefined;\n\n let approveTxHash: Hash | undefined;\n let approveTxReceipt: TransactionReceipt | undefined;\n\n // at this point this is the synchronously available price\n const allowanceToSet = approval.allowanceToSet;\n const allowanceToPermit = signPermit.amountToPermit;\n // we use this allowance as a max allowance we will accept new prices for\n\n // twapPrice here is the starting price, available before async code and waiting\n let freshPrice = twapPrice;\n if (freshPrice.id === lastPrice?.id) {\n // we are resubmitting the Twap order, because it failed the last time,\n // but the price hasn't updated yet, so force refetch,\n // comparing raw prices here before mutating to select by bridge preference\n const newPriceResult = await refetch({\n cancelRefetch: false,\n });\n // check if cancelled during refetch\n signal.throwIfAborted();\n\n if (newPriceResult.data) {\n freshPrice = newPriceResult.data;\n }\n }\n let unsubscribeFromPrice: (() => void) | undefined;\n // this also resets previous usingPriceRef\n usingPriceRef.current = freshPrice;\n\n const shouldDepositAndPreSign =\n // @TODO [depositNativeAndPreSign] ensureDeltaEthBalance and compare with price.srcAmount to skip the deposit,\n // or deposit the difference between user dETH balance and price.srcAmount to avoid unnecessary deposits\n isETHaddress(freshPrice.inputToken.address);\n\n /*\n if connected to Safe, or needs to approve a token with a tx, or needs to pre-wrap ETH\n and can batch txs, then pre-sign the batch;\n that way Safe does only one action (wrapETH?+Approve+setPreSignature batch tx)\n and a wallet that would otherwise potentially wrap ETH and then Approve Token (tx, not Permit),\n and then sign Order, basically has to make at least one tx, does only one action as well.\n */\n const { shouldDoApprovalTxOrPermit, tryPermit, shouldPreSignBatch } =\n shouldApproveOrBatch({\n approval,\n signPermit,\n canBatchTxs,\n isConnectedToSafe,\n });\n\n try {\n if (shouldDoApprovalTxOrPermit && allowanceToSet) {\n // queryKey used to fetch the current price,\n // it will be used for the subsequent price refetches as long as price params not changed\n const _queryKey = queryKey;\n\n // should always be available\n if (_queryKey) {\n // freeze allowanceToSet\n const approvedAmount = allowanceToSet;\n\n // subscribe to price updates to keep track of new prices for the same price params,\n // independently of the hook itself\n unsubscribeFromPrice = subscribeToPrice({\n queryKey: _queryKey,\n onData: (price) => {\n const newPrice: DeltaPriceV2 = price;\n\n if (signal.aborted) {\n // just in case unsubscribe in finally is not yet called\n // for the queued update with the price from an already cancelled flow\n unsubscribeFromPrice?.();\n unsubscribeFromPrice = undefined;\n return;\n }\n\n const { srcAmount: totalSrcAmount } = getTwapAmountsFromPrice({\n price: newPrice,\n numSlices,\n });\n\n // if new price fits into allowance, update it\n if (approvedAmount >= BigInt(totalSrcAmount)) {\n // add this check to resubmit flow\n logger.log(\"~ fresh price ~\", newPrice);\n freshPrice = newPrice;\n usingPriceRef.current = freshPrice;\n }\n },\n });\n }\n\n try {\n if (!tryPermit) {\n approveOrPermitEvents.onApproveTx.request({ allowanceToSet });\n\n approveTxHash = await approveTxMut.approveAsync({\n allowanceData: {\n allowanceToSet,\n },\n });\n\n approveOrPermitEvents.onApproveTx.sent({\n allowanceToSet,\n txHash: approveTxHash,\n });\n\n // if aborted by this point, throw an error\n signal.throwIfAborted();\n\n const approveTxReceiptPromise = ensureTxReceipt({\n hash: approveTxHash,\n chainId,\n onReplaced: (data) => {\n logger.log(\"onReplaced:approveTx\", approveTxHash, data);\n },\n });\n\n if (onTxSent) {\n onTxSent({\n chainId,\n action: \"approve\",\n transactionHash: approveTxHash,\n receiptPromise: approveTxReceiptPromise,\n transactionSpecificData: {\n action: \"approve\",\n approvedAmount: allowanceToSet,\n tokenAddress: approval.token as Address,\n spenderAddress: approval.spender as Address,\n },\n });\n }\n\n approveTxReceipt = await approveTxReceiptPromise;\n\n approveOrPermitEvents.onApproveTx.confirmed({\n allowanceToSet,\n txHash: approveTxHash,\n txReceipt: approveTxReceipt,\n });\n\n logger.log(\"~ approveTx ~ receipt:\", approveTxReceipt);\n } else {\n approveOrPermitEvents.onSignPermit.request({\n allowanceToSet: allowanceToPermit,\n });\n\n // sign Permit\n signedPermitResult = await signPermitMut.signPermitAsync({\n deadline: BigInt(orderDeadline),\n value: allowanceToPermit,\n });\n\n approveOrPermitEvents.onSignPermit.confirmed({\n allowanceToSet: allowanceToPermit,\n permit: signedPermitResult?.permitEncodedArgs,\n });\n }\n } catch (error) {\n if (!tryPermit) {\n approveOrPermitEvents.onApproveTx.failed({\n allowanceToSet,\n error: error as Error,\n txHash: approveTxHash, // won't necessarily be available\n });\n } else {\n approveOrPermitEvents.onSignPermit.failed({\n allowanceToSet: allowanceToPermit,\n error: error as Error,\n });\n }\n throw error;\n }\n }\n\n // if aborted by this point, throw an error\n signal.throwIfAborted();\n\n assert(account, \"Account is not connected\");\n\n // as long as we had set approvedAmount, we will only get new prices that satisfy the allowance\n const twapPriceToUse = freshPrice;\n usingPriceRef.current = twapPriceToUse;\n\n // no longer need updates, unsubscribe\n unsubscribeFromPrice?.();\n unsubscribeFromPrice = undefined;\n\n assert(twapPriceToUse, \"Twap price is not available\");\n const twapSide = getSwapSideFromDeltaPrice(twapPriceToUse);\n const { srcAmount: totalSrcAmount, destAmount: totalDestAmount } =\n getTwapAmountsFromPrice({ price: twapPriceToUse, numSlices });\n\n const permit = signedPermitResult?.permitEncodedArgs;\n\n onTwapOrder?.({\n event: {\n name: \"TwapOrder:request\",\n params: {\n price: twapPriceToUse,\n },\n },\n });\n\n let orderFromAPI: DeltaAuctionWithTwapOrder;\n let sellOrBuyParams: BuildTWAPSellOrBuySpecificParams;\n\n if (twapSide === \"SELL\") {\n sellOrBuyParams = {\n onChainOrderType: \"TWAPOrder\",\n totalSrcAmount,\n // server adds destAmountPerSlice internally with slippage applied\n };\n } else {\n sellOrBuyParams = {\n onChainOrderType: \"TWAPBuyOrder\",\n totalDestAmount,\n // server applies slippage to maxSrcAmount internally\n maxSrcAmount: totalSrcAmount,\n };\n }\n\n const createOrderInput: CreateAndSubmitTwapOrderInput = {\n signal,\n type: \"MARKET\",\n degenMode: priceParams.degenMode,\n referrerAddress,\n orderInput: {\n owner: account,\n beneficiary: receiverAddress,\n permit,\n // single-slice route from v2 price\n route: twapPriceToUse.route,\n\n partner,\n partnerAddress,\n partnerFeeBps,\n partnerTakesSurplus,\n\n deadline: orderDeadline,\n\n // twap specific params\n ...sellOrBuyParams,\n numSlices: numSlices,\n slippage: orderSlippageBps,\n interval: orderInterval,\n },\n };\n\n if (shouldDepositAndPreSign) {\n const depositAmount = getDepositAmount(sellOrBuyParams, twapSlippage);\n // deposit ETH + depositTx + POST order\n orderFromAPI = await depositAndSubmitTwapOrder({\n createOrderInput,\n depositAmount,\n onTxSent,\n });\n } else if (shouldPreSignBatch) {\n // prepare Order for pre-signing and POSTing:\n // 1. builds the order\n // 2. hashes the built order\n // 3. construct DeltaContract.setPreSignature(orderHash, true) tx calldata\n\n orderFromAPI = await preSignAndSubmitTwapOrder({\n createOrderInput,\n approval,\n onTxSent,\n });\n } else {\n // creating signing and POSTing the Order all together in one mutation\n orderFromAPI =\n await createAndSubmitOrderMut.mutateAsync(createOrderInput);\n }\n\n // Order is sent, consider Token nonce as used\n if (signedPermitResult) {\n markNonceAsUsed(signedPermitResult.signedPermitData);\n }\n\n onTwapOrder?.({\n event: {\n name: \"TwapOrder:sent\",\n params: {\n price: twapPriceToUse,\n order: orderFromAPI,\n },\n },\n });\n\n // no use aborting past this point, Order is already being processed\n\n return {\n tradeFlowType: twapOrderFlowType,\n approve: {\n txHash: approveTxHash,\n receipt: approveTxReceipt,\n },\n twapOrder: {\n sentOrder: orderFromAPI,\n },\n twapPrice: twapPriceToUse,\n account,\n receiverAddress,\n };\n } catch (error) {\n // Order failed, we can't be sure if nonce can be reused or it was incremented in a different Order\n if (signedPermitResult) {\n clearNonce(signedPermitResult.signedPermitData);\n }\n onTwapOrder?.({\n event: {\n name: \"TwapOrder:failed\",\n params: {\n error: error as Error,\n },\n },\n });\n\n throw error;\n } finally {\n // always unsubscribe if subscribed previously\n unsubscribeFromPrice?.();\n }\n };\n\n const cancelTwapOrder = async () => {\n try {\n return await cancelOrderMut.cancelDeltaOrder();\n } catch (error) {\n logger.error(\"Cancel Delta order error\", error);\n // allow to re-trigger cancellation after error (like UserCancelledError)\n cancelOrderMut.reset();\n }\n };\n\n const twapOrderMut = useMutation({\n mutationFn: submitTwapOrder,\n mutationKey: [TWAP_ORDER_MUTATION_KEY],\n onSuccess: (data) => {\n logger.log(\"Twap Order success\", data);\n },\n onError: (error) => {\n logger.error(\"Twap Order error\", error);\n },\n onSettled: () => {\n logger.log(\"Twap Order settled\");\n },\n });\n\n const runTwapOrderFlow = twapOrderMut.mutateAsync;\n\n const reset = () => {\n usingPriceRef.current = null;\n\n approveTxMut.reset();\n signPermitMut.reset();\n createAndSubmitOrderMut.reset();\n twapOrderMut.reset();\n cancelOrderMut.reset();\n resetPreSignAndSubmitTwapOrder();\n resetDepositAndSubmitTwapOrder();\n };\n\n const retryFlow = (\n options?: RunTwapOrderOptions\n ): Promise<SubmitTwapOrderResult> => {\n const lastPrice = usingPriceRef.current;\n reset();\n return runTwapOrderFlow({ ...options, lastPrice });\n };\n\n // finalPrice if we reached that point, or usable price (based on allowance given)\n const usedPrice: typeof twapPrice = usingPriceRef.current || twapPrice;\n\n let result: SubmitTwapOrderResult | undefined = twapOrderMut.data;\n if (result && twapOrderExecution.lastOrderState) {\n result = {\n ...result,\n twapOrder: {\n sentOrder: result.twapOrder.sentOrder,\n // lastOrderState may be CANCELLED here\n lastOrderState: twapOrderExecution.lastOrderState,\n },\n };\n }\n\n /**\n * priority:\n * 1. sentOrder = just sent Order from final result\n * 2. twapOrderExecution.lastOrderState = updated sent Order from watchOrderExecution (intermediate result)\n * 3. twapOrderExecution.sentOrder = just sent Order from watchOrderExecution (intermediate result)\n */\n const submittedTwapOrder: DeltaAuctionWithTwapOrder | undefined =\n result?.twapOrder.sentOrder ||\n twapOrderExecution.lastOrderState ||\n twapOrderExecution.sentOrder;\n\n /* 6. return result */\n return {\n tradeFlowType: twapOrderFlowType,\n chainId,\n runTwapOrderFlow,\n reset,\n cancelFlow,\n retryFlow,\n cancelTwapOrder,\n approval,\n signPermit,\n twapOrderPreSign: twapOrderPreSign,\n twapOrderDeposit: twapOrderDeposit,\n twapOrderSubmission,\n twapOrderExecution,\n twapOrderCancelation,\n // twapOrderMut includes all steps' queries and mutations and returns more precise errors (including cancellation)\n isPending: twapOrderMut.isPending,\n isSuccess: twapOrderSubmission.isSuccess && twapOrderExecution.isSuccess, // approval is an optional step\n isError: twapOrderMut.isError,\n error: twapOrderMut.error,\n result,\n usedPrice,\n freshPrice: twapPrice,\n submittedTwapOrder,\n };\n}\n\nfunction getDepositAmount(\n params: BuildTWAPSellOrBuySpecificParams,\n slippage: number\n) {\n if (\"totalSrcAmount\" in params) {\n return params.totalSrcAmount;\n }\n return amountAfterSlippage(params.maxSrcAmount, slippage, \"BUY\").toFixed(0);\n}\n"],"mappings":"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"}
|
package/dist/hooks/useSDK.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { LimitOrderHandlers, GetRateFunctions, APIVersion, GetDeltaOrdersFunctions, GetDeltaPriceFunctions, PostDeltaOrderFunctions, BuildDeltaOrderFunctions, SignDeltaOrderFunctions, PreSignDeltaOrderFunctions, CancelDeltaOrderFunctions, GetBridgeInfoFunctions, IsTokenSupportedInDeltaFunctions, BuildTxFunctions, GetSpenderFunctions, GetAdaptersFunctions, MinViemClient, GetLimitOrdersFunctions, BuildLimitOrderFunctions, PostLimitOrderFunctions, FillOrderDirectlyFunctions, DeltaTokenModuleFunctions, BuildTWAPDeltaOrderFunctions, PostTWAPDeltaOrderFunctions, PreSignTWAPDeltaOrderFunctions, SignTWAPDeltaOrderFunctions } from '@velora-dex/sdk';
|
|
1
|
+
import { LimitOrderHandlers, GetRateFunctions, APIVersion, GetDeltaOrdersFunctions, GetDeltaPriceFunctions, PostDeltaOrderFunctions, BuildDeltaOrderFunctions, SignDeltaOrderFunctions, PreSignDeltaOrderFunctions, CancelDeltaOrderFunctions, GetBridgeInfoFunctions, IsTokenSupportedInDeltaFunctions, BuildTxFunctions, GetSpenderFunctions, GetAdaptersFunctions, MinViemClient, GetLimitOrdersFunctions, BuildLimitOrderFunctions, PostLimitOrderFunctions, FillOrderDirectlyFunctions, DeltaTokenModuleFunctions, BuildTWAPDeltaOrderFunctions, PostTWAPDeltaOrderFunctions, PreSignTWAPDeltaOrderFunctions, SignTWAPDeltaOrderFunctions, GetDeltaPriceV2Functions, GetDeltaOrdersV2Functions, BuildDeltaOrderV2Functions, BuildTWAPDeltaOrderV2Functions, PostDeltaOrderV2Functions, PostTWAPDeltaOrderV2Functions, SignDeltaOrderV2Functions, CancelDeltaOrderV2Functions, GetBridgeRoutesFunctions, IsTokenSupportedInDeltaV2Functions, GetAgentsListV2Functions } from '@velora-dex/sdk';
|
|
2
2
|
import { Address, Hash, Hex } from 'viem';
|
|
3
3
|
import { Prettify } from 'ts-essentials';
|
|
4
4
|
type SDKCreateParams = {
|
|
@@ -28,8 +28,8 @@ export declare function useLimitOrdersSDK({ chainId, apiURL, account, client, }:
|
|
|
28
28
|
client: MinViemClient;
|
|
29
29
|
}): ConstructedSDKOutput<LimitOrdersSDK>;
|
|
30
30
|
export declare function useLimitOrdersSDK({ chainId, apiURL, account, client, }: LimitOrdersSDKCreateParams): ConstructedSDKOutput<LimitOrdersSDK | ReadOnlyLimitOrdersSDK>;
|
|
31
|
-
export declare const useFetchOnlySDK: ({ chainId, apiURL, }: SDKCreateParams) => Partial<ConstructedSDKOutput<
|
|
32
|
-
export declare const useCalldataSDK: ({ chainId, apiURL, client, }: Omit<LimitOrdersSDKCreateParams, "account">) => Partial<ConstructedSDKOutput<FillOrderDirectlyFunctions<Hex> & PreSignDeltaOrderFunctions<Hex> &
|
|
31
|
+
export declare const useFetchOnlySDK: ({ chainId, apiURL, }: SDKCreateParams) => Partial<ConstructedSDKOutput<PostDeltaOrderV2Functions>>;
|
|
32
|
+
export declare const useCalldataSDK: ({ chainId, apiURL, client, }: Omit<LimitOrdersSDKCreateParams, "account">) => Partial<ConstructedSDKOutput<FillOrderDirectlyFunctions<Hex> & PreSignDeltaOrderFunctions<Hex> & BuildDeltaOrderV2Functions & PreSignTWAPDeltaOrderFunctions<Hex> & BuildTWAPDeltaOrderV2Functions>>;
|
|
33
33
|
type ReadOnlyDeltaSDK = Prettify<GetDeltaOrdersFunctions & GetDeltaPriceFunctions & BuildDeltaOrderFunctions & PostDeltaOrderFunctions & BuildTWAPDeltaOrderFunctions & PostTWAPDeltaOrderFunctions & GetBridgeInfoFunctions & IsTokenSupportedInDeltaFunctions & {
|
|
34
34
|
chainId: number;
|
|
35
35
|
}>;
|
|
@@ -46,5 +46,21 @@ export declare function useDeltaSDK({ chainId, apiURL, account, client, }: Delta
|
|
|
46
46
|
client: MinViemClient;
|
|
47
47
|
}): ConstructedSDKOutput<DeltaSDK>;
|
|
48
48
|
export declare function useDeltaSDK({ chainId, apiURL, account, client, }: DeltaSDKCreateParams): ConstructedSDKOutput<DeltaSDK | ReadOnlyDeltaSDK>;
|
|
49
|
+
type ReadOnlyDeltaV2SDK = Prettify<GetDeltaPriceV2Functions & GetDeltaOrdersV2Functions & BuildDeltaOrderV2Functions & PostDeltaOrderV2Functions & BuildTWAPDeltaOrderV2Functions & PostTWAPDeltaOrderV2Functions & GetBridgeRoutesFunctions & IsTokenSupportedInDeltaV2Functions & GetAgentsListV2Functions & {
|
|
50
|
+
chainId: number;
|
|
51
|
+
}>;
|
|
52
|
+
export type DeltaV2SDK = Prettify<ReadOnlyDeltaV2SDK & SignDeltaOrderV2Functions & CancelDeltaOrderV2Functions & PreSignDeltaOrderFunctions<Hash> & DeltaTokenModuleFunctions<Hash> & PreSignTWAPDeltaOrderFunctions<Hash>>;
|
|
53
|
+
type DeltaV2SDKCreateParams = SDKCreateParams & {
|
|
54
|
+
client?: MinViemClient;
|
|
55
|
+
};
|
|
56
|
+
export declare function useDeltaV2SDK({ chainId, apiURL, account, client, }: DeltaV2SDKCreateParams & {
|
|
57
|
+
account?: undefined;
|
|
58
|
+
client?: undefined;
|
|
59
|
+
}): ConstructedSDKOutput<ReadOnlyDeltaV2SDK>;
|
|
60
|
+
export declare function useDeltaV2SDK({ chainId, apiURL, account, client, }: DeltaV2SDKCreateParams & {
|
|
61
|
+
account: Address;
|
|
62
|
+
client: MinViemClient;
|
|
63
|
+
}): ConstructedSDKOutput<DeltaV2SDK>;
|
|
64
|
+
export declare function useDeltaV2SDK({ chainId, apiURL, account, client, }: DeltaV2SDKCreateParams): ConstructedSDKOutput<DeltaV2SDK | ReadOnlyDeltaV2SDK>;
|
|
49
65
|
export {};
|
|
50
66
|
//# sourceMappingURL=useSDK.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useSDK.d.ts","sourceRoot":"","sources":["../../src/hooks/useSDK.ts"],"names":[],"mappings":"AAGA,OAAO,EAoBL,KAAK,kBAAkB,EACvB,KAAK,gBAAgB,EACrB,KAAK,UAAU,EACf,KAAK,uBAAuB,EAC5B,KAAK,sBAAsB,EAC3B,KAAK,uBAAuB,EAC5B,KAAK,wBAAwB,EAC7B,KAAK,uBAAuB,EAC5B,KAAK,0BAA0B,EAC/B,KAAK,yBAAyB,EAC9B,KAAK,sBAAsB,EAC3B,KAAK,gCAAgC,EACrC,KAAK,gBAAgB,EACrB,KAAK,mBAAmB,EACxB,KAAK,oBAAoB,EACzB,KAAK,aAAa,EAKlB,KAAK,uBAAuB,EAC5B,KAAK,wBAAwB,EAC7B,KAAK,uBAAuB,EAC5B,KAAK,0BAA0B,EAE/B,KAAK,yBAAyB,EAC9B,KAAK,4BAA4B,EACjC,KAAK,2BAA2B,EAGhC,KAAK,8BAA8B,EAInC,KAAK,2BAA2B,
|
|
1
|
+
{"version":3,"file":"useSDK.d.ts","sourceRoot":"","sources":["../../src/hooks/useSDK.ts"],"names":[],"mappings":"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"}
|
package/dist/hooks/useSDK.js
CHANGED
|
@@ -3,21 +3,21 @@ import { getApiURL as t } from "../lib/constants/urls.js";
|
|
|
3
3
|
import { useApiConfig as n } from "../core/state/apiConfigAtom.js";
|
|
4
4
|
import { useMemo as r } from "react";
|
|
5
5
|
import i from "axios";
|
|
6
|
-
import { constructAllLimitOrdersHandlers as a, constructAxiosFetcher as o, constructBuildDeltaOrder as s,
|
|
7
|
-
import { encodeFunctionData as
|
|
6
|
+
import { constructAllLimitOrdersHandlers as a, constructAxiosFetcher as o, constructBuildDeltaOrder as s, constructBuildDeltaOrderV2 as c, constructBuildLimitOrder as l, constructBuildTWAPDeltaOrder as u, constructBuildTWAPDeltaOrderV2 as d, constructBuildTx as f, constructCancelDeltaOrder as p, constructCancelDeltaOrderV2 as m, constructDeltaTokenModule as h, constructFillOrderDirectly as g, constructGetAdapters as _, constructGetAgentsListV2 as v, constructGetBridgeInfo as y, constructGetBridgeRoutes as b, constructGetDeltaOrders as x, constructGetDeltaOrdersV2 as S, constructGetDeltaPrice as C, constructGetDeltaPriceV2 as w, constructGetLimitOrders as T, constructGetRate as E, constructGetSpender as D, constructIsTokenSupportedInDelta as O, constructIsTokenSupportedInDeltaV2 as k, constructPartialSDK as A, constructPostDeltaOrder as j, constructPostDeltaOrderV2 as M, constructPostLimitOrder as N, constructPostTWAPDeltaOrder as P, constructPostTWAPDeltaOrderV2 as F, constructPreSignDeltaOrder as I, constructPreSignTWAPDeltaOrder as L, constructSignDeltaOrder as R, constructSignDeltaOrderV2 as z, constructSignTWAPDeltaOrder as B, constructSubmitTWAPDeltaOrder as V, constructViemContractCaller as H } from "@velora-dex/sdk";
|
|
7
|
+
import { encodeFunctionData as U } from "viem";
|
|
8
8
|
//#region src/hooks/useSDK.ts
|
|
9
|
-
function
|
|
9
|
+
function W() {
|
|
10
10
|
"use no memo";
|
|
11
11
|
let e = n();
|
|
12
12
|
return r(() => o(i, e), [e]);
|
|
13
13
|
}
|
|
14
|
-
function
|
|
14
|
+
function G({ chainId: e, apiURL: n }) {
|
|
15
15
|
"use no memo";
|
|
16
|
-
let i =
|
|
16
|
+
let i = W(), a = r(() => A({
|
|
17
17
|
apiURL: n ?? t(),
|
|
18
18
|
chainId: e,
|
|
19
19
|
fetcher: i
|
|
20
|
-
},
|
|
20
|
+
}, E, D, _, f), [
|
|
21
21
|
n,
|
|
22
22
|
e,
|
|
23
23
|
i
|
|
@@ -29,21 +29,21 @@ function P({ chainId: e, apiURL: n }) {
|
|
|
29
29
|
sdk: a
|
|
30
30
|
};
|
|
31
31
|
}
|
|
32
|
-
var
|
|
33
|
-
function
|
|
32
|
+
var K = e("LimitOrdersSDK");
|
|
33
|
+
function q({ chainId: e, apiURL: n, account: i, client: o }) {
|
|
34
34
|
"use no memo";
|
|
35
|
-
let s =
|
|
36
|
-
|
|
35
|
+
let s = W(), c = r(() => {
|
|
36
|
+
K.once.log("init sdk");
|
|
37
37
|
let r = {
|
|
38
38
|
apiURL: n ?? t(),
|
|
39
39
|
chainId: e,
|
|
40
40
|
fetcher: s
|
|
41
41
|
};
|
|
42
|
-
if (!o || !i) return
|
|
43
|
-
let
|
|
44
|
-
return
|
|
42
|
+
if (!o || !i) return A(r, T, l, N);
|
|
43
|
+
let c = H(o, i);
|
|
44
|
+
return A({
|
|
45
45
|
...r,
|
|
46
|
-
contractCaller:
|
|
46
|
+
contractCaller: c
|
|
47
47
|
}, a);
|
|
48
48
|
}, [
|
|
49
49
|
o,
|
|
@@ -53,16 +53,16 @@ function I({ chainId: e, apiURL: n, account: i, client: o }) {
|
|
|
53
53
|
s
|
|
54
54
|
]);
|
|
55
55
|
return {
|
|
56
|
-
appVersion:
|
|
57
|
-
chainId:
|
|
58
|
-
apiURL:
|
|
59
|
-
sdk:
|
|
56
|
+
appVersion: c.version,
|
|
57
|
+
chainId: c.chainId,
|
|
58
|
+
apiURL: c.apiURL,
|
|
59
|
+
sdk: c
|
|
60
60
|
};
|
|
61
61
|
}
|
|
62
|
-
var
|
|
62
|
+
var J = () => {
|
|
63
63
|
let e = async (e) => {
|
|
64
64
|
let { abi: t, contractMethod: n, args: r } = e;
|
|
65
|
-
return
|
|
65
|
+
return U({
|
|
66
66
|
abi: t,
|
|
67
67
|
functionName: n,
|
|
68
68
|
args: r
|
|
@@ -75,18 +75,18 @@ var L = () => {
|
|
|
75
75
|
staticCall: t,
|
|
76
76
|
signTypedDataCall: t
|
|
77
77
|
};
|
|
78
|
-
},
|
|
78
|
+
}, Y = e("CalldataSDK"), X = ({ chainId: e, apiURL: n, client: i }) => {
|
|
79
79
|
"use no memo";
|
|
80
|
-
let a =
|
|
80
|
+
let a = W(), o = r(() => {
|
|
81
81
|
if (!i) return;
|
|
82
|
-
|
|
83
|
-
let r =
|
|
84
|
-
return
|
|
82
|
+
Y.once.log("init sdk");
|
|
83
|
+
let r = J();
|
|
84
|
+
return A({
|
|
85
85
|
apiURL: n ?? t(),
|
|
86
86
|
chainId: e,
|
|
87
87
|
fetcher: a,
|
|
88
88
|
contractCaller: r
|
|
89
|
-
},
|
|
89
|
+
}, g, I, c, L, d);
|
|
90
90
|
}, [
|
|
91
91
|
n,
|
|
92
92
|
e,
|
|
@@ -99,22 +99,22 @@ var L = () => {
|
|
|
99
99
|
apiURL: o?.apiURL,
|
|
100
100
|
sdk: o
|
|
101
101
|
};
|
|
102
|
-
},
|
|
103
|
-
function
|
|
102
|
+
}, Z = e("DeltaSDK");
|
|
103
|
+
function Q({ chainId: e, apiURL: n, account: i, client: a }) {
|
|
104
104
|
"use no memo";
|
|
105
|
-
let o =
|
|
106
|
-
|
|
105
|
+
let o = W(), c = r(() => {
|
|
106
|
+
Z.once.log("init sdk");
|
|
107
107
|
let r = {
|
|
108
108
|
apiURL: n ?? t(),
|
|
109
109
|
chainId: e,
|
|
110
110
|
fetcher: o
|
|
111
111
|
};
|
|
112
|
-
if (!a || !i) return
|
|
113
|
-
let c =
|
|
114
|
-
return
|
|
112
|
+
if (!a || !i) return A(r, x, C, s, j, u, P, y, O);
|
|
113
|
+
let c = H(a, i);
|
|
114
|
+
return A({
|
|
115
115
|
...r,
|
|
116
116
|
contractCaller: c
|
|
117
|
-
},
|
|
117
|
+
}, x, C, s, j, p, y, O, R, I, P, u, B, L, V, h);
|
|
118
118
|
}, [
|
|
119
119
|
n,
|
|
120
120
|
e,
|
|
@@ -129,7 +129,37 @@ function V({ chainId: e, apiURL: n, account: i, client: a }) {
|
|
|
129
129
|
sdk: c
|
|
130
130
|
};
|
|
131
131
|
}
|
|
132
|
+
var $ = e("DeltaV2SDK");
|
|
133
|
+
function ee({ chainId: e, apiURL: n, account: i, client: a }) {
|
|
134
|
+
"use no memo";
|
|
135
|
+
let o = W(), s = r(() => {
|
|
136
|
+
$.once.log("init sdk");
|
|
137
|
+
let r = {
|
|
138
|
+
apiURL: n ?? t(),
|
|
139
|
+
chainId: e,
|
|
140
|
+
fetcher: o
|
|
141
|
+
};
|
|
142
|
+
if (!a || !i) return A(r, w, S, c, M, d, F, b, k, v);
|
|
143
|
+
let s = H(a, i);
|
|
144
|
+
return A({
|
|
145
|
+
...r,
|
|
146
|
+
contractCaller: s
|
|
147
|
+
}, w, S, c, M, d, F, b, k, v, z, m, I, L, h);
|
|
148
|
+
}, [
|
|
149
|
+
n,
|
|
150
|
+
e,
|
|
151
|
+
a,
|
|
152
|
+
i,
|
|
153
|
+
o
|
|
154
|
+
]);
|
|
155
|
+
return {
|
|
156
|
+
appVersion: s.version,
|
|
157
|
+
chainId: s.chainId,
|
|
158
|
+
apiURL: s.apiURL,
|
|
159
|
+
sdk: s
|
|
160
|
+
};
|
|
161
|
+
}
|
|
132
162
|
//#endregion
|
|
133
|
-
export {
|
|
163
|
+
export { X as useCalldataSDK, Q as useDeltaSDK, ee as useDeltaV2SDK, q as useLimitOrdersSDK, G as useMarketSwapSDK };
|
|
134
164
|
|
|
135
165
|
//# sourceMappingURL=useSDK.js.map
|
package/dist/hooks/useSDK.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useSDK.js","names":["axios","useMemo","constructAxiosFetcher","constructFetchFetcher","constructPartialSDK","constructGetSpender","constructGetAdapters","constructBuildTx","constructAllLimitOrdersHandlers","constructGetRate","constructGetDeltaPrice","constructGetDeltaOrders","constructBuildDeltaOrder","constructSignDeltaOrder","constructPreSignDeltaOrder","constructPostDeltaOrder","constructCancelDeltaOrder","constructGetBridgeInfo","constructIsTokenSupportedInDelta","constructDeltaTokenModule","constructViemContractCaller","LimitOrderHandlers","GetRateFunctions","APIVersion","GetDeltaOrdersFunctions","GetDeltaPriceFunctions","PostDeltaOrderFunctions","BuildDeltaOrderFunctions","SignDeltaOrderFunctions","PreSignDeltaOrderFunctions","CancelDeltaOrderFunctions","GetBridgeInfoFunctions","IsTokenSupportedInDeltaFunctions","BuildTxFunctions","GetSpenderFunctions","GetAdaptersFunctions","MinViemClient","constructGetLimitOrders","constructBuildLimitOrder","constructPostLimitOrder","constructFillOrderDirectly","GetLimitOrdersFunctions","BuildLimitOrderFunctions","PostLimitOrderFunctions","FillOrderDirectlyFunctions","ContractCallerFunctions","DeltaTokenModuleFunctions","BuildTWAPDeltaOrderFunctions","PostTWAPDeltaOrderFunctions","constructPreSignTWAPDeltaOrder","constructBuildTWAPDeltaOrder","PreSignTWAPDeltaOrderFunctions","constructPostTWAPDeltaOrder","constructSignTWAPDeltaOrder","constructSubmitTWAPDeltaOrder","SignTWAPDeltaOrderFunctions","encodeFunctionData","Address","Hash","Hex","Prettify","getLogger","getApiURL","useApiConfig","useSDKFetcher","apiConfig","useKeepAliveSDKFetcher","window","fetch","keepalive","SDKCreateParams","chainId","apiURL","account","MarketSwapSDK","ConstructedSDKOutput","sdk","T","appVersion","useMarketSwapSDK","fetcher","SDKconfig","version","LimitOrdersSDKCreateParams","client","ReadOnlyLimitOrdersSDK","LimitOrdersSDK","limitSDKLogger","useLimitOrdersSDK","once","log","contractCaller","CalldataContractCaller","constructCalldataContractCaller","transactCall","params","abi","contractMethod","functionName","args","calldata","staticCall","Error","signTypedDataCall","useFetchOnlySDK","Partial","calldataSDKLogger","useCalldataSDK","Omit","ReadOnlyDeltaSDK","DeltaSDK","DeltaSDKCreateParams","deltaSDKLogger","useDeltaSDK"],"sources":["../../src/hooks/useSDK.ts"],"sourcesContent":["import axios from \"axios\";\nimport { useMemo } from \"react\";\n\nimport {\n constructAxiosFetcher,\n constructFetchFetcher,\n constructPartialSDK,\n constructGetSpender,\n constructGetAdapters,\n constructBuildTx,\n constructAllLimitOrdersHandlers,\n constructGetRate,\n constructGetDeltaPrice,\n constructGetDeltaOrders,\n constructBuildDeltaOrder,\n constructSignDeltaOrder,\n constructPreSignDeltaOrder,\n constructPostDeltaOrder,\n constructCancelDeltaOrder,\n constructGetBridgeInfo,\n constructIsTokenSupportedInDelta,\n constructDeltaTokenModule,\n constructViemContractCaller,\n type LimitOrderHandlers,\n type GetRateFunctions,\n type APIVersion,\n type GetDeltaOrdersFunctions,\n type GetDeltaPriceFunctions,\n type PostDeltaOrderFunctions,\n type BuildDeltaOrderFunctions,\n type SignDeltaOrderFunctions,\n type PreSignDeltaOrderFunctions,\n type CancelDeltaOrderFunctions,\n type GetBridgeInfoFunctions,\n type IsTokenSupportedInDeltaFunctions,\n type BuildTxFunctions,\n type GetSpenderFunctions,\n type GetAdaptersFunctions,\n type MinViemClient,\n constructGetLimitOrders,\n constructBuildLimitOrder,\n constructPostLimitOrder,\n constructFillOrderDirectly,\n type GetLimitOrdersFunctions,\n type BuildLimitOrderFunctions,\n type PostLimitOrderFunctions,\n type FillOrderDirectlyFunctions,\n type ContractCallerFunctions,\n type DeltaTokenModuleFunctions,\n type BuildTWAPDeltaOrderFunctions,\n type PostTWAPDeltaOrderFunctions,\n constructPreSignTWAPDeltaOrder,\n constructBuildTWAPDeltaOrder,\n type PreSignTWAPDeltaOrderFunctions,\n constructPostTWAPDeltaOrder,\n constructSignTWAPDeltaOrder,\n constructSubmitTWAPDeltaOrder,\n type SignTWAPDeltaOrderFunctions,\n} from \"@velora-dex/sdk\";\nimport { encodeFunctionData, type Address, type Hash, type Hex } from \"viem\";\nimport type { Prettify } from \"ts-essentials\";\nimport { getLogger } from \"@/core/logger\";\nimport { getApiURL } from \"@/lib/constants/urls\";\nimport { useApiConfig } from \"@/core/state/apiConfigAtom\";\n\nfunction useSDKFetcher() {\n \"use no memo\";\n\n const apiConfig = useApiConfig();\n\n return useMemo(() => {\n return constructAxiosFetcher(axios, apiConfig);\n }, [apiConfig]);\n}\n\nfunction useKeepAliveSDKFetcher() {\n \"use no memo\";\n\n const apiConfig = useApiConfig();\n\n return useMemo(() => {\n if (typeof window === \"undefined\") return;\n return constructFetchFetcher(window.fetch, {\n ...apiConfig,\n keepalive: true,\n });\n }, [apiConfig]);\n}\n\ntype SDKCreateParams = {\n chainId: number;\n apiURL?: string;\n account?: Address;\n};\n\nexport type MarketSwapSDK = Prettify<\n GetSpenderFunctions &\n BuildTxFunctions &\n GetRateFunctions &\n GetAdaptersFunctions\n>;\n\ntype ConstructedSDKOutput<T> = {\n sdk: T;\n appVersion: APIVersion;\n chainId: number;\n apiURL: string;\n};\n\nexport function useMarketSwapSDK({\n chainId,\n apiURL,\n}: SDKCreateParams): ConstructedSDKOutput<MarketSwapSDK> {\n \"use no memo\";\n\n const fetcher = useSDKFetcher();\n\n const sdk = useMemo(() => {\n const SDKconfig = {\n apiURL: apiURL ?? getApiURL(),\n chainId,\n fetcher,\n };\n\n return constructPartialSDK(\n SDKconfig,\n constructGetRate,\n constructGetSpender,\n constructGetAdapters,\n constructBuildTx\n );\n }, [apiURL, chainId, fetcher]);\n\n return {\n appVersion: sdk.version,\n chainId: sdk.chainId,\n apiURL: sdk.apiURL,\n sdk,\n };\n}\ntype LimitOrdersSDKCreateParams = SDKCreateParams & {\n client?: MinViemClient;\n};\n\ntype ReadOnlyLimitOrdersSDK = Prettify<\n GetLimitOrdersFunctions & BuildLimitOrderFunctions & PostLimitOrderFunctions\n>;\n\nexport type LimitOrdersSDK = Prettify<LimitOrderHandlers<Hash>>;\n\nconst limitSDKLogger = getLogger(\"LimitOrdersSDK\");\n\n// can paraswap.fillOrder from a taker address to simulate happy path\n// @TODO check that we always use correct SDK version\nexport function useLimitOrdersSDK({\n chainId,\n apiURL,\n account,\n client,\n}: LimitOrdersSDKCreateParams & {\n account?: undefined;\n client?: undefined;\n}): ConstructedSDKOutput<ReadOnlyLimitOrdersSDK>;\nexport function useLimitOrdersSDK({\n chainId,\n apiURL,\n account,\n client,\n}: LimitOrdersSDKCreateParams & {\n account: Address;\n client: MinViemClient;\n}): ConstructedSDKOutput<LimitOrdersSDK>;\nexport function useLimitOrdersSDK({\n chainId,\n apiURL,\n account,\n client,\n}: LimitOrdersSDKCreateParams): ConstructedSDKOutput<\n LimitOrdersSDK | ReadOnlyLimitOrdersSDK\n>;\nexport function useLimitOrdersSDK({\n chainId,\n apiURL,\n account,\n client,\n}: LimitOrdersSDKCreateParams): ConstructedSDKOutput<\n LimitOrdersSDK | ReadOnlyLimitOrdersSDK\n> {\n \"use no memo\";\n\n const fetcher = useSDKFetcher();\n\n const sdk = useMemo(() => {\n limitSDKLogger.once.log(\"init sdk\");\n const SDKconfig = {\n apiURL: apiURL ?? getApiURL(),\n chainId,\n fetcher,\n };\n\n if (!client || !account) {\n return constructPartialSDK(\n SDKconfig,\n constructGetLimitOrders,\n constructBuildLimitOrder,\n constructPostLimitOrder\n );\n }\n\n const contractCaller = constructViemContractCaller(client, account);\n\n return constructPartialSDK(\n { ...SDKconfig, contractCaller },\n constructAllLimitOrdersHandlers\n );\n }, [client, account, apiURL, chainId, fetcher]);\n\n return {\n appVersion: sdk.version,\n chainId: sdk.chainId,\n apiURL: sdk.apiURL,\n sdk,\n };\n}\n\n// ContractCaller that returns Contract[method](args) calldata instead of sending out a transaction\ntype CalldataContractCaller = ContractCallerFunctions<Hex>;\n\nconst constructCalldataContractCaller = (): CalldataContractCaller => {\n const transactCall: CalldataContractCaller[\"transactCall\"] = async (\n params\n ) => {\n const { abi, contractMethod: functionName, args } = params;\n const calldata = encodeFunctionData<typeof abi, string>({\n abi,\n functionName,\n args,\n });\n return calldata;\n };\n\n // won't be used, but needed for types\n const staticCall = () => {\n throw new Error(\"Not implemented\");\n };\n\n return {\n transactCall,\n staticCall,\n signTypedDataCall: staticCall,\n };\n};\n\n// can be used to POST final data before page is closed\nexport const useFetchOnlySDK = ({\n chainId,\n apiURL,\n}: SDKCreateParams): Partial<ConstructedSDKOutput<PostDeltaOrderFunctions>> => {\n \"use no memo\";\n\n // fetch, unlike axios allows for `keepalive` parameter,\n // so we can use it to keep the request alive a bit after the page is closed.\n // the alternative of using navigator.sendBeacon doesn't work with API because it includes credentials=always\n // which is incompatible with API CORS settings\n const fetcher = useKeepAliveSDKFetcher();\n\n const sdk = useMemo(() => {\n if (!fetcher) return;\n\n return constructPartialSDK(\n {\n apiURL: apiURL ?? getApiURL(),\n chainId,\n fetcher,\n },\n constructPostDeltaOrder\n );\n }, [apiURL, chainId, fetcher]);\n\n return {\n appVersion: sdk?.version,\n chainId: sdk?.chainId,\n apiURL: sdk?.apiURL,\n sdk,\n };\n};\n\nconst calldataSDKLogger = getLogger(\"CalldataSDK\");\n\nexport const useCalldataSDK = ({\n chainId,\n apiURL,\n client,\n}: Omit<LimitOrdersSDKCreateParams, \"account\">): Partial<\n ConstructedSDKOutput<\n FillOrderDirectlyFunctions<Hex> &\n PreSignDeltaOrderFunctions<Hex> &\n BuildDeltaOrderFunctions &\n PreSignTWAPDeltaOrderFunctions<Hex> &\n BuildTWAPDeltaOrderFunctions\n >\n> => {\n \"use no memo\";\n\n const fetcher = useSDKFetcher();\n\n const sdk = useMemo(() => {\n if (!client) return;\n calldataSDKLogger.once.log(\"init sdk\");\n\n const contractCaller = constructCalldataContractCaller();\n\n const SDKconfig = {\n apiURL: apiURL ?? getApiURL(),\n chainId,\n fetcher,\n contractCaller,\n };\n\n return constructPartialSDK(\n SDKconfig,\n constructFillOrderDirectly,\n constructPreSignDeltaOrder,\n constructBuildDeltaOrder,\n constructPreSignTWAPDeltaOrder,\n constructBuildTWAPDeltaOrder\n );\n }, [apiURL, chainId, client, fetcher]);\n\n return {\n appVersion: sdk?.version,\n chainId: sdk?.chainId,\n apiURL: sdk?.apiURL,\n sdk,\n };\n};\n\ntype ReadOnlyDeltaSDK = Prettify<\n GetDeltaOrdersFunctions &\n GetDeltaPriceFunctions &\n BuildDeltaOrderFunctions &\n PostDeltaOrderFunctions &\n BuildTWAPDeltaOrderFunctions &\n PostTWAPDeltaOrderFunctions &\n GetBridgeInfoFunctions &\n IsTokenSupportedInDeltaFunctions & { chainId: number }\n>;\n\nexport type DeltaSDK = Prettify<\n ReadOnlyDeltaSDK &\n SignDeltaOrderFunctions &\n CancelDeltaOrderFunctions &\n PreSignDeltaOrderFunctions<Hash> &\n DeltaTokenModuleFunctions<Hash> &\n SignTWAPDeltaOrderFunctions &\n PreSignTWAPDeltaOrderFunctions<Hash>\n>;\n\ntype DeltaSDKCreateParams = SDKCreateParams & {\n client?: MinViemClient;\n};\n\nconst deltaSDKLogger = getLogger(\"DeltaSDK\");\n\nexport function useDeltaSDK({\n chainId,\n apiURL,\n account,\n client,\n}: DeltaSDKCreateParams & {\n account?: undefined;\n client?: undefined;\n}): ConstructedSDKOutput<ReadOnlyDeltaSDK>;\nexport function useDeltaSDK({\n chainId,\n apiURL,\n account,\n client,\n}: DeltaSDKCreateParams & {\n account: Address;\n client: MinViemClient;\n}): ConstructedSDKOutput<DeltaSDK>;\nexport function useDeltaSDK({\n chainId,\n apiURL,\n account,\n client,\n}: DeltaSDKCreateParams): ConstructedSDKOutput<DeltaSDK | ReadOnlyDeltaSDK>;\nexport function useDeltaSDK({\n chainId,\n apiURL,\n account,\n client,\n}: DeltaSDKCreateParams): ConstructedSDKOutput<DeltaSDK | ReadOnlyDeltaSDK> {\n \"use no memo\";\n // react-compiler fails here and sdk is created anew\n\n const fetcher = useSDKFetcher();\n\n const sdk = useMemo(() => {\n deltaSDKLogger.once.log(\"init sdk\");\n const SDKconfig = {\n apiURL: apiURL ?? getApiURL(),\n chainId,\n fetcher,\n };\n\n if (!client || !account) {\n return constructPartialSDK(\n SDKconfig,\n constructGetDeltaOrders,\n constructGetDeltaPrice,\n constructBuildDeltaOrder,\n constructPostDeltaOrder,\n constructBuildTWAPDeltaOrder,\n constructPostTWAPDeltaOrder,\n constructGetBridgeInfo,\n constructIsTokenSupportedInDelta\n );\n }\n\n const contractCaller = constructViemContractCaller(client, account);\n\n return constructPartialSDK(\n { ...SDKconfig, contractCaller },\n constructGetDeltaOrders,\n constructGetDeltaPrice,\n constructBuildDeltaOrder,\n constructPostDeltaOrder,\n constructCancelDeltaOrder,\n constructGetBridgeInfo,\n constructIsTokenSupportedInDelta,\n constructSignDeltaOrder,\n constructPreSignDeltaOrder,\n constructPostTWAPDeltaOrder,\n constructBuildTWAPDeltaOrder,\n constructSignTWAPDeltaOrder,\n constructPreSignTWAPDeltaOrder,\n constructSubmitTWAPDeltaOrder,\n constructDeltaTokenModule\n );\n }, [apiURL, chainId, client, account, fetcher]);\n\n return {\n appVersion: sdk.version,\n chainId: sdk.chainId,\n apiURL: sdk.apiURL,\n sdk,\n };\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"useSDK.js","names":["axios","useMemo","constructAxiosFetcher","constructFetchFetcher","constructPartialSDK","constructGetSpender","constructGetAdapters","constructBuildTx","constructAllLimitOrdersHandlers","constructGetRate","constructGetDeltaPrice","constructGetDeltaOrders","constructBuildDeltaOrder","constructSignDeltaOrder","constructPreSignDeltaOrder","constructPostDeltaOrder","constructCancelDeltaOrder","constructGetBridgeInfo","constructIsTokenSupportedInDelta","constructDeltaTokenModule","constructViemContractCaller","LimitOrderHandlers","GetRateFunctions","APIVersion","GetDeltaOrdersFunctions","GetDeltaPriceFunctions","PostDeltaOrderFunctions","BuildDeltaOrderFunctions","SignDeltaOrderFunctions","PreSignDeltaOrderFunctions","CancelDeltaOrderFunctions","GetBridgeInfoFunctions","IsTokenSupportedInDeltaFunctions","BuildTxFunctions","GetSpenderFunctions","GetAdaptersFunctions","MinViemClient","constructGetLimitOrders","constructBuildLimitOrder","constructPostLimitOrder","constructFillOrderDirectly","GetLimitOrdersFunctions","BuildLimitOrderFunctions","PostLimitOrderFunctions","FillOrderDirectlyFunctions","ContractCallerFunctions","DeltaTokenModuleFunctions","BuildTWAPDeltaOrderFunctions","PostTWAPDeltaOrderFunctions","constructPreSignTWAPDeltaOrder","constructBuildTWAPDeltaOrder","PreSignTWAPDeltaOrderFunctions","constructPostTWAPDeltaOrder","constructSignTWAPDeltaOrder","constructSubmitTWAPDeltaOrder","SignTWAPDeltaOrderFunctions","constructGetDeltaPriceV2","constructGetDeltaOrdersV2","constructBuildDeltaOrderV2","constructBuildTWAPDeltaOrderV2","constructPostDeltaOrderV2","constructPostTWAPDeltaOrderV2","constructSignDeltaOrderV2","constructCancelDeltaOrderV2","constructGetBridgeRoutes","constructIsTokenSupportedInDeltaV2","constructGetAgentsListV2","GetDeltaPriceV2Functions","GetDeltaOrdersV2Functions","BuildDeltaOrderV2Functions","BuildTWAPDeltaOrderV2Functions","PostDeltaOrderV2Functions","PostTWAPDeltaOrderV2Functions","SignDeltaOrderV2Functions","CancelDeltaOrderV2Functions","GetBridgeRoutesFunctions","IsTokenSupportedInDeltaV2Functions","GetAgentsListV2Functions","encodeFunctionData","Address","Hash","Hex","Prettify","getLogger","getApiURL","useApiConfig","useSDKFetcher","apiConfig","useKeepAliveSDKFetcher","window","fetch","keepalive","SDKCreateParams","chainId","apiURL","account","MarketSwapSDK","ConstructedSDKOutput","sdk","T","appVersion","useMarketSwapSDK","fetcher","SDKconfig","version","LimitOrdersSDKCreateParams","client","ReadOnlyLimitOrdersSDK","LimitOrdersSDK","limitSDKLogger","useLimitOrdersSDK","once","log","contractCaller","CalldataContractCaller","constructCalldataContractCaller","transactCall","params","abi","contractMethod","functionName","args","calldata","staticCall","Error","signTypedDataCall","useFetchOnlySDK","Partial","calldataSDKLogger","useCalldataSDK","Omit","ReadOnlyDeltaSDK","DeltaSDK","DeltaSDKCreateParams","deltaSDKLogger","useDeltaSDK","ReadOnlyDeltaV2SDK","DeltaV2SDK","DeltaV2SDKCreateParams","deltaV2SDKLogger","useDeltaV2SDK"],"sources":["../../src/hooks/useSDK.ts"],"sourcesContent":["import axios from \"axios\";\nimport { useMemo } from \"react\";\n\nimport {\n constructAxiosFetcher,\n constructFetchFetcher,\n constructPartialSDK,\n constructGetSpender,\n constructGetAdapters,\n constructBuildTx,\n constructAllLimitOrdersHandlers,\n constructGetRate,\n constructGetDeltaPrice,\n constructGetDeltaOrders,\n constructBuildDeltaOrder,\n constructSignDeltaOrder,\n constructPreSignDeltaOrder,\n constructPostDeltaOrder,\n constructCancelDeltaOrder,\n constructGetBridgeInfo,\n constructIsTokenSupportedInDelta,\n constructDeltaTokenModule,\n constructViemContractCaller,\n type LimitOrderHandlers,\n type GetRateFunctions,\n type APIVersion,\n type GetDeltaOrdersFunctions,\n type GetDeltaPriceFunctions,\n type PostDeltaOrderFunctions,\n type BuildDeltaOrderFunctions,\n type SignDeltaOrderFunctions,\n type PreSignDeltaOrderFunctions,\n type CancelDeltaOrderFunctions,\n type GetBridgeInfoFunctions,\n type IsTokenSupportedInDeltaFunctions,\n type BuildTxFunctions,\n type GetSpenderFunctions,\n type GetAdaptersFunctions,\n type MinViemClient,\n constructGetLimitOrders,\n constructBuildLimitOrder,\n constructPostLimitOrder,\n constructFillOrderDirectly,\n type GetLimitOrdersFunctions,\n type BuildLimitOrderFunctions,\n type PostLimitOrderFunctions,\n type FillOrderDirectlyFunctions,\n type ContractCallerFunctions,\n type DeltaTokenModuleFunctions,\n type BuildTWAPDeltaOrderFunctions,\n type PostTWAPDeltaOrderFunctions,\n constructPreSignTWAPDeltaOrder,\n constructBuildTWAPDeltaOrder,\n type PreSignTWAPDeltaOrderFunctions,\n constructPostTWAPDeltaOrder,\n constructSignTWAPDeltaOrder,\n constructSubmitTWAPDeltaOrder,\n type SignTWAPDeltaOrderFunctions,\n constructGetDeltaPriceV2,\n constructGetDeltaOrdersV2,\n constructBuildDeltaOrderV2,\n constructBuildTWAPDeltaOrderV2,\n constructPostDeltaOrderV2,\n constructPostTWAPDeltaOrderV2,\n constructSignDeltaOrderV2,\n constructCancelDeltaOrderV2,\n constructGetBridgeRoutes,\n constructIsTokenSupportedInDeltaV2,\n constructGetAgentsListV2,\n type GetDeltaPriceV2Functions,\n type GetDeltaOrdersV2Functions,\n type BuildDeltaOrderV2Functions,\n type BuildTWAPDeltaOrderV2Functions,\n type PostDeltaOrderV2Functions,\n type PostTWAPDeltaOrderV2Functions,\n type SignDeltaOrderV2Functions,\n type CancelDeltaOrderV2Functions,\n type GetBridgeRoutesFunctions,\n type IsTokenSupportedInDeltaV2Functions,\n type GetAgentsListV2Functions,\n} from \"@velora-dex/sdk\";\nimport { encodeFunctionData, type Address, type Hash, type Hex } from \"viem\";\nimport type { Prettify } from \"ts-essentials\";\nimport { getLogger } from \"@/core/logger\";\nimport { getApiURL } from \"@/lib/constants/urls\";\nimport { useApiConfig } from \"@/core/state/apiConfigAtom\";\n\nfunction useSDKFetcher() {\n \"use no memo\";\n\n const apiConfig = useApiConfig();\n\n return useMemo(() => {\n return constructAxiosFetcher(axios, apiConfig);\n }, [apiConfig]);\n}\n\nfunction useKeepAliveSDKFetcher() {\n \"use no memo\";\n\n const apiConfig = useApiConfig();\n\n return useMemo(() => {\n if (typeof window === \"undefined\") return;\n return constructFetchFetcher(window.fetch, {\n ...apiConfig,\n keepalive: true,\n });\n }, [apiConfig]);\n}\n\ntype SDKCreateParams = {\n chainId: number;\n apiURL?: string;\n account?: Address;\n};\n\nexport type MarketSwapSDK = Prettify<\n GetSpenderFunctions &\n BuildTxFunctions &\n GetRateFunctions &\n GetAdaptersFunctions\n>;\n\ntype ConstructedSDKOutput<T> = {\n sdk: T;\n appVersion: APIVersion;\n chainId: number;\n apiURL: string;\n};\n\nexport function useMarketSwapSDK({\n chainId,\n apiURL,\n}: SDKCreateParams): ConstructedSDKOutput<MarketSwapSDK> {\n \"use no memo\";\n\n const fetcher = useSDKFetcher();\n\n const sdk = useMemo(() => {\n const SDKconfig = {\n apiURL: apiURL ?? getApiURL(),\n chainId,\n fetcher,\n };\n\n return constructPartialSDK(\n SDKconfig,\n constructGetRate,\n constructGetSpender,\n constructGetAdapters,\n constructBuildTx\n );\n }, [apiURL, chainId, fetcher]);\n\n return {\n appVersion: sdk.version,\n chainId: sdk.chainId,\n apiURL: sdk.apiURL,\n sdk,\n };\n}\ntype LimitOrdersSDKCreateParams = SDKCreateParams & {\n client?: MinViemClient;\n};\n\ntype ReadOnlyLimitOrdersSDK = Prettify<\n GetLimitOrdersFunctions & BuildLimitOrderFunctions & PostLimitOrderFunctions\n>;\n\nexport type LimitOrdersSDK = Prettify<LimitOrderHandlers<Hash>>;\n\nconst limitSDKLogger = getLogger(\"LimitOrdersSDK\");\n\n// can paraswap.fillOrder from a taker address to simulate happy path\n// @TODO check that we always use correct SDK version\nexport function useLimitOrdersSDK({\n chainId,\n apiURL,\n account,\n client,\n}: LimitOrdersSDKCreateParams & {\n account?: undefined;\n client?: undefined;\n}): ConstructedSDKOutput<ReadOnlyLimitOrdersSDK>;\nexport function useLimitOrdersSDK({\n chainId,\n apiURL,\n account,\n client,\n}: LimitOrdersSDKCreateParams & {\n account: Address;\n client: MinViemClient;\n}): ConstructedSDKOutput<LimitOrdersSDK>;\nexport function useLimitOrdersSDK({\n chainId,\n apiURL,\n account,\n client,\n}: LimitOrdersSDKCreateParams): ConstructedSDKOutput<\n LimitOrdersSDK | ReadOnlyLimitOrdersSDK\n>;\nexport function useLimitOrdersSDK({\n chainId,\n apiURL,\n account,\n client,\n}: LimitOrdersSDKCreateParams): ConstructedSDKOutput<\n LimitOrdersSDK | ReadOnlyLimitOrdersSDK\n> {\n \"use no memo\";\n\n const fetcher = useSDKFetcher();\n\n const sdk = useMemo(() => {\n limitSDKLogger.once.log(\"init sdk\");\n const SDKconfig = {\n apiURL: apiURL ?? getApiURL(),\n chainId,\n fetcher,\n };\n\n if (!client || !account) {\n return constructPartialSDK(\n SDKconfig,\n constructGetLimitOrders,\n constructBuildLimitOrder,\n constructPostLimitOrder\n );\n }\n\n const contractCaller = constructViemContractCaller(client, account);\n\n return constructPartialSDK(\n { ...SDKconfig, contractCaller },\n constructAllLimitOrdersHandlers\n );\n }, [client, account, apiURL, chainId, fetcher]);\n\n return {\n appVersion: sdk.version,\n chainId: sdk.chainId,\n apiURL: sdk.apiURL,\n sdk,\n };\n}\n\n// ContractCaller that returns Contract[method](args) calldata instead of sending out a transaction\ntype CalldataContractCaller = ContractCallerFunctions<Hex>;\n\nconst constructCalldataContractCaller = (): CalldataContractCaller => {\n const transactCall: CalldataContractCaller[\"transactCall\"] = async (\n params\n ) => {\n const { abi, contractMethod: functionName, args } = params;\n const calldata = encodeFunctionData<typeof abi, string>({\n abi,\n functionName,\n args,\n });\n return calldata;\n };\n\n // won't be used, but needed for types\n const staticCall = () => {\n throw new Error(\"Not implemented\");\n };\n\n return {\n transactCall,\n staticCall,\n signTypedDataCall: staticCall,\n };\n};\n\n// can be used to POST final data before page is closed\nexport const useFetchOnlySDK = ({\n chainId,\n apiURL,\n}: SDKCreateParams): Partial<\n ConstructedSDKOutput<PostDeltaOrderV2Functions>\n> => {\n \"use no memo\";\n\n // fetch, unlike axios allows for `keepalive` parameter,\n // so we can use it to keep the request alive a bit after the page is closed.\n // the alternative of using navigator.sendBeacon doesn't work with API because it includes credentials=always\n // which is incompatible with API CORS settings\n const fetcher = useKeepAliveSDKFetcher();\n\n const sdk = useMemo(() => {\n if (!fetcher) return;\n\n return constructPartialSDK(\n {\n apiURL: apiURL ?? getApiURL(),\n chainId,\n fetcher,\n },\n constructPostDeltaOrderV2\n );\n }, [apiURL, chainId, fetcher]);\n\n return {\n appVersion: sdk?.version,\n chainId: sdk?.chainId,\n apiURL: sdk?.apiURL,\n sdk,\n };\n};\n\nconst calldataSDKLogger = getLogger(\"CalldataSDK\");\n\nexport const useCalldataSDK = ({\n chainId,\n apiURL,\n client,\n}: Omit<LimitOrdersSDKCreateParams, \"account\">): Partial<\n ConstructedSDKOutput<\n FillOrderDirectlyFunctions<Hex> &\n PreSignDeltaOrderFunctions<Hex> &\n BuildDeltaOrderV2Functions &\n PreSignTWAPDeltaOrderFunctions<Hex> &\n BuildTWAPDeltaOrderV2Functions\n >\n> => {\n \"use no memo\";\n\n const fetcher = useSDKFetcher();\n\n const sdk = useMemo(() => {\n if (!client) return;\n calldataSDKLogger.once.log(\"init sdk\");\n\n const contractCaller = constructCalldataContractCaller();\n\n const SDKconfig = {\n apiURL: apiURL ?? getApiURL(),\n chainId,\n fetcher,\n contractCaller,\n };\n\n return constructPartialSDK(\n SDKconfig,\n constructFillOrderDirectly,\n constructPreSignDeltaOrder,\n constructBuildDeltaOrderV2,\n constructPreSignTWAPDeltaOrder,\n constructBuildTWAPDeltaOrderV2\n );\n }, [apiURL, chainId, client, fetcher]);\n\n return {\n appVersion: sdk?.version,\n chainId: sdk?.chainId,\n apiURL: sdk?.apiURL,\n sdk,\n };\n};\n\ntype ReadOnlyDeltaSDK = Prettify<\n GetDeltaOrdersFunctions &\n GetDeltaPriceFunctions &\n BuildDeltaOrderFunctions &\n PostDeltaOrderFunctions &\n BuildTWAPDeltaOrderFunctions &\n PostTWAPDeltaOrderFunctions &\n GetBridgeInfoFunctions &\n IsTokenSupportedInDeltaFunctions & { chainId: number }\n>;\n\nexport type DeltaSDK = Prettify<\n ReadOnlyDeltaSDK &\n SignDeltaOrderFunctions &\n CancelDeltaOrderFunctions &\n PreSignDeltaOrderFunctions<Hash> &\n DeltaTokenModuleFunctions<Hash> &\n SignTWAPDeltaOrderFunctions &\n PreSignTWAPDeltaOrderFunctions<Hash>\n>;\n\ntype DeltaSDKCreateParams = SDKCreateParams & {\n client?: MinViemClient;\n};\n\nconst deltaSDKLogger = getLogger(\"DeltaSDK\");\n\nexport function useDeltaSDK({\n chainId,\n apiURL,\n account,\n client,\n}: DeltaSDKCreateParams & {\n account?: undefined;\n client?: undefined;\n}): ConstructedSDKOutput<ReadOnlyDeltaSDK>;\nexport function useDeltaSDK({\n chainId,\n apiURL,\n account,\n client,\n}: DeltaSDKCreateParams & {\n account: Address;\n client: MinViemClient;\n}): ConstructedSDKOutput<DeltaSDK>;\nexport function useDeltaSDK({\n chainId,\n apiURL,\n account,\n client,\n}: DeltaSDKCreateParams): ConstructedSDKOutput<DeltaSDK | ReadOnlyDeltaSDK>;\nexport function useDeltaSDK({\n chainId,\n apiURL,\n account,\n client,\n}: DeltaSDKCreateParams): ConstructedSDKOutput<DeltaSDK | ReadOnlyDeltaSDK> {\n \"use no memo\";\n // react-compiler fails here and sdk is created anew\n\n const fetcher = useSDKFetcher();\n\n const sdk = useMemo(() => {\n deltaSDKLogger.once.log(\"init sdk\");\n const SDKconfig = {\n apiURL: apiURL ?? getApiURL(),\n chainId,\n fetcher,\n };\n\n if (!client || !account) {\n return constructPartialSDK(\n SDKconfig,\n constructGetDeltaOrders,\n constructGetDeltaPrice,\n constructBuildDeltaOrder,\n constructPostDeltaOrder,\n constructBuildTWAPDeltaOrder,\n constructPostTWAPDeltaOrder,\n constructGetBridgeInfo,\n constructIsTokenSupportedInDelta\n );\n }\n\n const contractCaller = constructViemContractCaller(client, account);\n\n return constructPartialSDK(\n { ...SDKconfig, contractCaller },\n constructGetDeltaOrders,\n constructGetDeltaPrice,\n constructBuildDeltaOrder,\n constructPostDeltaOrder,\n constructCancelDeltaOrder,\n constructGetBridgeInfo,\n constructIsTokenSupportedInDelta,\n constructSignDeltaOrder,\n constructPreSignDeltaOrder,\n constructPostTWAPDeltaOrder,\n constructBuildTWAPDeltaOrder,\n constructSignTWAPDeltaOrder,\n constructPreSignTWAPDeltaOrder,\n constructSubmitTWAPDeltaOrder,\n constructDeltaTokenModule\n );\n }, [apiURL, chainId, client, account, fetcher]);\n\n return {\n appVersion: sdk.version,\n chainId: sdk.chainId,\n apiURL: sdk.apiURL,\n sdk,\n };\n}\n\ntype ReadOnlyDeltaV2SDK = Prettify<\n GetDeltaPriceV2Functions &\n GetDeltaOrdersV2Functions &\n BuildDeltaOrderV2Functions &\n PostDeltaOrderV2Functions &\n BuildTWAPDeltaOrderV2Functions &\n PostTWAPDeltaOrderV2Functions &\n GetBridgeRoutesFunctions &\n IsTokenSupportedInDeltaV2Functions &\n GetAgentsListV2Functions & { chainId: number }\n>;\n\nexport type DeltaV2SDK = Prettify<\n ReadOnlyDeltaV2SDK &\n SignDeltaOrderV2Functions &\n CancelDeltaOrderV2Functions &\n PreSignDeltaOrderFunctions<Hash> &\n DeltaTokenModuleFunctions<Hash> &\n PreSignTWAPDeltaOrderFunctions<Hash>\n>;\n\ntype DeltaV2SDKCreateParams = SDKCreateParams & {\n client?: MinViemClient;\n};\n\nconst deltaV2SDKLogger = getLogger(\"DeltaV2SDK\");\n\nexport function useDeltaV2SDK({\n chainId,\n apiURL,\n account,\n client,\n}: DeltaV2SDKCreateParams & {\n account?: undefined;\n client?: undefined;\n}): ConstructedSDKOutput<ReadOnlyDeltaV2SDK>;\nexport function useDeltaV2SDK({\n chainId,\n apiURL,\n account,\n client,\n}: DeltaV2SDKCreateParams & {\n account: Address;\n client: MinViemClient;\n}): ConstructedSDKOutput<DeltaV2SDK>;\nexport function useDeltaV2SDK({\n chainId,\n apiURL,\n account,\n client,\n}: DeltaV2SDKCreateParams): ConstructedSDKOutput<\n DeltaV2SDK | ReadOnlyDeltaV2SDK\n>;\nexport function useDeltaV2SDK({\n chainId,\n apiURL,\n account,\n client,\n}: DeltaV2SDKCreateParams): ConstructedSDKOutput<\n DeltaV2SDK | ReadOnlyDeltaV2SDK\n> {\n \"use no memo\";\n\n const fetcher = useSDKFetcher();\n\n const sdk = useMemo(() => {\n deltaV2SDKLogger.once.log(\"init sdk\");\n const SDKconfig = {\n apiURL: apiURL ?? getApiURL(),\n chainId,\n fetcher,\n };\n\n if (!client || !account) {\n return constructPartialSDK(\n SDKconfig,\n constructGetDeltaPriceV2,\n constructGetDeltaOrdersV2,\n constructBuildDeltaOrderV2,\n constructPostDeltaOrderV2,\n constructBuildTWAPDeltaOrderV2,\n constructPostTWAPDeltaOrderV2,\n constructGetBridgeRoutes,\n constructIsTokenSupportedInDeltaV2,\n constructGetAgentsListV2\n );\n }\n\n const contractCaller = constructViemContractCaller(client, account);\n\n return constructPartialSDK(\n { ...SDKconfig, contractCaller },\n constructGetDeltaPriceV2,\n constructGetDeltaOrdersV2,\n constructBuildDeltaOrderV2,\n constructPostDeltaOrderV2,\n constructBuildTWAPDeltaOrderV2,\n constructPostTWAPDeltaOrderV2,\n constructGetBridgeRoutes,\n constructIsTokenSupportedInDeltaV2,\n constructGetAgentsListV2,\n constructSignDeltaOrderV2,\n constructCancelDeltaOrderV2,\n constructPreSignDeltaOrder,\n constructPreSignTWAPDeltaOrder,\n constructDeltaTokenModule\n );\n }, [apiURL, chainId, client, account, fetcher]);\n\n return {\n appVersion: sdk.version,\n chainId: sdk.chainId,\n apiURL: sdk.apiURL,\n sdk,\n };\n}\n"],"mappings":"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"}
|
package/dist/lib/queryClient.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { getLogger as e } from "../core/logger.js";
|
|
2
|
-
import {
|
|
2
|
+
import { isDataDeltaPriceV2 as t } from "../hooks/swap/prices/delta/queries/useDeltaPriceQuery.js";
|
|
3
3
|
import { notifyOnPriceChange as n } from "../events/effects/price.js";
|
|
4
4
|
import { isDeltaAuctionData as r, isExecutedDeltaAuction as i } from "../hooks/swap/prices/delta/orders/utils.js";
|
|
5
5
|
import { deltaAuctionPollingQueryKey as a } from "../hooks/swap/prices/delta/queries/useWatchDeltaOrder.js";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"queryClient.js","names":["getLogger","notifyOnPriceChange","isDeltaAuctionData","isExecutedDeltaAuction","DeltaPriceQueryKeyPrefix","
|
|
1
|
+
{"version":3,"file":"queryClient.js","names":["getLogger","notifyOnPriceChange","isDeltaAuctionData","isExecutedDeltaAuction","DeltaPriceQueryKeyPrefix","isDataDeltaPriceV2","deltaAuctionPollingQueryKey","isDataMarketPrice","MarketPriceQueryKeyPrefix","invalidateBalancesAndAllowancesFactory","isReceiptsInWaitForCallsStatusData","isTransactionReceipt","isWaitForCallsStatusData","QueryCache","QueryClient","hashFn","waitForCallsStatusQueryKey","waitForTransactionReceiptQueryKey","logger","queryClient","defaultOptions","queries","queryKeyHashFn","queryCache","onSuccess","data","query","queryKeyPrefix","queryKey","waitForTransactionReceiptQueryKeyPrefix","log","transactionHash","invalidateBalancesAndAllowances","nonces","waitForCallsStatusDataQueryKeyPrefix","status","id","deltaAuctionPollingQueryKeyPrefix","order","permit"],"sources":["../../src/lib/queryClient.ts"],"sourcesContent":["import { getLogger } from \"@/core/logger\";\nimport { notifyOnPriceChange } from \"@/events/effects/price\";\nimport {\n isDeltaAuctionData,\n isExecutedDeltaAuction,\n} from \"@/hooks/swap/prices/delta/orders/utils\";\nimport {\n DeltaPriceQueryKeyPrefix,\n isDataDeltaPriceV2,\n} from \"@/hooks/swap/prices/delta/queries/useDeltaPriceQuery\";\nimport { deltaAuctionPollingQueryKey } from \"@/hooks/swap/prices/delta/queries/useWatchDeltaOrder\";\nimport {\n isDataMarketPrice,\n MarketPriceQueryKeyPrefix,\n} from \"@/hooks/swap/prices/market/queries/useMarketPriceQuery\";\nimport { invalidateBalancesAndAllowancesFactory } from \"@/hooks/tokens/balances/useInvalidateTokenData\";\nimport {\n isReceiptsInWaitForCallsStatusData,\n isTransactionReceipt,\n isWaitForCallsStatusData,\n} from \"@/hooks/txs/queries/utils\";\nimport { QueryCache, QueryClient } from \"@tanstack/react-query\";\nimport {\n hashFn,\n waitForCallsStatusQueryKey,\n waitForTransactionReceiptQueryKey,\n} from \"wagmi/query\";\n\nconst logger = getLogger(\"QueryCache\");\n\nexport const queryClient = new QueryClient({\n defaultOptions: {\n queries: {\n queryKeyHashFn: hashFn, // for bigint support\n },\n },\n queryCache: new QueryCache({\n onSuccess(data, query) {\n const queryKeyPrefix = query.queryKey[0];\n\n if (\n queryKeyPrefix === waitForTransactionReceiptQueryKeyPrefix &&\n isTransactionReceipt(data)\n ) {\n logger.log(\n `waitForTransactionReceiptQuery:: tx ${data.transactionHash} is mined, invalidating balances and allowances`\n );\n invalidateBalancesAndAllowances({ nonces: true });\n return;\n }\n\n if (\n queryKeyPrefix === waitForCallsStatusDataQueryKeyPrefix &&\n isWaitForCallsStatusData(data) &&\n data.status === \"success\" &&\n isReceiptsInWaitForCallsStatusData(data)\n ) {\n logger.log(\n `waitForCallsStatusDataQuery:: batch ${data.id} success, invalidating balances and allowances`\n );\n invalidateBalancesAndAllowances({ nonces: false });\n return;\n }\n\n if (\n queryKeyPrefix === deltaAuctionPollingQueryKeyPrefix &&\n isDeltaAuctionData(data) &&\n isExecutedDeltaAuction(data)\n ) {\n logger.log(\n `deltaAuctionPollingQueryKey:: order ${data.id} is executed, invalidating balances and allowances`\n );\n invalidateBalancesAndAllowances({ nonces: !!data.order.permit });\n return;\n }\n\n if (\n queryKeyPrefix === DeltaPriceQueryKeyPrefix &&\n isDataDeltaPriceV2(data)\n ) {\n notifyOnPriceChange(data, queryClient);\n return;\n }\n\n if (\n queryKeyPrefix === MarketPriceQueryKeyPrefix &&\n isDataMarketPrice(data)\n ) {\n notifyOnPriceChange(data, queryClient);\n return;\n }\n },\n }),\n});\n\nconst invalidateBalancesAndAllowances =\n invalidateBalancesAndAllowancesFactory(queryClient);\n\nconst waitForTransactionReceiptQueryKeyPrefix =\n waitForTransactionReceiptQueryKey()[0];\nconst waitForCallsStatusDataQueryKeyPrefix = waitForCallsStatusQueryKey({})[0];\nconst deltaAuctionPollingQueryKeyPrefix = deltaAuctionPollingQueryKey()[0];\n"],"mappings":";;;;;;;;;;;AA4BA,IAAMkB,IAASlB,EAAU,aAAa,EAEzBmB,IAAc,IAAIL,EAAY;CACzCM,gBAAgB,EACdC,SAAS,EACPC,gBAAgBP,GAClB,EACD;CACDQ,YAAY,IAAIV,EAAW,EACzBW,UAAUC,GAAMC,GAAO;EACrB,IAAMC,IAAiBD,EAAME,SAAS;EAEtC,IACED,MAAmBE,KACnBlB,EAAqBc,EAAK,EAC1B;GAIAO,AAHAd,EAAOY,IACL,uCAAuCL,EAAKM,gBAAe,iDAC5D,EACDC,EAAgC,EAAEC,QAAQ,IAAM,CAAC;GACjD;;EAGF,IACEN,MAAmBO,KACnBtB,EAAyBa,EAAK,IAC9BA,EAAKU,WAAW,aAChBzB,EAAmCe,EAAK,EACxC;GAIAO,AAHAd,EAAOY,IACL,uCAAuCL,EAAKW,GAAE,gDAC/C,EACDJ,EAAgC,EAAEC,QAAQ,IAAO,CAAC;GAClD;;EAGF,IACEN,MAAmBU,KACnBnC,EAAmBuB,EAAK,IACxBtB,EAAuBsB,EAAK,EAC5B;GAIAO,AAHAd,EAAOY,IACL,uCAAuCL,EAAKW,GAAE,oDAC/C,EACDJ,EAAgC,EAAEC,QAAQ,CAAC,CAACR,EAAKa,MAAMC,QAAQ,CAAC;GAChE;;EAGF,IACEZ,MAAAA,uBACAtB,EAAmBoB,EAAK,EACxB;GACAxB,EAAoBwB,GAAMN,EAAY;GACtC;;EAGF,IACEQ,MAAAA,wBACApB,EAAkBkB,EAAK,EACvB;GACAxB,EAAoBwB,GAAMN,EAAY;GACtC;;IAGL,CAAA;CACF,CAAC,EAEIa,IACJvB,EAAuCU,EAAY,EAE/CU,IACJZ,GAAmC,CAAC,IAChCiB,IAAuClB,EAA2B,EAAE,CAAC,CAAC,IACtEqB,IAAoC/B,GAA6B,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { DeltaOrMarketPrice } from '../../hooks/swap/prices/types';
|
|
2
2
|
/**
|
|
3
|
-
* Applies slippage to
|
|
3
|
+
* Applies slippage to a {srcAmount, destAmount} pair.
|
|
4
4
|
*
|
|
5
5
|
* @param srcAmount - The source amount of the trade.
|
|
6
6
|
* @param destAmount - The destination amount of the trade.
|
|
@@ -8,7 +8,10 @@ import { DeltaOrMarketPrice } from '../../hooks/swap/prices/types';
|
|
|
8
8
|
* @param side - The side of the trade, either "BUY" or "SELL".
|
|
9
9
|
* @returns An object containing the adjusted srcAmount and destAmount after applying slippage.
|
|
10
10
|
*/
|
|
11
|
-
export declare function applySlippage({ srcAmount, destAmount
|
|
11
|
+
export declare function applySlippage({ srcAmount, destAmount }: {
|
|
12
|
+
srcAmount: string;
|
|
13
|
+
destAmount: string;
|
|
14
|
+
}, slippage: number, side: "BUY" | "SELL"): {
|
|
12
15
|
srcAmount: string;
|
|
13
16
|
destAmount: string;
|
|
14
17
|
};
|