@velora-dex/widget 0.7.0 → 0.7.2

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.
Files changed (80) hide show
  1. package/dist/components/ui/tooltip.js +1 -1
  2. package/dist/components/ui/tooltip.js.map +1 -1
  3. package/dist/components/widget/AppHeader/AppHeader.d.ts.map +1 -1
  4. package/dist/components/widget/AppHeader/AppHeader.js +45 -41
  5. package/dist/components/widget/AppHeader/AppHeader.js.map +1 -1
  6. package/dist/components/widget/AppHeader/TradeModeSwitcher.d.ts +3 -1
  7. package/dist/components/widget/AppHeader/TradeModeSwitcher.d.ts.map +1 -1
  8. package/dist/components/widget/AppHeader/TradeModeSwitcher.js +69 -34
  9. package/dist/components/widget/AppHeader/TradeModeSwitcher.js.map +1 -1
  10. package/dist/components/widget/SwapRate/SwapRate.d.ts +2 -1
  11. package/dist/components/widget/SwapRate/SwapRate.d.ts.map +1 -1
  12. package/dist/components/widget/SwapRate/SwapRate.js +25 -37
  13. package/dist/components/widget/SwapRate/SwapRate.js.map +1 -1
  14. package/dist/components/widget/SwapRate/SwapRateWithTooltip.d.ts +3 -0
  15. package/dist/components/widget/SwapRate/SwapRateWithTooltip.d.ts.map +1 -0
  16. package/dist/components/widget/SwapRate/SwapRateWithTooltip.js +42 -0
  17. package/dist/components/widget/SwapRate/SwapRateWithTooltip.js.map +1 -0
  18. package/dist/components/widget/SwapRate/utils.d.ts +3 -0
  19. package/dist/components/widget/SwapRate/utils.d.ts.map +1 -0
  20. package/dist/components/widget/SwapRate/utils.js +26 -0
  21. package/dist/components/widget/SwapRate/utils.js.map +1 -0
  22. package/dist/components/widget/SwapRateWithPriceImpactRow/SwapRateWithPriceImpactRow.d.ts.map +1 -1
  23. package/dist/components/widget/SwapRateWithPriceImpactRow/SwapRateWithPriceImpactRow.js +20 -27
  24. package/dist/components/widget/SwapRateWithPriceImpactRow/SwapRateWithPriceImpactRow.js.map +1 -1
  25. package/dist/core/index.d.ts.map +1 -1
  26. package/dist/core/index.js +134 -131
  27. package/dist/core/index.js.map +1 -1
  28. package/dist/core/logger.d.ts +2 -2
  29. package/dist/core/logger.d.ts.map +1 -1
  30. package/dist/core/logger.js +8 -2
  31. package/dist/core/logger.js.map +1 -1
  32. package/dist/core/screen/hooks/useRunOnMount.d.ts +10 -0
  33. package/dist/core/screen/hooks/useRunOnMount.d.ts.map +1 -1
  34. package/dist/core/screen/hooks/useRunOnMount.js +6 -1
  35. package/dist/core/screen/hooks/useRunOnMount.js.map +1 -1
  36. package/dist/core/state/configActionsAtom.d.ts.map +1 -1
  37. package/dist/core/state/configActionsAtom.js +8 -8
  38. package/dist/core/state/configActionsAtom.js.map +1 -1
  39. package/dist/core/state/configAtom.d.ts +4 -2
  40. package/dist/core/state/configAtom.d.ts.map +1 -1
  41. package/dist/core/state/configAtom.js +7 -4
  42. package/dist/core/state/configAtom.js.map +1 -1
  43. package/dist/core/state/validatedReferrerConfigAtom.d.ts +3 -0
  44. package/dist/core/state/validatedReferrerConfigAtom.d.ts.map +1 -0
  45. package/dist/core/state/validatedReferrerConfigAtom.js +12 -0
  46. package/dist/core/state/validatedReferrerConfigAtom.js.map +1 -0
  47. package/dist/core/types.d.ts +6 -0
  48. package/dist/core/types.d.ts.map +1 -1
  49. package/dist/hooks/swap/tradeFlow/useDeltaFlow.d.ts.map +1 -1
  50. package/dist/hooks/swap/tradeFlow/useDeltaFlow.js +203 -201
  51. package/dist/hooks/swap/tradeFlow/useDeltaFlow.js.map +1 -1
  52. package/dist/hooks/swap/tradeFlow/useLimitOrderFlow.d.ts.map +1 -1
  53. package/dist/hooks/swap/tradeFlow/useLimitOrderFlow.js +85 -82
  54. package/dist/hooks/swap/tradeFlow/useLimitOrderFlow.js.map +1 -1
  55. package/dist/hooks/swap/tradeFlow/useMarketFlow.d.ts.map +1 -1
  56. package/dist/hooks/swap/tradeFlow/useMarketFlow.js +156 -154
  57. package/dist/hooks/swap/tradeFlow/useMarketFlow.js.map +1 -1
  58. package/dist/hooks/swap/tradeFlow/useTwapFlow.d.ts.map +1 -1
  59. package/dist/hooks/swap/tradeFlow/useTwapFlow.js +230 -228
  60. package/dist/hooks/swap/tradeFlow/useTwapFlow.js.map +1 -1
  61. package/dist/hooks/useReferrer.d.ts +2 -0
  62. package/dist/hooks/useReferrer.d.ts.map +1 -0
  63. package/dist/hooks/useReferrer.js +8 -0
  64. package/dist/hooks/useReferrer.js.map +1 -0
  65. package/dist/lib/utils/logger.d.ts +7 -4
  66. package/dist/lib/utils/logger.d.ts.map +1 -1
  67. package/dist/lib/utils/logger.js +70 -33
  68. package/dist/lib/utils/logger.js.map +1 -1
  69. package/dist/lib/web3/privy/config.js +1 -1
  70. package/dist/lib/web3/privy/config.js.map +1 -1
  71. package/dist/lib/web3/wagmi/config.js +1 -1
  72. package/dist/lib/web3/wagmi/config.js.map +1 -1
  73. package/dist/lib/web3/wagmi/isInsideSafeIframe.js +11 -11
  74. package/dist/lib/web3/wagmi/isInsideSafeIframe.js.map +1 -1
  75. package/dist/styles.css +1 -1
  76. package/dist/tokens/utils/transferAmountsFromReceipt.js +14 -14
  77. package/dist/tokens/utils/transferAmountsFromReceipt.js.map +1 -1
  78. package/dist/transactions/queries/ensureTxReceipt.js +8 -8
  79. package/dist/transactions/queries/ensureTxReceipt.js.map +1 -1
  80. package/package.json +7 -7
@@ -1 +1 @@
1
- {"version":3,"file":"useDeltaFlow.js","names":["BridgePrice","DeltaPrice","useAccount","assert","useEnsureTxReceipt","Address","Hash","TransactionReceipt","deltaOrdersQueryKey","ApprovalFlowResult","SignPermitFlowResult","SubmitTxResult","useCreateAndSubmitDeltaOrder","CreateAndSubmitDeltaOrderInput","useMinViemClient","useEnsureDeltaOrderExecuted","useWatchDeltaAuction","getOverallOrderStatus","applySlippage","useSlippage","useMutation","useQueryClient","useRef","SupportedChainId","isTransactionCancelledError","UserCancelledError","useSwapReceiverAddressValue","CallsSentObject","TxSentObject","OrderSentObject","useApproveOrPermit","useMarkPermit1Or2NonceAsUsed","SignedPermitResult","produceDeltaOrderDeadline","encodePermit2TransferFromSigDataForDelta","useLogger","isBridgePrice","useDeltaPriceQuery","useSubscribeToDeltaPrice","usePartner","useWidgetEvents","shouldApproveOrBatch","usePreSignAndSubmitDeltaOrder","DeltaOrderPreSignResult","useSwapSide","getSwapSideFromDeltaPrice","extractSelectedBridgePrice","DeltaOrBridgePrice","useAtomValue","bridgePreferenceAtom","protocolNameAtom","useDepositAndSubmitDeltaOrder","DeltaOrderDepositResult","isETHaddress","useCancelOrWithdrawAndCancelDeltaOrder","CancelDeltaOrdersReturn","useExtraDeltaPriceParams","usePricesParams","useSelectedBridgePrice","DeltaAuctionWithOrder","CancelOrderStepKey","deltaOrderFlowType","UseDeltaFlowInput","deltaPrice","SubmitDeltaOrderResult","tradeFlowType","approve","deltaOrder","sentOrder","lastOrderState","account","receiverAddress","OnTxSent","txSent","OnOrderSent","orderSent","RunDeltaOrderOptions","onTxSent","onOrderSent","DeltaOrderSubmissionResult","order","isCreatingOrder","isPostingOrder","isOrderSent","isPending","isError","isSuccess","error","Error","DeltaOrderExecutionResult","isOrderPending","isOrderExecuting","isOrderExecuted","DeltaOrderCancelationResult","step","receipt","txHash","response","isCancelingOrder","isOrderCancellable","isOrderCanceled","result","UseDeltaFlowResult","chainId","runDeltaOrderFlow","options","Promise","reset","cancelFlow","retryFlow","cancelDeltaOrder","approval","signPermit","deltaOrderPreSign","deltaOrderDeposit","deltaOrderSubmission","deltaOrderExecution","deltaOrderCancelation","usedPrice","freshPrice","submittedDeltaOrder","DELTA_ORDER_MUTATION_KEY","useDeltaFlow","_deltaPrice","logger","resolvedSlippage","priceParams","destChainId","extraDeltaPriceParams","deltaPriceQuery","queryKey","deltaPriceQueryKey","query","enabled","selectedBridgePrice","price","data","swapSideFromInput","shouldApplySlippage","srcToken","toLowerCase","destToken","approveTxMut","signPermitMut","events","approveOrPermitEvents","srcAmount","spenderContractType","swapSide","tradeMode","address","minClient","queryClient","createAndSubmitOrderMut","client","mutationOptions","onSuccess","log","onError","deltaOrderCreateAndSubmit","canBatchTxs","isConnectedToSafe","preSignAndSubmitDeltaOrder","resetPreSignAndSubmitDeltaOrder","viemClient","resetDepositAndSubmitDeltaOrder","depositAndSubmitDeltaOrder","postingOrder","watchOrderExecution","orderId","id","onAuctionSuccess","onAuctionFailure","onUpdatedAuction","orderStatus","isLoading","isRefetching","onSwap","orderToCancel","cancelOrderMut","onMutate","_details","_variables","onMutateResult","event","name","params","swapMode","cancelOrderResponse","ensureOrderExecuted","invalidateQueries","userAddress","user","exact","ensureTxReceipt","currentAbortControllerRef","AbortController","usingPriceRef","current","abort","markNonceAsUsed","clearNonce","partner","partnerAddress","partnerFeeBps","partnerTakesSurplus","protocolName","bridgePreference","subscribeToPrice","submitDeltaOrder","lastPrice","abortController","signal","orderDeadline","signedPermitResult","approveTxHash","approveTxReceipt","allowanceToSet","allowanceToPermit","amountToPermit","hmac","newPriceResult","refetch","cancelRefetch","throwIfAborted","unsubscribeFromPrice","shouldDepositAndPreSign","shouldDoApprovalTxOrPermit","tryPermit","shouldPreSignBatch","approvedAmount","onData","newPrice","aborted","undefined","amounts","destAmount","amountsAfterSlippage","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","deltaPriceToUse","signedPermitData","type","variant","nonce","signature","bridge","destinationChainId","orderFromAPI","createOrderInput","degenMode","orderInput","owner","beneficiary","Number","side","depositAmount","mutateAsync","lastOrderStatePromise","deltaOrderMut","mutationFn","mutationKey","onSettled"],"sources":["../../../../src/hooks/swap/tradeFlow/useDeltaFlow.ts"],"sourcesContent":["import type { BridgePrice, DeltaPrice } from \"@velora-dex/sdk\";\nimport { useAccount } from \"wagmi\";\nimport { assert } from \"ts-essentials\";\nimport { useEnsureTxReceipt } from \"@/hooks/txs/queries/useAwaitTx\";\nimport type { Address, Hash, TransactionReceipt } from \"viem\";\nimport { deltaOrdersQueryKey } from \"../prices/delta/queries/useDeltaOrders\";\nimport type {\n ApprovalFlowResult,\n SignPermitFlowResult,\n SubmitTxResult,\n} from \"./common/types\";\nimport {\n useCreateAndSubmitDeltaOrder,\n type CreateAndSubmitDeltaOrderInput,\n} from \"../prices/delta/mutations/useCreateDeltaOrder\";\nimport { useMinViemClient } from \"@/hooks/useMinViemClient\";\nimport {\n useEnsureDeltaOrderExecuted,\n useWatchDeltaAuction,\n} from \"../prices/delta/queries/useWatchDeltaOrder\";\nimport { getOverallOrderStatus } from \"../prices/delta/orders/utils\";\nimport { applySlippage } from \"@/lib/utils/price\";\nimport { useSlippage } from \"@/hooks/useSlippage\";\nimport { useMutation, useQueryClient } from \"@tanstack/react-query\";\nimport { useRef } from \"react\";\nimport type { SupportedChainId } from \"@/lib/web3/wagmi/types\";\nimport {\n isTransactionCancelledError,\n UserCancelledError,\n} from \"./common/errors\";\nimport { useSwapReceiverAddressValue } from \"@/components/widget/ReceiverAddress/state/receiverAddressAtom\";\nimport type {\n CallsSentObject,\n TxSentObject,\n} from \"@/lib/utils/transactionHandlers\";\nimport type { OrderSentObject } from \"@/lib/utils/toasts\";\nimport { useApproveOrPermit } from \"./common/useApproveOrPermit\";\nimport {\n useMarkPermit1Or2NonceAsUsed,\n type SignedPermitResult,\n} from \"./common/useSignPermit1Or2\";\nimport { produceDeltaOrderDeadline } from \"@/lib/utils/delta\";\nimport { encodePermit2TransferFromSigDataForDelta } from \"@/hooks/permit/utils/encodeArgs\";\nimport { useLogger } from \"@/core/logger\";\nimport {\n isBridgePrice,\n useDeltaPriceQuery,\n useSubscribeToDeltaPrice,\n} from \"../prices/delta/queries/useDeltaPriceQuery\";\nimport { usePartner } from \"@/hooks/usePartner\";\nimport { useWidgetEvents } from \"@/core/state/widgetEventsAtom\";\nimport {\n shouldApproveOrBatch,\n usePreSignAndSubmitDeltaOrder,\n type DeltaOrderPreSignResult,\n} from \"./common/usePreSignAndSubmitDeltaOrder\";\nimport { useSwapSide } from \"@/components/widget/SwapModeSwitcher/state/swapSideAtom\";\nimport { getSwapSideFromDeltaPrice } from \"../prices/delta/orders/utils\";\nimport { extractSelectedBridgePrice } from \"../prices/delta/bridge/utils\";\nimport type { DeltaOrBridgePrice } from \"../prices/types\";\nimport { useAtomValue } from \"@/core/store\";\nimport { bridgePreferenceAtom } from \"@/components/widget/TradeParameters/state/bridgePreferences/bridgePreferenceAtom\";\nimport { protocolNameAtom } from \"@/components/widget/TradeParameters/state/bridgePreferences/protocolNameAtom\";\nimport {\n useDepositAndSubmitDeltaOrder,\n type DeltaOrderDepositResult,\n} from \"./common/useDepositAndSubmitDeltaOrder\";\nimport { isETHaddress } from \"@/tokens/utils/eth\";\nimport { useCancelOrWithdrawAndCancelDeltaOrder } from \"../prices/delta/mutations/useCancelOrWithdrawAndCancelDeltaOrder\";\nimport type { CancelDeltaOrdersReturn } from \"../prices/delta/mutations/useCancelDeltaOrders\";\n\nimport {\n useExtraDeltaPriceParams,\n usePricesParams,\n} from \"../prices/usePricesParams\";\nimport { useSelectedBridgePrice } from \"../prices/delta/bridge/useSelectedBridgePrice\";\nimport type { DeltaAuctionWithOrder } from \"../prices/delta/orders/types\";\nimport type { CancelOrderStepKey } from \"@/components/widget/TradeOverview/steps\";\n\nconst deltaOrderFlowType = \"deltaOrder\";\n\nexport type UseDeltaFlowInput = {\n deltaPrice?: DeltaPrice | BridgePrice;\n};\n\nexport type SubmitDeltaOrderResult = {\n tradeFlowType: typeof deltaOrderFlowType;\n approve: SubmitTxResult;\n deltaOrder: {\n sentOrder: DeltaAuctionWithOrder;\n lastOrderState: DeltaAuctionWithOrder;\n };\n deltaPrice: DeltaPrice | BridgePrice;\n account: Address;\n receiverAddress?: Address;\n};\n\ntype OnTxSent = (txSent: TxSentObject | CallsSentObject) => void;\n\ntype OnOrderSent = (orderSent: OrderSentObject) => void;\n\n// @TODO instead add global onTxSent subscription to\n// MutationCache({onSuccess: txHash}) when sent\n// and QueryCache({onSuccess: txReceipt|Order executed}) when mined,\n// maybe??\ntype RunDeltaOrderOptions = {\n onTxSent?: OnTxSent;\n onOrderSent?: OnOrderSent;\n};\n\ntype DeltaOrderSubmissionResult = {\n order?: DeltaAuctionWithOrder;\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 DeltaOrderExecutionResult = {\n sentOrder?: DeltaAuctionWithOrder;\n lastOrderState?: DeltaAuctionWithOrder;\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 DeltaOrderCancelationResult = {\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 UseDeltaFlowResult = {\n tradeFlowType: typeof deltaOrderFlowType;\n chainId: SupportedChainId;\n runDeltaOrderFlow: (\n options?: RunDeltaOrderOptions\n ) => Promise<SubmitDeltaOrderResult>;\n reset: () => void; // reset on Error to retry\n cancelFlow: () => void; // cancel flow\n retryFlow: (\n options?: RunDeltaOrderOptions\n ) => Promise<SubmitDeltaOrderResult>; // reset and retry flow\n cancelDeltaOrder: () => Promise<\n TransactionReceipt | CancelDeltaOrdersReturn | undefined\n >;\n approval: ApprovalFlowResult;\n signPermit: SignPermitFlowResult;\n deltaOrderPreSign: DeltaOrderPreSignResult;\n deltaOrderDeposit: DeltaOrderDepositResult;\n // submission represents either normal signing and POSTing of Order or pre-signing (in a tx) and POSTing\n deltaOrderSubmission: DeltaOrderSubmissionResult;\n deltaOrderExecution: DeltaOrderExecutionResult;\n deltaOrderCancelation: DeltaOrderCancelationResult;\n isPending: boolean;\n isSuccess: boolean;\n isError: boolean;\n error: Error | null;\n result?: SubmitDeltaOrderResult;\n usedPrice?: DeltaPrice | BridgePrice;\n freshPrice?: DeltaPrice | BridgePrice;\n submittedDeltaOrder?: DeltaAuctionWithOrder;\n};\n\nconst DELTA_ORDER_MUTATION_KEY = \"runDeltaOrderFlow\";\n\nexport function useDeltaFlow({\n deltaPrice: _deltaPrice,\n}: UseDeltaFlowInput): UseDeltaFlowResult {\n const logger = useLogger(\"DeltaFlow\");\n const { resolvedSlippage } = useSlippage(\"swap\");\n\n const { priceParams, chainId, destChainId } = usePricesParams(\"swap\");\n const extraDeltaPriceParams = useExtraDeltaPriceParams();\n const { result: deltaPriceQuery, queryKey: deltaPriceQueryKey } =\n useDeltaPriceQuery({\n priceParams: {\n ...priceParams,\n ...extraDeltaPriceParams,\n },\n chainId,\n destChainId,\n query: {\n enabled: false,\n },\n });\n const selectedBridgePrice = useSelectedBridgePrice({\n price: deltaPriceQuery.data,\n });\n const deltaPrice: DeltaOrBridgePrice | undefined =\n selectedBridgePrice || deltaPriceQuery.data || _deltaPrice;\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 swapSideFromInput = useSwapSide();\n\n const shouldApplySlippage =\n !!deltaPrice &&\n deltaPrice.srcToken.toLowerCase() !== deltaPrice.destToken.toLowerCase();\n\n const {\n approval,\n signPermit,\n approveTxMut,\n signPermitMut,\n events: approveOrPermitEvents,\n } = useApproveOrPermit({\n srcToken: deltaPrice?.srcToken,\n srcAmount: deltaPrice?.srcAmount,\n spenderContractType: \"ParaswapDelta\",\n swapSide:\n (deltaPrice && getSwapSideFromDeltaPrice(deltaPrice)) ||\n swapSideFromInput,\n tradeMode: \"swap\",\n chainId,\n applySlippage: shouldApplySlippage,\n });\n\n /* 4.1. Build and Submit Delta Order */\n\n const { address: account } = useAccount();\n\n const { minClient } = useMinViemClient({\n chainId,\n account,\n });\n const queryClient = useQueryClient();\n\n const createAndSubmitOrderMut = useCreateAndSubmitDeltaOrder({\n chainId,\n account,\n client: minClient,\n mutationOptions: {\n onSuccess: (order) => {\n logger.log(\"Create Delta Order success\", order);\n },\n onError: (error) => {\n logger.error(\"Create Delta Order error\", error);\n },\n },\n });\n\n const deltaOrderCreateAndSubmit: UseDeltaFlowResult[\"deltaOrderSubmission\"] =\n {\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 + Delta pre-sign)\n 2. await Batch tx\n 3. post Pre-signed Order\n */\n\n const {\n deltaOrderPreSign,\n canBatchTxs,\n isConnectedToSafe,\n preSignAndSubmitDeltaOrder,\n reset: resetPreSignAndSubmitDeltaOrder,\n } = usePreSignAndSubmitDeltaOrder({\n chainId,\n account,\n logger,\n viemClient: minClient,\n });\n\n const {\n deltaOrderDeposit,\n reset: resetDepositAndSubmitDeltaOrder,\n depositAndSubmitDeltaOrder: depositAndSubmitDeltaOrder,\n } = useDepositAndSubmitDeltaOrder({\n chainId,\n account,\n logger,\n viemClient: minClient,\n });\n\n /* final Delta Order submission for step 4 */\n const deltaOrderSubmission: UseDeltaFlowResult[\"deltaOrderSubmission\"] = {\n order:\n deltaOrderCreateAndSubmit.order ||\n deltaOrderPreSign.order ||\n deltaOrderDeposit.order,\n isPostingOrder:\n deltaOrderCreateAndSubmit.isPostingOrder ||\n deltaOrderPreSign.postingOrder.isPostingOrder ||\n deltaOrderDeposit.postingOrder.isPostingOrder,\n isCreatingOrder:\n deltaOrderCreateAndSubmit.isCreatingOrder ||\n deltaOrderPreSign.isCreatingOrder ||\n deltaOrderDeposit.isCreatingOrder,\n isOrderSent:\n deltaOrderCreateAndSubmit.isOrderSent ||\n deltaOrderPreSign.isOrderSent ||\n deltaOrderDeposit.isOrderSent,\n isPending:\n deltaOrderCreateAndSubmit.isPending ||\n deltaOrderPreSign.isPending ||\n deltaOrderDeposit.isPending,\n isError:\n deltaOrderCreateAndSubmit.isError ||\n deltaOrderPreSign.isError ||\n deltaOrderDeposit.isError,\n isSuccess:\n deltaOrderCreateAndSubmit.isSuccess ||\n deltaOrderPreSign.isSuccess ||\n deltaOrderDeposit.isSuccess,\n error:\n deltaOrderCreateAndSubmit.error ||\n deltaOrderPreSign.error ||\n deltaOrderDeposit.error,\n };\n\n /* 5. await Order execution */\n\n const watchOrderExecution = useWatchDeltaAuction<DeltaAuctionWithOrder>({\n orderId: deltaOrderSubmission.order?.id,\n onAuctionSuccess: (order) => {\n logger.log(\"Delta Order success\", order);\n },\n onAuctionFailure: (order) => {\n logger.log(\"Delta Order failure\", order);\n },\n onUpdatedAuction: (order) => {\n logger.log(\"Delta Order updated\", order);\n },\n });\n\n const orderStatus = watchOrderExecution.data\n ? getOverallOrderStatus(watchOrderExecution.data)\n : null;\n\n const deltaOrderExecution: UseDeltaFlowResult[\"deltaOrderExecution\"] = {\n sentOrder: deltaOrderSubmission.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 { onSwap } = useWidgetEvents();\n\n const orderToCancel =\n deltaOrderExecution.lastOrderState || deltaOrderExecution.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 onSuccess: (_details, _variables, onMutateResult) => {\n onSwap?.({\n event: {\n name: \"Swap:cancelled\",\n params: {\n swapMode: \"delta\",\n order: onMutateResult,\n },\n },\n });\n },\n },\n });\n\n const deltaOrderCancelation: UseDeltaFlowResult[\"deltaOrderCancelation\"] = {\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 ensureOrderExecuted =\n useEnsureDeltaOrderExecuted<DeltaAuctionWithOrder>({\n onAuctionSuccess: (order) => {\n queryClient.invalidateQueries({\n queryKey: deltaOrdersQueryKey({\n userAddress: order.user,\n }),\n exact: false,\n });\n },\n onAuctionFailure: (order) => {\n queryClient.invalidateQueries({\n queryKey: deltaOrdersQueryKey({\n userAddress: order.user,\n }),\n exact: false,\n });\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 = useSwapReceiverAddressValue();\n\n const { markNonceAsUsed, clearNonce } = useMarkPermit1Or2NonceAsUsed({\n chainId,\n });\n\n const { partner, partnerAddress, partnerFeeBps, partnerTakesSurplus } =\n usePartner();\n const protocolName = useAtomValue(protocolNameAtom);\n const bridgePreference = useAtomValue(bridgePreferenceAtom);\n\n const subscribeToPrice = useSubscribeToDeltaPrice();\n\n const submitDeltaOrder = async ({\n onTxSent,\n onOrderSent,\n lastPrice,\n }: RunDeltaOrderOptions & {\n lastPrice?: DeltaPrice | BridgePrice | null;\n } = {}): Promise<SubmitDeltaOrderResult> => {\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 resetPreSignAndSubmitDeltaOrder();\n resetDepositAndSubmitDeltaOrder();\n\n // no sense in starting flow without a price,\n // which may be unavailable only if we are retrying and deltaPrice response now returns an error.\n // Otherwise this flow will be stopped by disabling Swap button in the first place\n assert(deltaPrice, \"Delta price is not available\");\n const swapSide = getSwapSideFromDeltaPrice(deltaPrice);\n\n const abortController = new AbortController();\n currentAbortControllerRef.current = abortController;\n\n const signal = abortController.signal;\n\n // on Delta the order.deadline must exactly match permit2.deadline\n const orderDeadline = produceDeltaOrderDeadline();\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 syncronously 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 // deltaPrice here is the starting price, available before async code and waiting\n let freshPrice = deltaPrice;\n if (freshPrice.hmac === lastPrice?.hmac) {\n // we are resubmitting the Delta 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 deltaPriceQuery.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 // if we have a specific bridge we need to use\n if (isBridgePrice(freshPrice)) {\n // extract the selected bridge price\n freshPrice = extractSelectedBridgePrice({\n price: freshPrice,\n protocolName,\n bridgePreference,\n });\n }\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 = deltaPriceQueryKey;\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,\n onData: (price) => {\n let newPrice: DeltaOrBridgePrice = price;\n if (isBridgePrice(price)) {\n newPrice = extractSelectedBridgePrice({\n price,\n protocolName,\n bridgePreference,\n });\n }\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 amounts = {\n srcAmount: newPrice.srcAmount,\n destAmount: newPrice.destAmount,\n };\n\n const amountsAfterSlippage = shouldApplySlippage\n ? // slightly higher srcAmount if BUY with slippage,\n // slightly lower destAmount if SELL with slippage\n applySlippage(amounts, resolvedSlippage, swapSide)\n : amounts;\n\n // if new price fits into allowance, update it\n if (approvedAmount >= BigInt(amountsAfterSlippage.srcAmount)) {\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: 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 deltaPriceToUse = freshPrice;\n usingPriceRef.current = deltaPriceToUse;\n\n // no longer need updates, unsubscribe\n unsubscribeFromPrice?.();\n unsubscribeFromPrice = undefined;\n\n assert(deltaPriceToUse, \"Delta price is not available\");\n\n const amounts = {\n srcAmount: deltaPriceToUse.srcAmount,\n destAmount: deltaPriceToUse.destAmount,\n };\n\n const amountsAfterSlippage = shouldApplySlippage\n ? // slightly higher srcAmount if BUY with slippage,\n // slightly lower destAmount if SELL with slippage\n applySlippage(amounts, resolvedSlippage, swapSide)\n : amounts;\n\n let permit = signedPermitResult?.permitEncodedArgs;\n if (\n signedPermitResult?.signedPermitData.type === \"permit2\" &&\n signedPermitResult.signedPermitData.variant === \"transferFrom\"\n ) {\n // In the Delta Contract, specifically for Permit2 transferFrom, we have signature consisting of\n // bytes32(permit2nonce) + bytes64(signature) = bytes96 Permit2 Transfer format\n permit = encodePermit2TransferFromSigDataForDelta({\n nonce: signedPermitResult.signedPermitData.nonce,\n signature: signedPermitResult.signature,\n });\n }\n\n const destChainId = isBridgePrice(deltaPriceToUse)\n ? deltaPriceToUse.bridge.destinationChainId\n : chainId;\n\n onSwap?.({\n event: {\n name: \"Swap:request\",\n params: {\n swapMode: \"delta\",\n price: deltaPriceToUse,\n },\n },\n });\n\n let orderFromAPI: DeltaAuctionWithOrder;\n\n const createOrderInput: CreateAndSubmitDeltaOrderInput = {\n signal,\n type: \"MARKET\",\n degenMode: priceParams.degenMode,\n orderInput: {\n owner: account,\n beneficiary: receiverAddress,\n srcToken: deltaPriceToUse.srcToken,\n destToken: deltaPriceToUse.destToken,\n permit,\n destChainId,\n deltaPrice: deltaPriceToUse,\n\n partner,\n partnerAddress,\n partnerFeeBps,\n partnerTakesSurplus,\n\n ...amountsAfterSlippage,\n deadline: Number(orderDeadline),\n side: swapSide,\n },\n };\n\n if (shouldDepositAndPreSign) {\n const depositAmount = createOrderInput.orderInput.srcAmount;\n // deposit ETH + depositTx + POST order\n orderFromAPI = await depositAndSubmitDeltaOrder({\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 preSignAndSubmitDeltaOrder({\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 onSwap?.({\n event: {\n name: \"Swap:sent\",\n params: {\n swapMode: \"delta\",\n price: deltaPriceToUse,\n order: orderFromAPI,\n },\n },\n });\n\n // will refetch Order on interval until completed.\n // in parallel with useWatchDeltaAuction but independently if useWatchDeltaAuction is unmounted\n const lastOrderStatePromise = ensureOrderExecuted({\n orderId: orderFromAPI.id,\n // signal, // fails the toast if aborted, don't use\n });\n\n if (onOrderSent) {\n onOrderSent({\n order: orderFromAPI,\n lastOrderState: lastOrderStatePromise,\n });\n }\n\n const lastOrderState = await lastOrderStatePromise;\n\n onSwap?.({\n event: {\n name: \"Swap:confirmed\",\n params: {\n swapMode: \"delta\",\n price: deltaPriceToUse,\n order: lastOrderState ?? orderFromAPI,\n },\n },\n });\n\n // no use aborting past this point, Order is already being processed\n\n return {\n tradeFlowType: deltaOrderFlowType,\n approve: {\n txHash: approveTxHash,\n receipt: approveTxReceipt,\n },\n deltaOrder: {\n sentOrder: orderFromAPI,\n lastOrderState,\n },\n deltaPrice: deltaPriceToUse,\n // @TODO add whatever else may be relevant\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 // or even a Market swap tx in the meantime\n if (signedPermitResult) {\n clearNonce(signedPermitResult.signedPermitData);\n }\n if (!isTransactionCancelledError(error)) {\n // Swap:cancelled event is handled in cancelOrderMut.onSuccess\n onSwap?.({\n event: {\n name: \"Swap:failed\",\n params: {\n swapMode: \"delta\",\n error: error as Error,\n },\n },\n });\n }\n\n throw error;\n } finally {\n // always unsubscribe if subscribed previously\n unsubscribeFromPrice?.();\n }\n };\n\n const cancelDeltaOrder = 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 deltaOrderMut = useMutation({\n mutationFn: submitDeltaOrder,\n mutationKey: [DELTA_ORDER_MUTATION_KEY],\n onSuccess: (data) => {\n logger.log(\"Delta Order success\", data);\n },\n onError: (error) => {\n logger.error(\"Delta Order error\", error);\n },\n onSettled: () => {\n logger.log(\"Delta Order settled\");\n },\n });\n\n const runDeltaOrderFlow = deltaOrderMut.mutateAsync;\n\n const reset = () => {\n usingPriceRef.current = null;\n\n approveTxMut.reset();\n signPermitMut.reset();\n createAndSubmitOrderMut.reset();\n deltaOrderMut.reset();\n cancelOrderMut.reset();\n resetPreSignAndSubmitDeltaOrder();\n resetDepositAndSubmitDeltaOrder();\n };\n\n const retryFlow = (\n options?: RunDeltaOrderOptions\n ): Promise<SubmitDeltaOrderResult> => {\n const lastPrice = usingPriceRef.current;\n reset();\n return runDeltaOrderFlow({ ...options, lastPrice });\n };\n\n // finalPrice if we reached that point, or usable price (based on allowance given)\n const usedPrice: typeof deltaPrice = usingPriceRef.current || deltaPrice;\n\n const result = deltaOrderMut.data;\n\n /**\n * priority:\n * 1. lastOrderState = updated sent Order from final result\n * 2. sentOrder = just sent Order from final result\n * 3. deltaOrderExecution.lastOrderState = updated sent Order from watchOrderExecution (intermediate result)\n * 4. deltaOrderExecution.sentOrder = just sent Order from watchOrderExecution (intermediate result)\n */\n const submittedDeltaOrder: DeltaAuctionWithOrder | undefined =\n result?.deltaOrder.lastOrderState ||\n result?.deltaOrder.sentOrder ||\n deltaOrderExecution.lastOrderState ||\n deltaOrderExecution.sentOrder;\n\n /* 6. return result */\n return {\n tradeFlowType: deltaOrderFlowType,\n chainId,\n runDeltaOrderFlow,\n reset,\n cancelFlow,\n retryFlow,\n cancelDeltaOrder,\n approval,\n signPermit,\n deltaOrderPreSign,\n deltaOrderDeposit,\n deltaOrderSubmission,\n deltaOrderExecution,\n deltaOrderCancelation,\n // deltaOrderMut includes all steps' queries and mutations and returns more precise errors (including cancellation)\n isPending: deltaOrderMut.isPending,\n isSuccess: deltaOrderSubmission.isSuccess && deltaOrderExecution.isSuccess, // approval is an optional step\n isError: deltaOrderMut.isError,\n error: deltaOrderMut.error,\n result,\n usedPrice,\n freshPrice: deltaPrice,\n submittedDeltaOrder,\n };\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"useDeltaFlow.js","names":["BridgePrice","DeltaPrice","useAccount","assert","useEnsureTxReceipt","Address","Hash","TransactionReceipt","deltaOrdersQueryKey","ApprovalFlowResult","SignPermitFlowResult","SubmitTxResult","useCreateAndSubmitDeltaOrder","CreateAndSubmitDeltaOrderInput","useMinViemClient","useEnsureDeltaOrderExecuted","useWatchDeltaAuction","getOverallOrderStatus","applySlippage","useSlippage","useMutation","useQueryClient","useRef","SupportedChainId","isTransactionCancelledError","UserCancelledError","useSwapReceiverAddressValue","CallsSentObject","TxSentObject","OrderSentObject","useApproveOrPermit","useMarkPermit1Or2NonceAsUsed","SignedPermitResult","produceDeltaOrderDeadline","encodePermit2TransferFromSigDataForDelta","useLogger","isBridgePrice","useDeltaPriceQuery","useSubscribeToDeltaPrice","usePartner","useWidgetEvents","shouldApproveOrBatch","usePreSignAndSubmitDeltaOrder","DeltaOrderPreSignResult","useSwapSide","getSwapSideFromDeltaPrice","extractSelectedBridgePrice","DeltaOrBridgePrice","useAtomValue","bridgePreferenceAtom","protocolNameAtom","useDepositAndSubmitDeltaOrder","DeltaOrderDepositResult","isETHaddress","useCancelOrWithdrawAndCancelDeltaOrder","CancelDeltaOrdersReturn","useExtraDeltaPriceParams","usePricesParams","useSelectedBridgePrice","DeltaAuctionWithOrder","CancelOrderStepKey","useReferrer","deltaOrderFlowType","UseDeltaFlowInput","deltaPrice","SubmitDeltaOrderResult","tradeFlowType","approve","deltaOrder","sentOrder","lastOrderState","account","receiverAddress","OnTxSent","txSent","OnOrderSent","orderSent","RunDeltaOrderOptions","onTxSent","onOrderSent","DeltaOrderSubmissionResult","order","isCreatingOrder","isPostingOrder","isOrderSent","isPending","isError","isSuccess","error","Error","DeltaOrderExecutionResult","isOrderPending","isOrderExecuting","isOrderExecuted","DeltaOrderCancelationResult","step","receipt","txHash","response","isCancelingOrder","isOrderCancellable","isOrderCanceled","result","UseDeltaFlowResult","chainId","runDeltaOrderFlow","options","Promise","reset","cancelFlow","retryFlow","cancelDeltaOrder","approval","signPermit","deltaOrderPreSign","deltaOrderDeposit","deltaOrderSubmission","deltaOrderExecution","deltaOrderCancelation","usedPrice","freshPrice","submittedDeltaOrder","DELTA_ORDER_MUTATION_KEY","useDeltaFlow","_deltaPrice","logger","resolvedSlippage","priceParams","destChainId","extraDeltaPriceParams","deltaPriceQuery","queryKey","deltaPriceQueryKey","query","enabled","selectedBridgePrice","price","data","swapSideFromInput","shouldApplySlippage","srcToken","toLowerCase","destToken","approveTxMut","signPermitMut","events","approveOrPermitEvents","srcAmount","spenderContractType","swapSide","tradeMode","address","minClient","queryClient","createAndSubmitOrderMut","client","mutationOptions","onSuccess","log","onError","deltaOrderCreateAndSubmit","canBatchTxs","isConnectedToSafe","preSignAndSubmitDeltaOrder","resetPreSignAndSubmitDeltaOrder","viemClient","resetDepositAndSubmitDeltaOrder","depositAndSubmitDeltaOrder","postingOrder","watchOrderExecution","orderId","id","onAuctionSuccess","onAuctionFailure","onUpdatedAuction","orderStatus","isLoading","isRefetching","onSwap","orderToCancel","cancelOrderMut","onMutate","_details","_variables","onMutateResult","event","name","params","swapMode","cancelOrderResponse","ensureOrderExecuted","invalidateQueries","userAddress","user","exact","ensureTxReceipt","currentAbortControllerRef","AbortController","usingPriceRef","current","abort","markNonceAsUsed","clearNonce","partner","partnerAddress","partnerFeeBps","partnerTakesSurplus","referrerAddress","protocolName","bridgePreference","subscribeToPrice","submitDeltaOrder","lastPrice","abortController","signal","orderDeadline","signedPermitResult","approveTxHash","approveTxReceipt","allowanceToSet","allowanceToPermit","amountToPermit","hmac","newPriceResult","refetch","cancelRefetch","throwIfAborted","unsubscribeFromPrice","shouldDepositAndPreSign","shouldDoApprovalTxOrPermit","tryPermit","shouldPreSignBatch","approvedAmount","onData","newPrice","aborted","undefined","amounts","destAmount","amountsAfterSlippage","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","deltaPriceToUse","signedPermitData","type","variant","nonce","signature","bridge","destinationChainId","orderFromAPI","createOrderInput","degenMode","orderInput","owner","beneficiary","Number","side","depositAmount","mutateAsync","lastOrderStatePromise","deltaOrderMut","mutationFn","mutationKey","onSettled"],"sources":["../../../../src/hooks/swap/tradeFlow/useDeltaFlow.ts"],"sourcesContent":["import type { BridgePrice, DeltaPrice } from \"@velora-dex/sdk\";\nimport { useAccount } from \"wagmi\";\nimport { assert } from \"ts-essentials\";\nimport { useEnsureTxReceipt } from \"@/hooks/txs/queries/useAwaitTx\";\nimport type { Address, Hash, TransactionReceipt } from \"viem\";\nimport { deltaOrdersQueryKey } from \"../prices/delta/queries/useDeltaOrders\";\nimport type {\n ApprovalFlowResult,\n SignPermitFlowResult,\n SubmitTxResult,\n} from \"./common/types\";\nimport {\n useCreateAndSubmitDeltaOrder,\n type CreateAndSubmitDeltaOrderInput,\n} from \"../prices/delta/mutations/useCreateDeltaOrder\";\nimport { useMinViemClient } from \"@/hooks/useMinViemClient\";\nimport {\n useEnsureDeltaOrderExecuted,\n useWatchDeltaAuction,\n} from \"../prices/delta/queries/useWatchDeltaOrder\";\nimport { getOverallOrderStatus } from \"../prices/delta/orders/utils\";\nimport { applySlippage } from \"@/lib/utils/price\";\nimport { useSlippage } from \"@/hooks/useSlippage\";\nimport { useMutation, useQueryClient } from \"@tanstack/react-query\";\nimport { useRef } from \"react\";\nimport type { SupportedChainId } from \"@/lib/web3/wagmi/types\";\nimport {\n isTransactionCancelledError,\n UserCancelledError,\n} from \"./common/errors\";\nimport { useSwapReceiverAddressValue } from \"@/components/widget/ReceiverAddress/state/receiverAddressAtom\";\nimport type {\n CallsSentObject,\n TxSentObject,\n} from \"@/lib/utils/transactionHandlers\";\nimport type { OrderSentObject } from \"@/lib/utils/toasts\";\nimport { useApproveOrPermit } from \"./common/useApproveOrPermit\";\nimport {\n useMarkPermit1Or2NonceAsUsed,\n type SignedPermitResult,\n} from \"./common/useSignPermit1Or2\";\nimport { produceDeltaOrderDeadline } from \"@/lib/utils/delta\";\nimport { encodePermit2TransferFromSigDataForDelta } from \"@/hooks/permit/utils/encodeArgs\";\nimport { useLogger } from \"@/core/logger\";\nimport {\n isBridgePrice,\n useDeltaPriceQuery,\n useSubscribeToDeltaPrice,\n} from \"../prices/delta/queries/useDeltaPriceQuery\";\nimport { usePartner } from \"@/hooks/usePartner\";\nimport { useWidgetEvents } from \"@/core/state/widgetEventsAtom\";\nimport {\n shouldApproveOrBatch,\n usePreSignAndSubmitDeltaOrder,\n type DeltaOrderPreSignResult,\n} from \"./common/usePreSignAndSubmitDeltaOrder\";\nimport { useSwapSide } from \"@/components/widget/SwapModeSwitcher/state/swapSideAtom\";\nimport { getSwapSideFromDeltaPrice } from \"../prices/delta/orders/utils\";\nimport { extractSelectedBridgePrice } from \"../prices/delta/bridge/utils\";\nimport type { DeltaOrBridgePrice } from \"../prices/types\";\nimport { useAtomValue } from \"@/core/store\";\nimport { bridgePreferenceAtom } from \"@/components/widget/TradeParameters/state/bridgePreferences/bridgePreferenceAtom\";\nimport { protocolNameAtom } from \"@/components/widget/TradeParameters/state/bridgePreferences/protocolNameAtom\";\nimport {\n useDepositAndSubmitDeltaOrder,\n type DeltaOrderDepositResult,\n} from \"./common/useDepositAndSubmitDeltaOrder\";\nimport { isETHaddress } from \"@/tokens/utils/eth\";\nimport { useCancelOrWithdrawAndCancelDeltaOrder } from \"../prices/delta/mutations/useCancelOrWithdrawAndCancelDeltaOrder\";\nimport type { CancelDeltaOrdersReturn } from \"../prices/delta/mutations/useCancelDeltaOrders\";\n\nimport {\n useExtraDeltaPriceParams,\n usePricesParams,\n} from \"../prices/usePricesParams\";\nimport { useSelectedBridgePrice } from \"../prices/delta/bridge/useSelectedBridgePrice\";\nimport type { DeltaAuctionWithOrder } from \"../prices/delta/orders/types\";\nimport type { CancelOrderStepKey } from \"@/components/widget/TradeOverview/steps\";\nimport { useReferrer } from \"@/hooks/useReferrer\";\n\nconst deltaOrderFlowType = \"deltaOrder\";\n\nexport type UseDeltaFlowInput = {\n deltaPrice?: DeltaPrice | BridgePrice;\n};\n\nexport type SubmitDeltaOrderResult = {\n tradeFlowType: typeof deltaOrderFlowType;\n approve: SubmitTxResult;\n deltaOrder: {\n sentOrder: DeltaAuctionWithOrder;\n lastOrderState: DeltaAuctionWithOrder;\n };\n deltaPrice: DeltaPrice | BridgePrice;\n account: Address;\n receiverAddress?: Address;\n};\n\ntype OnTxSent = (txSent: TxSentObject | CallsSentObject) => void;\n\ntype OnOrderSent = (orderSent: OrderSentObject) => void;\n\n// @TODO instead add global onTxSent subscription to\n// MutationCache({onSuccess: txHash}) when sent\n// and QueryCache({onSuccess: txReceipt|Order executed}) when mined,\n// maybe??\ntype RunDeltaOrderOptions = {\n onTxSent?: OnTxSent;\n onOrderSent?: OnOrderSent;\n};\n\ntype DeltaOrderSubmissionResult = {\n order?: DeltaAuctionWithOrder;\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 DeltaOrderExecutionResult = {\n sentOrder?: DeltaAuctionWithOrder;\n lastOrderState?: DeltaAuctionWithOrder;\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 DeltaOrderCancelationResult = {\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 UseDeltaFlowResult = {\n tradeFlowType: typeof deltaOrderFlowType;\n chainId: SupportedChainId;\n runDeltaOrderFlow: (\n options?: RunDeltaOrderOptions\n ) => Promise<SubmitDeltaOrderResult>;\n reset: () => void; // reset on Error to retry\n cancelFlow: () => void; // cancel flow\n retryFlow: (\n options?: RunDeltaOrderOptions\n ) => Promise<SubmitDeltaOrderResult>; // reset and retry flow\n cancelDeltaOrder: () => Promise<\n TransactionReceipt | CancelDeltaOrdersReturn | undefined\n >;\n approval: ApprovalFlowResult;\n signPermit: SignPermitFlowResult;\n deltaOrderPreSign: DeltaOrderPreSignResult;\n deltaOrderDeposit: DeltaOrderDepositResult;\n // submission represents either normal signing and POSTing of Order or pre-signing (in a tx) and POSTing\n deltaOrderSubmission: DeltaOrderSubmissionResult;\n deltaOrderExecution: DeltaOrderExecutionResult;\n deltaOrderCancelation: DeltaOrderCancelationResult;\n isPending: boolean;\n isSuccess: boolean;\n isError: boolean;\n error: Error | null;\n result?: SubmitDeltaOrderResult;\n usedPrice?: DeltaPrice | BridgePrice;\n freshPrice?: DeltaPrice | BridgePrice;\n submittedDeltaOrder?: DeltaAuctionWithOrder;\n};\n\nconst DELTA_ORDER_MUTATION_KEY = \"runDeltaOrderFlow\";\n\nexport function useDeltaFlow({\n deltaPrice: _deltaPrice,\n}: UseDeltaFlowInput): UseDeltaFlowResult {\n const logger = useLogger(\"DeltaFlow\");\n const { resolvedSlippage } = useSlippage(\"swap\");\n\n const { priceParams, chainId, destChainId } = usePricesParams(\"swap\");\n const extraDeltaPriceParams = useExtraDeltaPriceParams();\n const { result: deltaPriceQuery, queryKey: deltaPriceQueryKey } =\n useDeltaPriceQuery({\n priceParams: {\n ...priceParams,\n ...extraDeltaPriceParams,\n },\n chainId,\n destChainId,\n query: {\n enabled: false,\n },\n });\n const selectedBridgePrice = useSelectedBridgePrice({\n price: deltaPriceQuery.data,\n });\n const deltaPrice: DeltaOrBridgePrice | undefined =\n selectedBridgePrice || deltaPriceQuery.data || _deltaPrice;\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 swapSideFromInput = useSwapSide();\n\n const shouldApplySlippage =\n !!deltaPrice &&\n deltaPrice.srcToken.toLowerCase() !== deltaPrice.destToken.toLowerCase();\n\n const {\n approval,\n signPermit,\n approveTxMut,\n signPermitMut,\n events: approveOrPermitEvents,\n } = useApproveOrPermit({\n srcToken: deltaPrice?.srcToken,\n srcAmount: deltaPrice?.srcAmount,\n spenderContractType: \"ParaswapDelta\",\n swapSide:\n (deltaPrice && getSwapSideFromDeltaPrice(deltaPrice)) ||\n swapSideFromInput,\n tradeMode: \"swap\",\n chainId,\n applySlippage: shouldApplySlippage,\n });\n\n /* 4.1. Build and Submit Delta Order */\n\n const { address: account } = useAccount();\n\n const { minClient } = useMinViemClient({\n chainId,\n account,\n });\n const queryClient = useQueryClient();\n\n const createAndSubmitOrderMut = useCreateAndSubmitDeltaOrder({\n chainId,\n account,\n client: minClient,\n mutationOptions: {\n onSuccess: (order) => {\n logger.log(\"Create Delta Order success\", order);\n },\n onError: (error) => {\n logger.error(\"Create Delta Order error\", error);\n },\n },\n });\n\n const deltaOrderCreateAndSubmit: UseDeltaFlowResult[\"deltaOrderSubmission\"] =\n {\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 + Delta pre-sign)\n 2. await Batch tx\n 3. post Pre-signed Order\n */\n\n const {\n deltaOrderPreSign,\n canBatchTxs,\n isConnectedToSafe,\n preSignAndSubmitDeltaOrder,\n reset: resetPreSignAndSubmitDeltaOrder,\n } = usePreSignAndSubmitDeltaOrder({\n chainId,\n account,\n logger,\n viemClient: minClient,\n });\n\n const {\n deltaOrderDeposit,\n reset: resetDepositAndSubmitDeltaOrder,\n depositAndSubmitDeltaOrder: depositAndSubmitDeltaOrder,\n } = useDepositAndSubmitDeltaOrder({\n chainId,\n account,\n logger,\n viemClient: minClient,\n });\n\n /* final Delta Order submission for step 4 */\n const deltaOrderSubmission: UseDeltaFlowResult[\"deltaOrderSubmission\"] = {\n order:\n deltaOrderCreateAndSubmit.order ||\n deltaOrderPreSign.order ||\n deltaOrderDeposit.order,\n isPostingOrder:\n deltaOrderCreateAndSubmit.isPostingOrder ||\n deltaOrderPreSign.postingOrder.isPostingOrder ||\n deltaOrderDeposit.postingOrder.isPostingOrder,\n isCreatingOrder:\n deltaOrderCreateAndSubmit.isCreatingOrder ||\n deltaOrderPreSign.isCreatingOrder ||\n deltaOrderDeposit.isCreatingOrder,\n isOrderSent:\n deltaOrderCreateAndSubmit.isOrderSent ||\n deltaOrderPreSign.isOrderSent ||\n deltaOrderDeposit.isOrderSent,\n isPending:\n deltaOrderCreateAndSubmit.isPending ||\n deltaOrderPreSign.isPending ||\n deltaOrderDeposit.isPending,\n isError:\n deltaOrderCreateAndSubmit.isError ||\n deltaOrderPreSign.isError ||\n deltaOrderDeposit.isError,\n isSuccess:\n deltaOrderCreateAndSubmit.isSuccess ||\n deltaOrderPreSign.isSuccess ||\n deltaOrderDeposit.isSuccess,\n error:\n deltaOrderCreateAndSubmit.error ||\n deltaOrderPreSign.error ||\n deltaOrderDeposit.error,\n };\n\n /* 5. await Order execution */\n\n const watchOrderExecution = useWatchDeltaAuction<DeltaAuctionWithOrder>({\n orderId: deltaOrderSubmission.order?.id,\n onAuctionSuccess: (order) => {\n logger.log(\"Delta Order success\", order);\n },\n onAuctionFailure: (order) => {\n logger.log(\"Delta Order failure\", order);\n },\n onUpdatedAuction: (order) => {\n logger.log(\"Delta Order updated\", order);\n },\n });\n\n const orderStatus = watchOrderExecution.data\n ? getOverallOrderStatus(watchOrderExecution.data)\n : null;\n\n const deltaOrderExecution: UseDeltaFlowResult[\"deltaOrderExecution\"] = {\n sentOrder: deltaOrderSubmission.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 { onSwap } = useWidgetEvents();\n\n const orderToCancel =\n deltaOrderExecution.lastOrderState || deltaOrderExecution.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 onSuccess: (_details, _variables, onMutateResult) => {\n onSwap?.({\n event: {\n name: \"Swap:cancelled\",\n params: {\n swapMode: \"delta\",\n order: onMutateResult,\n },\n },\n });\n },\n },\n });\n\n const deltaOrderCancelation: UseDeltaFlowResult[\"deltaOrderCancelation\"] = {\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 ensureOrderExecuted =\n useEnsureDeltaOrderExecuted<DeltaAuctionWithOrder>({\n onAuctionSuccess: (order) => {\n queryClient.invalidateQueries({\n queryKey: deltaOrdersQueryKey({\n userAddress: order.user,\n }),\n exact: false,\n });\n },\n onAuctionFailure: (order) => {\n queryClient.invalidateQueries({\n queryKey: deltaOrdersQueryKey({\n userAddress: order.user,\n }),\n exact: false,\n });\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 = useSwapReceiverAddressValue();\n\n const { markNonceAsUsed, clearNonce } = useMarkPermit1Or2NonceAsUsed({\n chainId,\n });\n\n const { partner, partnerAddress, partnerFeeBps, partnerTakesSurplus } =\n usePartner();\n const { referrerAddress } = useReferrer();\n const protocolName = useAtomValue(protocolNameAtom);\n const bridgePreference = useAtomValue(bridgePreferenceAtom);\n\n const subscribeToPrice = useSubscribeToDeltaPrice();\n\n const submitDeltaOrder = async ({\n onTxSent,\n onOrderSent,\n lastPrice,\n }: RunDeltaOrderOptions & {\n lastPrice?: DeltaPrice | BridgePrice | null;\n } = {}): Promise<SubmitDeltaOrderResult> => {\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 resetPreSignAndSubmitDeltaOrder();\n resetDepositAndSubmitDeltaOrder();\n\n // no sense in starting flow without a price,\n // which may be unavailable only if we are retrying and deltaPrice response now returns an error.\n // Otherwise this flow will be stopped by disabling Swap button in the first place\n assert(deltaPrice, \"Delta price is not available\");\n const swapSide = getSwapSideFromDeltaPrice(deltaPrice);\n\n const abortController = new AbortController();\n currentAbortControllerRef.current = abortController;\n\n const signal = abortController.signal;\n\n // on Delta the order.deadline must exactly match permit2.deadline\n const orderDeadline = produceDeltaOrderDeadline();\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 // deltaPrice here is the starting price, available before async code and waiting\n let freshPrice = deltaPrice;\n if (freshPrice.hmac === lastPrice?.hmac) {\n // we are resubmitting the Delta 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 deltaPriceQuery.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 // if we have a specific bridge we need to use\n if (isBridgePrice(freshPrice)) {\n // extract the selected bridge price\n freshPrice = extractSelectedBridgePrice({\n price: freshPrice,\n protocolName,\n bridgePreference,\n });\n }\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 = deltaPriceQueryKey;\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,\n onData: (price) => {\n let newPrice: DeltaOrBridgePrice = price;\n if (isBridgePrice(price)) {\n newPrice = extractSelectedBridgePrice({\n price,\n protocolName,\n bridgePreference,\n });\n }\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 amounts = {\n srcAmount: newPrice.srcAmount,\n destAmount: newPrice.destAmount,\n };\n\n const amountsAfterSlippage = shouldApplySlippage\n ? // slightly higher srcAmount if BUY with slippage,\n // slightly lower destAmount if SELL with slippage\n applySlippage(amounts, resolvedSlippage, swapSide)\n : amounts;\n\n // if new price fits into allowance, update it\n if (approvedAmount >= BigInt(amountsAfterSlippage.srcAmount)) {\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: 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 deltaPriceToUse = freshPrice;\n usingPriceRef.current = deltaPriceToUse;\n\n // no longer need updates, unsubscribe\n unsubscribeFromPrice?.();\n unsubscribeFromPrice = undefined;\n\n assert(deltaPriceToUse, \"Delta price is not available\");\n\n const amounts = {\n srcAmount: deltaPriceToUse.srcAmount,\n destAmount: deltaPriceToUse.destAmount,\n };\n\n const amountsAfterSlippage = shouldApplySlippage\n ? // slightly higher srcAmount if BUY with slippage,\n // slightly lower destAmount if SELL with slippage\n applySlippage(amounts, resolvedSlippage, swapSide)\n : amounts;\n\n let permit = signedPermitResult?.permitEncodedArgs;\n if (\n signedPermitResult?.signedPermitData.type === \"permit2\" &&\n signedPermitResult.signedPermitData.variant === \"transferFrom\"\n ) {\n // In the Delta Contract, specifically for Permit2 transferFrom, we have signature consisting of\n // bytes32(permit2nonce) + bytes64(signature) = bytes96 Permit2 Transfer format\n permit = encodePermit2TransferFromSigDataForDelta({\n nonce: signedPermitResult.signedPermitData.nonce,\n signature: signedPermitResult.signature,\n });\n }\n\n const destChainId = isBridgePrice(deltaPriceToUse)\n ? deltaPriceToUse.bridge.destinationChainId\n : chainId;\n\n onSwap?.({\n event: {\n name: \"Swap:request\",\n params: {\n swapMode: \"delta\",\n price: deltaPriceToUse,\n },\n },\n });\n\n let orderFromAPI: DeltaAuctionWithOrder;\n\n const createOrderInput: CreateAndSubmitDeltaOrderInput = {\n signal,\n type: \"MARKET\",\n degenMode: priceParams.degenMode,\n referrerAddress,\n orderInput: {\n owner: account,\n beneficiary: receiverAddress,\n srcToken: deltaPriceToUse.srcToken,\n destToken: deltaPriceToUse.destToken,\n permit,\n destChainId,\n deltaPrice: deltaPriceToUse,\n\n partner,\n partnerAddress,\n partnerFeeBps,\n partnerTakesSurplus,\n\n ...amountsAfterSlippage,\n deadline: Number(orderDeadline),\n side: swapSide,\n },\n };\n\n if (shouldDepositAndPreSign) {\n const depositAmount = createOrderInput.orderInput.srcAmount;\n // deposit ETH + depositTx + POST order\n orderFromAPI = await depositAndSubmitDeltaOrder({\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 preSignAndSubmitDeltaOrder({\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 onSwap?.({\n event: {\n name: \"Swap:sent\",\n params: {\n swapMode: \"delta\",\n price: deltaPriceToUse,\n order: orderFromAPI,\n },\n },\n });\n\n // will refetch Order on interval until completed.\n // in parallel with useWatchDeltaAuction but independently if useWatchDeltaAuction is unmounted\n const lastOrderStatePromise = ensureOrderExecuted({\n orderId: orderFromAPI.id,\n // signal, // fails the toast if aborted, don't use\n });\n\n if (onOrderSent) {\n onOrderSent({\n order: orderFromAPI,\n lastOrderState: lastOrderStatePromise,\n });\n }\n\n const lastOrderState = await lastOrderStatePromise;\n\n onSwap?.({\n event: {\n name: \"Swap:confirmed\",\n params: {\n swapMode: \"delta\",\n price: deltaPriceToUse,\n order: lastOrderState ?? orderFromAPI,\n },\n },\n });\n\n // no use aborting past this point, Order is already being processed\n\n return {\n tradeFlowType: deltaOrderFlowType,\n approve: {\n txHash: approveTxHash,\n receipt: approveTxReceipt,\n },\n deltaOrder: {\n sentOrder: orderFromAPI,\n lastOrderState,\n },\n deltaPrice: deltaPriceToUse,\n // @TODO add whatever else may be relevant\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 // or even a Market swap tx in the meantime\n if (signedPermitResult) {\n clearNonce(signedPermitResult.signedPermitData);\n }\n if (!isTransactionCancelledError(error)) {\n // Swap:cancelled event is handled in cancelOrderMut.onSuccess\n onSwap?.({\n event: {\n name: \"Swap:failed\",\n params: {\n swapMode: \"delta\",\n error: error as Error,\n },\n },\n });\n }\n\n throw error;\n } finally {\n // always unsubscribe if subscribed previously\n unsubscribeFromPrice?.();\n }\n };\n\n const cancelDeltaOrder = 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 deltaOrderMut = useMutation({\n mutationFn: submitDeltaOrder,\n mutationKey: [DELTA_ORDER_MUTATION_KEY],\n onSuccess: (data) => {\n logger.log(\"Delta Order success\", data);\n },\n onError: (error) => {\n logger.error(\"Delta Order error\", error);\n },\n onSettled: () => {\n logger.log(\"Delta Order settled\");\n },\n });\n\n const runDeltaOrderFlow = deltaOrderMut.mutateAsync;\n\n const reset = () => {\n usingPriceRef.current = null;\n\n approveTxMut.reset();\n signPermitMut.reset();\n createAndSubmitOrderMut.reset();\n deltaOrderMut.reset();\n cancelOrderMut.reset();\n resetPreSignAndSubmitDeltaOrder();\n resetDepositAndSubmitDeltaOrder();\n };\n\n const retryFlow = (\n options?: RunDeltaOrderOptions\n ): Promise<SubmitDeltaOrderResult> => {\n const lastPrice = usingPriceRef.current;\n reset();\n return runDeltaOrderFlow({ ...options, lastPrice });\n };\n\n // finalPrice if we reached that point, or usable price (based on allowance given)\n const usedPrice: typeof deltaPrice = usingPriceRef.current || deltaPrice;\n\n const result = deltaOrderMut.data;\n\n /**\n * priority:\n * 1. lastOrderState = updated sent Order from final result\n * 2. sentOrder = just sent Order from final result\n * 3. deltaOrderExecution.lastOrderState = updated sent Order from watchOrderExecution (intermediate result)\n * 4. deltaOrderExecution.sentOrder = just sent Order from watchOrderExecution (intermediate result)\n */\n const submittedDeltaOrder: DeltaAuctionWithOrder | undefined =\n result?.deltaOrder.lastOrderState ||\n result?.deltaOrder.sentOrder ||\n deltaOrderExecution.lastOrderState ||\n deltaOrderExecution.sentOrder;\n\n /* 6. return result */\n return {\n tradeFlowType: deltaOrderFlowType,\n chainId,\n runDeltaOrderFlow,\n reset,\n cancelFlow,\n retryFlow,\n cancelDeltaOrder,\n approval,\n signPermit,\n deltaOrderPreSign,\n deltaOrderDeposit,\n deltaOrderSubmission,\n deltaOrderExecution,\n deltaOrderCancelation,\n // deltaOrderMut includes all steps' queries and mutations and returns more precise errors (including cancellation)\n isPending: deltaOrderMut.isPending,\n isSuccess: deltaOrderSubmission.isSuccess && deltaOrderExecution.isSuccess, // approval is an optional step\n isError: deltaOrderMut.isError,\n error: deltaOrderMut.error,\n result,\n usedPrice,\n freshPrice: deltaPrice,\n submittedDeltaOrder,\n };\n}\n"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"useLimitOrderFlow.d.ts","sourceRoot":"","sources":["../../../../src/hooks/swap/tradeFlow/useLimitOrderFlow.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"useLimitOrderFlow.d.ts","sourceRoot":"","sources":["../../../../src/hooks/swap/tradeFlow/useLimitOrderFlow.ts"],"names":[],"mappings":"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"}
@@ -11,29 +11,30 @@ import { usePartner as l } from "../../usePartner.js";
11
11
  import { useEnsureTxReceipt as u } from "../../txs/queries/useAwaitTx.js";
12
12
  import { useCancelOrWithdrawAndCancelDeltaOrder as d } from "../prices/delta/mutations/useCancelOrWithdrawAndCancelDeltaOrder.js";
13
13
  import { UserCancelledError as f } from "./common/errors.js";
14
- import { useCreateAndSubmitDeltaOrder as p } from "../prices/delta/mutations/useCreateDeltaOrder.js";
15
- import { useApproveOrPermit as m } from "./common/useApproveOrPermit.js";
16
- import { shouldApproveOrBatch as ee, usePreSignAndSubmitDeltaOrder as te } from "./common/usePreSignAndSubmitDeltaOrder.js";
17
- import { useDepositAndSubmitDeltaOrder as ne } from "./common/useDepositAndSubmitDeltaOrder.js";
18
- import { DEFAULT_DELTA_BRIDGE as h } from "../prices/delta/bridge/const.js";
19
- import { useRef as g } from "react";
20
- import { useMutation as _ } from "@tanstack/react-query";
14
+ import { useCreateAndSubmitDeltaOrder as ee } from "../prices/delta/mutations/useCreateDeltaOrder.js";
15
+ import { useApproveOrPermit as te } from "./common/useApproveOrPermit.js";
16
+ import { shouldApproveOrBatch as ne, usePreSignAndSubmitDeltaOrder as p } from "./common/usePreSignAndSubmitDeltaOrder.js";
17
+ import { useDepositAndSubmitDeltaOrder as m } from "./common/useDepositAndSubmitDeltaOrder.js";
18
+ import { useReferrer as h } from "../../useReferrer.js";
19
+ import { DEFAULT_DELTA_BRIDGE as g } from "../prices/delta/bridge/const.js";
20
+ import { useRef as _ } from "react";
21
+ import { useMutation as re } from "@tanstack/react-query";
21
22
  import { assert as v } from "ts-essentials";
22
- import { useAccount as y, useChainId as re } from "wagmi";
23
+ import { useAccount as ie, useChainId as ae } from "wagmi";
23
24
  //#region src/hooks/swap/tradeFlow/useLimitOrderFlow.ts
24
- var b = "limitOrder", ie = "runLimitOrderFlow";
25
+ var y = "limitOrder", b = "runLimitOrderFlow";
25
26
  function x({ limitPrice: x }) {
26
- let S = e("LimitOrderFlow"), C = re(), { approval: w, approveTxMut: T, events: E } = m({
27
+ let S = e("LimitOrderFlow"), C = ae(), { approval: w, approveTxMut: T, events: E } = te({
27
28
  srcToken: x?.srcTokenAddress,
28
29
  srcAmount: x?.srcAmount,
29
30
  spenderContractType: "ParaswapDelta",
30
31
  swapSide: "SELL",
31
32
  tradeMode: "limit",
32
33
  chainId: C
33
- }), { address: D } = y(), { minClient: O } = c({
34
+ }), { address: D } = ie(), { minClient: O } = c({
34
35
  chainId: C,
35
36
  account: D
36
- }), k = p({
37
+ }), k = ee({
37
38
  chainId: C,
38
39
  account: D,
39
40
  client: O,
@@ -54,27 +55,27 @@ function x({ limitPrice: x }) {
54
55
  isError: k.isError,
55
56
  isSuccess: k.isSuccess,
56
57
  error: k.error
57
- }, { deltaOrderPreSign: j, canBatchTxs: M, isConnectedToSafe: N, preSignAndSubmitDeltaOrder: ae, reset: P } = te({
58
+ }, { deltaOrderPreSign: j, canBatchTxs: M, isConnectedToSafe: N, preSignAndSubmitDeltaOrder: P, reset: F } = p({
58
59
  chainId: C,
59
60
  account: D,
60
61
  logger: S,
61
62
  viemClient: O
62
- }), { deltaOrderDeposit: F, reset: I, depositAndSubmitDeltaOrder: oe } = ne({
63
+ }), { deltaOrderDeposit: I, reset: L, depositAndSubmitDeltaOrder: R } = m({
63
64
  chainId: C,
64
65
  account: D,
65
66
  logger: S,
66
67
  viemClient: O
67
- }), L = {
68
- order: A.order || j.order || F.order,
69
- isPostingOrder: A.isPostingOrder || j.postingOrder.isPostingOrder || F.postingOrder.isPostingOrder,
70
- isCreatingOrder: A.isCreatingOrder || j.isCreatingOrder || F.isCreatingOrder,
71
- isOrderSent: A.isOrderSent || j.isOrderSent || F.isOrderSent,
72
- isPending: A.isPending || j.isPending || F.isPending,
73
- isError: A.isError || j.isError || F.isError,
74
- isSuccess: A.isSuccess || j.isSuccess || F.isSuccess,
75
- error: A.error || j.error || F.error
76
- }, R = s({
77
- orderId: L.order?.id,
68
+ }), z = {
69
+ order: A.order || j.order || I.order,
70
+ isPostingOrder: A.isPostingOrder || j.postingOrder.isPostingOrder || I.postingOrder.isPostingOrder,
71
+ isCreatingOrder: A.isCreatingOrder || j.isCreatingOrder || I.isCreatingOrder,
72
+ isOrderSent: A.isOrderSent || j.isOrderSent || I.isOrderSent,
73
+ isPending: A.isPending || j.isPending || I.isPending,
74
+ isError: A.isError || j.isError || I.isError,
75
+ isSuccess: A.isSuccess || j.isSuccess || I.isSuccess,
76
+ error: A.error || j.error || I.error
77
+ }, B = s({
78
+ orderId: z.order?.id,
78
79
  refetchInterval: i,
79
80
  onAuctionSuccess: (e) => {
80
81
  S.log("Limit Order success", e);
@@ -85,41 +86,41 @@ function x({ limitPrice: x }) {
85
86
  onUpdatedAuction: (e) => {
86
87
  S.log("Limit Order updated", e);
87
88
  }
88
- }), z = R.data ? o(R.data) : null, B = {
89
- sentOrder: L.order,
90
- lastOrderState: R.data,
91
- isOrderPending: z === "pending",
92
- isOrderExecuting: z === "executing",
93
- isOrderExecuted: z === "confirmed",
94
- isPending: R.isLoading || R.isRefetching || z === "pending" || z === "executing",
95
- isError: R.isError || z === "failed",
96
- isSuccess: z === "confirmed",
97
- error: R.error
98
- }, V = d({
99
- order: B.lastOrderState || B.sentOrder,
89
+ }), V = B.data ? o(B.data) : null, H = {
90
+ sentOrder: z.order,
91
+ lastOrderState: B.data,
92
+ isOrderPending: V === "pending",
93
+ isOrderExecuting: V === "executing",
94
+ isOrderExecuted: V === "confirmed",
95
+ isPending: B.isLoading || B.isRefetching || V === "pending" || V === "executing",
96
+ isError: B.isError || V === "failed",
97
+ isSuccess: V === "confirmed",
98
+ error: B.error
99
+ }, U = d({
100
+ order: H.lastOrderState || H.sentOrder,
100
101
  chainId: C,
101
102
  account: D,
102
103
  client: O,
103
104
  logger: S
104
- }), H = {
105
- receipt: V.receipt,
106
- txHash: V.txHash,
107
- response: V.cancelOrderResponse,
108
- isCancelingOrder: V.isPending,
109
- isOrderCancellable: V.isOrderCancellable,
110
- isOrderCanceled: V.isSuccess,
111
- isPending: V.isPending,
112
- isError: V.isError,
113
- isSuccess: V.isSuccess,
114
- error: V.error,
115
- step: V.step
116
- }, U = u(), W = g(null), G = () => {
105
+ }), oe = {
106
+ receipt: U.receipt,
107
+ txHash: U.txHash,
108
+ response: U.cancelOrderResponse,
109
+ isCancelingOrder: U.isPending,
110
+ isOrderCancellable: U.isOrderCancellable,
111
+ isOrderCanceled: U.isSuccess,
112
+ isPending: U.isPending,
113
+ isError: U.isError,
114
+ isSuccess: U.isSuccess,
115
+ error: U.error,
116
+ step: U.step
117
+ }, se = u(), W = _(null), ce = () => {
117
118
  W.current?.abort(new f()), W.current = null;
118
- }, { partner: K } = l(), q = r(), J = n(), { onLimitOrder: Y } = a(), se = async ({ onTxSent: e } = {}) => {
119
- T.reset(), k.reset(), V.reset(), P(), I(), v(x, "Limit price data is not available");
119
+ }, { partner: G } = l(), { referrerAddress: K } = h(), q = r(), J = n(), { onLimitOrder: Y } = a(), le = async ({ onTxSent: e } = {}) => {
120
+ T.reset(), k.reset(), U.reset(), F(), L(), v(x, "Limit price data is not available");
120
121
  let n = new AbortController();
121
122
  W.current = n;
122
- let r = n.signal, i, a, o = w.allowanceToSet, s = t(x.srcTokenAddress), { shouldDoApprovalTxOrPermit: c, shouldPreSignBatch: l } = ee({
123
+ let r = n.signal, i, a, o = w.allowanceToSet, s = t(x.srcTokenAddress), { shouldDoApprovalTxOrPermit: c, shouldPreSignBatch: l } = ne({
123
124
  approval: w,
124
125
  signPermit: {
125
126
  isPermitSupported: !1,
@@ -134,7 +135,7 @@ function x({ limitPrice: x }) {
134
135
  allowanceToSet: o,
135
136
  txHash: i
136
137
  }), r.throwIfAborted();
137
- let t = U({
138
+ let t = se({
138
139
  hash: i,
139
140
  chainId: C,
140
141
  onReplaced: (e) => {
@@ -172,6 +173,7 @@ function x({ limitPrice: x }) {
172
173
  u = t ? {
173
174
  signal: r,
174
175
  type: "LIMIT",
176
+ referrerAddress: K,
175
177
  orderInput: {
176
178
  owner: D,
177
179
  beneficiary: q,
@@ -184,18 +186,19 @@ function x({ limitPrice: x }) {
184
186
  ...t,
185
187
  bridge: {
186
188
  ...t.bridge,
187
- protocolSelector: h.protocolSelector,
188
- protocolData: h.protocolData
189
+ protocolSelector: g.protocolSelector,
190
+ protocolData: g.protocolData
189
191
  },
190
- partner: K,
192
+ partner: G,
191
193
  partnerFee: 0
192
194
  },
193
- partner: K,
195
+ partner: G,
194
196
  deadline: J
195
197
  }
196
198
  } : {
197
199
  signal: r,
198
200
  type: "LIMIT",
201
+ referrerAddress: K,
199
202
  orderInput: {
200
203
  owner: D,
201
204
  beneficiary: q,
@@ -208,23 +211,23 @@ function x({ limitPrice: x }) {
208
211
  destToken: x.destTokenAddress,
209
212
  destAmount: x.destAmount,
210
213
  srcAmount: x.srcAmount,
211
- bridge: h,
212
- partner: K,
214
+ bridge: g,
215
+ partner: G,
213
216
  partnerFee: 0
214
217
  },
215
- partner: K,
218
+ partner: G,
216
219
  deadline: J
217
220
  }
218
221
  };
219
222
  let d;
220
223
  if (s) {
221
224
  let t = u.orderInput.srcAmount;
222
- d = await oe({
225
+ d = await R({
223
226
  createOrderInput: u,
224
227
  depositAmount: t,
225
228
  onTxSent: e
226
229
  });
227
- } else d = l ? await ae({
230
+ } else d = l ? await P({
228
231
  createOrderInput: u,
229
232
  approval: w,
230
233
  onTxSent: e
@@ -236,7 +239,7 @@ function x({ limitPrice: x }) {
236
239
  order: d
237
240
  }
238
241
  } }), {
239
- tradeFlowType: b,
242
+ tradeFlowType: y,
240
243
  approve: {
241
244
  txHash: i,
242
245
  receipt: a
@@ -255,15 +258,15 @@ function x({ limitPrice: x }) {
255
258
  }
256
259
  } }), e;
257
260
  }
258
- }, ce = async () => {
261
+ }, ue = async () => {
259
262
  try {
260
- return await V.cancelDeltaOrder();
263
+ return await U.cancelDeltaOrder();
261
264
  } catch (e) {
262
- S.error("Cancel Limit order error", e), V.reset();
265
+ S.error("Cancel Limit order error", e), U.reset();
263
266
  }
264
- }, X = _({
265
- mutationFn: se,
266
- mutationKey: [ie],
267
+ }, X = re({
268
+ mutationFn: le,
269
+ mutationKey: [b],
267
270
  onSuccess: (e) => {
268
271
  S.log("Order submission success", e);
269
272
  },
@@ -274,28 +277,28 @@ function x({ limitPrice: x }) {
274
277
  S.log("Order submission settled");
275
278
  }
276
279
  }), Z = X.mutateAsync, Q = () => {
277
- T.reset(), k.reset(), X.reset(), V.reset(), P(), I();
278
- }, le = (e) => (Q(), Z(e)), $ = X.data;
279
- return $ && B.lastOrderState && ($ = {
280
+ T.reset(), k.reset(), X.reset(), U.reset(), F(), L();
281
+ }, de = (e) => (Q(), Z(e)), $ = X.data;
282
+ return $ && H.lastOrderState && ($ = {
280
283
  ...$,
281
284
  limitOrder: {
282
285
  sentOrder: $.limitOrder.sentOrder,
283
- lastOrderState: B.lastOrderState
286
+ lastOrderState: H.lastOrderState
284
287
  }
285
288
  }), {
286
- tradeFlowType: b,
289
+ tradeFlowType: y,
287
290
  chainId: C,
288
291
  runLimitOrderFlow: Z,
289
292
  reset: Q,
290
- cancelFlow: G,
291
- retryFlow: le,
292
- cancelLimitOrder: ce,
293
+ cancelFlow: ce,
294
+ retryFlow: de,
295
+ cancelLimitOrder: ue,
293
296
  approval: w,
294
- limitOrderSubmission: L,
295
- limitOrderExecution: B,
296
- limitOrderCancelation: H,
297
+ limitOrderSubmission: z,
298
+ limitOrderExecution: H,
299
+ limitOrderCancelation: oe,
297
300
  isPending: X.isPending,
298
- isSuccess: L.isSuccess,
301
+ isSuccess: z.isSuccess,
299
302
  isError: X.isError,
300
303
  error: X.error,
301
304
  result: $,