@rango-dev/queue-manager-rango-preset 0.61.2-next.4 → 0.61.2-next.5

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 (75) hide show
  1. package/dist/actions/checkPrerequisites/checkPrerequisites.d.ts +5 -0
  2. package/dist/actions/checkPrerequisites/checkPrerequisites.d.ts.map +1 -0
  3. package/dist/actions/checkPrerequisites/index.d.ts +2 -0
  4. package/dist/actions/checkPrerequisites/index.d.ts.map +1 -0
  5. package/dist/actions/checkPrerequisites/utils.d.ts +21 -0
  6. package/dist/actions/checkPrerequisites/utils.d.ts.map +1 -0
  7. package/dist/actions/checkStellarTrustline/checkStellarTrustline.d.ts +5 -0
  8. package/dist/actions/checkStellarTrustline/checkStellarTrustline.d.ts.map +1 -0
  9. package/dist/actions/checkStellarTrustline/constants.d.ts +2 -0
  10. package/dist/actions/checkStellarTrustline/constants.d.ts.map +1 -0
  11. package/dist/actions/checkStellarTrustline/index.d.ts +3 -0
  12. package/dist/actions/checkStellarTrustline/index.d.ts.map +1 -0
  13. package/dist/actions/checkStellarTrustline/types.d.ts +9 -0
  14. package/dist/actions/checkStellarTrustline/types.d.ts.map +1 -0
  15. package/dist/actions/checkStellarTrustline/utils.d.ts +26 -0
  16. package/dist/actions/checkStellarTrustline/utils.d.ts.map +1 -0
  17. package/dist/actions/checkXrplTrustline/checkXrplTrustline.d.ts.map +1 -1
  18. package/dist/actions/checkXrplTrustline/constants.d.ts +2 -0
  19. package/dist/actions/checkXrplTrustline/constants.d.ts.map +1 -0
  20. package/dist/actions/checkXrplTrustline/index.d.ts +1 -1
  21. package/dist/actions/checkXrplTrustline/index.d.ts.map +1 -1
  22. package/dist/actions/checkXrplTrustline/utils.d.ts +20 -7
  23. package/dist/actions/checkXrplTrustline/utils.d.ts.map +1 -1
  24. package/dist/actions/checkXrplTrustlineTransactionStatus/checkXrplTrustlineTransactionStatus.d.ts +5 -0
  25. package/dist/actions/checkXrplTrustlineTransactionStatus/checkXrplTrustlineTransactionStatus.d.ts.map +1 -0
  26. package/dist/actions/checkXrplTrustlineTransactionStatus/constants.d.ts +3 -0
  27. package/dist/actions/checkXrplTrustlineTransactionStatus/constants.d.ts.map +1 -0
  28. package/dist/actions/checkXrplTrustlineTransactionStatus/index.d.ts +2 -0
  29. package/dist/actions/checkXrplTrustlineTransactionStatus/index.d.ts.map +1 -0
  30. package/dist/actions/executeStellarTransaction/executeStellarTransaction.d.ts +4 -0
  31. package/dist/actions/executeStellarTransaction/executeStellarTransaction.d.ts.map +1 -0
  32. package/dist/actions/executeStellarTransaction/helpers.d.ts +7 -0
  33. package/dist/actions/executeStellarTransaction/helpers.d.ts.map +1 -0
  34. package/dist/actions/executeStellarTransaction/index.d.ts +2 -0
  35. package/dist/actions/executeStellarTransaction/index.d.ts.map +1 -0
  36. package/dist/actions/executeXrplTransaction/executeXrplTransaction.d.ts.map +1 -1
  37. package/dist/actions/executeXrplTransaction/helpers.d.ts +5 -0
  38. package/dist/actions/executeXrplTransaction/helpers.d.ts.map +1 -1
  39. package/dist/actions/scheduleNextStep.d.ts.map +1 -1
  40. package/dist/helpers.d.ts +2 -1
  41. package/dist/helpers.d.ts.map +1 -1
  42. package/dist/index.js +1 -1
  43. package/dist/index.js.map +4 -4
  44. package/dist/queue-manager-rango-preset.build.json +1 -1
  45. package/dist/queueDef.d.ts.map +1 -1
  46. package/dist/types.d.ts +5 -1
  47. package/dist/types.d.ts.map +1 -1
  48. package/package.json +3 -2
  49. package/src/actions/checkPrerequisites/checkPrerequisites.ts +113 -0
  50. package/src/actions/checkPrerequisites/index.ts +1 -0
  51. package/src/actions/checkPrerequisites/utils.ts +124 -0
  52. package/src/actions/checkStellarTrustline/checkStellarTrustline.ts +237 -0
  53. package/src/actions/checkStellarTrustline/constants.ts +1 -0
  54. package/src/actions/checkStellarTrustline/index.ts +6 -0
  55. package/src/actions/checkStellarTrustline/types.ts +9 -0
  56. package/src/actions/checkStellarTrustline/utils.ts +200 -0
  57. package/src/actions/checkXrplTrustline/checkXrplTrustline.ts +147 -97
  58. package/src/actions/checkXrplTrustline/constants.ts +1 -0
  59. package/src/actions/checkXrplTrustline/index.ts +2 -1
  60. package/src/actions/checkXrplTrustline/utils.ts +134 -59
  61. package/src/actions/checkXrplTrustlineTransactionStatus/checkXrplTrustlineTransactionStatus.ts +145 -0
  62. package/src/actions/checkXrplTrustlineTransactionStatus/constants.ts +2 -0
  63. package/src/actions/checkXrplTrustlineTransactionStatus/index.ts +1 -0
  64. package/src/actions/executeStellarTransaction/executeStellarTransaction.ts +168 -0
  65. package/src/actions/executeStellarTransaction/helpers.ts +43 -0
  66. package/src/actions/executeStellarTransaction/index.ts +1 -0
  67. package/src/actions/executeXrplTransaction/executeXrplTransaction.ts +79 -47
  68. package/src/actions/executeXrplTransaction/helpers.ts +46 -0
  69. package/src/actions/scheduleNextStep.ts +2 -6
  70. package/src/helpers.ts +29 -0
  71. package/src/queueDef.ts +10 -1
  72. package/src/types.ts +8 -1
  73. package/dist/actions/executeXrplTransaction/constants.d.ts +0 -2
  74. package/dist/actions/executeXrplTransaction/constants.d.ts.map +0 -1
  75. package/src/actions/executeXrplTransaction/constants.ts +0 -1
package/dist/index.js CHANGED
@@ -1,2 +1,2 @@
1
- var Xt=Object.defineProperty;var i=(e,t)=>Xt(e,"name",{value:t,configurable:!0});function Qt(){return process.env.REACT_APP_RANGO_API_KEY}i(Qt,"getApiKeyFromEnv");function Je(){return Qt()||"NOT_SET"}i(Je,"getApiKeyFromEnvOrNotSet");var Ne={API_KEY:Je(),BASE_URL:""};function j(e){return Ne[e]}i(j,"getConfig");function ze(e){return Ne=e,Ne}i(ze,"initConfig");import{warn as ne}from"@rango-dev/logging-core";import{SignerError as vt}from"rango-types";import{warn as en}from"@rango-dev/logging-core";import{Status as Le}from"@rango-dev/queue-manager-core";import{legacyReadAccountAddress as tn}from"@rango-dev/wallets-core/legacy";import{getBlockChainNameFromId as nn,getEvmProvider as rn}from"@rango-dev/wallets-shared";import an from"bignumber.js";import{PendingSwapNetworkStatus as ee,SignerError as on,TransactionType as I}from"rango-types";var Ie="Waiting for other swaps to complete",Ze="Waiting for connecting wallet",et=i((e,t)=>`Please change your ${e||"wallet"} account to ${t||"proper address"}`,"ERROR_MESSAGE_WAIT_FOR_WALLET_DESCRIPTION_WRONG_WALLET"),Se=i(e=>`Please connect your ${e??""} wallet.`,"ERROR_MESSAGE_WAIT_FOR_WALLET_DESCRIPTION"),ge=i(e=>`Please change your network to ${e}.`,"ERROR_MESSAGE_WAIT_FOR_CHANGE_NETWORK"),P="CLIENT_UNEXPECTED_BEHAVIOUR";import{RangoClient as qt}from"rango-sdk";var me,q=i(()=>me||(me=new qt(j("API_KEY"),j("BASE_URL")),me),"httpService");import ot from"bignumber.js";import tt from"bignumber.js";var nt=i((e,t=null,n=null)=>{if(e===null||e==="")return"";let r=new tt(e),a=1,o=1e3;for(let l=0;l<60;l++)if(new tt(r.toFixed(l,a)).eq(r)){o=l;break}if(r.gte(1e4))return r.toFormat(0,a);if(r.gte(1e3)||r.gte(100))return r.toFormat(Math.min(o,Math.min(n||100,Math.max(t||0,1))),a);if(r.gte(1))return r.toFormat(Math.min(o,Math.min(n||100,Math.max(t||0,2))),a);if(r.gte(.01))return r.toFormat(Math.min(o,Math.min(n||100,Math.max(t||0,4))),a);for(let l=t||4;l<17;l++)if(r.gte(Math.pow(10,-l)))return r.toFormat(Math.min(o,Math.min(n||100,Math.max(t||0,l))),a);return r.isEqualTo(0)?"0":r.toFormat(Math.min(o,Math.min(n||100,Math.max(t||0,8))),a)},"numberToString");import{SignerErrorCode as G,SignerError as Ht,isSignerErrorCode as Gt,isAPIErrorCode as Kt}from"rango-types";var Vt="Assertion failed (Unexpected behaviour)",$t="Create transaction failed in Rango Server",rt="Input wallet not found",D=class e extends Error{constructor(n,r,a,o){super(r);this._isPrettyError=!0;Object.setPrototypeOf(this,e.prototype),e.prototype._isPrettyError=!0,this.code=n,this.detail=o,this.root=a}static{i(this,"PrettyError")}static isPrettyError(n){return n instanceof e||Object.prototype.hasOwnProperty.call(n,"_isPrettyError")}getErrorDetail(){let n=typeof this.root=="object"&&this.root&&this.root.error?this.root.error:JSON.stringify(this.root),r=typeof this.root=="string"?this.root:this.root instanceof Error?this.root.message:n;return{extraMessage:this.message,extraMessageDetail:this.detail||r,extraMessageErrorCode:this.code||null}}static AssertionFailed(n){return new e("CLIENT_UNEXPECTED_BEHAVIOUR",Vt,null,n)}static BadStatusCode(n,r){return new e("TX_FAIL",n,null,`status code = ${r}`)}static CreateTransaction(n){return new e("FETCH_TX_FAILED",$t,null,n)}static WalletMissing(){return new e("CLIENT_UNEXPECTED_BEHAVIOUR",rt,null,"Server requested for a blockchain or address not selected by user")}static BlockchainMissing(){return new e("CLIENT_UNEXPECTED_BEHAVIOUR",rt,null,"Server requested for a blockchain or address not selected by user")}};function at(e){try{return e?Kt(e)?e:Gt(e)?{[G.REJECTED_BY_USER]:"USER_REJECT",[G.SIGN_TX_ERROR]:"CALL_WALLET_FAILED",[G.SEND_TX_ERROR]:"SEND_TX_FAILED",[G.TX_FAILED_IN_BLOCKCHAIN]:"TX_FAILED_IN_BLOCKCHAIN",[G.NOT_IMPLEMENTED]:P,[G.OPERATION_UNSUPPORTED]:P,[G.UNEXPECTED_BEHAVIOUR]:P}[e]:P:P}catch{return P}}i(at,"mapAppErrorCodesToAPIErrorCode");var H=i(e=>{if(!e)return{extraMessage:"",extraMessageErrorCode:null};if(D.isPrettyError(e))return e.getErrorDetail();if(Ht.isSignerError(e)){let t=e.getErrorDetail();return{extraMessage:t.message,extraMessageDetail:t.detail,extraMessageErrorCode:t.code}}return e instanceof Error?{extraMessage:e.toString(),extraMessageErrorCode:null}:typeof e!="string"?{extraMessage:JSON.stringify(e),extraMessageErrorCode:null}:{extraMessage:e,extraMessageErrorCode:null}},"prettifyErrorMessage");var Te=(a=>(a.error="error",a.warning="warning",a.info="info",a.success="success",a))(Te||{}),W=i((e,t)=>{try{return F(e,t)}catch{return null}},"getCurrentNamespaceOfOrNull"),F=i((e,t)=>{let n=t.evmTransaction?.blockChain||t.evmApprovalTransaction?.blockChain,r=t.starknetTransaction?.blockChain||t.starknetApprovalTransaction?.blockChain,a=t.tronTransaction?.blockChain||t.tronApprovalTransaction?.blockChain,o=t.cosmosTransaction?.blockChain,l=t.solanaTransaction?.blockChain,s=t.tonTransaction?.blockChain,u=t.suiTransaction?.blockChain,p=t.xrplTransaction?.blockChain,c=t.stellarTransaction?.blockChain;if(n)return{namespace:"EVM",network:n};if(r)return{namespace:"Starknet",network:r};if(a)return{namespace:"Tron",network:a};if(o)return{namespace:"Cosmos",network:o};if(l)return{namespace:"Solana",network:l};if(s)return{namespace:"Ton",network:s};if(u)return{namespace:"Sui",network:u};if(p)return{namespace:"XRPL",network:p};if(c)return{namespace:"Stellar",network:c};if(t.transferTransaction){let S=t.transferTransaction.fromWalletAddress;if(!S)throw D.BlockchainMissing();let d=Object.keys(e.wallets).find(g=>e.wallets[g]?.address===S);if(!d)throw D.BlockchainMissing();return{namespace:"UTXO",network:d}}throw new Error("Unsupported transaction type has been included in your swap.",{cause:t})},"getCurrentNamespaceOf"),le=i((e,t,n)=>{let a=n[t].info?.transactionUrl;if(a)return a.indexOf("/{txHash}")!==-1?a.replace("{txHash}",e):`${a}/${e}`},"getScannerUrl");function it(e,t){return e.steps.find(n=>n.status!=="failed"&&n.status!=="success"&&n.id!==t.id)||null}i(it,"getNextStep");var ct=i((e,t)=>{let n=e.wallets[t.evmTransaction?.blockChain||""]||e.wallets[t.evmApprovalTransaction?.blockChain||""]||e.wallets[t.tronTransaction?.blockChain||""]||e.wallets[t.tronApprovalTransaction?.blockChain||""]||e.wallets[t.starknetTransaction?.blockChain||""]||e.wallets[t.starknetApprovalTransaction?.blockChain||""]||e.wallets[t.cosmosTransaction?.blockChain||""]||e.wallets[t.solanaTransaction?.blockChain||""]||e.wallets[t.tonTransaction?.blockChain||""]||e.wallets[t.suiTransaction?.blockChain||""]||e.wallets[t.xrplTransaction?.blockChain||""]||e.wallets[t.stellarTransaction?.blockChain||""]||(t.transferTransaction?.fromWalletAddress?{address:t.transferTransaction.fromWalletAddress,walletType:Object.values(e.wallets).find(r=>r.address===t.transferTransaction?.fromWalletAddress)?.walletType}:null)||null;if(n==null)throw D.WalletMissing();return n},"getCurrentWalletTypeAndAddress"),J=i((e,t)=>ct(e,t).address,"getCurrentAddressOf");function R(e,t){let{address:n,walletType:r}=ct(e,t),a=Object.keys(e.wallets).map(u=>({k:u,v:e.wallets[u]})).find(({v:u})=>u.address===n&&u.walletType===r)||null,o=a?.k||null,l=a?.v||null,s=l?.walletType;if(l===null)throw D.AssertionFailed(`Wallet for source ${o} not passed: walletType: ${s}`);return l}i(R,"getRelatedWallet");function Pe(e,t){if(!t)return null;try{return R(e,t)}catch(n){return console.log({e:n}),null}}i(Pe,"getRelatedWalletOrNull");var lt=i((e,t,n,r)=>r?.find(o=>o.blockchain===e&&o.symbol?.toUpperCase()===t?.toUpperCase()&&o.address===n)?.usdPrice||null,"getUsdPrice");function Yt(e,t){let n=new ot(0);for(let r=0;r<e.fee.length;r++){let a=e.fee[r];if(a.expenseType==="DECREASE_FROM_OUTPUT")continue;let o=lt(a.asset.blockchain,a.asset.symbol,a.asset.address,t);n=n.plus(new ot(a.amount).multipliedBy(o||0))}return n}i(Yt,"getUsdFeeOfStep");function st(e,t){return{fromBlockchain:e.from.blockchain,fromBlockchainLogo:e.from.blockchainLogo,fromLogo:e.from.logo,fromSymbol:e.from.symbol,fromSymbolAddress:e.from.address,fromDecimals:e.from.decimals,fromAmountPrecision:e.fromAmountPrecision,fromAmountMinValue:e.fromAmountMinValue,fromAmountMaxValue:e.fromAmountMaxValue,fromAmountRestrictionType:e.fromAmountRestrictionType,fromUsdPrice:e.from.usdPrice,toBlockchain:e.to.blockchain,toBlockchainLogo:e.to.blockchainLogo,toSymbol:e.to.symbol,toSymbolAddress:e.to.address,toDecimals:e.to.decimals,toLogo:e.to.logo,toUsdPrice:e.to.usdPrice,swapperId:e.swapperId,swapperLogo:e.swapperLogo,swapperType:e.swapperType,expectedOutputAmountHumanReadable:e.toAmount,feeInUsd:t?nt(Yt(e,t?.tokens),null,8):null,estimatedTimeInSeconds:e.estimatedTimeInSeconds||null,internalSteps:null}}i(st,"mapSwapStepToPendingSwapStep");function jt(e){let{inputAmount:t,bestRoute:n,wallets:r,settings:a,validateBalanceOrFee:o,meta:l,swapMode:s="swap"}=e,u=n.result;if(!u)throw Error("Simulation result should not be null");return{creationTime:new Date().getTime().toString(),finishTime:null,requestId:n.requestId||"",inputAmount:t,wallets:r,status:"running",mode:s,isPaused:!1,extraMessage:null,extraMessageSeverity:null,extraMessageDetail:null,extraMessageErrorCode:null,networkStatusExtraMessage:null,networkStatusExtraMessageDetail:null,lastNotificationTime:null,settings:a,simulationResult:u,validateBalanceOrFee:o,steps:n.result?.swaps?.map((p,c)=>{let S=st(p,l);return{id:c+1,...S,internalSwaps:p?.internalSwaps?.map(d=>st(d,l))||null,outputAmount:"",prerequisiteResults:[],status:"created",networkStatus:null,startTransactionTime:new Date().getTime(),externalTransactionId:null,executedTransactionId:null,executedTransactionTime:null,explorerUrl:null,diagnosisUrl:null,trackingCode:null,internalSteps:null,evmTransaction:null,evmApprovalTransaction:null,starknetTransaction:null,starknetApprovalTransaction:null,tronTransaction:null,tronApprovalTransaction:null,cosmosTransaction:null,solanaTransaction:null,transferTransaction:null,tonTransaction:null,suiTransaction:null,xrplTransaction:null,stellarTransaction:null,hyperliquidTransaction:null,hasAlreadyProceededToSign:!1}})||[]}}i(jt,"calculatePendingSwap");var Oe=(n=>(n.RouteEvent="routeEvent",n.StepEvent="stepEvent",n))(Oe||{}),De=(r=>(r.STARTED="started",r.FAILED="failed",r.SUCCEEDED="succeeded",r))(De||{}),z=(r=>(r.CREATE_TX="create_tx",r.SEND_TX="send_tx",r.TX_SENT="tx_sent",r))(z||{}),fe=(a=>(a.WAITING_FOR_QUEUE="waiting_for_queue",a.WAITING_FOR_WALLET_CONNECT="waiting_for_wallet_connect",a.WAITING_FOR_NETWORK_CHANGE="waiting_for_network_change",a.WAITING_FOR_CHANGE_WALLET_ACCOUNT="waiting_for_change_wallet_account",a))(fe||{}),B=(u=>(u.STARTED="started",u.FAILED="failed",u.SUCCEEDED="succeeded",u.TX_EXECUTION="tx_execution",u.TX_EXECUTION_BLOCKED="tx_execution_blocked",u.APPROVAL_TX_SUCCEEDED="approval_tx_succeeded",u.CHECK_STATUS="check_status",u.OUTPUT_REVEALED="output_revealed",u))(B||{}),Ue=(a=>(a.ERROR="error",a.SUCCESS="success",a.WARNING="warning",a.INFO="info",a))(Ue||{});function ut(e){return e.map(t=>{let{diagnosisUrl:n,estimatedTimeInSeconds:r,explorerUrl:a,feeInUsd:o,executedTransactionId:l,executedTransactionTime:s,expectedOutputAmountHumanReadable:u,fromBlockchain:p,toBlockchain:c,fromSymbol:S,toSymbol:d,fromSymbolAddress:g,toSymbolAddress:m,swapperType:E,swapperId:C,outputAmount:_,fromAmountMaxValue:T,fromAmountMinValue:A,fromAmountPrecision:y,fromAmountRestrictionType:v,fromDecimals:x,status:k}=t;return{diagnosisUrl:n,estimatedTimeInSeconds:r,explorerUrl:a,feeInUsd:o,executedTransactionId:l,executedTransactionTime:s,expectedOutputAmountHumanReadable:u,fromBlockchain:p,toBlockchain:c,fromSymbol:S,toSymbol:d,fromSymbolAddress:g,toSymbolAddress:m,swapperName:C,swapperType:E,outputAmount:_,fromAmountMaxValue:T,fromAmountMinValue:A,fromAmountPrecision:y,fromAmountRestrictionType:v,fromDecimals:x,status:k,transaction:h(t)}})}i(ut,"createSteps");function Jt(e,t,n){let{creationTime:r,finishTime:a,requestId:o,inputAmount:l,status:s,wallets:u,steps:p,settings:c}=e,S=ut(p),g={route:{creationTime:r,finishTime:a,requestId:o,inputAmount:l,status:s,wallets:u,steps:S,slippage:c.slippage,infiniteApproval:c.infiniteApprove},step:S[S.length-1]};if(n)g.step=ut([n])[0];else if(t==="failed"){let m=pt(S);m&&(g.step=m)}else{let m=Z(S);m&&(g.step=m)}return g}i(Jt,"getEventPayload");function zt(e,t,n){let r,{type:a}=e;switch(a){case"started":r={...e,type:"started"};break;case"failed":r={...e,type:"failed",inputAmount:n.inputAmount,inputAmountUsd:be(n),swapMode:n.mode||"swap"};break;case"succeeded":{r={...e,type:"succeeded",inputAmount:n.inputAmount,inputAmountUsd:be(n),outputAmount:n.steps[n.steps.length-1].outputAmount??"",outputAmountUsd:dt(n),swapMode:n.mode||"swap"};break}default:break}r&&j("emitter")?.emit("routeEvent",{event:r,route:t})}i(zt,"emitRouteEvent");function Zt(e,t,n){j("emitter")?.emit("stepEvent",{event:e,route:t,step:n})}i(Zt,"emitStepEvent");function w(e){let{event:t}=e,{type:n}=t,{route:r,step:a}=Jt(e.swap,n,e.step??void 0),o=`${a.fromBlockchain}.${a.fromSymbol}`,l=`${a.toBlockchain}.${a.toSymbol}`,s=a.outputAmount??"",u=e.step?W(e.swap,e.step):null,p="",c="info";switch(n){case"started":p="Swap process started",c="success";break;case"succeeded":p=`You received ${s} ${l}, hooray!`,c="success";break;case"failed":p=`Swap failed: ${e.swap?.extraMessage??"Reason is unknown"}`,c="error";break;case"tx_execution":t.status==="create_tx"?(p="Please wait while the transaction is created ...",c="info"):t.status==="send_tx"?(e.step&&L(e.step)?p=`Please confirm '${a.swapperName}' smart contract access to ${o}`:p="Please confirm transaction request in your wallet",c="warning"):t.status==="tx_sent"&&(p="Transaction sent successfully",c="info");break;case"check_status":e.step&&L(e.step)?p="Checking approve transaction status ...":p="Checking transaction status ...",c="info";break;case"approval_tx_succeeded":p="Smart contract called successfully",c="success";break;case"output_revealed":p="Transaction output amount revealed",c="success";break;case"tx_execution_blocked":t.status==="waiting_for_wallet_connect"?(p="Please connect your wallet.",c="warning"):t.status==="waiting_for_queue"?(p="Waiting for other swaps to complete",c="warning"):t.status==="waiting_for_change_wallet_account"?(p="Please change your wallet account.",c="warning"):t.status==="waiting_for_network_change"&&(p=`Please change your wallet network to ${u?.network}.`,c="warning");break;default:break}e.step&&Zt({...t,message:p,messageSeverity:c},r,a),(e.event.type==="failed"||!e.step)&&zt({...t,message:p,messageSeverity:c},r,e.swap)}i(w,"notifier");var We=null;function Ee(){return{claimedBy:()=>We?.id,setClaimer:e=>{We={id:e}},reset:()=>{We=null}}}i(Ee,"claimQueue");var K={};function we(){return{getTransactionDataByHash:e=>K[e]||{},setTransactionDataByHash:(e,t)=>{K[e]||(K[e]={}),K[e].response=t.response||K[e].response,K[e].receiptReceived=t.receiptReceived||K[e].receiptReceived||!1}}}i(we,"inMemoryTransactionsData");var f=i(e=>e.steps.find(t=>t.status!=="failed"&&t.status!=="success")||null,"getCurrentStep"),h=i(e=>{let{evmTransaction:t,evmApprovalTransaction:n,cosmosTransaction:r,solanaTransaction:a,transferTransaction:o,starknetApprovalTransaction:l,starknetTransaction:s,tronApprovalTransaction:u,tronTransaction:p,tonTransaction:c,suiTransaction:S,xrplTransaction:d}=e;return t||n||r||a||o||l||s||u||p||c||S||d},"getCurrentStepTx"),ye=i((e,t)=>{e.transferTransaction=null,e.cosmosTransaction=null,e.evmTransaction=null,e.solanaTransaction=null,e.evmApprovalTransaction=null,e.starknetApprovalTransaction=null,e.starknetTransaction=null,e.tronApprovalTransaction=null,e.tronTransaction=null,e.tonTransaction=null,e.suiTransaction=null,e.xrplTransaction=null,e.stellarTransaction=null;let n=t.type;switch(n){case I.EVM:t.isApprovalTx?e.evmApprovalTransaction=t:e.evmTransaction=t;break;case I.TRON:t.isApprovalTx?e.tronApprovalTransaction=t:e.tronTransaction=t;break;case I.STARKNET:t.isApprovalTx?e.starknetApprovalTransaction=t:e.starknetTransaction=t;break;case I.COSMOS:e.cosmosTransaction=t;break;case I.SOLANA:e.solanaTransaction=t;break;case I.TRANSFER:e.transferTransaction=t;break;case I.TON:e.tonTransaction=t;break;case I.SUI:e.suiTransaction=t;break;case I.XRPL:e.xrplTransaction=t;break;case I.STELLAR:e.stellarTransaction=t;break;case I.HYPERLIQUID:e.hyperliquidTransaction=t;break;default:(r=>{throw new Error(`${r} was unhandled!`)})(n)}return e},"setCurrentStepTx"),Me=i(e=>h(e)?.type,"getCurrentStepTxType"),L=i(e=>{let{evmApprovalTransaction:t,starknetApprovalTransaction:n,tronApprovalTransaction:r}=e;return!!(t||n||r)},"isApprovalCurrentStepTx");function O({getStorage:e,setStorage:t,nextStatus:n,nextStepStatus:r,message:a,details:o,errorCode:l=null,hasAlreadyProceededToSign:s,trace:u=null}){let p=e().swapDetails,c=f(p),S={swap:p,step:c};if(r&&c&&(c.status=r),n&&(p.status=n),p.hasAlreadyProceededToSign=s,n&&["failed","success"].includes(n)&&(p.finishTime=new Date().getTime().toString()),(a||o)&&(p.extraMessage=a||"",p.extraMessageDetail=o||""),r&&["failed"].includes(r)){let d=o&&o.includes("Warning")?"Swap canceled by user.":o,g=Pe(p,c)?.walletType;p.extraMessageSeverity="error";let m=at(l);S.failureType=m;let E=l!=="REJECTED_BY_USER"&&u?.message&&typeof u.message=="string"?u.message:d||"";q().reportFailure({requestId:p.requestId,step:c?.id||1,eventType:m,reason:E,tags:g?{wallet:g}:void 0}).then().catch()}else r&&["running"].includes(r)?p.extraMessageSeverity="info":r&&["success","approved"].includes(r)?p.extraMessageSeverity="success":r&&["waitingForApproval"].includes(r)&&(p.extraMessageSeverity="warning");return r==="running"&&c&&(c.startTransactionTime=new Date().getTime()),t({...e(),swapDetails:p}),S}i(O,"updateSwapStatus");function sn({getStorage:e,setStorage:t},n,r){let a=e().swapDetails;a.hasAlreadyProceededToSign=null;let o=f(a);o.executedTransactionId=n,o.executedTransactionTime=new Date().getTime().toString(),r?.url&&(o.explorerUrl=[...o.explorerUrl||[],{url:r.url,description:r.description||null}]),L(o)?a.extraMessage="Checking approve transaction status ...":a.extraMessage="Checking transaction status ...",a.extraMessageDetail="",a.extraMessageSeverity="info",t({...e(),swapDetails:a}),w({event:{type:"tx_execution",status:"tx_sent"},swap:a,step:o}),w({event:{type:"check_status"},swap:a,step:o})}i(sn,"setStepTransactionIds");function cn({getStorage:e,setStorage:t},n,r){let a=e().swapDetails,o=f(a);if(!o)return;let l=new Date;a.lastNotificationTime=l.getTime().toString(),!(o.networkStatus===ee.WaitingForConnectingWallet&&a.networkStatusExtraMessage===n&&a.networkStatusExtraMessageDetail===r)&&(o.networkStatus=ee.WaitingForConnectingWallet,a.networkStatusExtraMessage=n,a.networkStatusExtraMessageDetail=r,t({...e(),swapDetails:a}))}i(cn,"markRunningSwapAsWaitingForConnectingWallet");function gt({getStorage:e,setStorage:t}){let n=e().swapDetails,r=f(n);if(!r)return;let{type:a}=U(n),o=F(n,r),l=`Change ${a} wallet network to ${o.network}`,s=`We\u2019re switching the connected network to ${o.network}. Please check your wallet.`,u=new Date;return n.lastNotificationTime=u.getTime().toString(),r.networkStatus=ee.WaitingForNetworkChange,n.networkStatusExtraMessage=l,n.networkStatusExtraMessageDetail=s,t({...e(),swapDetails:n}),{swap:n,step:r}}i(gt,"markRunningSwapAsSwitchingNetwork");function mt({getStorage:e,setStorage:t}){let n=e().swapDetails,r=f(n);if(r)return n.networkStatusExtraMessage="",n.networkStatusExtraMessageDetail="",r.networkStatus=ee.WaitingForQueue,w({event:{type:"tx_execution_blocked",status:"waiting_for_queue"},swap:n,step:r}),t({...e(),swapDetails:n}),{swap:n,step:r}}i(mt,"markRunningSwapAsDependsOnOtherQueues");async function xe(e){return new Promise(t=>setTimeout(t,e))}i(xe,"delay");var ln=i((e,t)=>e.wallets[t]?.walletType,"getSwapWalletType");function Fe(e){return e===null||e?.blockchains===null||e?.blockchains.length===0}i(Fe,"isWalletNull");function U(e){let t=f(e),n=W(e,t);if(!n)return{type:null,namespace:null,address:null};let r=ln(e,n.network),a=e.wallets[n.network];return{type:r||null,namespace:n,address:a?a.address:null}}i(U,"getRequiredWallet");async function un(e){try{return await e.request({method:"eth_chainId"})||e?.chainId}catch{return e?.chainId}}i(un,"getChainId");async function pn(e,t,n){let r=rn(e,n);if(r)return await un(r);let o=t(n).get("evm");if(!o)throw new Error("EVM namespace not found for wallet type: "+n);return o.getChainId()}i(pn,"getProviderChainId");async function Tt(e,t,n,r,a,o){if(Fe(n))return!1;let l=W(e,t);if(!l)return!1;if(r.evmBasedChains.find(s=>s.name===l.network)){try{let s=e.wallets[l.network];if(s){let u=await pn(a,o,s.walletType);if(u){let p=nn(u,Object.entries(r.blockchains).map(([,c])=>c));if(p&&p.toLowerCase()===l.network.toLowerCase())return!0;if(p&&p.toLowerCase()!==l.network.toLowerCase())return!1}}}catch(s){console.log(s)}return!1}return!0}i(Tt,"isNetworkMatchedForTransaction");var ft=i((e,t)=>(e.wallets[t.evmTransaction?.blockChain||""]||e.wallets[t.evmApprovalTransaction?.blockChain||""]||e.wallets[t.tronTransaction?.blockChain||""]||e.wallets[t.tronApprovalTransaction?.blockChain||""]||e.wallets[t.starknetTransaction?.blockChain||""]||e.wallets[t.starknetApprovalTransaction?.blockChain||""]||e.wallets[t.cosmosTransaction?.blockChain||""]||e.wallets[t.solanaTransaction?.blockChain||""]||e.wallets[t.tonTransaction?.blockChain||""]||e.wallets[t.suiTransaction?.blockChain||""]||e.wallets[t.xrplTransaction?.blockChain||""]||t.transferTransaction?.fromWalletAddress||null)!==null,"isTxAlreadyCreated");function Ae(e){let{getStorage:t,setStorage:n}=e,r=t().swapDetails,a=f(r);a?.networkStatus&&(a.networkStatus=null,n({...t(),swapDetails:r}))}i(Ae,"resetNetworkStatus");function Be(e,t={message:"",details:"",status:null}){let{message:n,details:r,status:a}=t,{getStorage:o,setStorage:l}=e,s=o().swapDetails,u=f(s);u?.networkStatus&&(s.networkStatusExtraMessage=n,s.networkStatusExtraMessageDetail=r,u.networkStatus=a,l({...o(),swapDetails:s}))}i(Be,"updateNetworkStatus");function Et(e,t){let{context:n,queue:r}=t,a=r.getStorage().swapDetails,{ok:o,reason:l}=Xe(a,n.state);if(!o){let s=f(a),{type:u,address:p}=U(a);w({event:{type:"tx_execution_blocked",...l==="account_miss_match"?{status:"waiting_for_change_wallet_account",requiredAccount:p??void 0}:{status:"waiting_for_wallet_connect",requiredWallet:u??void 0,requiredAccount:p??void 0}},swap:a,step:s}),cn({getStorage:r.getStorage.bind(r),setStorage:r.setStorage.bind(r)},Ze,e.reason.description);return}r.unblock()}i(Et,"onBlockForConnectWallet");function wt(e,t){let{context:n,queue:r}=t,a=r.getStorage().swapDetails,o=f(a);if(!o||a.status!=="running")return;let l=gt({getStorage:r.getStorage.bind(r),setStorage:r.setStorage.bind(r)}),s=W(a,o)?.network,u=U(a).type,p=u?n.state(u).network:void 0;l&&w({event:{type:"tx_execution_blocked",status:"waiting_for_network_change",requiredNetwork:s??void 0,currentNetwork:p??void 0},swap:l.swap,step:l.step});let{type:c,namespace:S}=U(a);if(c&&S?.network&&n.canSwitchNetworkTo(c,S.network,S)){let d=n.switchNetwork(c,S);d&&d.then(()=>{r.unblock()}).catch(g=>{Be({getStorage:r.getStorage.bind(r),setStorage:r.setStorage.bind(r)},{message:g.message,details:g.message,status:ee.NetworkChangeFailed})})}}i(wt,"onBlockForChangeNetwork");function yt(e,t){let{getBlockedTasks:n,forceExecute:r,queue:a,manager:o,context:l}=t,{setClaimer:s,claimedBy:u,reset:p}=Ee(),c=n().filter(T=>T.reason.reason==="depends_on_other_queues");if(c.length===0)return;let S=u(),d=!!S;if(S===a.id)return;if(d){mt({getStorage:a.getStorage.bind(a),setStorage:a.setStorage.bind(a)});return}let g=c.find(T=>T.queue_id===t.queue_id);g||(g=c[0]),s(g.queue_id);let m=g.storage.get(),{type:E,namespace:C,address:_}=U(m.swapDetails);r(g.queue_id,{claimedBy:u(),resetClaimedBy:()=>{p(),E&&He({walletType:E,network:C?.network,accounts:_?[_]:[]},o,l.canSwitchNetworkTo)}})}i(yt,"onDependsOnOtherQueues");function Xe(e,t){let{type:n,address:r}=U(e);if(!n||!r)return{ok:!1,reason:"not_connected"};let a=t(n),{accounts:o,connected:l}=a,s=o||[];return l?{ok:s.some(p=>{let{address:c}=tn(p);return r.toLocaleLowerCase()===c.toLocaleLowerCase()}),reason:"account_miss_match"}:{ok:!1,reason:"not_connected"}}i(Xe,"isRequiredWalletConnected");function Qe(e,t,n){let{setTransactionDataByHash:r}=we(),{getStorage:a,context:o}=e,{meta:l}=o,s=a().swapDetails,u=f(s),p=F(s,u),c=le(t.hash,p.network,l.blockchains);sn(e,t.hash,c&&(!t.response||t.response&&!t.response.hashRequiringUpdate)?{url:c,description:n.isApproval?"Approve":"Swap"}:void 0),t.response&&r(t.hash,{response:t.response})}i(Qe,"updateStorageOnSuccessfulSign");function Ce(e,t){return({hash:n,response:r})=>{let{schedule:a,next:o}=e;Qe(e,{hash:n,response:r},t),a("CHECK_TRANSACTION_STATUS"),o()}}i(Ce,"handleSuccessfulSign");function $(e){return t=>{let{getStorage:n,setStorage:r,failed:a}=e,o=n().swapDetails,l=f(o);if(o.status==="failed")return;let s=R(o,l),{extraMessage:u,extraMessageDetail:p,extraMessageErrorCode:c}=H(t);en(t,{tags:{requestId:o.requestId,rpc:!0,swapper:l?.swapperId||"",walletType:s?.walletType||""},context:on.isSignerError(t)?t.getErrorContext():{}});let S=O({getStorage:n,setStorage:r,nextStatus:"failed",nextStepStatus:"failed",message:u,details:p,errorCode:c,trace:t?.cause});w({event:{type:"failed",reason:u,reasonCode:S.failureType??P,inputAmount:M(o),inputAmountUsd:X(o)},...S}),a()}}i($,"handleRejectedSign");function xt(e){let{lastConnectedWallet:t,evmChains:n,manager:r}=e,{walletType:a,network:o}=t;n.some(l=>l.name==o)&&r?.getAll().forEach(l=>{let s=l.list.getStorage(),u=s?.swapDetails;if(u&&u.status==="running"){let p=f(u);if(p){let c=s?.swapDetails.wallets[p.fromBlockchain]?.walletType,S=Object.keys(l.list.state.tasks).some(g=>{let m=l.list.state.tasks[g];return m.status===Le.BLOCKED&&["waiting_for_connecting_wallet"].includes(m.blockedFor?.reason)}),d=W(u,p)?.network;if(!n.some(g=>g.name==d))return;if(c===a&&S&&d!=o){let g=l.list,{type:m}=U(u),E=ge(m);l.list.block({reason:{reason:"waiting_for_network_change",description:E},silent:!0});let C=gt({getStorage:g.getStorage.bind(g),setStorage:g.setStorage.bind(g)});C&&w({event:{type:"tx_execution_blocked",status:"waiting_for_network_change",currentNetwork:o,requiredNetwork:d??void 0},swap:C.swap,step:C.step})}}}})}i(xt,"checkWaitingForConnectWalletChange");function qe(e){e?.getAll().forEach(t=>{if(Object.keys(t.list.state.tasks).some(r=>{let a=t.list.state.tasks[r];return a.status===Le.BLOCKED&&["waiting_for_network_change","depends_on_other_queues"].includes(a.blockedFor?.reason)})){let r=t.list.getStorage()?.swapDetails;if(r.status==="running"){let{type:a}=U(r),o=Se(a);t.list.block({reason:{reason:"waiting_for_connecting_wallet",description:o}})}}})}i(qe,"checkWaitingForNetworkChange");function dn(e){let t=e?.getAll()||new Map,n=[];return t.forEach(r=>{let o=r.list.getStorage()?.swapDetails;!o||o.status!=="running"||n.push(o)}),n}i(dn,"getRunningSwaps");function Sn(e){e.forEach(t=>{let n=f(t),r="tx_execution_blocked",a;n?.networkStatus===ee.WaitingForQueue?a="waiting_for_queue":t?.status==="running"&&(a="waiting_for_wallet_connect"),r&&w&&w({event:{type:r,status:a??"waiting_for_queue"},swap:t,step:n})})}i(Sn,"resetRunningSwapNotifsOnPageLoad");function He(e,t,n,r={fallbackToOnlyWallet:!0}){let{walletType:a,network:o}=e;if(!a)return;let l=[],s=[];t?.getAll().forEach(p=>{if(p.status===Le.BLOCKED){let c=p.list.getStorage(),S=c?.swapDetails;if(S&&S.status==="running"){let d=f(S);d&&(o&&W(S,d)?.network==o&&c?.swapDetails.wallets[o]?.walletType===a?l.push(p.list):c?.swapDetails.wallets[d.fromBlockchain]?.walletType===a&&s.push(p.list))}}});let u;if(l.length>0){if(u=l[0],l.length>1)for(let p=1;p<l.length;p++){let c=l[p];mt({getStorage:c.getStorage.bind(c),setStorage:c.setStorage.bind(c)})}}else s.length>0&&r.fallbackToOnlyWallet&&(u=s[0]);if(u){let p=u.getStorage(),c=f(p?.swapDetails),S=c?W(p.swapDetails,c):null;!o||!S||!n?.(a,o,S)?u.unblock():u.checkBlock()}}i(He,"retryOn");function At(e){return!!e.evmTransaction||!!e.evmApprovalTransaction}i(At,"isNeedBlockQueueForParallel");async function Ct(e){let t=await e;if(!t.ok||!t.transaction)throw D.CreateTransaction(t.error||"bad response from create tx endpoint");return t}i(Ct,"throwOnOK");function gn(e,t){let{reset:n}=Ee();e.actions.cancel();let r=O({getStorage:e.actions.getStorage,setStorage:e.actions.setStorage,message:"Swap canceled by user.",details:"Warning: If you've already signed and sent a transaction, it won't be affected, but next swap steps will not be executed.",nextStatus:"failed",nextStepStatus:"failed",errorCode:"USER_CANCEL"});return w({event:{type:"failed",reasonCode:"USER_CANCEL",reason:r.swap.extraMessage??void 0,inputAmount:M(r.swap),inputAmountUsd:X(r.swap)},swap:r.swap,step:r.step}),n(),t&&t?.retry(),r}i(gn,"cancelSwap");function Z(e){return e.slice().reverse().find(t=>t.status==="success")}i(Z,"getLastSuccessfulStep");function pt(e){return e.slice().reverse().find(t=>t.status==="failed")}i(pt,"getFailedStep");function mn(e){let{transaction:t}=e;return t?.type===I.EVM&&t.isApprovalTx||t?.type===I.STARKNET&&t.isApprovalTx||t?.type===I.TRON&&t.isApprovalTx}i(mn,"isApprovalTX");function ke(e,t){let n=new an(e).multipliedBy(t);return isNaN(n.toNumber())?"":n.toString()}i(ke,"getTokenAmountInUsd");function be(e){return ke(e.inputAmount,e.steps[0].fromUsdPrice??"")}i(be,"getSwapInputUsd");function dt(e){let t=e.steps[e.steps.length-1];return ke(t.outputAmount??"",t.toUsdPrice??"")}i(dt,"getSwapOutputUsd");function kt(e){let t=["success","failed"],n=e.steps.findLastIndex(r=>t.includes(r.status));return n<0?void 0:{step:e.steps[n],index:n}}i(kt,"getLastFinishedStep");function M(e){let t=kt(e);return t?t.index===0?e.inputAmount:e.steps[t.index-1].outputAmount??"":""}i(M,"getLastFinishedStepInput");function X(e){let t=kt(e);return ke(M(e),t?.step?.fromUsdPrice??"")}i(X,"getLastFinishedStepInputUsd");function _e(e){let t=Z(e.steps);return ke(t?.outputAmount??"",t?.toUsdPrice??"")}i(_e,"getLastSuccessfulStepOutputUsd");function te(e,t,n){return{type:"failed",reason:t,reasonCode:n??P,inputAmount:M(e),inputAmountUsd:X(e)}}i(te,"createStepFailedEvent");var _t=5e3,Tn=5e3;async function fn({getStorage:e,setStorage:t,next:n,schedule:r,retry:a,failed:o,context:l}){let s=e().swapDetails,{meta:u}=l,p=new Error("check status Error"),c=f(s);if(!c?.executedTransactionId)return;let S=h(c),d=c.executedTransactionId,g=!1,m=null,E=null,{getTransactionDataByHash:C,setTransactionDataByHash:_}=we();try{let x=Me(c),k=R(s,c);x&&k&&(E=(await l.getSigners(k.walletType)).getSigner(x))}catch{}try{let{response:x,receiptReceived:k}=C(d);if(E?.wait&&!k){let b=S?.blockChain&&u.blockchains?.[S?.blockChain]?.chainId||void 0,{hash:N,response:Y}=await E.wait(d,b,x);if(N!==d){c.executedTransactionId=N||c.executedTransactionId;let Q=F(s,c),ce;!!Object.keys(u.blockchains).length&&(ce=le(c.executedTransactionId,Q.network,u.blockchains)),ce&&c.explorerUrl&&c.explorerUrl?.length>=1&&(c.explorerUrl[c.explorerUrl.length-1]={url:ce,description:"Replaced Swap"}),d=c.executedTransactionId,N&&Y&&_(N,{response:Y})}else _(N,{receiptReceived:!0})}}catch(x){let{extraMessage:k,extraMessageDetail:b,extraMessageErrorCode:N}=H(x),Y=O({getStorage:e,setStorage:t,nextStatus:"failed",nextStepStatus:"failed",message:k,details:b,errorCode:N}),Q=te(s,k,Y.failureType);ne(p,{tags:{type:"singer-error",reason:Q.reason,reasonCode:Q.reasonCode,message:k,messageDetail:b,pendingSwap:s},context:vt.isSignerError(x)?x.getErrorContext():{}}),g=!0}let T={requestId:s.requestId,txId:d,step:c.id};try{m=await q().checkStatus(T)}catch{await xe(_t),a(),ne(p,{tags:{type:"request-error",requestBody:T,pendingSwap:s}});return}if(g)return o();if(c?.status==="failed")return;let A=m?.outputAmount||(c.outputAmount?c.outputAmount:null),y=c.outputAmount||null;s.extraMessage=m?.extraMessage||s.extraMessage,s.extraMessageSeverity="info",s.extraMessageDetail="",c.status=m?.status||c.status,c.diagnosisUrl=m?.diagnosisUrl||c.diagnosisUrl||null,c.outputAmount=A||c.outputAmount,c.explorerUrl=m?.explorerUrl||c.explorerUrl,c.internalSteps=m?.steps||null;let v=m?.newTx;if(v&&(c.status="created",c.executedTransactionId=null,c.executedTransactionTime=null,ye(c,v)),y===null&&A!==null?w({event:{type:"output_revealed",outputAmount:A},swap:s,step:c}):y===null&&A===null&&w({event:{type:"check_status"},swap:s,step:c}),c.status==="success"){let x=it(s,c);s.extraMessageDetail="",s.extraMessage=x?`starting next step: ${x.swapperId}: ${x.fromBlockchain} -> ${x.toBlockchain}`:"",w({event:{type:"succeeded",inputAmount:M(s),inputAmountUsd:X(s),outputAmount:c.outputAmount??"",outputAmountUsd:_e(s)},swap:s,step:c})}else c.status==="failed"&&(s.extraMessage="Transaction failed in blockchain",s.extraMessageSeverity="error",s.extraMessageDetail=m?.extraMessage||"",s.status="failed",s.finishTime=new Date().getTime().toString(),ne(p,{tags:{type:"transaction-failed",message:s.extraMessage,messageDetails:s.extraMessageDetail,pendingSwap:s}}));t({...e(),swapDetails:s}),m?.status==="failed"?o():m?.status==="success"||m?.status==="running"&&m.newTx?(r("SCHEDULE_NEXT_STEP"),n()):(await xe(_t),a())}i(fn,"checkTransactionStatus");async function En({getStorage:e,setStorage:t,next:n,schedule:r,retry:a,failed:o,context:l}){let s=e().swapDetails,{meta:u}=l,{getTransactionDataByHash:p,setTransactionDataByHash:c}=we(),S=new Error("check approval status error"),d=f(s);if(!d){console.log("ignore check status, current step is null");return}let g=h(d);if(!d?.executedTransactionId)return;let m=d.executedTransactionId,E=null;try{let T=Me(d),A=R(s,d);T&&A&&(E=(await l.getSigners(A.walletType)).getSigner(T))}catch{}try{let{response:T,receiptReceived:A}=p(m);if(E?.wait&&!A){let y=g?.blockChain&&u.blockchains?.[g?.blockChain]?.chainId||void 0,{hash:v,response:x}=await E.wait(m,y,T);if(v!==m){d.executedTransactionId=v||d.executedTransactionId;let k=F(s,d),b;!!Object.keys(u.blockchains).length&&(b=le(d.executedTransactionId,k.network,u.blockchains)),b&&d.explorerUrl&&d.explorerUrl?.length>=1&&(d.explorerUrl[d.explorerUrl.length-1]={url:b,description:"Replaced Approve"}),m=d.executedTransactionId,v&&x&&c(v,{response:x})}else c(v,{receiptReceived:!0})}}catch(T){let{extraMessage:A,extraMessageDetail:y,extraMessageErrorCode:v}=H(T),x=O({getStorage:e,setStorage:t,nextStatus:"failed",nextStepStatus:"failed",message:A,details:y,errorCode:v}),k=te(s,A,x.failureType);return w({event:k,...x}),ne(S,{tags:{type:"singer-error",reason:k.reason,reasonCode:k.reasonCode,message:A,messageDetail:y,pendingSwap:s},context:vt.isSignerError(T)?T.getErrorContext():{}}),o()}let C=!1,_={requestId:s.requestId,txId:d.executedTransactionId};try{let T=await q().checkApproval(_.requestId,_.txId);if(d?.status==="failed")return;if(C=T.isApproved,!C&&(T.txStatus==="failed"||T.txStatus==="success")){let A,y;T.txStatus==="failed"?(A="Approve transaction failed",y="Smart contract approval tx failed in blockchain."):(A="Not enough approval",T.requiredApprovedAmount&&T.currentApprovedAmount?y=`Required approval: ${T.requiredApprovedAmount}, current approval: ${T.currentApprovedAmount}`:y="You still don't have enough approval for this swap.");let v=O({getStorage:e,setStorage:t,nextStatus:"failed",nextStepStatus:"failed",errorCode:"INSUFFICIENT_APPROVE",message:A,details:y}),x=te(s,A,v.failureType);w({event:x,...v}),ne(S,{tags:{type:"approval-failed",message:s.extraMessage,messageDetails:s.extraMessageDetail,pendingSwap:s}}),o()}else C||w({event:{type:"check_status"},swap:s,step:d})}catch{C=!1,ne(S,{tags:{type:"request-error",requestBody:_,pendingSwap:s}})}C?(d.status="approved",s.extraMessage=`Spending ${d.fromSymbol} approved successfully.`,s.extraMessageDetail=null,s.extraMessageSeverity="success",d.evmApprovalTransaction=null,d.executedTransactionId=null,d.executedTransactionTime=null,d.starknetApprovalTransaction=null,d.tronApprovalTransaction=null,t({...e(),swapDetails:s}),w({event:{type:"approval_tx_succeeded"},swap:s,step:d}),r("SCHEDULE_NEXT_STEP"),n()):(await xe(Tn),a())}i(En,"checkApprovalStatus");async function ht(e){let t=e.getStorage().swapDetails,n=f(t);if(!n){console.log("ignore check status, current step is null",t.requestId);return}Ae(e),n.status==="running"?await fn(e):n.status==="waitingForApproval"&&await En(e)}i(ht,"checkStatus");import{PendingSwapNetworkStatus as Rt}from"rango-types";import{Err as he,Ok as Ge}from"ts-results";function ve(e){return e.claimedBy===e._queue?.id}i(ve,"isClaimedByCurrentQueue");function re(e,t){e.block(t),ve(e.context)&&e.context.resetClaimedBy&&e.context.resetClaimedBy()}i(re,"requestBlockQueue");async function ae(e){let{getStorage:t,context:n}=e,r=t().swapDetails,a=f(r),o=wn(e);if(o.err)return o;let l=await yn(e);if(l.err)return l;a.networkStatus===Rt.NetworkChanged&&Be(e,{message:"",details:"The network has been successfully changed.",status:Rt.NetworkChanged});let s=At(a),u=ve(n);if(s&&!u){let p={reason:"depends_on_other_queues",description:Ie,details:{}};return new he(p)}return new Ge(!0)}i(ae,"checkEnvironmentBeforeExecuteTransaction");function wn(e){let{getStorage:t,context:n}=e,{wallets:r}=n,a=t().swapDetails;if(!Xe(a,n.state).ok){let{type:l,address:s}=U(a),u=r?.blockchains?.find(S=>!S.accounts?.find(d=>d.walletType===l)),p=Fe(r)||u?Se(l):et(l,s),c={reason:"waiting_for_connecting_wallet",description:p};return new he(c)}return new Ge(!0)}i(wn,"ensureRequiredWalletIsConnected");async function yn(e){let{getStorage:t,context:n}=e,{meta:r,wallets:a,providers:o,hubProvider:l}=n,s=t().swapDetails,u=f(s),p=await Tt(s,u,a,r,o,l),{claimedBy:c}=Ee();if(!!c()&&!ve(n)&&!p){let g=Ie,m={reason:"depends_on_other_queues",details:g};return new he(m)}else if(!p){let g=F(s,u),m=ge(g.network),E={reason:"waiting_for_network_change",details:m};return new he(E)}return new Ge(!0)}i(yn,"ensureWalletIsOnCorrectNetwork");import{Err as Nt,Ok as It}from"ts-results";function oe(e){let{getStorage:t,context:n}=e,{isMobileWallet:r}=n,a=t().swapDetails,o=f(a),l=R(a,o),s=r(l?.walletType),u=h(o),p=L(o);if(!u||!u.type)return new Nt({nextStatus:"failed",nextStepStatus:"failed",message:"Unexpected Error: tx is null!",details:void 0,errorCode:"CLIENT_UNEXPECTED_BEHAVIOUR"});let c=!!a.hasAlreadyProceededToSign;return p?new It({nextStatus:void 0,nextStepStatus:"waitingForApproval",details:"Waiting for approve transaction to be mined and confirmed successfully",message:`Waiting for approval of ${o?.fromSymbol} coin ${s?"on your mobile phone!":""}`}):c?new Nt({message:"Transaction is expired. Please try again.",nextStepStatus:"failed",nextStatus:"failed",details:"",errorCode:"TX_EXPIRED"}):new It({message:"Executing transaction ...",nextStepStatus:"running",nextStatus:"running",details:`${s?"Check your mobile phone!":""}`})}i(oe,"produceNextStateForTransaction");function se(e,t){let{getStorage:n,setStorage:r}=e,a=n().swapDetails,o=f(a),l=L(o),s=typeof a.hasAlreadyProceededToSign=="boolean",u=O({getStorage:n,setStorage:r,nextStepStatus:t.nextStepStatus,nextStatus:t.nextStatus,message:t.message,details:t.details,errorCode:t.errorCode,hasAlreadyProceededToSign:l?void 0:s});w({event:{type:"failed",reason:t.message,reasonCode:u.failureType??P,inputAmount:M(a),inputAmountUsd:X(a)},...u})}i(se,"onNextStateError");function ie(e,t){let{getStorage:n,setStorage:r}=e,a=n().swapDetails,o=f(a),l=L(o),s=typeof a.hasAlreadyProceededToSign=="boolean",u=O({getStorage:n,setStorage:r,nextStepStatus:t.nextStepStatus,nextStatus:t.nextStatus,message:t.message,details:t.details,hasAlreadyProceededToSign:l?void 0:s});w({event:{type:"tx_execution",status:"send_tx"},...u})}i(ie,"onNextStateOk");import{isXrplTransaction as xn}from"rango-types";import{Err as Re,Ok as Pt}from"ts-results";async function ue(e){return e?xn(e)?e.data.TransactionType!=="Payment"?new Re({nextStatus:"failed",nextStepStatus:"failed",message:"Unexpected Error: We only support XRPL transactions with payment type",details:void 0,errorCode:"CLIENT_UNEXPECTED_BEHAVIOUR"}):Pt(e):new Re({nextStatus:"failed",nextStepStatus:"failed",message:"Unexpected Error: Expected XRPL transaction but it doesn't match with the structure.",details:void 0,errorCode:"CLIENT_UNEXPECTED_BEHAVIOUR"}):new Re({nextStatus:"failed",nextStepStatus:"failed",message:"Unexpected Error: tx is null!",details:void 0,errorCode:"CLIENT_UNEXPECTED_BEHAVIOUR"})}i(ue,"ensureXrplTransactionIsValid");async function pe(e,t){let r=e.hubProvider(t).get("xrpl");return r?Pt(r):new Re({nextStatus:"failed",nextStepStatus:"failed",message:"XRPL is not available on your wallet.",details:void 0,errorCode:"CLIENT_UNEXPECTED_BEHAVIOUR"})}i(pe,"ensureXrplNamespaceExists");async function Ot(e,t,n){return!!(await n.namespace.accountLines(e,{peer:t.account})).some(a=>a.currency===t.currency&&a.account===t.account&&a.limit!=="0")}i(Ot,"checkTruslineAlreadyOpened");function Dt(e,t){return{TransactionType:"TrustSet",Account:e,LimitAmount:{currency:t.currency,issuer:t.account,value:t.amount}}}i(Dt,"createTrustlineTransaction");async function Ke(e){let t=await ae(e);if(t.err){re(e,t.val);return}let{failed:n,context:r,schedule:a,getStorage:o,next:l}=e,{meta:s,getSigners:u}=r,p=o().swapDetails,c=f(p),S=h(c),d=R(p,c),g=J(p,c),m=i(()=>{e.context.resetClaimedBy&&e.context.resetClaimedBy()},"onFinish"),E=i(()=>{a("EXECUTE_XRPL_TRANSACTION"),l(),m()},"onSuccessfulFinish"),C=i(N=>{se(e,N.val),n(),m()},"handleErr"),_=oe(e);if(_.err){C(_);return}ie(e,_.val);let T=await ue(S);if(T.err){C(T);return}let A=await pe(r,d.walletType);if(A.err){C(A);return}let y=T.val.prerequisites.find(N=>N.type==="XRPL_CHANGE_TRUSTLINE");if(!y){E();return}let v=s.blockchains[T.val.blockChain]?.chainId,x=await u(d.walletType),k={currency:y.currency,account:y.issuer,amount:y.value};if(await Ot(y.wallet,k,{namespace:A.val})){E();return}else{let N=Dt(y.wallet,k),Y=x.getSigner(T.val.type);try{let Q={...T.val,data:N},ce=await Y.signAndSendTx(Q,g,v);Qe(e,ce,{isApproval:!0}),E()}catch(Q){$(e)(Q),m()}}}i(Ke,"checkXrplTrustline");import{warn as An}from"@rango-dev/logging-core";async function Ut(e){let{setStorage:t,getStorage:n,next:r,schedule:a}=e,o=n().swapDetails,l=f(o);if(!h(l)){w({event:{type:"tx_execution",status:"create_tx"},swap:o,step:l});let u={requestId:o.requestId,step:l.id,userSettings:{slippage:o.settings.slippage,infiniteApprove:o.settings.infiniteApprove},validations:{balance:o.validateBalanceOrFee,fee:o.validateBalanceOrFee,approve:!0}};try{let{transaction:p}=await Ct(q().createTransaction(u));p&&ye(l,p),t({...n(),swapDetails:o}),a("SCHEDULE_NEXT_STEP"),r()}catch(p){o.status="failed",o.finishTime=new Date().getTime().toString();let{extraMessage:c,extraMessageDetail:S}=H(p),d=O({getStorage:n,setStorage:t,nextStatus:"failed",nextStepStatus:"failed",message:c,details:S,errorCode:"FETCH_TX_FAILED"}),g=te(o,c,d.failureType);w({event:g,...d}),p instanceof Error&&An(new Error("create transaction error"),{tags:{message:p.message,requestBody:u,reason:g.reason,reasonCode:g.reasonCode,pendingSwap:o}}),e.failed()}}}i(Ut,"createTransaction");async function Ve(e){let t=await ae(e);if(t.err){re(e,t.val);return}Ae(e);let{failed:n,getStorage:r,context:a}=e,{meta:o,getSigners:l}=a,s=r().swapDetails,u=f(s),p=L(u),c=i(()=>{e.context.resetClaimedBy&&e.context.resetClaimedBy()},"onFinish"),S=oe(e);if(S.err){se(e,S.val),n(),c();return}ie(e,S.val);let d=h(u),g=R(s,u),m=J(s,u),E=o.blockchains?.[d.blockChain]?.chainId,C;try{C=await l(g.walletType)}catch(T){$(e)(T),c();return}await C.getSigner(d.type).signAndSendTx(d,m,E).then(Ce(e,{isApproval:p}),$(e)).finally(()=>{c()})}i(Ve,"executeTransaction");async function $e(e){let t=await ae(e);if(t.err){re(e,t.val);return}let{failed:n,getStorage:r,context:a}=e,{meta:o,getSigners:l}=a,s=r().swapDetails,u=f(s),p=h(u),c=R(s,u),S=J(s,u),d=i(()=>{e.context.resetClaimedBy&&e.context.resetClaimedBy()},"onFinish"),g=i(y=>{se(e,y.val),n(),d()},"handleErr"),m=oe(e);if(m.err){g(m);return}ie(e,m.val);let E=await ue(p);if(E.err){g(E);return}let C=await pe(a,c.walletType);if(C.err){g(C);return}let _=o.blockchains[E.val.blockChain]?.chainId,A=(await l(c.walletType)).getSigner(E.val.type);try{let y=await A.signAndSendTx(E.val,S,_);Ce(e,{isApproval:E.val.data.TransactionType==="TrustSet"})(y)}catch(y){$(e)(y)}d()}i($e,"executeXrplTransaction");import{TransactionType as Cn}from"rango-types";function bt({schedule:e,next:t,failed:n,setStorage:r,getStorage:a}){let o=a().swapDetails,l=f(o),s=o.steps.find(u=>u.status==="failed");if(l&&!s){if(ft(o,l))return l.fromBlockchain===Cn.XRPL?e("CHECK_XRPL_TRUSTLINE"):e("EXECUTE_TRANSACTION"),t();if(l?.executedTransactionId)return e("CHECK_TRANSACTION_STATUS"),t();o.status="running",r({...a(),swapDetails:o}),w({event:{type:"started"},swap:o,step:l}),e("CREATE_TRANSACTION"),t()}else{o.status=s?"failed":"success",o.finishTime=new Date().getTime().toString(),r({...a(),swapDetails:o});let u=M(o),p=X(o);w({...s?{event:{type:"failed",reason:o.extraMessage??void 0,reasonCode:"CALL_OR_SEND_FAILED",inputAmount:u,inputAmountUsd:p}}:{event:{type:"succeeded",inputAmount:u,inputAmountUsd:p,outputAmount:Z(o.steps)?.outputAmount??"",outputAmountUsd:_e(o)}},swap:o,step:null}),s?n():t()}}i(bt,"scheduleNextStep");function Wt({schedule:e,next:t,getStorage:n}){let r=n().swapDetails;w({event:{type:"started"},swap:r,step:null}),e("SCHEDULE_NEXT_STEP"),t()}i(Wt,"start");var Lt={name:"swap",actions:{START:Wt,SCHEDULE_NEXT_STEP:bt,CREATE_TRANSACTION:Ut,EXECUTE_TRANSACTION:Ve,EXECUTE_XRPL_TRANSACTION:$e,CHECK_XRPL_TRUSTLINE:Ke,CHECK_TRANSACTION_STATUS:ht},run:["START"],whenTaskBlocked:(e,t)=>{e.reason.reason==="waiting_for_connecting_wallet"?Et(e,t):e.reason.reason==="waiting_for_network_change"?wt(e,t):e.reason.reason==="depends_on_other_queues"&&yt(e,t)}};import{useManager as Rn}from"@rango-dev/queue-manager-react";import{useEffect as je,useState as Nn}from"react";import{DB_NAME as kn,Persistor as _n,Status as de}from"@rango-dev/queue-manager-core";import{v4 as vn}from"uuid";var Mt="migratedToQueueManager";function Ye(){return!!window.localStorage.getItem(Mt)}i(Ye,"migrated");async function hn(){try{return(await window.indexedDB.databases()).map(e=>e.name).includes(kn)}catch{return!1}}i(hn,"hasQueueManagerOnIDB");async function Ft(){let e=window.localStorage.getItem("pendingSwaps"),t=await hn();if(!e||Ye()||t)return!0;let n=JSON.parse(e),r=[];n.forEach(l=>{if(l.status==="running"){let s=vn(),u={id:l.requestId,createdAt:Number(l.creationTime),name:"swap",status:de.RUNNING,storage:{swapDetails:l},state:{status:de.RUNNING,activeTaskIndex:0,tasks:{[s]:{blockedFor:null,status:de.RUNNING}}},tasks:[{id:s,action:"SCHEDULE_NEXT_STEP"}]};r.push(u)}else{let s=l.status==="success"?de.SUCCESS:de.FAILED,u={id:l.requestId,createdAt:Number(l.creationTime),name:"swap",status:s,storage:{swapDetails:l},state:{status:s,activeTaskIndex:0,tasks:{}},tasks:[]};r.push(u)}});let a=new _n,o=r.map(async l=>a.insertQueue(l));return await Promise.all(o),window.localStorage.setItem(Mt,"1"),!0}i(Ft,"migration");var Bt=0;function In(e){return`${e?.walletType}-${e?.network}-${e?.accounts?.toString()}`}i(In,"getLastConnectedWalletHash");function Pn(){let e=Ye(),[t,n]=Nn(e);return je(()=>{(async()=>Bt||(Bt=1,Ft().finally(()=>{n(!0)})))()},[]),{status:t}}i(Pn,"useMigration");function On(e){let{manager:t}=Rn(),{lastConnectedWallet:n,disconnectedWallet:r,evmChains:a,canSwitchNetworkTo:o,clearDisconnectedWallet:l}=e;je(()=>{n&&(xt({evmChains:a,lastConnectedWallet:n,manager:t}),He(n,t,o))},[In(n)]),je(()=>{r&&(qe(t),l())},[r])}i(On,"useQueueManager");function vo(e){return ze(e),Lt}i(vo,"makeQueueDefinition");export{Ue as EventSeverity,Te as MessageSeverity,D as PrettyError,De as RouteEventType,B as StepEventType,fe as StepExecutionBlockedEventStatus,z as StepExecutionEventStatus,Oe as WidgetEvents,jt as calculatePendingSwap,gn as cancelSwap,qe as checkWaitingForNetworkChange,W as getCurrentNamespaceOfOrNull,f as getCurrentStep,Z as getLastSuccessfulStep,R as getRelatedWallet,Pe as getRelatedWalletOrNull,U as getRequiredWallet,dn as getRunningSwaps,lt as getUsdPrice,mn as isApprovalTX,vo as makeQueueDefinition,H as prettifyErrorMessage,Sn as resetRunningSwapNotifsOnPageLoad,O as updateSwapStatus,Pn as useMigration,On as useQueueManager};
1
+ var _r=Object.defineProperty;var o=(e,t)=>_r(e,"name",{value:t,configurable:!0});function hr(){return process.env.REACT_APP_RANGO_API_KEY}o(hr,"getApiKeyFromEnv");function xt(){return hr()||"NOT_SET"}o(xt,"getApiKeyFromEnvOrNotSet");var Xe={API_KEY:xt(),BASE_URL:""};function Z(e){return Xe[e]}o(Z,"getConfig");function yt(e){return Xe=e,Xe}o(yt,"initConfig");import{Networks as rn}from"@rango-dev/wallets-shared";import{STELLAR_CHANGE_TRUSTLINE_TYPE as nn,XRPL_CHANGE_TRUSTLINE_TYPE as an}from"rango-types";import{Err as ot,Ok as Jt}from"ts-results";import{warn as Mr}from"@rango-dev/logging-core";import{Status as Ze}from"@rango-dev/queue-manager-core";import{legacyReadAccountAddress as Br}from"@rango-dev/wallets-core/legacy";import{getBlockChainNameFromId as Xr,getEvmProvider as Qr}from"@rango-dev/wallets-shared";import Hr from"bignumber.js";import{PendingSwapNetworkStatus as ae,SignerError as Gr,TransactionType as k}from"rango-types";import{STELLAR_CHANGE_TRUSTLINE_TYPE as Nr,XRPL_CHANGE_TRUSTLINE_TYPE as kr}from"rango-types";import{Err as H,Ok as Ke}from"ts-results";var Qe=(r=>(r.RouteEvent="routeEvent",r.StepEvent="stepEvent",r))(Qe||{}),He=(n=>(n.STARTED="started",n.FAILED="failed",n.SUCCEEDED="succeeded",n))(He||{}),ee=(n=>(n.CREATE_TX="create_tx",n.SEND_TX="send_tx",n.TX_SENT="tx_sent",n))(ee||{}),ye=(a=>(a.WAITING_FOR_QUEUE="waiting_for_queue",a.WAITING_FOR_WALLET_CONNECT="waiting_for_wallet_connect",a.WAITING_FOR_NETWORK_CHANGE="waiting_for_network_change",a.WAITING_FOR_CHANGE_WALLET_ACCOUNT="waiting_for_change_wallet_account",a))(ye||{}),Q=(c=>(c.STARTED="started",c.FAILED="failed",c.SUCCEEDED="succeeded",c.TX_EXECUTION="tx_execution",c.TX_EXECUTION_BLOCKED="tx_execution_blocked",c.APPROVAL_TX_SUCCEEDED="approval_tx_succeeded",c.CHECK_STATUS="check_status",c.OUTPUT_REVEALED="output_revealed",c))(Q||{}),Ge=(a=>(a.ERROR="error",a.SUCCESS="success",a.WARNING="warning",a.INFO="info",a))(Ge||{});var At=o((e,t)=>{let r=Ve(t,e);return r?.status==="success"||r?.status==="skipped"},"checkIsPrerequisiteAlreadyMet");function Ve(e,t){return e.prerequisiteResults?.find(r=>$e(r,t))}o(Ve,"getPrerequisiteResult");var $e=o((e,t)=>e.prerequisiteIndex===t.prerequisiteIndex&&e.prerequisiteType===t.prerequisiteType,"matchesPrerequisiteKey");function Ct(e,t){let r=Ve(t,{prerequisiteType:kr,prerequisiteIndex:e});if(!r)return new Ke("CHECK_XRPL_TRUSTLINE");switch(r.status){case"pending":return new Ke("CHECK_XRPL_TRUSTLINE_TRANSACTION_STATUS");case"success":return new H("Unexpected Error: xrpl change trustline prerequisite is already met!");case"skipped":return new H("Unexpected Error: xrpl change trustline prerequisite is already met!");case"failed":return new H("Unexpected Error: xrpl change trustline prerequisite failed!");default:return new H("Unexpected Error: xrpl change trustline prerequisite has an invalid status!")}}o(Ct,"handleUnmetXrplChangeTrustLinePrerequisite");function Rt(e,t){let r=Ve(t,{prerequisiteType:Nr,prerequisiteIndex:e});if(!r)return new Ke("CHECK_STELLAR_TRUSTLINE");switch(r.status){case"pending":return new H('Unexpected Error: stellar change trustline prerequisite has invalid "pending" status!');case"success":return new H("Unexpected Error: stellar change trustline prerequisite is already met!");case"skipped":return new H("Unexpected Error: stellar change trustline prerequisite is already met!");case"failed":return new H("Unexpected Error: stellar change trustline prerequisite failed!");default:return new H("Unexpected Error: stellar change trustline prerequisite has an invalid status!")}}o(Rt,"handleUnmetStellarChangeTrustLinePrerequisite");var Ye="Waiting for other swaps to complete",_t="Waiting for connecting wallet",te=o((e,t)=>`Please change your ${e||"wallet"} account to ${t||"proper address"}`,"ERROR_MESSAGE_WAIT_FOR_WALLET_DESCRIPTION_WRONG_WALLET"),$=o(e=>`Please connect your ${e??""} wallet.`,"ERROR_MESSAGE_WAIT_FOR_WALLET_DESCRIPTION"),Ae=o(e=>`Please change your network to ${e}.`,"ERROR_MESSAGE_WAIT_FOR_CHANGE_NETWORK"),L="CLIENT_UNEXPECTED_BEHAVIOUR";import{RangoClient as Ir}from"rango-sdk";var Ce,Y=o(()=>Ce||(Ce=new Ir(Z("API_KEY"),Z("BASE_URL")),Ce),"httpService");import vt from"bignumber.js";import ht from"bignumber.js";var Nt=o((e,t=null,r=null)=>{if(e===null||e==="")return"";let n=new ht(e),a=1,s=1e3;for(let u=0;u<60;u++)if(new ht(n.toFixed(u,a)).eq(n)){s=u;break}if(n.gte(1e4))return n.toFormat(0,a);if(n.gte(1e3)||n.gte(100))return n.toFormat(Math.min(s,Math.min(r||100,Math.max(t||0,1))),a);if(n.gte(1))return n.toFormat(Math.min(s,Math.min(r||100,Math.max(t||0,2))),a);if(n.gte(.01))return n.toFormat(Math.min(s,Math.min(r||100,Math.max(t||0,4))),a);for(let u=t||4;u<17;u++)if(n.gte(Math.pow(10,-u)))return n.toFormat(Math.min(s,Math.min(r||100,Math.max(t||0,u))),a);return n.isEqualTo(0)?"0":n.toFormat(Math.min(s,Math.min(r||100,Math.max(t||0,8))),a)},"numberToString");import{SignerErrorCode as J,SignerError as vr,isSignerErrorCode as Pr,isAPIErrorCode as Lr}from"rango-types";var Or="Assertion failed (Unexpected behaviour)",Ur="Create transaction failed in Rango Server",kt="Input wallet not found",D=class e extends Error{constructor(r,n,a,s){super(n);this._isPrettyError=!0;Object.setPrototypeOf(this,e.prototype),e.prototype._isPrettyError=!0,this.code=r,this.detail=s,this.root=a}static{o(this,"PrettyError")}static isPrettyError(r){return r instanceof e||Object.prototype.hasOwnProperty.call(r,"_isPrettyError")}getErrorDetail(){let r=typeof this.root=="object"&&this.root&&this.root.error?this.root.error:JSON.stringify(this.root),n=typeof this.root=="string"?this.root:this.root instanceof Error?this.root.message:r;return{extraMessage:this.message,extraMessageDetail:this.detail||n,extraMessageErrorCode:this.code||null}}static AssertionFailed(r){return new e("CLIENT_UNEXPECTED_BEHAVIOUR",Or,null,r)}static BadStatusCode(r,n){return new e("TX_FAIL",r,null,`status code = ${n}`)}static CreateTransaction(r){return new e("FETCH_TX_FAILED",Ur,null,r)}static WalletMissing(){return new e("CLIENT_UNEXPECTED_BEHAVIOUR",kt,null,"Server requested for a blockchain or address not selected by user")}static BlockchainMissing(){return new e("CLIENT_UNEXPECTED_BEHAVIOUR",kt,null,"Server requested for a blockchain or address not selected by user")}};function It(e){try{return e?Lr(e)?e:Pr(e)?{[J.REJECTED_BY_USER]:"USER_REJECT",[J.SIGN_TX_ERROR]:"CALL_WALLET_FAILED",[J.SEND_TX_ERROR]:"SEND_TX_FAILED",[J.TX_FAILED_IN_BLOCKCHAIN]:"TX_FAILED_IN_BLOCKCHAIN",[J.NOT_IMPLEMENTED]:L,[J.OPERATION_UNSUPPORTED]:L,[J.UNEXPECTED_BEHAVIOUR]:L}[e]:L:L}catch{return L}}o(It,"mapAppErrorCodesToAPIErrorCode");var j=o(e=>{if(!e)return{extraMessage:"",extraMessageErrorCode:null};if(D.isPrettyError(e))return e.getErrorDetail();if(vr.isSignerError(e)){let t=e.getErrorDetail();return{extraMessage:t.message,extraMessageDetail:t.detail,extraMessageErrorCode:t.code}}return e instanceof Error?{extraMessage:e.toString(),extraMessageErrorCode:null}:typeof e!="string"?{extraMessage:JSON.stringify(e),extraMessageErrorCode:null}:{extraMessage:e,extraMessageErrorCode:null}},"prettifyErrorMessage");var Re=(a=>(a.error="error",a.warning="warning",a.info="info",a.success="success",a))(Re||{}),F=o((e,t)=>{try{return G(e,t)}catch{return null}},"getCurrentNamespaceOfOrNull"),G=o((e,t)=>{let r=t.evmTransaction?.blockChain||t.evmApprovalTransaction?.blockChain,n=t.starknetTransaction?.blockChain||t.starknetApprovalTransaction?.blockChain,a=t.tronTransaction?.blockChain||t.tronApprovalTransaction?.blockChain,s=t.cosmosTransaction?.blockChain,u=t.solanaTransaction?.blockChain,i=t.tonTransaction?.blockChain,c=t.suiTransaction?.blockChain,p=t.xrplTransaction?.blockChain,l=t.stellarTransaction?.blockChain;if(r)return{namespace:"EVM",network:r};if(n)return{namespace:"Starknet",network:n};if(a)return{namespace:"Tron",network:a};if(s)return{namespace:"Cosmos",network:s};if(u)return{namespace:"Solana",network:u};if(i)return{namespace:"Ton",network:i};if(c)return{namespace:"Sui",network:c};if(p)return{namespace:"XRPL",network:p};if(l)return{namespace:"Stellar",network:l};if(t.transferTransaction){let T=t.transferTransaction.fromWalletAddress;if(!T)throw D.BlockchainMissing();let d=Object.keys(e.wallets).find(S=>e.wallets[S]?.address===T);if(!d)throw D.BlockchainMissing();return{namespace:"UTXO",network:d}}throw new Error("Unsupported transaction type has been included in your swap.",{cause:t})},"getCurrentNamespaceOf"),pe=o((e,t,r)=>{let a=r[t].info?.transactionUrl;if(a)return a.indexOf("/{txHash}")!==-1?a.replace("{txHash}",e):`${a}/${e}`},"getScannerUrl");function Lt(e,t){return e.steps.find(r=>r.status!=="failed"&&r.status!=="success"&&r.id!==t.id)||null}o(Lt,"getNextStep");var Ot=o((e,t)=>{let r=e.wallets[t.evmTransaction?.blockChain||""]||e.wallets[t.evmApprovalTransaction?.blockChain||""]||e.wallets[t.tronTransaction?.blockChain||""]||e.wallets[t.tronApprovalTransaction?.blockChain||""]||e.wallets[t.starknetTransaction?.blockChain||""]||e.wallets[t.starknetApprovalTransaction?.blockChain||""]||e.wallets[t.cosmosTransaction?.blockChain||""]||e.wallets[t.solanaTransaction?.blockChain||""]||e.wallets[t.tonTransaction?.blockChain||""]||e.wallets[t.suiTransaction?.blockChain||""]||e.wallets[t.xrplTransaction?.blockChain||""]||e.wallets[t.stellarTransaction?.blockChain||""]||(t.transferTransaction?.fromWalletAddress?{address:t.transferTransaction.fromWalletAddress,walletType:Object.values(e.wallets).find(n=>n.address===t.transferTransaction?.fromWalletAddress)?.walletType}:null)||null;if(r==null)throw D.WalletMissing();return r},"getCurrentWalletTypeAndAddress"),re=o((e,t)=>Ot(e,t).address,"getCurrentAddressOf");function W(e,t){let{address:r,walletType:n}=Ot(e,t),a=Object.keys(e.wallets).map(c=>({k:c,v:e.wallets[c]})).find(({v:c})=>c.address===r&&c.walletType===n)||null,s=a?.k||null,u=a?.v||null,i=u?.walletType;if(u===null)throw D.AssertionFailed(`Wallet for source ${s} not passed: walletType: ${i}`);return u}o(W,"getRelatedWallet");function je(e,t){if(!t)return null;try{return W(e,t)}catch(r){return console.log({e:r}),null}}o(je,"getRelatedWalletOrNull");var Ut=o((e,t,r,n)=>n?.find(s=>s.blockchain===e&&s.symbol?.toUpperCase()===t?.toUpperCase()&&s.address===r)?.usdPrice||null,"getUsdPrice");function Dr(e,t){let r=new vt(0);for(let n=0;n<e.fee.length;n++){let a=e.fee[n];if(a.expenseType==="DECREASE_FROM_OUTPUT")continue;let s=Ut(a.asset.blockchain,a.asset.symbol,a.asset.address,t);r=r.plus(new vt(a.amount).multipliedBy(s||0))}return r}o(Dr,"getUsdFeeOfStep");function Pt(e,t){return{fromBlockchain:e.from.blockchain,fromBlockchainLogo:e.from.blockchainLogo,fromLogo:e.from.logo,fromSymbol:e.from.symbol,fromSymbolAddress:e.from.address,fromDecimals:e.from.decimals,fromAmountPrecision:e.fromAmountPrecision,fromAmountMinValue:e.fromAmountMinValue,fromAmountMaxValue:e.fromAmountMaxValue,fromAmountRestrictionType:e.fromAmountRestrictionType,fromUsdPrice:e.from.usdPrice,toBlockchain:e.to.blockchain,toBlockchainLogo:e.to.blockchainLogo,toSymbol:e.to.symbol,toSymbolAddress:e.to.address,toDecimals:e.to.decimals,toLogo:e.to.logo,toUsdPrice:e.to.usdPrice,swapperId:e.swapperId,swapperLogo:e.swapperLogo,swapperType:e.swapperType,expectedOutputAmountHumanReadable:e.toAmount,feeInUsd:t?Nt(Dr(e,t?.tokens),null,8):null,estimatedTimeInSeconds:e.estimatedTimeInSeconds||null,internalSteps:null}}o(Pt,"mapSwapStepToPendingSwapStep");function Wr(e){let{inputAmount:t,bestRoute:r,wallets:n,settings:a,validateBalanceOrFee:s,meta:u,swapMode:i="swap"}=e,c=r.result;if(!c)throw Error("Simulation result should not be null");return{creationTime:new Date().getTime().toString(),finishTime:null,requestId:r.requestId||"",inputAmount:t,wallets:n,status:"running",mode:i,isPaused:!1,extraMessage:null,extraMessageSeverity:null,extraMessageDetail:null,extraMessageErrorCode:null,networkStatusExtraMessage:null,networkStatusExtraMessageDetail:null,lastNotificationTime:null,settings:a,simulationResult:c,validateBalanceOrFee:s,steps:r.result?.swaps?.map((p,l)=>{let T=Pt(p,u);return{id:l+1,...T,internalSwaps:p?.internalSwaps?.map(d=>Pt(d,u))||null,outputAmount:"",prerequisiteResults:[],status:"created",networkStatus:null,startTransactionTime:new Date().getTime(),externalTransactionId:null,executedTransactionId:null,executedTransactionTime:null,explorerUrl:null,diagnosisUrl:null,trackingCode:null,internalSteps:null,evmTransaction:null,evmApprovalTransaction:null,starknetTransaction:null,starknetApprovalTransaction:null,tronTransaction:null,tronApprovalTransaction:null,cosmosTransaction:null,solanaTransaction:null,transferTransaction:null,tonTransaction:null,suiTransaction:null,xrplTransaction:null,stellarTransaction:null,hyperliquidTransaction:null,hasAlreadyProceededToSign:!1}})||[]}}o(Wr,"calculatePendingSwap");function Dt(e){return e.map(t=>{let{diagnosisUrl:r,estimatedTimeInSeconds:n,explorerUrl:a,feeInUsd:s,executedTransactionId:u,executedTransactionTime:i,expectedOutputAmountHumanReadable:c,fromBlockchain:p,toBlockchain:l,fromSymbol:T,toSymbol:d,fromSymbolAddress:S,toSymbolAddress:m,swapperType:w,swapperId:y,outputAmount:h,fromAmountMaxValue:E,fromAmountMinValue:x,fromAmountPrecision:f,fromAmountRestrictionType:R,fromDecimals:C,status:_}=t;return{diagnosisUrl:r,estimatedTimeInSeconds:n,explorerUrl:a,feeInUsd:s,executedTransactionId:u,executedTransactionTime:i,expectedOutputAmountHumanReadable:c,fromBlockchain:p,toBlockchain:l,fromSymbol:T,toSymbol:d,fromSymbolAddress:S,toSymbolAddress:m,swapperName:y,swapperType:w,outputAmount:h,fromAmountMaxValue:E,fromAmountMinValue:x,fromAmountPrecision:f,fromAmountRestrictionType:R,fromDecimals:C,status:_,transaction:N(t)}})}o(Dt,"createSteps");function br(e,t,r){let{creationTime:n,finishTime:a,requestId:s,inputAmount:u,status:i,wallets:c,steps:p,settings:l}=e,T=Dt(p),S={route:{creationTime:n,finishTime:a,requestId:s,inputAmount:u,status:i,wallets:c,steps:T,slippage:l.slippage,infiniteApproval:l.infiniteApprove},step:T[T.length-1]};if(r)S.step=Dt([r])[0];else if(t==="failed"){let m=Wt(T);m&&(S.step=m)}else{let m=ne(T);m&&(S.step=m)}return S}o(br,"getEventPayload");function qr(e,t,r){let n,{type:a}=e;switch(a){case"started":n={...e,type:"started"};break;case"failed":n={...e,type:"failed",inputAmount:r.inputAmount,inputAmountUsd:Je(r),swapMode:r.mode||"swap"};break;case"succeeded":{n={...e,type:"succeeded",inputAmount:r.inputAmount,inputAmountUsd:Je(r),outputAmount:r.steps[r.steps.length-1].outputAmount??"",outputAmountUsd:bt(r),swapMode:r.mode||"swap"};break}default:break}n&&Z("emitter")?.emit("routeEvent",{event:n,route:t})}o(qr,"emitRouteEvent");function Fr(e,t,r){Z("emitter")?.emit("stepEvent",{event:e,route:t,step:r})}o(Fr,"emitStepEvent");function A(e){let{event:t}=e,{type:r}=t,{route:n,step:a}=br(e.swap,r,e.step??void 0),s=`${a.fromBlockchain}.${a.fromSymbol}`,u=`${a.toBlockchain}.${a.toSymbol}`,i=a.outputAmount??"",c=e.step?F(e.swap,e.step):null,p="",l="info";switch(r){case"started":p="Swap process started",l="success";break;case"succeeded":p=`You received ${i} ${u}, hooray!`,l="success";break;case"failed":p=`Swap failed: ${e.swap?.extraMessage??"Reason is unknown"}`,l="error";break;case"tx_execution":t.status==="create_tx"?(p="Please wait while the transaction is created ...",l="info"):t.status==="send_tx"?(e.step&&M(e.step)?p=`Please confirm '${a.swapperName}' smart contract access to ${s}`:p="Please confirm transaction request in your wallet",l="warning"):t.status==="tx_sent"&&(p="Transaction sent successfully",l="info");break;case"check_status":e.step&&M(e.step)?p="Checking approve transaction status ...":p="Checking transaction status ...",l="info";break;case"approval_tx_succeeded":p="Smart contract called successfully",l="success";break;case"output_revealed":p="Transaction output amount revealed",l="success";break;case"tx_execution_blocked":t.status==="waiting_for_wallet_connect"?(p="Please connect your wallet.",l="warning"):t.status==="waiting_for_queue"?(p="Waiting for other swaps to complete",l="warning"):t.status==="waiting_for_change_wallet_account"?(p="Please change your wallet account.",l="warning"):t.status==="waiting_for_network_change"&&(p=`Please change your wallet network to ${c?.network}.`,l="warning");break;default:break}e.step&&Fr({...t,message:p,messageSeverity:l},n,a),(e.event.type==="failed"||!e.step)&&qr({...t,message:p,messageSeverity:l},n,e.swap)}o(A,"notifier");var ze=null;function he(){return{claimedBy:()=>ze?.id,setClaimer:e=>{ze={id:e}},reset:()=>{ze=null}}}o(he,"claimQueue");var z={};function Ne(){return{getTransactionDataByHash:e=>z[e]||{},setTransactionDataByHash:(e,t)=>{z[e]||(z[e]={}),z[e].response=t.response||z[e].response,z[e].receiptReceived=t.receiptReceived||z[e].receiptReceived||!1}}}o(Ne,"inMemoryTransactionsData");var g=o(e=>e.steps.find(t=>t.status!=="failed"&&t.status!=="success")||null,"getCurrentStep"),N=o(e=>{let{evmTransaction:t,evmApprovalTransaction:r,cosmosTransaction:n,solanaTransaction:a,transferTransaction:s,starknetApprovalTransaction:u,starknetTransaction:i,stellarTransaction:c,tronApprovalTransaction:p,tronTransaction:l,tonTransaction:T,suiTransaction:d,xrplTransaction:S}=e;return t||r||n||a||s||u||i||c||p||l||T||d||S},"getCurrentStepTx"),ke=o((e,t)=>{e.transferTransaction=null,e.cosmosTransaction=null,e.evmTransaction=null,e.solanaTransaction=null,e.evmApprovalTransaction=null,e.starknetApprovalTransaction=null,e.starknetTransaction=null,e.tronApprovalTransaction=null,e.tronTransaction=null,e.tonTransaction=null,e.suiTransaction=null,e.xrplTransaction=null,e.stellarTransaction=null;let r=t.type;switch(r){case k.EVM:t.isApprovalTx?e.evmApprovalTransaction=t:e.evmTransaction=t;break;case k.TRON:t.isApprovalTx?e.tronApprovalTransaction=t:e.tronTransaction=t;break;case k.STARKNET:t.isApprovalTx?e.starknetApprovalTransaction=t:e.starknetTransaction=t;break;case k.COSMOS:e.cosmosTransaction=t;break;case k.SOLANA:e.solanaTransaction=t;break;case k.TRANSFER:e.transferTransaction=t;break;case k.TON:e.tonTransaction=t;break;case k.SUI:e.suiTransaction=t;break;case k.XRPL:e.xrplTransaction=t;break;case k.STELLAR:e.stellarTransaction=t;break;case k.HYPERLIQUID:e.hyperliquidTransaction=t;break;default:(n=>{throw new Error(`${n} was unhandled!`)})(r)}return e},"setCurrentStepTx"),et=o(e=>N(e)?.type,"getCurrentStepTxType"),M=o(e=>{let{evmApprovalTransaction:t,starknetApprovalTransaction:r,tronApprovalTransaction:n}=e;return!!(t||r||n)},"isApprovalCurrentStepTx");function O({getStorage:e,setStorage:t,nextStatus:r,nextStepStatus:n,message:a,details:s,errorCode:u=null,hasAlreadyProceededToSign:i,trace:c=null}){let p=e().swapDetails,l=g(p),T={swap:p,step:l};if(n&&l&&(l.status=n),r&&(p.status=r),p.hasAlreadyProceededToSign=i,r&&["failed","success"].includes(r)&&(p.finishTime=new Date().getTime().toString()),(a||s)&&(p.extraMessage=a||"",p.extraMessageDetail=s||""),n&&["failed"].includes(n)){let d=s&&s.includes("Warning")?"Swap canceled by user.":s,S=je(p,l)?.walletType;p.extraMessageSeverity="error";let m=It(u);T.failureType=m;let w=u!=="REJECTED_BY_USER"&&c?.message&&typeof c.message=="string"?c.message:d||"";Y().reportFailure({requestId:p.requestId,step:l?.id||1,eventType:m,reason:w,tags:S?{wallet:S}:void 0}).then().catch()}else n&&["running"].includes(n)?p.extraMessageSeverity="info":n&&["success","approved"].includes(n)?p.extraMessageSeverity="success":n&&["waitingForApproval"].includes(n)&&(p.extraMessageSeverity="warning");return n==="running"&&l&&(l.startTransactionTime=new Date().getTime()),t({...e(),swapDetails:p}),T}o(O,"updateSwapStatus");function Kr({getStorage:e,setStorage:t},r,n){let a=e().swapDetails;a.hasAlreadyProceededToSign=null;let s=g(a);s.executedTransactionId=r,s.executedTransactionTime=new Date().getTime().toString(),n?.url&&(s.explorerUrl=[...s.explorerUrl||[],{url:n.url,description:n.description||null}]),M(s)?a.extraMessage="Checking approve transaction status ...":a.extraMessage="Checking transaction status ...",a.extraMessageDetail="",a.extraMessageSeverity="info",t({...e(),swapDetails:a}),A({event:{type:"tx_execution",status:"tx_sent"},swap:a,step:s}),A({event:{type:"check_status"},swap:a,step:s})}o(Kr,"setStepTransactionIds");function Vr({getStorage:e,setStorage:t},r,n){let a=e().swapDetails,s=g(a);if(!s)return;let u=new Date;a.lastNotificationTime=u.getTime().toString(),!(s.networkStatus===ae.WaitingForConnectingWallet&&a.networkStatusExtraMessage===r&&a.networkStatusExtraMessageDetail===n)&&(s.networkStatus=ae.WaitingForConnectingWallet,a.networkStatusExtraMessage=r,a.networkStatusExtraMessageDetail=n,t({...e(),swapDetails:a}))}o(Vr,"markRunningSwapAsWaitingForConnectingWallet");function qt({getStorage:e,setStorage:t}){let r=e().swapDetails,n=g(r);if(!n)return;let{type:a}=b(r),s=G(r,n),u=`Change ${a} wallet network to ${s.network}`,i=`We\u2019re switching the connected network to ${s.network}. Please check your wallet.`,c=new Date;return r.lastNotificationTime=c.getTime().toString(),n.networkStatus=ae.WaitingForNetworkChange,r.networkStatusExtraMessage=u,r.networkStatusExtraMessageDetail=i,t({...e(),swapDetails:r}),{swap:r,step:n}}o(qt,"markRunningSwapAsSwitchingNetwork");function Ft({getStorage:e,setStorage:t}){let r=e().swapDetails,n=g(r);if(n)return r.networkStatusExtraMessage="",r.networkStatusExtraMessageDetail="",n.networkStatus=ae.WaitingForQueue,A({event:{type:"tx_execution_blocked",status:"waiting_for_queue"},swap:r,step:n}),t({...e(),swapDetails:r}),{swap:r,step:n}}o(Ft,"markRunningSwapAsDependsOnOtherQueues");async function se(e){return new Promise(t=>setTimeout(t,e))}o(se,"delay");var $r=o((e,t)=>e.wallets[t]?.walletType,"getSwapWalletType");function tt(e){return e===null||e?.blockchains===null||e?.blockchains.length===0}o(tt,"isWalletNull");function b(e){let t=g(e),r=F(e,t);if(!r)return{type:null,namespace:null,address:null};let n=$r(e,r.network),a=e.wallets[r.network];return{type:n||null,namespace:r,address:a?a.address:null}}o(b,"getRequiredWallet");async function Yr(e){try{return await e.request({method:"eth_chainId"})||e?.chainId}catch{return e?.chainId}}o(Yr,"getChainId");async function jr(e,t,r){let n=Qr(e,r);if(n)return await Yr(n);let s=t(r).get("evm");if(!s)throw new Error("EVM namespace not found for wallet type: "+r);return s.getChainId()}o(jr,"getProviderChainId");async function Mt(e,t,r,n,a,s){if(tt(r))return!1;let u=F(e,t);if(!u)return!1;if(n.evmBasedChains.find(i=>i.name===u.network)){try{let i=e.wallets[u.network];if(i){let c=await jr(a,s,i.walletType);if(c){let p=Xr(c,Object.entries(n.blockchains).map(([,l])=>l));if(p&&p.toLowerCase()===u.network.toLowerCase())return!0;if(p&&p.toLowerCase()!==u.network.toLowerCase())return!1}}}catch(i){console.log(i)}return!1}return!0}o(Mt,"isNetworkMatchedForTransaction");var Bt=o((e,t)=>(e.wallets[t.evmTransaction?.blockChain||""]||e.wallets[t.evmApprovalTransaction?.blockChain||""]||e.wallets[t.tronTransaction?.blockChain||""]||e.wallets[t.tronApprovalTransaction?.blockChain||""]||e.wallets[t.starknetTransaction?.blockChain||""]||e.wallets[t.starknetApprovalTransaction?.blockChain||""]||e.wallets[t.cosmosTransaction?.blockChain||""]||e.wallets[t.solanaTransaction?.blockChain||""]||e.wallets[t.tonTransaction?.blockChain||""]||e.wallets[t.suiTransaction?.blockChain||""]||e.wallets[t.stellarTransaction?.blockChain||""]||e.wallets[t.xrplTransaction?.blockChain||""]||t.transferTransaction?.fromWalletAddress||null)!==null,"isTxAlreadyCreated");function Ie(e){let{getStorage:t,setStorage:r}=e,n=t().swapDetails,a=g(n);a?.networkStatus&&(a.networkStatus=null,r({...t(),swapDetails:n}))}o(Ie,"resetNetworkStatus");function rt(e,t={message:"",details:"",status:null}){let{message:r,details:n,status:a}=t,{getStorage:s,setStorage:u}=e,i=s().swapDetails,c=g(i);c?.networkStatus&&(i.networkStatusExtraMessage=r,i.networkStatusExtraMessageDetail=n,c.networkStatus=a,u({...s(),swapDetails:i}))}o(rt,"updateNetworkStatus");function Xt(e,t){let{context:r,queue:n}=t,a=n.getStorage().swapDetails,{ok:s,reason:u}=nt(a,r.state);if(!s){let i=g(a),{type:c,address:p}=b(a);A({event:{type:"tx_execution_blocked",...u==="account_miss_match"?{status:"waiting_for_change_wallet_account",requiredAccount:p??void 0}:{status:"waiting_for_wallet_connect",requiredWallet:c??void 0,requiredAccount:p??void 0}},swap:a,step:i}),Vr({getStorage:n.getStorage.bind(n),setStorage:n.setStorage.bind(n)},_t,e.reason.description);return}n.unblock()}o(Xt,"onBlockForConnectWallet");function Qt(e,t){let{context:r,queue:n}=t,a=n.getStorage().swapDetails,s=g(a);if(!s||a.status!=="running")return;let u=qt({getStorage:n.getStorage.bind(n),setStorage:n.setStorage.bind(n)}),i=F(a,s)?.network,c=b(a).type,p=c?r.state(c).network:void 0;u&&A({event:{type:"tx_execution_blocked",status:"waiting_for_network_change",requiredNetwork:i??void 0,currentNetwork:p??void 0},swap:u.swap,step:u.step});let{type:l,namespace:T}=b(a);if(l&&T?.network&&r.canSwitchNetworkTo(l,T.network,T)){let d=r.switchNetwork(l,T);d&&d.then(()=>{n.unblock()}).catch(S=>{rt({getStorage:n.getStorage.bind(n),setStorage:n.setStorage.bind(n)},{message:S.message,details:S.message,status:ae.NetworkChangeFailed})})}}o(Qt,"onBlockForChangeNetwork");function Ht(e,t){let{getBlockedTasks:r,forceExecute:n,queue:a,manager:s,context:u}=t,{setClaimer:i,claimedBy:c,reset:p}=he(),l=r().filter(E=>E.reason.reason==="depends_on_other_queues");if(l.length===0)return;let T=c(),d=!!T;if(T===a.id)return;if(d){Ft({getStorage:a.getStorage.bind(a),setStorage:a.setStorage.bind(a)});return}let S=l.find(E=>E.queue_id===t.queue_id);S||(S=l[0]),i(S.queue_id);let m=S.storage.get(),{type:w,namespace:y,address:h}=b(m.swapDetails);n(S.queue_id,{claimedBy:c(),resetClaimedBy:()=>{p(),w&&st({walletType:w,network:y?.network,accounts:h?[h]:[]},s,u.canSwitchNetworkTo)}})}o(Ht,"onDependsOnOtherQueues");function nt(e,t){let{type:r,address:n}=b(e);if(!r||!n)return{ok:!1,reason:"not_connected"};let a=t(r),{accounts:s,connected:u}=a,i=s||[];return u?{ok:i.some(p=>{let{address:l}=Br(p);return n.toLocaleLowerCase()===l.toLocaleLowerCase()}),reason:"account_miss_match"}:{ok:!1,reason:"not_connected"}}o(nt,"isRequiredWalletConnected");function K(e,t){let{getStorage:r,setStorage:n}=e,a=r().swapDetails,s=g(a),u=s.prerequisiteResults.findIndex(i=>$e(i,t));u>=0?s.prerequisiteResults[u]=t:s.prerequisiteResults.push(t),n({...r(),swapDetails:a})}o(K,"updateStorageWithPrerequisiteResult");function Jr(e,t,r){let{setTransactionDataByHash:n}=Ne(),{getStorage:a,context:s}=e,{meta:u}=s,i=a().swapDetails,c=g(i),p=G(i,c),l=pe(t.hash,p.network,u.blockchains);Kr(e,t.hash,l&&(!t.response||t.response&&!t.response.hashRequiringUpdate)?{url:l,description:r.isApproval?"Approve":"Swap"}:void 0),t.response&&n(t.hash,{response:t.response})}o(Jr,"updateStorageOnSuccessfulSign");function oe(e,t){return({hash:r,response:n})=>{let{schedule:a,next:s}=e;Jr(e,{hash:r,response:n},t),a("CHECK_TRANSACTION_STATUS"),s()}}o(oe,"handleSuccessfulSign");function q(e){return t=>{let{getStorage:r,setStorage:n,failed:a}=e,s=r().swapDetails,u=g(s);if(s.status==="failed")return;let i=W(s,u),{extraMessage:c,extraMessageDetail:p,extraMessageErrorCode:l}=j(t);Mr(t,{tags:{requestId:s.requestId,rpc:!0,swapper:u?.swapperId||"",walletType:i?.walletType||""},context:Gr.isSignerError(t)?t.getErrorContext():{}});let T=O({getStorage:r,setStorage:n,nextStatus:"failed",nextStepStatus:"failed",message:c,details:p,errorCode:l,trace:t?.cause});A({event:{type:"failed",reason:c,reasonCode:T.failureType??L,inputAmount:B(s),inputAmountUsd:V(s)},...T}),a()}}o(q,"handleRejectedSign");function Gt(e){let{lastConnectedWallet:t,evmChains:r,manager:n}=e,{walletType:a,network:s}=t;r.some(u=>u.name==s)&&n?.getAll().forEach(u=>{let i=u.list.getStorage(),c=i?.swapDetails;if(c&&c.status==="running"){let p=g(c);if(p){let l=i?.swapDetails.wallets[p.fromBlockchain]?.walletType,T=Object.keys(u.list.state.tasks).some(S=>{let m=u.list.state.tasks[S];return m.status===Ze.BLOCKED&&["waiting_for_connecting_wallet"].includes(m.blockedFor?.reason)}),d=F(c,p)?.network;if(!r.some(S=>S.name==d))return;if(l===a&&T&&d!=s){let S=u.list,{type:m}=b(c),w=Ae(m);u.list.block({reason:{reason:"waiting_for_network_change",description:w},silent:!0});let y=qt({getStorage:S.getStorage.bind(S),setStorage:S.setStorage.bind(S)});y&&A({event:{type:"tx_execution_blocked",status:"waiting_for_network_change",currentNetwork:s,requiredNetwork:d??void 0},swap:y.swap,step:y.step})}}}})}o(Gt,"checkWaitingForConnectWalletChange");function at(e){e?.getAll().forEach(t=>{if(Object.keys(t.list.state.tasks).some(n=>{let a=t.list.state.tasks[n];return a.status===Ze.BLOCKED&&["waiting_for_network_change","depends_on_other_queues"].includes(a.blockedFor?.reason)})){let n=t.list.getStorage()?.swapDetails;if(n.status==="running"){let{type:a}=b(n),s=$(a);t.list.block({reason:{reason:"waiting_for_connecting_wallet",description:s}})}}})}o(at,"checkWaitingForNetworkChange");function zr(e){let t=e?.getAll()||new Map,r=[];return t.forEach(n=>{let s=n.list.getStorage()?.swapDetails;!s||s.status!=="running"||r.push(s)}),r}o(zr,"getRunningSwaps");function Zr(e){e.forEach(t=>{let r=g(t),n="tx_execution_blocked",a;r?.networkStatus===ae.WaitingForQueue?a="waiting_for_queue":t?.status==="running"&&(a="waiting_for_wallet_connect"),n&&A&&A({event:{type:n,status:a??"waiting_for_queue"},swap:t,step:r})})}o(Zr,"resetRunningSwapNotifsOnPageLoad");function st(e,t,r,n={fallbackToOnlyWallet:!0}){let{walletType:a,network:s}=e;if(!a)return;let u=[],i=[];t?.getAll().forEach(p=>{if(p.status===Ze.BLOCKED){let l=p.list.getStorage(),T=l?.swapDetails;if(T&&T.status==="running"){let d=g(T);d&&(s&&F(T,d)?.network==s&&l?.swapDetails.wallets[s]?.walletType===a?u.push(p.list):l?.swapDetails.wallets[d.fromBlockchain]?.walletType===a&&i.push(p.list))}}});let c;if(u.length>0){if(c=u[0],u.length>1)for(let p=1;p<u.length;p++){let l=u[p];Ft({getStorage:l.getStorage.bind(l),setStorage:l.setStorage.bind(l)})}}else i.length>0&&n.fallbackToOnlyWallet&&(c=i[0]);if(c){let p=c.getStorage(),l=g(p?.swapDetails),T=l?F(p.swapDetails,l):null;!s||!T||!r?.(a,s,T)?c.unblock():c.checkBlock()}}o(st,"retryOn");function Kt(e){return!!e.evmTransaction||!!e.evmApprovalTransaction}o(Kt,"isNeedBlockQueueForParallel");async function Vt(e){let t=await e;if(!t.ok||!t.transaction)throw D.CreateTransaction(t.error||"bad response from create tx endpoint");return t}o(Vt,"throwOnOK");function en(e,t){let{reset:r}=he();e.actions.cancel();let n=O({getStorage:e.actions.getStorage,setStorage:e.actions.setStorage,message:"Swap canceled by user.",details:"Warning: If you've already signed and sent a transaction, it won't be affected, but next swap steps will not be executed.",nextStatus:"failed",nextStepStatus:"failed",errorCode:"USER_CANCEL"});return A({event:{type:"failed",reasonCode:"USER_CANCEL",reason:n.swap.extraMessage??void 0,inputAmount:B(n.swap),inputAmountUsd:V(n.swap)},swap:n.swap,step:n.step}),r(),t&&t?.retry(),n}o(en,"cancelSwap");function ne(e){return e.slice().reverse().find(t=>t.status==="success")}o(ne,"getLastSuccessfulStep");function Wt(e){return e.slice().reverse().find(t=>t.status==="failed")}o(Wt,"getFailedStep");function tn(e){let{transaction:t}=e;return t?.type===k.EVM&&t.isApprovalTx||t?.type===k.STARKNET&&t.isApprovalTx||t?.type===k.TRON&&t.isApprovalTx}o(tn,"isApprovalTX");function ve(e,t){let r=new Hr(e).multipliedBy(t);return isNaN(r.toNumber())?"":r.toString()}o(ve,"getTokenAmountInUsd");function Je(e){return ve(e.inputAmount,e.steps[0].fromUsdPrice??"")}o(Je,"getSwapInputUsd");function bt(e){let t=e.steps[e.steps.length-1];return ve(t.outputAmount??"",t.toUsdPrice??"")}o(bt,"getSwapOutputUsd");function $t(e){let t=["success","failed"],r=e.steps.findLastIndex(n=>t.includes(n.status));return r<0?void 0:{step:e.steps[r],index:r}}o($t,"getLastFinishedStep");function B(e){let t=$t(e);return t?t.index===0?e.inputAmount:e.steps[t.index-1].outputAmount??"":""}o(B,"getLastFinishedStepInput");function V(e){let t=$t(e);return ve(B(e),t?.step?.fromUsdPrice??"")}o(V,"getLastFinishedStepInputUsd");function Pe(e){let t=ne(e.steps);return ve(t?.outputAmount??"",t?.toUsdPrice??"")}o(Pe,"getLastSuccessfulStepOutputUsd");function ie(e,t,r){return{type:"failed",reason:t,reasonCode:r??L,inputAmount:B(e),inputAmountUsd:V(e)}}o(ie,"createStepFailedEvent");import{Err as Yt,Ok as jt}from"ts-results";function ue(e){let{getStorage:t,context:r}=e,{isMobileWallet:n}=r,a=t().swapDetails,s=g(a),u=W(a,s),i=n(u?.walletType),c=N(s),p=M(s);if(!c||!c.type)return new Yt({nextStatus:"failed",nextStepStatus:"failed",message:"Unexpected Error: tx is null!",details:void 0,errorCode:"CLIENT_UNEXPECTED_BEHAVIOUR"});let l=!!a.hasAlreadyProceededToSign;return p?new jt({nextStatus:void 0,nextStepStatus:"waitingForApproval",details:"Waiting for approve transaction to be mined and confirmed successfully",message:`Waiting for approval of ${s?.fromSymbol} coin ${i?"on your mobile phone!":""}`}):l?new Yt({message:"Transaction is expired. Please try again.",nextStepStatus:"failed",nextStatus:"failed",details:"",errorCode:"TX_EXPIRED"}):new jt({message:"Executing transaction ...",nextStepStatus:"running",nextStatus:"running",details:`${i?"Check your mobile phone!":""}`})}o(ue,"produceNextStateForTransaction");function I(e,t){let{getStorage:r,setStorage:n}=e,a=r().swapDetails,s=g(a),u=M(s),i=typeof a.hasAlreadyProceededToSign=="boolean",c=O({getStorage:r,setStorage:n,nextStepStatus:t.nextStepStatus,nextStatus:t.nextStatus,message:t.message,details:t.details,errorCode:t.errorCode,hasAlreadyProceededToSign:u?void 0:i});A({event:{type:"failed",reason:t.message,reasonCode:c.failureType??L,inputAmount:B(a),inputAmountUsd:V(a)},...c})}o(I,"onNextStateError");function le(e,t){let{getStorage:r,setStorage:n}=e,a=r().swapDetails,s=g(a),u=M(s),i=typeof a.hasAlreadyProceededToSign=="boolean",c=O({getStorage:r,setStorage:n,nextStepStatus:t.nextStepStatus,nextStatus:t.nextStatus,message:t.message,details:t.details,hasAlreadyProceededToSign:u?void 0:i});A({event:{type:"tx_execution",status:"send_tx"},...c})}o(le,"onNextStateOk");async function it(e){let{failed:t,schedule:r,getStorage:n,next:a}=e,s=o(()=>{e.context.resetClaimedBy&&e.context.resetClaimedBy()},"onFinish"),u=o(m=>{I(e,m.val),t(),s()},"handleErr"),i=o(m=>{r(m),a(),s()},"scheduleAction"),c=n().swapDetails,p=g(c),l=N(p);if(!l){u(new ot({nextStatus:"failed",nextStepStatus:"failed",message:"Unexpected Error: tx is null!",details:void 0,errorCode:"CLIENT_UNEXPECTED_BEHAVIOUR"}));return}let T=l.prerequisites,d=T.findIndex((m,w)=>!At({prerequisiteType:m.type,prerequisiteIndex:w},p)),S=null;if(d!==-1)switch(T[d].type){case an:S=Ct(d,p);break;case nn:S=Rt(d,p);break;default:S=new ot("Unexpected Error: unknown prerequisite type!");break}else p.fromBlockchain===rn.XRPL?S=new Jt("EXECUTE_XRPL_TRANSACTION"):S=new Jt("EXECUTE_TRANSACTION");S?.err?u(new ot({nextStatus:"failed",nextStepStatus:"failed",message:S.val,details:void 0,errorCode:"CLIENT_UNEXPECTED_BEHAVIOUR"})):i(S.val)}o(it,"checkPrerequisites");import{warn as ce}from"@rango-dev/logging-core";import{SignerError as Zt}from"rango-types";var zt=5e3,sn=5e3;async function on({getStorage:e,setStorage:t,next:r,schedule:n,retry:a,failed:s,context:u}){let i=e().swapDetails,{meta:c}=u,p=new Error("check status Error"),l=g(i);if(!l?.executedTransactionId)return;let T=N(l),d=l.executedTransactionId,S=!1,m=null,w=null,{getTransactionDataByHash:y,setTransactionDataByHash:h}=Ne();try{let C=et(l),_=W(i,l);C&&_&&(w=(await u.getSigners(_.walletType)).getSigner(C))}catch{}try{let{response:C,receiptReceived:_}=y(d);if(w?.wait&&!_){let v=T?.blockChain&&c.blockchains?.[T?.blockChain]?.chainId||void 0,{hash:P,response:we}=await w.wait(d,v,C);if(P!==d){l.executedTransactionId=P||l.executedTransactionId;let xe=G(i,l),Be;!!Object.keys(c.blockchains).length&&(Be=pe(l.executedTransactionId,xe.network,c.blockchains)),Be&&l.explorerUrl&&l.explorerUrl?.length>=1&&(l.explorerUrl[l.explorerUrl.length-1]={url:Be,description:"Replaced Swap"}),d=l.executedTransactionId,P&&we&&h(P,{response:we})}else h(P,{receiptReceived:!0})}}catch(C){let{extraMessage:_,extraMessageDetail:v,extraMessageErrorCode:P}=j(C),we=O({getStorage:e,setStorage:t,nextStatus:"failed",nextStepStatus:"failed",message:_,details:v,errorCode:P}),xe=ie(i,_,we.failureType);ce(p,{tags:{type:"singer-error",reason:xe.reason,reasonCode:xe.reasonCode,message:_,messageDetail:v,pendingSwap:i},context:Zt.isSignerError(C)?C.getErrorContext():{}}),S=!0}let E={requestId:i.requestId,txId:d,step:l.id};try{m=await Y().checkStatus(E)}catch{await se(zt),a(),ce(p,{tags:{type:"request-error",requestBody:E,pendingSwap:i}});return}if(S)return s();if(l?.status==="failed")return;let x=m?.outputAmount||(l.outputAmount?l.outputAmount:null),f=l.outputAmount||null;i.extraMessage=m?.extraMessage||i.extraMessage,i.extraMessageSeverity="info",i.extraMessageDetail="",l.status=m?.status||l.status,l.diagnosisUrl=m?.diagnosisUrl||l.diagnosisUrl||null,l.outputAmount=x||l.outputAmount,l.explorerUrl=m?.explorerUrl||l.explorerUrl,l.internalSteps=m?.steps||null;let R=m?.newTx;if(R&&(l.status="created",l.executedTransactionId=null,l.executedTransactionTime=null,ke(l,R)),f===null&&x!==null?A({event:{type:"output_revealed",outputAmount:x},swap:i,step:l}):f===null&&x===null&&A({event:{type:"check_status"},swap:i,step:l}),l.status==="success"){let C=Lt(i,l);i.extraMessageDetail="",i.extraMessage=C?`starting next step: ${C.swapperId}: ${C.fromBlockchain} -> ${C.toBlockchain}`:"",A({event:{type:"succeeded",inputAmount:B(i),inputAmountUsd:V(i),outputAmount:l.outputAmount??"",outputAmountUsd:Pe(i)},swap:i,step:l})}else l.status==="failed"&&(i.extraMessage="Transaction failed in blockchain",i.extraMessageSeverity="error",i.extraMessageDetail=m?.extraMessage||"",i.status="failed",i.finishTime=new Date().getTime().toString(),ce(p,{tags:{type:"transaction-failed",message:i.extraMessage,messageDetails:i.extraMessageDetail,pendingSwap:i}}));t({...e(),swapDetails:i}),m?.status==="failed"?s():m?.status==="success"||m?.status==="running"&&m.newTx?(n("SCHEDULE_NEXT_STEP"),r()):(await se(zt),a())}o(on,"checkTransactionStatus");async function un({getStorage:e,setStorage:t,next:r,schedule:n,retry:a,failed:s,context:u}){let i=e().swapDetails,{meta:c}=u,{getTransactionDataByHash:p,setTransactionDataByHash:l}=Ne(),T=new Error("check approval status error"),d=g(i);if(!d){console.log("ignore check status, current step is null");return}let S=N(d);if(!d?.executedTransactionId)return;let m=d.executedTransactionId,w=null;try{let E=et(d),x=W(i,d);E&&x&&(w=(await u.getSigners(x.walletType)).getSigner(E))}catch{}try{let{response:E,receiptReceived:x}=p(m);if(w?.wait&&!x){let f=S?.blockChain&&c.blockchains?.[S?.blockChain]?.chainId||void 0,{hash:R,response:C}=await w.wait(m,f,E);if(R!==m){d.executedTransactionId=R||d.executedTransactionId;let _=G(i,d),v;!!Object.keys(c.blockchains).length&&(v=pe(d.executedTransactionId,_.network,c.blockchains)),v&&d.explorerUrl&&d.explorerUrl?.length>=1&&(d.explorerUrl[d.explorerUrl.length-1]={url:v,description:"Replaced Approve"}),m=d.executedTransactionId,R&&C&&l(R,{response:C})}else l(R,{receiptReceived:!0})}}catch(E){let{extraMessage:x,extraMessageDetail:f,extraMessageErrorCode:R}=j(E),C=O({getStorage:e,setStorage:t,nextStatus:"failed",nextStepStatus:"failed",message:x,details:f,errorCode:R}),_=ie(i,x,C.failureType);return A({event:_,...C}),ce(T,{tags:{type:"singer-error",reason:_.reason,reasonCode:_.reasonCode,message:x,messageDetail:f,pendingSwap:i},context:Zt.isSignerError(E)?E.getErrorContext():{}}),s()}let y=!1,h={requestId:i.requestId,txId:d.executedTransactionId};try{let E=await Y().checkApproval(h.requestId,h.txId);if(d?.status==="failed")return;if(y=E.isApproved,!y&&(E.txStatus==="failed"||E.txStatus==="success")){let x,f;E.txStatus==="failed"?(x="Approve transaction failed",f="Smart contract approval tx failed in blockchain."):(x="Not enough approval",E.requiredApprovedAmount&&E.currentApprovedAmount?f=`Required approval: ${E.requiredApprovedAmount}, current approval: ${E.currentApprovedAmount}`:f="You still don't have enough approval for this swap.");let R=O({getStorage:e,setStorage:t,nextStatus:"failed",nextStepStatus:"failed",errorCode:"INSUFFICIENT_APPROVE",message:x,details:f}),C=ie(i,x,R.failureType);A({event:C,...R}),ce(T,{tags:{type:"approval-failed",message:i.extraMessage,messageDetails:i.extraMessageDetail,pendingSwap:i}}),s()}else y||A({event:{type:"check_status"},swap:i,step:d})}catch{y=!1,ce(T,{tags:{type:"request-error",requestBody:h,pendingSwap:i}})}y?(d.status="approved",i.extraMessage=`Spending ${d.fromSymbol} approved successfully.`,i.extraMessageDetail=null,i.extraMessageSeverity="success",d.evmApprovalTransaction=null,d.executedTransactionId=null,d.executedTransactionTime=null,d.starknetApprovalTransaction=null,d.tronApprovalTransaction=null,t({...e(),swapDetails:i}),A({event:{type:"approval_tx_succeeded"},swap:i,step:d}),n("SCHEDULE_NEXT_STEP"),r()):(await se(sn),a())}o(un,"checkApprovalStatus");async function er(e){let t=e.getStorage().swapDetails,r=g(t);if(!r){console.log("ignore check status, current step is null",t.requestId);return}Ie(e),r.status==="running"?await on(e):r.status==="waitingForApproval"&&await un(e)}o(er,"checkStatus");import{STELLAR_CHANGE_TRUSTLINE_TYPE as We,TransactionType as pn}from"rango-types";import{Err as ar}from"ts-results";function Le(e){return e.claimedBy===e._queue?.id}o(Le,"isClaimedByCurrentQueue");function X(e,t){e.block(t),Le(e.context)&&e.context.resetClaimedBy&&e.context.resetClaimedBy()}o(X,"requestBlockQueue");import{legacyReadAccountAddress as ln}from"@rango-dev/wallets-core/legacy";import*as De from"@stellar/stellar-sdk";import tr from"bignumber.js";import{TransactionType as cn}from"rango-types";import{Err as Oe,Ok as Ue}from"ts-results";var ut="922337203685.4775807";async function de(e,t){let n=e.hubProvider(t).get("stellar");return n?Ue(n):new Oe({nextStatus:"failed",nextStepStatus:"failed",message:"Stellar is not available on your wallet.",details:void 0,errorCode:"CLIENT_UNEXPECTED_BEHAVIOUR"})}o(de,"ensureStellarNamespaceExists");async function rr(e,t,r){try{let a=(await r.namespace.balanceLines(e)).filter(i=>i.asset_type!=="native"&&i.asset_type!=="liquidity_pool_shares").find(i=>i.asset_code===t.code&&i.asset_issuer===t.issuer);if(!a)return new Ue({trustLineIsAlreadyOpened:!1});let s=new tr(a.limit),u=new tr(ut);return new Ue({trustLineIsAlreadyOpened:s.gte(u)})}catch{return new Oe({nextStatus:"failed",nextStepStatus:"failed",message:"Could not get account lines from Stellar.",details:void 0,errorCode:"CLIENT_UNEXPECTED_BEHAVIOUR"})}}o(rr,"checkIfTrustLineIsAlreadyOpened");function nr(e,t){let r=new De.Asset(t.code,t.issuer),n="100",a=30,s=Math.floor(Date.now()/1e3),u=De.Operation.changeTrust({asset:r,limit:ut});return{type:cn.STELLAR,blockChain:"Stellar",prerequisites:[],data:{baseFee:n,memoXdrBase64:null,preconditions:{timeBounds:{minTime:0,maxTime:s+a},ledgerBounds:{minLedger:0,maxLedger:0},minSeqNumber:null,minSeqAge:null,minSeqLedgerGap:null,extraSigners:null},operationsXdrBase64:[u.toXDR("base64")]}}}o(nr,"createTrustLineTransaction");function Se(e){let t=e.wallets.STELLAR;return t?{type:t.walletType,namespace:{namespace:"Stellar",network:"Stellar"},address:t.address}:null}o(Se,"getStellarWalletFromSwap");async function me(e,t){let{context:r}=e,n=r.state(t.type),{accounts:a,connected:s}=n;return s?a?.find(u=>ln(u).address===t.address)?new Ue(!0):new Oe({reason:"waiting_for_connecting_wallet",description:te(t.type,t.address)}):new Oe({reason:"waiting_for_connecting_wallet",description:$(t.type)})}o(me,"ensureRequiredStellarWalletIsConnected");async function lt(e){let{failed:t,context:r,schedule:n,getStorage:a,next:s}=e,{meta:u,getSigners:i}=r,c=o(()=>{e.context.resetClaimedBy&&e.context.resetClaimedBy()},"onFinish"),p=o(()=>{n("CHECK_PREREQUISITES"),s(),c()},"scheduleCheckPrerequisites"),l=o(f=>{I(e,f.val),t(),c()},"handleErr"),T=a().swapDetails,d=g(T),S=N(d);if(!S){l(new ar({nextStatus:"failed",nextStepStatus:"failed",message:"Unexpected Error: tx is null!",details:void 0,errorCode:"CLIENT_UNEXPECTED_BEHAVIOUR"}));return}let m=null;for(let f=0;f<S.prerequisites.length;f++){let R=S.prerequisites[f];if(R.type===We&&!d.prerequisiteResults.find(_=>_.prerequisiteIndex===f&&_.prerequisiteType===We)){m={prerequisite:R,prerequisiteIndex:f};break}}if(!m){p();return}let w=Se(T);if(!w){l(new ar({nextStatus:"failed",nextStepStatus:"failed",message:"Unexpected Error: Stellar wallet was not found in the swap!",details:void 0,errorCode:"CLIENT_UNEXPECTED_BEHAVIOUR"}));return}let y=await de(r,w.type);if(y.err){l(y);return}let h=await me(e,w);if(h.err){X(e,h.val);return}let E={code:m.prerequisite.code,issuer:m.prerequisite.issuer,value:m.prerequisite.value},x=await rr(m.prerequisite.wallet,E,{namespace:y.val});if(x.err){l(x);return}if(x.val.trustLineIsAlreadyOpened){let f={prerequisiteIndex:m.prerequisiteIndex,prerequisiteType:We,status:"skipped",data:null};K(e,f),p();return}try{let f=await nr(m.prerequisite.wallet,E),R=u.blockchains.Stellar?.chainId,v=await(await i(w.type)).getSigner(pn.STELLAR).signAndSendTx(f,w.address,R),P={prerequisiteIndex:m.prerequisiteIndex,prerequisiteType:We,status:"success",data:{executedTransactionHash:v.hash}};K(e,P),p()}catch(f){q(e)(f),c()}}o(lt,"checkStellarTrustline");import{TransactionType as mn,XRPL_CHANGE_TRUSTLINE_TYPE as Fe}from"rango-types";import{Err as ur}from"ts-results";import{legacyReadAccountAddress as dn}from"@rango-dev/wallets-core/legacy";import sr from"bignumber.js";import{TransactionType as Sn}from"rango-types";import{Err as be,Ok as qe}from"ts-results";var ct="10000000000000";async function Te(e,t){let n=e.hubProvider(t).get("xrpl");return n?qe(n):new be({nextStatus:"failed",nextStepStatus:"failed",message:"XRPL is not available on your wallet.",details:void 0,errorCode:"CLIENT_UNEXPECTED_BEHAVIOUR"})}o(Te,"ensureXrplNamespaceExists");async function or(e,t,r){try{let a=(await r.namespace.accountLines(e,{peer:t.account})).find(i=>i.currency===t.currency&&i.account===t.account);if(!a)return new qe({trustLineIsAlreadyOpened:!1});let s=new sr(a.limit),u=new sr(ct);return new qe({trustLineIsAlreadyOpened:s.gte(u)})}catch{return new be({nextStatus:"failed",nextStepStatus:"failed",message:"Could not get account lines from XRPL.",details:void 0,errorCode:"CLIENT_UNEXPECTED_BEHAVIOUR"})}}o(or,"checkIfTrustLineIsAlreadyOpened");function ir(e,t){return{type:Sn.XRPL,blockChain:"XRPL",prerequisites:[],data:{TransactionType:"TrustSet",Account:e,LimitAmount:{currency:t.currency,issuer:t.account,value:ct}}}}o(ir,"createTrustLineTransaction");function ge(e){let t=e.wallets.XRPL;return t?{type:t.walletType,namespace:{namespace:"XRPL",network:"XRPL"},address:t.address}:null}o(ge,"getXrplWalletFromSwap");async function Ee(e,t){let{context:r}=e,n=r.state(t.type),{accounts:a,connected:s}=n;return s?a?.find(u=>dn(u).address===t.address)?new qe(!0):new be({reason:"waiting_for_connecting_wallet",description:te(t.type,t.address)}):new be({reason:"waiting_for_connecting_wallet",description:$(t.type)})}o(Ee,"ensureRequiredXrplWalletIsConnected");async function pt(e){let{failed:t,context:r,schedule:n,getStorage:a,next:s}=e,{meta:u,getSigners:i}=r,c=o(()=>{e.context.resetClaimedBy&&e.context.resetClaimedBy()},"onFinish"),p=o(()=>{n("CHECK_PREREQUISITES"),s(),c()},"scheduleCheckPrerequisites"),l=o(f=>{I(e,f.val),t(),c()},"handleErr"),T=a().swapDetails,d=g(T),S=N(d);if(!S){l(new ur({nextStatus:"failed",nextStepStatus:"failed",message:"Unexpected Error: tx is null!",details:void 0,errorCode:"CLIENT_UNEXPECTED_BEHAVIOUR"}));return}let m=null;for(let f=0;f<S.prerequisites.length;f++){let R=S.prerequisites[f];R.type===Fe&&(d.prerequisiteResults?.find(_=>_.prerequisiteIndex===f&&_.prerequisiteType===Fe)||(m={prerequisite:R,prerequisiteIndex:f}))}if(!m){p();return}let w=ge(T);if(!w){l(new ur({nextStatus:"failed",nextStepStatus:"failed",message:"Unexpected Error: XRPL wallet was not found in the swap!",details:void 0,errorCode:"CLIENT_UNEXPECTED_BEHAVIOUR"}));return}let y=await Te(r,w.type);if(y.err){l(y);return}let h=await Ee(e,w);if(h.err){X(e,h.val);return}let E={currency:m.prerequisite.currency,account:m.prerequisite.issuer,amount:m.prerequisite.value},x=await or(m.prerequisite.wallet,E,{namespace:y.val});if(x.err){l(x);return}if(x.val.trustLineIsAlreadyOpened){let f={prerequisiteIndex:m.prerequisiteIndex,prerequisiteType:Fe,status:"skipped",data:null};K(e,f),p();return}try{let f=ir(m.prerequisite.wallet,E),R=u.blockchains.XRPL?.chainId,v=await(await i(w.type)).getSigner(mn.XRPL).signAndSendTx(f,w.address,R),P={prerequisiteIndex:m.prerequisiteIndex,prerequisiteType:Fe,status:"pending",data:{executedTransactionHash:v.hash}};K(e,P),p()}catch(f){q(e)(f),c()}}o(pt,"checkXrplTrustline");import{isXrplChangeTrustLinePrerequisiteResult as gn,XRPL_CHANGE_TRUSTLINE_TYPE as cr}from"rango-types";import{Err as En}from"ts-results";import{Client as fn}from"xrpl";var lr="wss://xrplcluster.com/";async function dt(e){let{failed:t,getStorage:r,retry:n,next:a,schedule:s}=e,u=r().swapDetails,i=g(u),c=o(()=>{e.context.resetClaimedBy&&e.context.resetClaimedBy()},"onFinish"),p=o(()=>{s("CHECK_PREREQUISITES"),a(),c()},"onSuccessfulFinish"),l=o(S=>{I(e,S.val),t(),c()},"handleErr"),T=o(async()=>{await se(5e3),n()},"retryAfterDelay"),d=null;for(let S of i.prerequisiteResults)if(gn(S)&&S.status==="pending"){d=S;break}if(!d){p();return}try{let S=new fn(lr);await S.connect();let m=await S.request({command:"tx",transaction:d.data.executedTransactionHash});if(!m.result.validated){await T();return}if(typeof m.result.meta!="string"&&m.result.meta?.TransactionResult==="tesSUCCESS"){let w={prerequisiteIndex:d.prerequisiteIndex,prerequisiteType:cr,status:"success",data:{executedTransactionHash:d.data.executedTransactionHash}};K(e,w),p()}else{let w={prerequisiteIndex:d.prerequisiteIndex,prerequisiteType:cr,status:"failed",data:{executedTransactionHash:d.data.executedTransactionHash}};K(e,w),l(new En({nextStatus:"failed",nextStepStatus:"failed",message:"Unexpected Error: xrpl change trustline transaction failed!",details:void 0,errorCode:"CLIENT_UNEXPECTED_BEHAVIOUR"}))}}catch{await T()}}o(dt,"checkXrplTrustLineTransactionStatus");import{warn as wn}from"@rango-dev/logging-core";async function pr(e){let{setStorage:t,getStorage:r,next:n,schedule:a}=e,s=r().swapDetails,u=g(s);if(!N(u)){A({event:{type:"tx_execution",status:"create_tx"},swap:s,step:u});let c={requestId:s.requestId,step:u.id,userSettings:{slippage:s.settings.slippage,infiniteApprove:s.settings.infiniteApprove},validations:{balance:s.validateBalanceOrFee,fee:s.validateBalanceOrFee,approve:!0}};try{let{transaction:p}=await Vt(Y().createTransaction(c));p&&ke(u,p),t({...r(),swapDetails:s}),a("SCHEDULE_NEXT_STEP"),n()}catch(p){s.status="failed",s.finishTime=new Date().getTime().toString();let{extraMessage:l,extraMessageDetail:T}=j(p),d=O({getStorage:r,setStorage:t,nextStatus:"failed",nextStepStatus:"failed",message:l,details:T,errorCode:"FETCH_TX_FAILED"}),S=ie(s,l,d.failureType);A({event:S,...d}),p instanceof Error&&wn(new Error("create transaction error"),{tags:{message:p.message,requestBody:c,reason:S.reason,reasonCode:S.reasonCode,pendingSwap:s}}),e.failed()}}}o(pr,"createTransaction");import{TransactionType as An}from"rango-types";import{Err as mr}from"ts-results";import{isStellarTransaction as xn}from"rango-types";import{Err as dr,Ok as yn}from"ts-results";async function Sr(e){return e?xn(e)?yn(e):new dr({nextStatus:"failed",nextStepStatus:"failed",message:"Unexpected Error: Expected Stellar transaction but it doesn't match with the structure.",details:void 0,errorCode:"CLIENT_UNEXPECTED_BEHAVIOUR"}):new dr({nextStatus:"failed",nextStepStatus:"failed",message:"Unexpected Error: tx is null!",details:void 0,errorCode:"CLIENT_UNEXPECTED_BEHAVIOUR"})}o(Sr,"ensureStellarTransactionIsValid");async function St(e){let{failed:t,getStorage:r,context:n}=e,{meta:a,getSigners:s}=n,u=o(()=>{e.context.resetClaimedBy&&e.context.resetClaimedBy()},"onFinish"),i=o(x=>{I(e,x.val),t(),u()},"handleErr"),c=r().swapDetails,p=g(c),l=N(p),T=await Sr(l);if(T.err){i(T);return}let d=Se(c);if(!d){i(new mr({nextStatus:"failed",nextStepStatus:"failed",message:"Unexpected Error: Stellar wallet was not found in the swap!",details:void 0,errorCode:"CLIENT_UNEXPECTED_BEHAVIOUR"}));return}let S=await de(n,d.type);if(S.err){i(S);return}let m=await me(e,d);if(m.err){X(e,m.val);return}let w=re(c,p),y=ue(e);if(y.err){i(y);return}le(e,y.val);let h=a.blockchains.Stellar?.chainId,E;try{E=(await s(d.type)).getSigner(An.STELLAR)}catch{i(new mr({nextStatus:"failed",nextStepStatus:"failed",message:"Unexpected Error: Failed to load the signer. Please refresh the page and try again.",details:void 0,errorCode:"CLIENT_UNEXPECTED_BEHAVIOUR"}));return}try{let x=await E.signAndSendTx(T.val,w,h);oe(e,{isApproval:!1})(x)}catch(x){q(e)(x)}u()}o(St,"executeStellarTransaction");import{PendingSwapNetworkStatus as Tr}from"rango-types";import{Err as Me,Ok as mt}from"ts-results";async function gr(e){let{getStorage:t,context:r}=e,n=t().swapDetails,a=g(n),s=Cn(e);if(s.err)return s;let u=await Rn(e);if(u.err)return u;a.networkStatus===Tr.NetworkChanged&&rt(e,{message:"",details:"The network has been successfully changed.",status:Tr.NetworkChanged});let i=Kt(a),c=Le(r);if(i&&!c){let p={reason:"depends_on_other_queues",description:Ye,details:{}};return new Me(p)}return new mt(!0)}o(gr,"checkEnvironmentBeforeExecuteTransaction");function Cn(e){let{getStorage:t,context:r}=e,{wallets:n}=r,a=t().swapDetails;if(!nt(a,r.state).ok){let{type:u,address:i}=b(a),c=n?.blockchains?.find(T=>!T.accounts?.find(d=>d.walletType===u)),p=tt(n)||c?$(u):te(u,i),l={reason:"waiting_for_connecting_wallet",description:p};return new Me(l)}return new mt(!0)}o(Cn,"ensureRequiredWalletIsConnected");async function Rn(e){let{getStorage:t,context:r}=e,{meta:n,wallets:a,providers:s,hubProvider:u}=r,i=t().swapDetails,c=g(i),p=await Mt(i,c,a,n,s,u),{claimedBy:l}=he();if(!!l()&&!Le(r)&&!p){let S=Ye,m={reason:"depends_on_other_queues",details:S};return new Me(m)}else if(!p){let S=G(i,c),m=Ae(S.network),w={reason:"waiting_for_network_change",details:m};return new Me(w)}return new mt(!0)}o(Rn,"ensureWalletIsOnCorrectNetwork");async function Tt(e){let t=await gr(e);if(t.err){X(e,t.val);return}Ie(e);let{failed:r,getStorage:n,context:a}=e,{meta:s,getSigners:u}=a,i=n().swapDetails,c=g(i),p=M(c),l=o(()=>{e.context.resetClaimedBy&&e.context.resetClaimedBy()},"onFinish"),T=ue(e);if(T.err){I(e,T.val),r(),l();return}le(e,T.val);let d=N(c),S=W(i,c),m=re(i,c),w=s.blockchains?.[d.blockChain]?.chainId,y;try{y=await u(S.walletType)}catch(E){q(e)(E),l();return}await y.getSigner(d.type).signAndSendTx(d,m,w).then(oe(e,{isApproval:p}),q(e)).finally(()=>{l()})}o(Tt,"executeTransaction");import{TransactionType as Nn}from"rango-types";import{Err as fr}from"ts-results";import{isXrplTransaction as _n}from"rango-types";import{Err as gt,Ok as hn}from"ts-results";async function Er(e){return e?_n(e)?e.data.TransactionType!=="Payment"?new gt({nextStatus:"failed",nextStepStatus:"failed",message:"Unexpected Error: Only XRPL transactions with payment type are supported",details:void 0,errorCode:"CLIENT_UNEXPECTED_BEHAVIOUR"}):hn(e):new gt({nextStatus:"failed",nextStepStatus:"failed",message:"Unexpected Error: Expected XRPL transaction but it doesn't match with the structure.",details:void 0,errorCode:"CLIENT_UNEXPECTED_BEHAVIOUR"}):new gt({nextStatus:"failed",nextStepStatus:"failed",message:"Unexpected Error: tx is null!",details:void 0,errorCode:"CLIENT_UNEXPECTED_BEHAVIOUR"})}o(Er,"ensureXrplTransactionIsValid");async function Et(e){let{failed:t,getStorage:r,context:n}=e,{meta:a,getSigners:s}=n,u=o(()=>{e.context.resetClaimedBy&&e.context.resetClaimedBy()},"onFinish"),i=o(x=>{I(e,x.val),t(),u()},"handleErr"),c=r().swapDetails,p=g(c),l=N(p),T=await Er(l);if(T.err){i(T);return}let d=ge(c);if(!d){i(new fr({nextStatus:"failed",nextStepStatus:"failed",message:"Unexpected Error: Stellar wallet was not found in the swap!",details:void 0,errorCode:"CLIENT_UNEXPECTED_BEHAVIOUR"}));return}let S=await Te(n,d.type);if(S.err){i(S);return}let m=await Ee(e,d);if(m.err){X(e,m.val);return}let w=re(c,p),y=ue(e);if(y.err){i(y);return}le(e,y.val);let h=a.blockchains.XRPL?.chainId,E;try{E=(await s(d.type)).getSigner(Nn.XRPL)}catch{i(new fr({nextStatus:"failed",nextStepStatus:"failed",message:"Unexpected Error: Failed to load the signer. Please refresh the page and try again.",details:void 0,errorCode:"CLIENT_UNEXPECTED_BEHAVIOUR"}));return}try{let x=await E.signAndSendTx(T.val,w,h);oe(e,{isApproval:T.val.data.TransactionType==="TrustSet"})(x)}catch(x){q(e)(x)}u()}o(Et,"executeXrplTransaction");function wr({schedule:e,next:t,failed:r,setStorage:n,getStorage:a}){let s=a().swapDetails,u=g(s),i=s.steps.find(c=>c.status==="failed");if(u&&!i){if(Bt(s,u))return e("CHECK_PREREQUISITES"),t();if(u?.executedTransactionId)return e("CHECK_TRANSACTION_STATUS"),t();s.status="running",n({...a(),swapDetails:s}),A({event:{type:"started"},swap:s,step:u}),e("CREATE_TRANSACTION"),t()}else{s.status=i?"failed":"success",s.finishTime=new Date().getTime().toString(),n({...a(),swapDetails:s});let c=B(s),p=V(s);A({...i?{event:{type:"failed",reason:s.extraMessage??void 0,reasonCode:"CALL_OR_SEND_FAILED",inputAmount:c,inputAmountUsd:p}}:{event:{type:"succeeded",inputAmount:c,inputAmountUsd:p,outputAmount:ne(s.steps)?.outputAmount??"",outputAmountUsd:Pe(s)}},swap:s,step:null}),i?r():t()}}o(wr,"scheduleNextStep");function xr({schedule:e,next:t,getStorage:r}){let n=r().swapDetails;A({event:{type:"started"},swap:n,step:null}),e("SCHEDULE_NEXT_STEP"),t()}o(xr,"start");var yr={name:"swap",actions:{START:xr,SCHEDULE_NEXT_STEP:wr,CREATE_TRANSACTION:pr,CHECK_PREREQUISITES:it,CHECK_XRPL_TRUSTLINE:pt,CHECK_XRPL_TRUSTLINE_TRANSACTION_STATUS:dt,CHECK_STELLAR_TRUSTLINE:lt,EXECUTE_TRANSACTION:Tt,EXECUTE_XRPL_TRANSACTION:Et,EXECUTE_STELLAR_TRANSACTION:St,CHECK_TRANSACTION_STATUS:er},run:["START"],whenTaskBlocked:(e,t)=>{e.reason.reason==="waiting_for_connecting_wallet"?Xt(e,t):e.reason.reason==="waiting_for_network_change"?Qt(e,t):e.reason.reason==="depends_on_other_queues"&&Ht(e,t)}};import{useManager as Ln}from"@rango-dev/queue-manager-react";import{useEffect as wt,useState as On}from"react";import{DB_NAME as kn,Persistor as In,Status as fe}from"@rango-dev/queue-manager-core";import{v4 as vn}from"uuid";var Ar="migratedToQueueManager";function ft(){return!!window.localStorage.getItem(Ar)}o(ft,"migrated");async function Pn(){try{return(await window.indexedDB.databases()).map(e=>e.name).includes(kn)}catch{return!1}}o(Pn,"hasQueueManagerOnIDB");async function Cr(){let e=window.localStorage.getItem("pendingSwaps"),t=await Pn();if(!e||ft()||t)return!0;let r=JSON.parse(e),n=[];r.forEach(u=>{if(u.status==="running"){let i=vn(),c={id:u.requestId,createdAt:Number(u.creationTime),name:"swap",status:fe.RUNNING,storage:{swapDetails:u},state:{status:fe.RUNNING,activeTaskIndex:0,tasks:{[i]:{blockedFor:null,status:fe.RUNNING}}},tasks:[{id:i,action:"SCHEDULE_NEXT_STEP"}]};n.push(c)}else{let i=u.status==="success"?fe.SUCCESS:fe.FAILED,c={id:u.requestId,createdAt:Number(u.creationTime),name:"swap",status:i,storage:{swapDetails:u},state:{status:i,activeTaskIndex:0,tasks:{}},tasks:[]};n.push(c)}});let a=new In,s=n.map(async u=>a.insertQueue(u));return await Promise.all(s),window.localStorage.setItem(Ar,"1"),!0}o(Cr,"migration");var Rr=0;function Un(e){return`${e?.walletType}-${e?.network}-${e?.accounts?.toString()}`}o(Un,"getLastConnectedWalletHash");function Dn(){let e=ft(),[t,r]=On(e);return wt(()=>{(async()=>Rr||(Rr=1,Cr().finally(()=>{r(!0)})))()},[]),{status:t}}o(Dn,"useMigration");function Wn(e){let{manager:t}=Ln(),{lastConnectedWallet:r,disconnectedWallet:n,evmChains:a,canSwitchNetworkTo:s,clearDisconnectedWallet:u}=e;wt(()=>{r&&(Gt({evmChains:a,lastConnectedWallet:r,manager:t}),st(r,t,s))},[Un(r)]),wt(()=>{n&&(at(t),u())},[n])}o(Wn,"useQueueManager");function au(e){return yt(e),yr}o(au,"makeQueueDefinition");export{Ge as EventSeverity,Re as MessageSeverity,D as PrettyError,He as RouteEventType,Q as StepEventType,ye as StepExecutionBlockedEventStatus,ee as StepExecutionEventStatus,Qe as WidgetEvents,Wr as calculatePendingSwap,en as cancelSwap,at as checkWaitingForNetworkChange,F as getCurrentNamespaceOfOrNull,g as getCurrentStep,ne as getLastSuccessfulStep,W as getRelatedWallet,je as getRelatedWalletOrNull,b as getRequiredWallet,zr as getRunningSwaps,Ut as getUsdPrice,tn as isApprovalTX,au as makeQueueDefinition,j as prettifyErrorMessage,Zr as resetRunningSwapNotifsOnPageLoad,O as updateSwapStatus,Dn as useMigration,Wn as useQueueManager};
2
2
  //# sourceMappingURL=index.js.map