@atomiqlabs/sdk 8.6.6 → 8.6.8

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 (226) hide show
  1. package/dist/SmartChainAssets.d.ts +181 -181
  2. package/dist/SmartChainAssets.js +181 -181
  3. package/dist/bitcoin/coinselect2/accumulative.d.ts +6 -6
  4. package/dist/bitcoin/coinselect2/accumulative.js +52 -51
  5. package/dist/bitcoin/coinselect2/blackjack.d.ts +6 -6
  6. package/dist/bitcoin/coinselect2/blackjack.js +38 -37
  7. package/dist/bitcoin/coinselect2/index.d.ts +19 -17
  8. package/dist/bitcoin/coinselect2/index.js +69 -69
  9. package/dist/bitcoin/coinselect2/utils.d.ts +77 -75
  10. package/dist/bitcoin/coinselect2/utils.js +123 -123
  11. package/dist/bitcoin/wallet/BitcoinWallet.d.ts +130 -128
  12. package/dist/bitcoin/wallet/BitcoinWallet.js +322 -322
  13. package/dist/bitcoin/wallet/IBitcoinWallet.d.ts +78 -78
  14. package/dist/bitcoin/wallet/IBitcoinWallet.js +21 -20
  15. package/dist/bitcoin/wallet/SingleAddressBitcoinWallet.d.ts +101 -99
  16. package/dist/bitcoin/wallet/SingleAddressBitcoinWallet.js +190 -176
  17. package/dist/enums/FeeType.d.ts +15 -15
  18. package/dist/enums/FeeType.js +19 -19
  19. package/dist/enums/SwapAmountType.d.ts +15 -15
  20. package/dist/enums/SwapAmountType.js +19 -19
  21. package/dist/enums/SwapDirection.d.ts +15 -15
  22. package/dist/enums/SwapDirection.js +19 -19
  23. package/dist/enums/SwapSide.d.ts +15 -15
  24. package/dist/enums/SwapSide.js +19 -19
  25. package/dist/enums/SwapType.d.ts +75 -75
  26. package/dist/enums/SwapType.js +79 -79
  27. package/dist/errors/IntermediaryError.d.ts +13 -13
  28. package/dist/errors/IntermediaryError.js +27 -27
  29. package/dist/errors/RequestError.d.ts +32 -32
  30. package/dist/errors/RequestError.js +54 -54
  31. package/dist/errors/UserError.d.ts +8 -8
  32. package/dist/errors/UserError.js +16 -16
  33. package/dist/events/UnifiedSwapEventListener.d.ts +23 -23
  34. package/dist/events/UnifiedSwapEventListener.js +130 -130
  35. package/dist/http/HttpUtils.d.ts +27 -27
  36. package/dist/http/HttpUtils.js +91 -90
  37. package/dist/http/paramcoders/IParamReader.d.ts +8 -8
  38. package/dist/http/paramcoders/IParamReader.js +2 -2
  39. package/dist/http/paramcoders/ParamDecoder.d.ts +44 -42
  40. package/dist/http/paramcoders/ParamDecoder.js +137 -137
  41. package/dist/http/paramcoders/ParamEncoder.d.ts +20 -18
  42. package/dist/http/paramcoders/ParamEncoder.js +36 -36
  43. package/dist/http/paramcoders/SchemaVerifier.d.ts +26 -26
  44. package/dist/http/paramcoders/SchemaVerifier.js +145 -145
  45. package/dist/http/paramcoders/client/ResponseParamDecoder.d.ts +11 -11
  46. package/dist/http/paramcoders/client/ResponseParamDecoder.js +57 -57
  47. package/dist/http/paramcoders/client/StreamParamEncoder.d.ts +13 -11
  48. package/dist/http/paramcoders/client/StreamParamEncoder.js +26 -26
  49. package/dist/http/paramcoders/client/StreamingFetchPromise.d.ts +16 -16
  50. package/dist/http/paramcoders/client/StreamingFetchPromise.js +174 -173
  51. package/dist/index.d.ts +85 -85
  52. package/dist/index.js +158 -158
  53. package/dist/intermediaries/Intermediary.d.ts +157 -157
  54. package/dist/intermediaries/Intermediary.js +142 -142
  55. package/dist/intermediaries/IntermediaryDiscovery.d.ts +199 -198
  56. package/dist/intermediaries/IntermediaryDiscovery.js +406 -406
  57. package/dist/intermediaries/apis/IntermediaryAPI.d.ts +439 -437
  58. package/dist/intermediaries/apis/IntermediaryAPI.js +603 -603
  59. package/dist/intermediaries/apis/TrustedIntermediaryAPI.d.ts +155 -155
  60. package/dist/intermediaries/apis/TrustedIntermediaryAPI.js +137 -137
  61. package/dist/lnurl/LNURL.d.ts +102 -102
  62. package/dist/lnurl/LNURL.js +321 -321
  63. package/dist/prices/RedundantSwapPrice.d.ts +110 -110
  64. package/dist/prices/RedundantSwapPrice.js +222 -222
  65. package/dist/prices/SingleSwapPrice.d.ts +34 -34
  66. package/dist/prices/SingleSwapPrice.js +44 -44
  67. package/dist/prices/SwapPriceWithChain.d.ts +107 -107
  68. package/dist/prices/SwapPriceWithChain.js +128 -128
  69. package/dist/prices/abstract/ICachedSwapPrice.d.ts +28 -28
  70. package/dist/prices/abstract/ICachedSwapPrice.js +62 -62
  71. package/dist/prices/abstract/IPriceProvider.d.ts +81 -81
  72. package/dist/prices/abstract/IPriceProvider.js +74 -74
  73. package/dist/prices/abstract/ISwapPrice.d.ts +168 -168
  74. package/dist/prices/abstract/ISwapPrice.js +279 -279
  75. package/dist/prices/providers/BinancePriceProvider.d.ts +23 -23
  76. package/dist/prices/providers/BinancePriceProvider.js +30 -30
  77. package/dist/prices/providers/CoinGeckoPriceProvider.d.ts +23 -23
  78. package/dist/prices/providers/CoinGeckoPriceProvider.js +29 -29
  79. package/dist/prices/providers/CoinPaprikaPriceProvider.d.ts +25 -25
  80. package/dist/prices/providers/CoinPaprikaPriceProvider.js +29 -29
  81. package/dist/prices/providers/CustomPriceProvider.d.ts +24 -24
  82. package/dist/prices/providers/CustomPriceProvider.js +35 -35
  83. package/dist/prices/providers/KrakenPriceProvider.d.ts +38 -38
  84. package/dist/prices/providers/KrakenPriceProvider.js +45 -45
  85. package/dist/prices/providers/OKXPriceProvider.d.ts +34 -34
  86. package/dist/prices/providers/OKXPriceProvider.js +29 -29
  87. package/dist/prices/providers/abstract/ExchangePriceProvider.d.ts +17 -17
  88. package/dist/prices/providers/abstract/ExchangePriceProvider.js +21 -21
  89. package/dist/prices/providers/abstract/HttpPriceProvider.d.ts +7 -7
  90. package/dist/prices/providers/abstract/HttpPriceProvider.js +12 -12
  91. package/dist/storage/IUnifiedStorage.d.ts +85 -85
  92. package/dist/storage/IUnifiedStorage.js +2 -2
  93. package/dist/storage/UnifiedSwapStorage.d.ts +114 -114
  94. package/dist/storage/UnifiedSwapStorage.js +116 -116
  95. package/dist/storage-browser/IndexedDBUnifiedStorage.d.ts +63 -63
  96. package/dist/storage-browser/IndexedDBUnifiedStorage.js +298 -298
  97. package/dist/storage-browser/LocalStorageManager.d.ts +49 -49
  98. package/dist/storage-browser/LocalStorageManager.js +93 -93
  99. package/dist/swapper/Swapper.d.ts +687 -686
  100. package/dist/swapper/Swapper.js +1603 -1603
  101. package/dist/swapper/SwapperFactory.d.ts +135 -135
  102. package/dist/swapper/SwapperFactory.js +162 -162
  103. package/dist/swapper/SwapperUtils.d.ts +200 -200
  104. package/dist/swapper/SwapperUtils.js +467 -467
  105. package/dist/swapper/SwapperWithChain.d.ts +404 -404
  106. package/dist/swapper/SwapperWithChain.js +469 -469
  107. package/dist/swapper/SwapperWithSigner.d.ts +322 -322
  108. package/dist/swapper/SwapperWithSigner.js +318 -318
  109. package/dist/swaps/IAddressSwap.d.ts +22 -22
  110. package/dist/swaps/IAddressSwap.js +14 -13
  111. package/dist/swaps/IBTCWalletSwap.d.ts +73 -73
  112. package/dist/swaps/IBTCWalletSwap.js +18 -17
  113. package/dist/swaps/IClaimableSwap.d.ts +49 -49
  114. package/dist/swaps/IClaimableSwap.js +15 -14
  115. package/dist/swaps/IClaimableSwapWrapper.d.ts +15 -15
  116. package/dist/swaps/IClaimableSwapWrapper.js +2 -2
  117. package/dist/swaps/IRefundableSwap.d.ts +43 -43
  118. package/dist/swaps/IRefundableSwap.js +14 -13
  119. package/dist/swaps/ISwap.d.ts +387 -386
  120. package/dist/swaps/ISwap.js +346 -346
  121. package/dist/swaps/ISwapWithGasDrop.d.ts +21 -21
  122. package/dist/swaps/ISwapWithGasDrop.js +12 -11
  123. package/dist/swaps/ISwapWrapper.d.ts +285 -283
  124. package/dist/swaps/ISwapWrapper.js +353 -353
  125. package/dist/swaps/escrow_swaps/IEscrowSelfInitSwap.d.ts +98 -98
  126. package/dist/swaps/escrow_swaps/IEscrowSelfInitSwap.js +126 -126
  127. package/dist/swaps/escrow_swaps/IEscrowSwap.d.ts +135 -133
  128. package/dist/swaps/escrow_swaps/IEscrowSwap.js +169 -169
  129. package/dist/swaps/escrow_swaps/IEscrowSwapWrapper.d.ts +115 -114
  130. package/dist/swaps/escrow_swaps/IEscrowSwapWrapper.js +134 -134
  131. package/dist/swaps/escrow_swaps/frombtc/IFromBTCLNWrapper.d.ts +101 -98
  132. package/dist/swaps/escrow_swaps/frombtc/IFromBTCLNWrapper.js +130 -130
  133. package/dist/swaps/escrow_swaps/frombtc/IFromBTCSelfInitSwap.d.ts +162 -162
  134. package/dist/swaps/escrow_swaps/frombtc/IFromBTCSelfInitSwap.js +190 -190
  135. package/dist/swaps/escrow_swaps/frombtc/IFromBTCWrapper.d.ts +58 -58
  136. package/dist/swaps/escrow_swaps/frombtc/IFromBTCWrapper.js +78 -78
  137. package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNSwap.d.ts +531 -529
  138. package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNSwap.js +1285 -1285
  139. package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNWrapper.d.ts +184 -181
  140. package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNWrapper.js +418 -418
  141. package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoSwap.d.ts +583 -581
  142. package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoSwap.js +1371 -1371
  143. package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoWrapper.d.ts +228 -225
  144. package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoWrapper.js +506 -506
  145. package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCSwap.d.ts +458 -458
  146. package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCSwap.js +1126 -1126
  147. package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCWrapper.d.ts +191 -190
  148. package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCWrapper.js +378 -378
  149. package/dist/swaps/escrow_swaps/tobtc/IToBTCSwap.d.ts +403 -403
  150. package/dist/swaps/escrow_swaps/tobtc/IToBTCSwap.js +924 -924
  151. package/dist/swaps/escrow_swaps/tobtc/IToBTCWrapper.d.ts +62 -62
  152. package/dist/swaps/escrow_swaps/tobtc/IToBTCWrapper.js +112 -112
  153. package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNSwap.d.ts +127 -125
  154. package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNSwap.js +256 -256
  155. package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNWrapper.d.ts +242 -241
  156. package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNWrapper.js +520 -520
  157. package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCSwap.d.ts +73 -73
  158. package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCSwap.js +155 -155
  159. package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCWrapper.d.ts +128 -127
  160. package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCWrapper.js +278 -278
  161. package/dist/swaps/spv_swaps/SpvFromBTCSwap.d.ts +630 -630
  162. package/dist/swaps/spv_swaps/SpvFromBTCSwap.js +1443 -1443
  163. package/dist/swaps/spv_swaps/SpvFromBTCWrapper.d.ts +214 -213
  164. package/dist/swaps/spv_swaps/SpvFromBTCWrapper.js +756 -756
  165. package/dist/swaps/trusted/ln/LnForGasSwap.d.ts +261 -261
  166. package/dist/swaps/trusted/ln/LnForGasSwap.js +511 -511
  167. package/dist/swaps/trusted/ln/LnForGasWrapper.d.ts +40 -40
  168. package/dist/swaps/trusted/ln/LnForGasWrapper.js +82 -82
  169. package/dist/swaps/trusted/onchain/OnchainForGasSwap.d.ts +342 -342
  170. package/dist/swaps/trusted/onchain/OnchainForGasSwap.js +715 -715
  171. package/dist/swaps/trusted/onchain/OnchainForGasWrapper.d.ts +69 -68
  172. package/dist/swaps/trusted/onchain/OnchainForGasWrapper.js +92 -92
  173. package/dist/types/AmountData.d.ts +10 -10
  174. package/dist/types/AmountData.js +2 -2
  175. package/dist/types/CustomPriceFunction.d.ts +11 -11
  176. package/dist/types/CustomPriceFunction.js +2 -2
  177. package/dist/types/PriceInfoType.d.ts +28 -28
  178. package/dist/types/PriceInfoType.js +57 -56
  179. package/dist/types/SwapExecutionAction.d.ts +88 -88
  180. package/dist/types/SwapExecutionAction.js +2 -2
  181. package/dist/types/SwapStateInfo.d.ts +5 -5
  182. package/dist/types/SwapStateInfo.js +2 -2
  183. package/dist/types/SwapWithSigner.d.ts +17 -17
  184. package/dist/types/SwapWithSigner.js +43 -42
  185. package/dist/types/Token.d.ts +99 -99
  186. package/dist/types/Token.js +76 -76
  187. package/dist/types/TokenAmount.d.ts +69 -69
  188. package/dist/types/TokenAmount.js +60 -59
  189. package/dist/types/fees/Fee.d.ts +50 -50
  190. package/dist/types/fees/Fee.js +2 -2
  191. package/dist/types/fees/FeeBreakdown.d.ts +11 -11
  192. package/dist/types/fees/FeeBreakdown.js +2 -2
  193. package/dist/types/fees/PercentagePPM.d.ts +17 -17
  194. package/dist/types/fees/PercentagePPM.js +18 -17
  195. package/dist/types/lnurl/LNURLPay.d.ts +61 -61
  196. package/dist/types/lnurl/LNURLPay.js +31 -30
  197. package/dist/types/lnurl/LNURLWithdraw.d.ts +48 -48
  198. package/dist/types/lnurl/LNURLWithdraw.js +27 -26
  199. package/dist/types/wallets/LightningInvoiceCreateService.d.ts +24 -24
  200. package/dist/types/wallets/LightningInvoiceCreateService.js +15 -14
  201. package/dist/types/wallets/MinimalBitcoinWalletInterface.d.ts +23 -23
  202. package/dist/types/wallets/MinimalBitcoinWalletInterface.js +2 -2
  203. package/dist/types/wallets/MinimalLightningNetworkWalletInterface.d.ts +9 -9
  204. package/dist/types/wallets/MinimalLightningNetworkWalletInterface.js +2 -2
  205. package/dist/utils/AutomaticClockDriftCorrection.d.ts +1 -1
  206. package/dist/utils/AutomaticClockDriftCorrection.js +70 -69
  207. package/dist/utils/BitcoinUtils.d.ts +14 -12
  208. package/dist/utils/BitcoinUtils.js +102 -101
  209. package/dist/utils/BitcoinWalletUtils.d.ts +7 -7
  210. package/dist/utils/BitcoinWalletUtils.js +14 -13
  211. package/dist/utils/Logger.d.ts +7 -7
  212. package/dist/utils/Logger.js +12 -11
  213. package/dist/utils/RetryUtils.d.ts +22 -22
  214. package/dist/utils/RetryUtils.js +67 -66
  215. package/dist/utils/SwapUtils.d.ts +88 -88
  216. package/dist/utils/SwapUtils.js +72 -72
  217. package/dist/utils/TimeoutUtils.d.ts +17 -17
  218. package/dist/utils/TimeoutUtils.js +55 -54
  219. package/dist/utils/TokenUtils.d.ts +19 -19
  220. package/dist/utils/TokenUtils.js +37 -36
  221. package/dist/utils/TypeUtils.d.ts +7 -7
  222. package/dist/utils/TypeUtils.js +2 -2
  223. package/dist/utils/Utils.d.ts +58 -56
  224. package/dist/utils/Utils.js +194 -193
  225. package/package.json +1 -1
  226. package/src/bitcoin/wallet/SingleAddressBitcoinWallet.ts +14 -2
@@ -1,76 +1,76 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.BitcoinTokens = void 0;
4
- exports.isToken = isToken;
5
- exports.isBtcToken = isBtcToken;
6
- exports.isSCToken = isSCToken;
7
- /**
8
- * Type guard for a {@link Token} type, encompassing all tokens (BTC or smart chain)
9
- *
10
- * @category Tokens
11
- */
12
- function isToken(obj) {
13
- return typeof (obj) === "object" &&
14
- (obj.chain === "SC" || obj.chain === "BTC") &&
15
- typeof (obj.ticker) === "string" &&
16
- typeof (obj.decimals) === "number" &&
17
- typeof (obj.name) === "string";
18
- }
19
- /**
20
- * Type guard for {@link BtcToken} (token on the bitcoin network - lightning or on-chain)
21
- *
22
- * @category Tokens
23
- */
24
- function isBtcToken(obj) {
25
- return typeof (obj) === "object" &&
26
- obj.chain === "BTC" &&
27
- typeof (obj.lightning) === "boolean" &&
28
- typeof (obj.ticker) === "string" &&
29
- typeof (obj.decimals) === "number" &&
30
- typeof (obj.name) === "string";
31
- }
32
- /**
33
- * Predefined Bitcoin token constants
34
- *
35
- * @category Tokens
36
- */
37
- exports.BitcoinTokens = {
38
- BTC: {
39
- chain: "BTC",
40
- chainId: "BITCOIN",
41
- lightning: false,
42
- ticker: "BTC",
43
- decimals: 8,
44
- displayDecimals: 8,
45
- name: "Bitcoin (on-chain L1)",
46
- address: "",
47
- equals: (other) => other.chainId === "BITCOIN" && other.ticker === "BTC",
48
- toString: () => "BTC"
49
- },
50
- BTCLN: {
51
- chain: "BTC",
52
- chainId: "LIGHTNING",
53
- lightning: true,
54
- ticker: "BTC",
55
- decimals: 8,
56
- displayDecimals: 8,
57
- name: "Bitcoin (lightning L2)",
58
- address: "",
59
- equals: (other) => other.chainId === "LIGHTNING" && other.ticker === "BTC",
60
- toString: () => "BTC-LN"
61
- }
62
- };
63
- /**
64
- * Type guard for {@link SCToken} (token on the smart chain)
65
- * @category Tokens
66
- */
67
- function isSCToken(obj, chainIdentifier) {
68
- return typeof (obj) === "object" &&
69
- obj.chain === "SC" &&
70
- typeof (obj.chainId) === "string" &&
71
- (chainIdentifier == null || chainIdentifier.includes(obj.chainId)) &&
72
- typeof (obj.address) === "string" &&
73
- typeof (obj.ticker) === "string" &&
74
- typeof (obj.decimals) === "number" &&
75
- typeof (obj.name) === "string";
76
- }
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.isSCToken = exports.BitcoinTokens = exports.isBtcToken = exports.isToken = void 0;
4
+ /**
5
+ * Type guard for a {@link Token} type, encompassing all tokens (BTC or smart chain)
6
+ *
7
+ * @category Tokens
8
+ */
9
+ function isToken(obj) {
10
+ return typeof (obj) === "object" &&
11
+ (obj.chain === "SC" || obj.chain === "BTC") &&
12
+ typeof (obj.ticker) === "string" &&
13
+ typeof (obj.decimals) === "number" &&
14
+ typeof (obj.name) === "string";
15
+ }
16
+ exports.isToken = isToken;
17
+ /**
18
+ * Type guard for {@link BtcToken} (token on the bitcoin network - lightning or on-chain)
19
+ *
20
+ * @category Tokens
21
+ */
22
+ function isBtcToken(obj) {
23
+ return typeof (obj) === "object" &&
24
+ obj.chain === "BTC" &&
25
+ typeof (obj.lightning) === "boolean" &&
26
+ typeof (obj.ticker) === "string" &&
27
+ typeof (obj.decimals) === "number" &&
28
+ typeof (obj.name) === "string";
29
+ }
30
+ exports.isBtcToken = isBtcToken;
31
+ /**
32
+ * Predefined Bitcoin token constants
33
+ *
34
+ * @category Tokens
35
+ */
36
+ exports.BitcoinTokens = {
37
+ BTC: {
38
+ chain: "BTC",
39
+ chainId: "BITCOIN",
40
+ lightning: false,
41
+ ticker: "BTC",
42
+ decimals: 8,
43
+ displayDecimals: 8,
44
+ name: "Bitcoin (on-chain L1)",
45
+ address: "",
46
+ equals: (other) => other.chainId === "BITCOIN" && other.ticker === "BTC",
47
+ toString: () => "BTC"
48
+ },
49
+ BTCLN: {
50
+ chain: "BTC",
51
+ chainId: "LIGHTNING",
52
+ lightning: true,
53
+ ticker: "BTC",
54
+ decimals: 8,
55
+ displayDecimals: 8,
56
+ name: "Bitcoin (lightning L2)",
57
+ address: "",
58
+ equals: (other) => other.chainId === "LIGHTNING" && other.ticker === "BTC",
59
+ toString: () => "BTC-LN"
60
+ }
61
+ };
62
+ /**
63
+ * Type guard for {@link SCToken} (token on the smart chain)
64
+ * @category Tokens
65
+ */
66
+ function isSCToken(obj, chainIdentifier) {
67
+ return typeof (obj) === "object" &&
68
+ obj.chain === "SC" &&
69
+ typeof (obj.chainId) === "string" &&
70
+ (chainIdentifier == null || chainIdentifier.includes(obj.chainId)) &&
71
+ typeof (obj.address) === "string" &&
72
+ typeof (obj.ticker) === "string" &&
73
+ typeof (obj.decimals) === "number" &&
74
+ typeof (obj.name) === "string";
75
+ }
76
+ exports.isSCToken = isSCToken;
@@ -1,69 +1,69 @@
1
- import { ISwapPrice } from "../prices/abstract/ISwapPrice";
2
- import { Token } from "./Token";
3
- import { PriceInfoType } from "./PriceInfoType";
4
- /**
5
- * Represents a token amount along with its formatted values and USD valuation helpers
6
- *
7
- * @category Tokens
8
- */
9
- export type TokenAmount<T extends Token = Token, Known extends boolean = boolean> = {
10
- /**
11
- * Raw amount in base units represented as bigint, might be `undefined` when the amount is unknown
12
- */
13
- rawAmount: Known extends true ? bigint : undefined;
14
- /**
15
- * Human readable amount with decimal places, might be empty string `""` when the amount is unknown
16
- */
17
- amount: string;
18
- /**
19
- * Number representation of the decimal token amount (can lose precision!), might be `NaN` when
20
- * the amount is unknown
21
- */
22
- _amount: number;
23
- /**
24
- * Token associated with this amount
25
- */
26
- token: T;
27
- /**
28
- * Fetches the current USD value of the amount, might return `NaN` when the amount is unknown
29
- *
30
- * @param abortSignal
31
- * @param preFetchedUsdPrice You can supply a pre-fetched usd price to the pricing function
32
- * @returns A promise resolving to the current USD value of the token amount
33
- */
34
- currentUsdValue: (abortSignal?: AbortSignal, preFetchedUsdPrice?: number) => Promise<number>;
35
- /**
36
- * Gets USD value of the amount, if this amount was returned from a swap it uses the USD value
37
- * when the swap was created, otherwise fetches the usd value on-demand, might return `NaN`
38
- * when the amount is unknown
39
- *
40
- * @param abortSignal
41
- * @param preFetchedUsdPrice You can supply a pre-fetched usd price to the pricing function
42
- * @returns A promise resolving to the current USD value of the token amount
43
- */
44
- usdValue: (abortSignal?: AbortSignal, preFetchedUsdPrice?: number) => Promise<number>;
45
- /**
46
- * USD value of the amount when swap was created - only present for token amounts obtained
47
- * from swaps, left for convenience only, use usdValue() instead, which automatically
48
- * recognizes which pricing to use (either past value if available or fetches it on-demand),
49
- * might be `NaN` when the amount is unknown
50
- */
51
- pastUsdValue?: number;
52
- /**
53
- * Returns the string representation of the amount along with the token ticker in format: `"{amount} {ticker}"`,
54
- * in case the anmount is unknown returns `"??? {ticker}"`
55
- */
56
- toString: () => string;
57
- /**
58
- * Whether the token amount contains an unknown or undefined amount, in this case numeric values are `NaN`,
59
- * raw amount is `undefined`, string representation is `""` and `toString()` returns `"??? {ticker}"`
60
- */
61
- isUnknown: Known extends true ? false : true;
62
- };
63
- /**
64
- * Factory function to create a TokenAmount
65
- *
66
- * @category Tokens
67
- * @internal
68
- */
69
- export declare function toTokenAmount<T extends Token = Token, Known extends boolean = boolean>(amount: Known extends true ? bigint : null, token: T, prices: ISwapPrice, pricingInfo?: PriceInfoType): TokenAmount<T, Known>;
1
+ import { ISwapPrice } from "../prices/abstract/ISwapPrice";
2
+ import { Token } from "./Token";
3
+ import { PriceInfoType } from "./PriceInfoType";
4
+ /**
5
+ * Represents a token amount along with its formatted values and USD valuation helpers
6
+ *
7
+ * @category Tokens
8
+ */
9
+ export type TokenAmount<T extends Token = Token, Known extends boolean = boolean> = {
10
+ /**
11
+ * Raw amount in base units represented as bigint, might be `undefined` when the amount is unknown
12
+ */
13
+ rawAmount: Known extends true ? bigint : undefined;
14
+ /**
15
+ * Human readable amount with decimal places, might be empty string `""` when the amount is unknown
16
+ */
17
+ amount: string;
18
+ /**
19
+ * Number representation of the decimal token amount (can lose precision!), might be `NaN` when
20
+ * the amount is unknown
21
+ */
22
+ _amount: number;
23
+ /**
24
+ * Token associated with this amount
25
+ */
26
+ token: T;
27
+ /**
28
+ * Fetches the current USD value of the amount, might return `NaN` when the amount is unknown
29
+ *
30
+ * @param abortSignal
31
+ * @param preFetchedUsdPrice You can supply a pre-fetched usd price to the pricing function
32
+ * @returns A promise resolving to the current USD value of the token amount
33
+ */
34
+ currentUsdValue: (abortSignal?: AbortSignal, preFetchedUsdPrice?: number) => Promise<number>;
35
+ /**
36
+ * Gets USD value of the amount, if this amount was returned from a swap it uses the USD value
37
+ * when the swap was created, otherwise fetches the usd value on-demand, might return `NaN`
38
+ * when the amount is unknown
39
+ *
40
+ * @param abortSignal
41
+ * @param preFetchedUsdPrice You can supply a pre-fetched usd price to the pricing function
42
+ * @returns A promise resolving to the current USD value of the token amount
43
+ */
44
+ usdValue: (abortSignal?: AbortSignal, preFetchedUsdPrice?: number) => Promise<number>;
45
+ /**
46
+ * USD value of the amount when swap was created - only present for token amounts obtained
47
+ * from swaps, left for convenience only, use usdValue() instead, which automatically
48
+ * recognizes which pricing to use (either past value if available or fetches it on-demand),
49
+ * might be `NaN` when the amount is unknown
50
+ */
51
+ pastUsdValue?: number;
52
+ /**
53
+ * Returns the string representation of the amount along with the token ticker in format: `"{amount} {ticker}"`,
54
+ * in case the anmount is unknown returns `"??? {ticker}"`
55
+ */
56
+ toString: () => string;
57
+ /**
58
+ * Whether the token amount contains an unknown or undefined amount, in this case numeric values are `NaN`,
59
+ * raw amount is `undefined`, string representation is `""` and `toString()` returns `"??? {ticker}"`
60
+ */
61
+ isUnknown: Known extends true ? false : true;
62
+ };
63
+ /**
64
+ * Factory function to create a TokenAmount
65
+ *
66
+ * @category Tokens
67
+ * @internal
68
+ */
69
+ export declare function toTokenAmount<T extends Token = Token, Known extends boolean = boolean>(amount: Known extends true ? bigint : null, token: T, prices: ISwapPrice, pricingInfo?: PriceInfoType): TokenAmount<T, Known>;
@@ -1,59 +1,60 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.toTokenAmount = toTokenAmount;
4
- const Utils_1 = require("../utils/Utils");
5
- /**
6
- * Factory function to create a TokenAmount
7
- *
8
- * @category Tokens
9
- * @internal
10
- */
11
- function toTokenAmount(amount, token, prices, pricingInfo) {
12
- if (amount == null)
13
- return {
14
- rawAmount: undefined,
15
- amount: "",
16
- _amount: NaN,
17
- token,
18
- currentUsdValue: () => Promise.resolve(NaN),
19
- pastUsdValue: NaN,
20
- usdValue: () => Promise.resolve(NaN),
21
- toString: () => "??? " + token.ticker,
22
- isUnknown: true
23
- };
24
- const amountStr = (0, Utils_1.toDecimal)(amount, token.decimals, undefined, token.displayDecimals);
25
- const _amount = parseFloat(amountStr);
26
- let usdValue = undefined;
27
- if (pricingInfo != null) {
28
- if (token.chain === "BTC" && token.ticker === "BTC") {
29
- if (pricingInfo.realPriceUsdPerBitcoin != null) {
30
- usdValue = Number(amount) * pricingInfo.realPriceUsdPerBitcoin;
31
- }
32
- }
33
- else {
34
- if (pricingInfo.realPriceUsdPerBitcoin != null && pricingInfo.realPriceUSatPerToken != null) {
35
- usdValue = _amount
36
- * pricingInfo.realPriceUsdPerBitcoin
37
- * Number(pricingInfo.realPriceUSatPerToken)
38
- / 1_000_000;
39
- }
40
- }
41
- }
42
- const currentUsdValue = (abortSignal, preFetchedUsdPrice) => prices.getUsdValue(amount, token, abortSignal, preFetchedUsdPrice);
43
- return {
44
- rawAmount: amount,
45
- amount: amountStr,
46
- _amount,
47
- token,
48
- currentUsdValue,
49
- pastUsdValue: usdValue,
50
- usdValue: async (abortSignal, preFetchedUsdPrice) => {
51
- if (usdValue == null) {
52
- usdValue = await currentUsdValue(abortSignal, preFetchedUsdPrice);
53
- }
54
- return usdValue;
55
- },
56
- toString: () => amountStr + " " + token.ticker,
57
- isUnknown: false
58
- };
59
- }
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.toTokenAmount = void 0;
4
+ const Utils_1 = require("../utils/Utils");
5
+ /**
6
+ * Factory function to create a TokenAmount
7
+ *
8
+ * @category Tokens
9
+ * @internal
10
+ */
11
+ function toTokenAmount(amount, token, prices, pricingInfo) {
12
+ if (amount == null)
13
+ return {
14
+ rawAmount: undefined,
15
+ amount: "",
16
+ _amount: NaN,
17
+ token,
18
+ currentUsdValue: () => Promise.resolve(NaN),
19
+ pastUsdValue: NaN,
20
+ usdValue: () => Promise.resolve(NaN),
21
+ toString: () => "??? " + token.ticker,
22
+ isUnknown: true
23
+ };
24
+ const amountStr = (0, Utils_1.toDecimal)(amount, token.decimals, undefined, token.displayDecimals);
25
+ const _amount = parseFloat(amountStr);
26
+ let usdValue = undefined;
27
+ if (pricingInfo != null) {
28
+ if (token.chain === "BTC" && token.ticker === "BTC") {
29
+ if (pricingInfo.realPriceUsdPerBitcoin != null) {
30
+ usdValue = Number(amount) * pricingInfo.realPriceUsdPerBitcoin;
31
+ }
32
+ }
33
+ else {
34
+ if (pricingInfo.realPriceUsdPerBitcoin != null && pricingInfo.realPriceUSatPerToken != null) {
35
+ usdValue = _amount
36
+ * pricingInfo.realPriceUsdPerBitcoin
37
+ * Number(pricingInfo.realPriceUSatPerToken)
38
+ / 1000000;
39
+ }
40
+ }
41
+ }
42
+ const currentUsdValue = (abortSignal, preFetchedUsdPrice) => prices.getUsdValue(amount, token, abortSignal, preFetchedUsdPrice);
43
+ return {
44
+ rawAmount: amount,
45
+ amount: amountStr,
46
+ _amount,
47
+ token,
48
+ currentUsdValue,
49
+ pastUsdValue: usdValue,
50
+ usdValue: async (abortSignal, preFetchedUsdPrice) => {
51
+ if (usdValue == null) {
52
+ usdValue = await currentUsdValue(abortSignal, preFetchedUsdPrice);
53
+ }
54
+ return usdValue;
55
+ },
56
+ toString: () => amountStr + " " + token.ticker,
57
+ isUnknown: false
58
+ };
59
+ }
60
+ exports.toTokenAmount = toTokenAmount;
@@ -1,50 +1,50 @@
1
- import { PercentagePPM } from "./PercentagePPM";
2
- import { TokenAmount } from "../TokenAmount";
3
- import { Token } from "../Token";
4
- /**
5
- * Fee represented in both, source and destination tokens, as well as providing USD valuation helpers and
6
- * fee composition
7
- *
8
- * @category Pricing
9
- */
10
- export type Fee<ChainIdentifier extends string = string, TSrc extends Token<ChainIdentifier> = Token<ChainIdentifier>, TDst extends Token<ChainIdentifier> = Token<ChainIdentifier>> = {
11
- /**
12
- * Fee value equivalent in source token
13
- */
14
- amountInSrcToken: TokenAmount<TSrc, true>;
15
- /**
16
- * Fee value equivalent in destination token
17
- */
18
- amountInDstToken: TokenAmount<TDst, true>;
19
- /**
20
- * Fetches the current USD value of the fee
21
- *
22
- * @param abortSignal
23
- * @param preFetchedUsdPrice You can supply a pre-fetched usd price to the pricing function
24
- * @returns A promise resolving to the current USD value of the token amount
25
- */
26
- currentUsdValue: (abortSignal?: AbortSignal, preFetchedUsdPrice?: number) => Promise<number>;
27
- /**
28
- * Gets USD value of the fee, if the USD value when the swap was created is known (newer swaps) it returns this value,
29
- * otherwise fetches the usd value on-demand
30
- *
31
- * @param abortSignal
32
- * @param preFetchedUsdPrice You can supply a pre-fetched usd price to the pricing function
33
- * @returns A promise resolving to the current USD value of the fee
34
- */
35
- usdValue: (abortSignal?: AbortSignal, preFetchedUsdPrice?: number) => Promise<number>;
36
- /**
37
- * USD value of the fee when swap was created - only present for newer swaps where the USD value at create
38
- * time is known. Left for convenience only, use usdValue() instead, which automatically
39
- * recognizes which pricing to use (either past value if available or fetches it on-demand)
40
- */
41
- pastUsdValue?: number;
42
- /**
43
- * Returns the composition of the fee (base fee + percentage fee) if known, the total fee is calculated as:
44
- * base_fee + amount * percentage_fee
45
- */
46
- composition?: {
47
- base: TokenAmount;
48
- percentage: PercentagePPM;
49
- };
50
- };
1
+ import { PercentagePPM } from "./PercentagePPM";
2
+ import { TokenAmount } from "../TokenAmount";
3
+ import { Token } from "../Token";
4
+ /**
5
+ * Fee represented in both, source and destination tokens, as well as providing USD valuation helpers and
6
+ * fee composition
7
+ *
8
+ * @category Pricing
9
+ */
10
+ export type Fee<ChainIdentifier extends string = string, TSrc extends Token<ChainIdentifier> = Token<ChainIdentifier>, TDst extends Token<ChainIdentifier> = Token<ChainIdentifier>> = {
11
+ /**
12
+ * Fee value equivalent in source token
13
+ */
14
+ amountInSrcToken: TokenAmount<TSrc, true>;
15
+ /**
16
+ * Fee value equivalent in destination token
17
+ */
18
+ amountInDstToken: TokenAmount<TDst, true>;
19
+ /**
20
+ * Fetches the current USD value of the fee
21
+ *
22
+ * @param abortSignal
23
+ * @param preFetchedUsdPrice You can supply a pre-fetched usd price to the pricing function
24
+ * @returns A promise resolving to the current USD value of the token amount
25
+ */
26
+ currentUsdValue: (abortSignal?: AbortSignal, preFetchedUsdPrice?: number) => Promise<number>;
27
+ /**
28
+ * Gets USD value of the fee, if the USD value when the swap was created is known (newer swaps) it returns this value,
29
+ * otherwise fetches the usd value on-demand
30
+ *
31
+ * @param abortSignal
32
+ * @param preFetchedUsdPrice You can supply a pre-fetched usd price to the pricing function
33
+ * @returns A promise resolving to the current USD value of the fee
34
+ */
35
+ usdValue: (abortSignal?: AbortSignal, preFetchedUsdPrice?: number) => Promise<number>;
36
+ /**
37
+ * USD value of the fee when swap was created - only present for newer swaps where the USD value at create
38
+ * time is known. Left for convenience only, use usdValue() instead, which automatically
39
+ * recognizes which pricing to use (either past value if available or fetches it on-demand)
40
+ */
41
+ pastUsdValue?: number;
42
+ /**
43
+ * Returns the composition of the fee (base fee + percentage fee) if known, the total fee is calculated as:
44
+ * base_fee + amount * percentage_fee
45
+ */
46
+ composition?: {
47
+ base: TokenAmount;
48
+ percentage: PercentagePPM;
49
+ };
50
+ };
@@ -1,2 +1,2 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
@@ -1,11 +1,11 @@
1
- import { FeeType } from "../../enums/FeeType";
2
- import { Fee } from "./Fee";
3
- /**
4
- * Breakdown of fees by type (swap fee, network fee, etc.)
5
- *
6
- * @category Pricing
7
- */
8
- export type FeeBreakdown<ChainIdentifier extends string = string> = {
9
- type: FeeType;
10
- fee: Fee<ChainIdentifier>;
11
- }[];
1
+ import { FeeType } from "../../enums/FeeType";
2
+ import { Fee } from "./Fee";
3
+ /**
4
+ * Breakdown of fees by type (swap fee, network fee, etc.)
5
+ *
6
+ * @category Pricing
7
+ */
8
+ export type FeeBreakdown<ChainIdentifier extends string = string> = {
9
+ type: FeeType;
10
+ fee: Fee<ChainIdentifier>;
11
+ }[];
@@ -1,2 +1,2 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
@@ -1,17 +1,17 @@
1
- /**
2
- * Parts-per-million fee representation with conversion helpers
3
- *
4
- * @category Pricing
5
- */
6
- export type PercentagePPM = {
7
- ppm: bigint;
8
- decimal: number;
9
- percentage: number;
10
- toString: (decimal?: number) => string;
11
- };
12
- /**
13
- * Converts parts-per-million to percentage representation
14
- *
15
- * @category Pricing
16
- */
17
- export declare function ppmToPercentage(ppm: bigint): PercentagePPM;
1
+ /**
2
+ * Parts-per-million fee representation with conversion helpers
3
+ *
4
+ * @category Pricing
5
+ */
6
+ export type PercentagePPM = {
7
+ ppm: bigint;
8
+ decimal: number;
9
+ percentage: number;
10
+ toString: (decimal?: number) => string;
11
+ };
12
+ /**
13
+ * Converts parts-per-million to percentage representation
14
+ *
15
+ * @category Pricing
16
+ */
17
+ export declare function ppmToPercentage(ppm: bigint): PercentagePPM;
@@ -1,17 +1,18 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.ppmToPercentage = ppmToPercentage;
4
- /**
5
- * Converts parts-per-million to percentage representation
6
- *
7
- * @category Pricing
8
- */
9
- function ppmToPercentage(ppm) {
10
- const percentage = Number(ppm) / 10_000;
11
- return {
12
- ppm,
13
- decimal: Number(ppm) / 1_000_000,
14
- percentage: percentage,
15
- toString: (decimals) => (decimals != null ? percentage.toFixed(decimals) : percentage) + "%"
16
- };
17
- }
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ppmToPercentage = void 0;
4
+ /**
5
+ * Converts parts-per-million to percentage representation
6
+ *
7
+ * @category Pricing
8
+ */
9
+ function ppmToPercentage(ppm) {
10
+ const percentage = Number(ppm) / 10000;
11
+ return {
12
+ ppm,
13
+ decimal: Number(ppm) / 1000000,
14
+ percentage: percentage,
15
+ toString: (decimals) => (decimals != null ? percentage.toFixed(decimals) : percentage) + "%"
16
+ };
17
+ }
18
+ exports.ppmToPercentage = ppmToPercentage;