@hot-labs/kit 1.1.3 → 1.2.0-alpha.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (203) hide show
  1. package/README.md +9 -2
  2. package/build/HotConnector.d.ts +7 -8
  3. package/build/HotConnector.js +24 -21
  4. package/build/HotConnector.js.map +1 -1
  5. package/build/OmniConnector.d.ts +0 -5
  6. package/build/OmniConnector.js +5 -5
  7. package/build/OmniConnector.js.map +1 -1
  8. package/build/OmniWallet.d.ts +17 -10
  9. package/build/OmniWallet.js +19 -14
  10. package/build/OmniWallet.js.map +1 -1
  11. package/build/core/Intents.d.ts +43 -53
  12. package/build/core/Intents.js +133 -209
  13. package/build/core/Intents.js.map +1 -1
  14. package/build/core/api.d.ts +0 -22
  15. package/build/core/api.js +4 -28
  16. package/build/core/api.js.map +1 -1
  17. package/build/core/bridge.js +1 -1
  18. package/build/core/bridge.js.map +1 -1
  19. package/build/core/index.d.ts +1 -1
  20. package/build/core/index.js +1 -1
  21. package/build/core/index.js.map +1 -1
  22. package/build/{near/rpc.d.ts → core/nearRpc.d.ts} +1 -0
  23. package/build/{near/rpc.js → core/nearRpc.js} +12 -7
  24. package/build/core/nearRpc.js.map +1 -0
  25. package/build/core/types.d.ts +0 -17
  26. package/build/core/utils.d.ts +0 -1
  27. package/build/core/utils.js +1 -21
  28. package/build/core/utils.js.map +1 -1
  29. package/build/cosmos/connector.d.ts +2 -2
  30. package/build/cosmos/connector.js +21 -17
  31. package/build/cosmos/connector.js.map +1 -1
  32. package/build/cosmos/wallet.d.ts +4 -2
  33. package/build/cosmos/wallet.js +8 -3
  34. package/build/cosmos/wallet.js.map +1 -1
  35. package/build/evm/connector.d.ts +0 -1
  36. package/build/evm/connector.js +0 -4
  37. package/build/evm/connector.js.map +1 -1
  38. package/build/evm/wallet.d.ts +1 -2
  39. package/build/evm/wallet.js +5 -7
  40. package/build/evm/wallet.js.map +1 -1
  41. package/build/exchange.d.ts +1 -4
  42. package/build/exchange.js +30 -24
  43. package/build/exchange.js.map +1 -1
  44. package/build/hot-wallet/google.js +5 -10
  45. package/build/hot-wallet/google.js.map +1 -1
  46. package/build/hot-wallet/proxy.js +2 -2
  47. package/build/hot-wallet/proxy.js.map +1 -1
  48. package/build/index.d.ts +0 -1
  49. package/build/index.js +0 -1
  50. package/build/index.js.map +1 -1
  51. package/build/near/connector.js +2 -2
  52. package/build/near/connector.js.map +1 -1
  53. package/build/near/wallet.d.ts +4 -2
  54. package/build/near/wallet.js +9 -4
  55. package/build/near/wallet.js.map +1 -1
  56. package/build/solana/connector.d.ts +1 -1
  57. package/build/solana/connector.js +8 -9
  58. package/build/solana/connector.js.map +1 -1
  59. package/build/solana/injected/solana-wallet.js.map +1 -1
  60. package/build/solana/{WalletStandard.d.ts → protocol.d.ts} +1 -1
  61. package/build/solana/{WalletStandard.js → protocol.js} +1 -1
  62. package/build/solana/protocol.js.map +1 -0
  63. package/build/solana/wallet.d.ts +7 -5
  64. package/build/solana/wallet.js +17 -8
  65. package/build/solana/wallet.js.map +1 -1
  66. package/build/solana/{walletStandartList.js → wallets.js} +1 -1
  67. package/build/solana/wallets.js.map +1 -0
  68. package/build/stellar/connector.d.ts +2 -0
  69. package/build/stellar/connector.js +4 -1
  70. package/build/stellar/connector.js.map +1 -1
  71. package/build/stellar/wallet.d.ts +8 -10
  72. package/build/stellar/wallet.js +16 -12
  73. package/build/stellar/wallet.js.map +1 -1
  74. package/build/ton/connector.d.ts +1 -0
  75. package/build/ton/connector.js +4 -1
  76. package/build/ton/connector.js.map +1 -1
  77. package/build/ton/wallet.d.ts +3 -2
  78. package/build/ton/wallet.js +4 -3
  79. package/build/ton/wallet.js.map +1 -1
  80. package/build/ui/Popup.d.ts +2 -2
  81. package/build/ui/Popup.js +1 -5
  82. package/build/ui/Popup.js.map +1 -1
  83. package/build/ui/connect/AuthPopup.js +1 -1
  84. package/build/ui/connect/AuthPopup.js.map +1 -1
  85. package/build/ui/connect/ConnectWallet.d.ts +2 -7
  86. package/build/ui/connect/ConnectWallet.js +5 -5
  87. package/build/ui/connect/ConnectWallet.js.map +1 -1
  88. package/build/ui/icons/arrow-right.js +1 -1
  89. package/build/ui/icons/arrow-right.js.map +1 -1
  90. package/build/ui/icons/close.js +1 -1
  91. package/build/ui/icons/close.js.map +1 -1
  92. package/build/ui/icons/exchange.js +1 -1
  93. package/build/ui/icons/exchange.js.map +1 -1
  94. package/build/ui/icons/logout.js +1 -1
  95. package/build/ui/icons/logout.js.map +1 -1
  96. package/build/ui/icons/pending.js +1 -1
  97. package/build/ui/icons/pending.js.map +1 -1
  98. package/build/ui/icons/qr.js +1 -1
  99. package/build/ui/icons/qr.js.map +1 -1
  100. package/build/ui/icons/search.js +1 -1
  101. package/build/ui/icons/search.js.map +1 -1
  102. package/build/ui/icons/switch.js +1 -1
  103. package/build/ui/icons/switch.js.map +1 -1
  104. package/build/ui/icons/wallet.js +1 -1
  105. package/build/ui/icons/wallet.js.map +1 -1
  106. package/build/ui/payment/Bridge.js +6 -21
  107. package/build/ui/payment/Bridge.js.map +1 -1
  108. package/build/ui/payment/Payment.d.ts +9 -16
  109. package/build/ui/payment/Payment.js +39 -128
  110. package/build/ui/payment/Payment.js.map +1 -1
  111. package/build/ui/payment/Profile.js +1 -1
  112. package/build/ui/payment/Profile.js.map +1 -1
  113. package/build/ui/payment/SelectToken.js +1 -1
  114. package/build/ui/payment/SelectToken.js.map +1 -1
  115. package/build/ui/payment/TokenCard.d.ts +2 -4
  116. package/build/ui/payment/TokenCard.js +5 -5
  117. package/build/ui/payment/TokenCard.js.map +1 -1
  118. package/build/ui/router.d.ts +4 -18
  119. package/build/ui/router.js +8 -20
  120. package/build/ui/router.js.map +1 -1
  121. package/build/ui/styles.js +0 -2
  122. package/build/ui/styles.js.map +1 -1
  123. package/package.json +4 -8
  124. package/src/HotConnector.ts +31 -24
  125. package/src/OmniConnector.ts +9 -10
  126. package/src/OmniWallet.ts +25 -24
  127. package/src/core/Intents.ts +151 -224
  128. package/src/core/api.ts +4 -44
  129. package/src/core/bridge.ts +2 -3
  130. package/src/core/index.ts +1 -1
  131. package/src/{near/rpc.ts → core/nearRpc.ts} +12 -7
  132. package/src/core/types.ts +0 -21
  133. package/src/core/utils.ts +1 -17
  134. package/src/cosmos/connector.ts +26 -22
  135. package/src/cosmos/wallet.ts +8 -3
  136. package/src/evm/connector.ts +0 -5
  137. package/src/evm/wallet.ts +6 -9
  138. package/src/exchange.ts +30 -24
  139. package/src/hot-wallet/google.ts +5 -12
  140. package/src/hot-wallet/proxy.ts +2 -2
  141. package/src/index.ts +0 -2
  142. package/src/near/connector.ts +2 -2
  143. package/src/near/wallet.ts +9 -4
  144. package/src/solana/connector.ts +8 -9
  145. package/src/solana/injected/solana-wallet.ts +6 -6
  146. package/src/solana/{WalletStandard.ts → protocol.ts} +4 -2
  147. package/src/solana/wallet.ts +20 -11
  148. package/src/stellar/connector.ts +6 -1
  149. package/src/stellar/wallet.ts +17 -17
  150. package/src/ton/connector.ts +5 -1
  151. package/src/ton/wallet.ts +3 -3
  152. package/src/ui/Popup.tsx +4 -12
  153. package/src/ui/connect/AuthPopup.tsx +1 -2
  154. package/src/ui/connect/ConnectWallet.tsx +6 -12
  155. package/src/ui/icons/arrow-right.tsx +2 -2
  156. package/src/ui/icons/close.tsx +1 -1
  157. package/src/ui/icons/exchange.tsx +4 -4
  158. package/src/ui/icons/logout.tsx +6 -6
  159. package/src/ui/icons/pending.tsx +4 -2
  160. package/src/ui/icons/qr.tsx +2 -1
  161. package/src/ui/icons/search.tsx +4 -4
  162. package/src/ui/icons/switch.tsx +4 -4
  163. package/src/ui/icons/wallet.tsx +4 -2
  164. package/src/ui/payment/Bridge.tsx +6 -25
  165. package/src/ui/payment/Payment.tsx +46 -244
  166. package/src/ui/payment/Profile.tsx +8 -10
  167. package/src/ui/payment/SelectToken.tsx +1 -1
  168. package/src/ui/payment/TokenCard.tsx +18 -22
  169. package/src/ui/router.tsx +16 -56
  170. package/src/ui/styles.ts +0 -2
  171. package/build/core/telemetry.d.ts +0 -13
  172. package/build/core/telemetry.js +0 -27
  173. package/build/core/telemetry.js.map +0 -1
  174. package/build/near/rpc.js.map +0 -1
  175. package/build/solana/WalletStandard.js.map +0 -1
  176. package/build/solana/walletStandartList.js.map +0 -1
  177. package/build/tron/connector.d.ts +0 -51
  178. package/build/tron/connector.js +0 -65
  179. package/build/tron/connector.js.map +0 -1
  180. package/build/tron/index.d.ts +0 -6
  181. package/build/tron/index.js +0 -5
  182. package/build/tron/index.js.map +0 -1
  183. package/build/tron/wallet.d.ts +0 -52
  184. package/build/tron/wallet.js +0 -122
  185. package/build/tron/wallet.js.map +0 -1
  186. package/build/ui/Toast.d.ts +0 -4
  187. package/build/ui/Toast.js +0 -33
  188. package/build/ui/Toast.js.map +0 -1
  189. package/build/ui/connect/PrimaryWallet.d.ts +0 -6
  190. package/build/ui/connect/PrimaryWallet.js +0 -18
  191. package/build/ui/connect/PrimaryWallet.js.map +0 -1
  192. package/build/ui/payment/Stepper.d.ts +0 -13
  193. package/build/ui/payment/Stepper.js +0 -22
  194. package/build/ui/payment/Stepper.js.map +0 -1
  195. package/src/core/telemetry.ts +0 -28
  196. package/src/tron/connector.ts +0 -89
  197. package/src/tron/index.ts +0 -7
  198. package/src/tron/wallet.ts +0 -146
  199. package/src/ui/Toast.tsx +0 -45
  200. package/src/ui/connect/PrimaryWallet.tsx +0 -65
  201. package/src/ui/payment/Stepper.tsx +0 -50
  202. /package/build/solana/{walletStandartList.d.ts → wallets.d.ts} +0 -0
  203. /package/src/solana/{walletStandartList.ts → wallets.ts} +0 -0
@@ -1,277 +1,79 @@
1
1
  import { observer } from "mobx-react-lite";
2
- import { useEffect, useState } from "react";
2
+ import { useEffect } from "react";
3
3
 
4
- import { WalletIcon } from "../icons/wallet";
5
- import { PopupButton, PopupOption, PopupOptionInfo } from "../styles";
6
- import { Commitment, Intents } from "../../core";
4
+ import { HotConnector } from "../../HotConnector";
5
+ import { openBridge, openConnector } from "../router";
7
6
  import { Recipient } from "../../core/recipient";
8
- import { Token } from "../../core/token";
9
-
10
7
  import { BridgeReview } from "../../exchange";
11
- import { openConnector } from "../router";
12
-
13
8
  import { OmniWallet } from "../../OmniWallet";
14
- import { HotConnector } from "../../HotConnector";
9
+ import { Network } from "../../core/chains";
10
+ import { Token } from "../../core/token";
15
11
  import Popup from "../Popup";
16
12
 
17
13
  import { TokenCard } from "./TokenCard";
18
- import { HorizontalStepper } from "./Stepper";
19
- import { Loader } from "./Profile";
14
+ import { PopupOption, PopupOptionInfo } from "../styles";
15
+ import { WalletIcon } from "../icons/wallet";
20
16
 
21
17
  interface PaymentProps {
22
- intents: Intents;
23
- title?: string;
24
- allowedTokens?: string[];
25
- prepaidAmount: bigint;
26
- payableToken: Token;
27
- needAmount: bigint;
28
18
  connector: HotConnector;
29
- onReject: (message: string) => void;
30
- onConfirm: (args: { depositQoute?: BridgeReview; processing?: () => Promise<BridgeReview> }) => Promise<void>;
31
- close: () => void;
19
+ token: Token;
20
+ amount: bigint;
21
+ recipient?: Recipient;
22
+ onClose: () => void;
23
+ onProcess: (task: Promise<BridgeReview>) => void;
32
24
  }
33
25
 
34
- const animations = {
35
- success: "https://hex.exchange/success.json",
36
- failed: "https://hex.exchange/error.json",
37
- loading: "https://hex.exchange/loading.json",
38
- };
39
-
40
- const PAY_SLIPPAGE = 0.002;
41
-
42
- const serializeError = (error: any) => {
43
- try {
44
- if (error instanceof Error) return error.message;
45
- if (typeof error === "object" && Object.keys(error).length > 0) return JSON.stringify(error);
46
- if (typeof error === "string" || typeof error === "number") return error.toString();
47
- return "";
48
- } catch (error) {
49
- return "Unknown error";
50
- }
51
- };
52
-
53
- export const Payment = observer(({ connector, intents, title = "Payment", allowedTokens, prepaidAmount, payableToken, needAmount, onReject, onConfirm, close }: PaymentProps) => {
54
- useState(() => {
55
- fetch(animations.loading);
56
- fetch(animations.success);
57
- fetch(animations.failed);
58
- });
59
-
60
- useEffect(() => {
61
- if (connector.wallets.length !== 0) return;
62
- openConnector(connector);
63
- }, [connector.wallets.length]);
64
-
65
- const [flow, setFlow] = useState<{
66
- token?: Token;
67
- wallet?: OmniWallet;
68
- commitment?: Commitment;
69
- review?: BridgeReview;
70
- success?: { depositQoute?: BridgeReview; processing?: () => Promise<BridgeReview> };
71
- step?: "selectToken" | "sign" | "transfer" | "success" | "error" | "loading";
72
- loading?: boolean;
73
- error?: any;
74
- } | null>(needAmount === 0n ? { step: "transfer" } : null);
75
-
76
- const paymentTitle = title || `Pay ${payableToken.readable(needAmount)} ${payableToken.symbol}`;
77
-
26
+ export const Payment = observer(({ connector, recipient, token: need, amount: needAmount, onProcess, onClose }: PaymentProps) => {
27
+ const title = `Need ${need.readable(needAmount)} ${need.symbol}`;
78
28
  const selectToken = async (from: Token, wallet?: OmniWallet) => {
79
- if (!wallet) return;
80
-
81
- try {
82
- setFlow({ token: from, wallet, review: undefined, step: "sign" });
83
- const review = await connector.exchange.reviewSwap({
84
- recipient: Recipient.fromWallet(intents.signer)!,
85
- amount: needAmount + (needAmount * BigInt(Math.floor(PAY_SLIPPAGE * 1000))) / BigInt(1000),
86
- slippage: PAY_SLIPPAGE,
29
+ onProcess(
30
+ openBridge(connector, {
87
31
  sender: wallet,
88
- refund: wallet,
32
+ autoClose: true,
89
33
  type: "exactOut",
90
- to: payableToken,
91
- from,
92
- });
93
-
94
- setFlow({ token: from, wallet, review, step: "sign" });
95
- } catch {
96
- setFlow({ token: from, wallet, error: true, step: "sign" });
97
- }
98
- };
99
-
100
- const signStep = async () => {
101
- try {
102
- setFlow((t) => (t ? { ...t, step: "sign", loading: true } : null));
103
- await intents.sign();
104
- setFlow((t) => (t ? { ...t, step: "transfer", loading: false } : null));
105
- } catch (error) {
106
- console.error(error);
107
- setFlow((t) => (t ? { ...t, step: "error", loading: false, error } : null));
108
- throw error;
109
- }
110
- };
111
-
112
- const confirmPaymentStep = async () => {
113
- try {
114
- setFlow((t) => (t ? { ...t, step: "loading" } : null));
115
-
116
- if (flow?.review == null) {
117
- await intents.sign();
118
- await onConfirm({});
119
- setFlow({ loading: false, step: "success" });
120
- setTimeout(() => close(), 2000);
121
- return;
122
- }
123
-
124
- const result = await connector.exchange.makeSwap(flow.review, { log: () => {} });
125
- await onConfirm({ depositQoute: result.review, processing: result.processing });
126
- setFlow({ loading: false, step: "success" });
127
- setTimeout(() => close(), 2000);
128
- } catch (error) {
129
- console.error(error);
130
- setFlow((t) => (t ? { ...t, step: "error", loading: false, error } : null));
131
- throw error;
132
- }
133
- };
134
-
135
- if (flow?.step === "success") {
136
- return (
137
- <Popup header={<p>{paymentTitle}</p>}>
138
- <div style={{ width: "100%", height: 400, display: "flex", justifyContent: "center", alignItems: "center", flexDirection: "column" }}>
139
- {/* @ts-expect-error: dotlottie-wc is not typed */}
140
- <dotlottie-wc key="success" src={animations.success} speed="1" style={{ width: 300, height: 300 }} mode="forward" loop autoplay></dotlottie-wc>
141
- <p style={{ fontSize: 24, marginTop: -32, fontWeight: "bold" }}>Transaction successful</p>
142
- </div>
143
- <PopupButton style={{ marginTop: "auto" }} onClick={() => close()}>
144
- Continue
145
- </PopupButton>
146
- </Popup>
34
+ recipient: recipient || Recipient.fromWallet(connector.priorityWallet!),
35
+ readonlyTo: recipient ? true : false,
36
+ amount: need.float(needAmount),
37
+ readonlyAmount: true,
38
+ title: title,
39
+ from: from,
40
+ to: need,
41
+ })
147
42
  );
148
- }
149
-
150
- if (flow?.step === "loading") {
151
- return (
152
- <Popup header={<p>{paymentTitle}</p>}>
153
- <div style={{ width: "100%", height: 400, display: "flex", justifyContent: "center", alignItems: "center", flexDirection: "column" }}>
154
- {/* @ts-expect-error: dotlottie-wc is not typed */}
155
- <dotlottie-wc key="loading" src={animations.loading} speed="1" style={{ marginTop: -64, width: 300, height: 300 }} mode="forward" loop autoplay></dotlottie-wc>
156
- <p style={{ fontSize: 24, marginTop: -16, fontWeight: "bold" }}>Transaction processing</p>
157
- </div>
158
- </Popup>
159
- );
160
- }
161
-
162
- if (flow?.step === "error") {
163
- return (
164
- <Popup header={<p>{paymentTitle}</p>}>
165
- <div style={{ width: "100%", height: 400, gap: 8, display: "flex", justifyContent: "center", alignItems: "center", flexDirection: "column" }}>
166
- {/* @ts-expect-error: dotlottie-wc is not typed */}
167
- <dotlottie-wc key="error" src={animations.failed} speed="1" style={{ width: 300, height: 300 }} mode="forward" loop autoplay></dotlottie-wc>
168
- <p style={{ fontSize: 24, marginTop: -32, fontWeight: "bold" }}>Transaction failed</p>
169
- <p style={{ fontSize: 14, width: "80%", textAlign: "center", overflowY: "auto", lineBreak: "anywhere" }}>{serializeError(flow.error)}</p>
170
- </div>
171
- <PopupButton onClick={() => onReject(serializeError(flow.error))}>Close</PopupButton>
172
- </Popup>
173
- );
174
- }
175
-
176
- if (flow?.step === "transfer") {
177
- return (
178
- <Popup onClose={() => onReject("closed")} header={<p>{paymentTitle}</p>}>
179
- <HorizontalStepper steps={[{ label: "Select" }, { label: "Review" }, { label: "Confirm" }]} currentStep={2} />
180
-
181
- {prepaidAmount > 0n && <TokenCard token={payableToken} hot={connector} wallet={intents.signer} amount={prepaidAmount} />}
182
-
183
- {flow.token != null && (
184
- <TokenCard //
185
- hot={connector}
186
- token={flow.token}
187
- wallet={flow.wallet}
188
- amount={flow.review == null ? needAmount : flow.review?.amountIn ?? 0n}
189
- />
190
- )}
191
-
192
- <PopupButton style={{ marginTop: 24 }} onClick={confirmPaymentStep}>
193
- {flow?.loading ? "Confirming..." : "Confirm transaction"}
194
- </PopupButton>
195
- </Popup>
196
- );
197
- }
198
-
199
- if (flow?.step === "sign") {
200
- const rightControl = <div style={{ paddingRight: 4, marginLeft: "auto", alignItems: "flex-end" }}>{flow.error ? <ErrorIcon /> : <Loader />}</div>;
201
-
202
- return (
203
- <Popup onClose={() => onReject("closed")} header={<p>{title}</p>}>
204
- <HorizontalStepper steps={[{ label: "Select" }, { label: "Review" }, { label: "Confirm" }]} currentStep={1} />
205
-
206
- {prepaidAmount > 0n && <TokenCard token={payableToken} hot={connector} wallet={intents.signer} amount={prepaidAmount} />}
207
-
208
- {flow.token != null && (
209
- <TokenCard //
210
- hot={connector}
211
- token={flow.token}
212
- wallet={flow.wallet}
213
- rightControl={flow.review ? undefined : rightControl}
214
- amount={flow.review == null ? needAmount : flow.review?.amountIn ?? 0n}
215
- />
216
- )}
217
-
218
- {flow.error ? (
219
- <PopupButton style={{ marginTop: 24 }} onClick={() => setFlow(null)}>
220
- Select another token
221
- </PopupButton>
222
- ) : (
223
- <PopupButton style={{ marginTop: 24 }} disabled={!flow?.review} onClick={signStep}>
224
- {flow?.loading ? "Signing..." : flow?.review ? "Sign review" : "Quoting..."}
225
- </PopupButton>
226
- )}
227
- </Popup>
228
- );
229
- }
230
-
231
- const recommendedTokens = connector.walletsTokens.filter((t) => t.token.symbol === "USDT" || t.token.symbol === "USDC");
232
- const otherTokens = connector.walletsTokens.filter((t) => t.token.symbol !== "USDT" && t.token.symbol !== "USDC");
233
-
234
- const renderToken = (token: Token, wallet: OmniWallet, balance: bigint) => {
235
- if (token.id === payableToken.id) return null;
236
- const availableBalance = token.float(balance) - token.reserve;
43
+ };
237
44
 
238
- // Allow only tokens in the allowedTokens list
239
- if (allowedTokens != null && !allowedTokens?.includes(token.omniAddress)) return null;
45
+ useEffect(() => {
46
+ if (connector.wallets.length !== 0) return;
47
+ openConnector(connector);
48
+ }, [connector.wallets.length, connector]);
240
49
 
241
- // same token as need and enough balance is direct deposit
242
- if (token.originalChain === payableToken.originalChain && token.originalAddress === payableToken.originalAddress && availableBalance >= payableToken.float(needAmount)) {
243
- return <TokenCard key={token.id} token={token} onSelect={selectToken} hot={connector} wallet={wallet} />;
244
- }
50
+ return (
51
+ <Popup onClose={onClose} header={<p>{title}</p>}>
52
+ {connector.walletsTokens.map(({ token, wallet, balance }) => {
53
+ if (token.id === need.id) return null;
54
+ const availableBalance = token.float(balance) - token.reserve;
245
55
 
246
- if (availableBalance * token.usd <= payableToken.usd * payableToken.float(needAmount) * (1 + PAY_SLIPPAGE)) return null;
247
- return <TokenCard key={token.id} token={token} onSelect={selectToken} hot={connector} wallet={wallet} />;
248
- };
56
+ if (need.originalChain === Network.Gonka || need.originalChain === Network.Juno) {
57
+ if (token.id === need.id) return null;
58
+ if (token.originalAddress !== need.originalAddress) return null;
249
59
 
250
- return (
251
- <Popup onClose={() => onReject("closed")} header={<p>{title}</p>}>
252
- <HorizontalStepper steps={[{ label: "Select" }, { label: "Review" }, { label: "Confirm" }]} currentStep={0} />
60
+ if (availableBalance < need.float(needAmount)) return null;
61
+ return <TokenCard key={token.id} token={token} onSelect={selectToken} hot={connector} wallet={wallet} />;
62
+ }
253
63
 
254
- {recommendedTokens.map(({ token, wallet, balance }) => renderToken(token, wallet, balance))}
255
- {otherTokens.map(({ token, wallet, balance }) => renderToken(token, wallet, balance))}
64
+ if (availableBalance * token.usd <= need.usd * need.float(needAmount)) return null;
65
+ return <TokenCard key={token.id} token={token} onSelect={selectToken} hot={connector} wallet={wallet} />;
66
+ })}
256
67
 
257
68
  <PopupOption onClick={() => openConnector(connector)}>
258
69
  <div style={{ width: 44, height: 44, borderRadius: 16, background: "#000", display: "flex", alignItems: "center", justifyContent: "center" }}>
259
70
  <WalletIcon />
260
71
  </div>
261
72
  <PopupOptionInfo>
262
- <p>Don't find the right token?</p>
263
- <span className="wallet-address">Connect another wallet</span>
73
+ <p>Connect wallet</p>
74
+ <span className="wallet-address">To more pay options</span>
264
75
  </PopupOptionInfo>
265
76
  </PopupOption>
266
77
  </Popup>
267
78
  );
268
79
  });
269
-
270
- const ErrorIcon = () => {
271
- return (
272
- <svg width="28" height="28" viewBox="0 0 28 28" fill="none" xmlns="http://www.w3.org/2000/svg" aria-label="Failed" style={{ display: "block", margin: "0 auto" }}>
273
- <circle cx="14" cy="14" r="13" stroke="#E74C3C" strokeWidth="2" />
274
- <path d="M9 9l10 10M19 9l-10 10" stroke="#E74C3C" strokeWidth="2.5" strokeLinecap="round" />
275
- </svg>
276
- );
277
- };
@@ -1,6 +1,6 @@
1
1
  import { observer } from "mobx-react-lite";
2
2
  import styled from "styled-components";
3
- import { useEffect } from "react";
3
+ import { useEffect, useState } from "react";
4
4
 
5
5
  import { LogoutIcon } from "../icons/logout";
6
6
  import { openBridge, openConnector } from "../router";
@@ -72,15 +72,13 @@ export const Profile = observer(({ hot, onClose }: { hot: HotConnector; onClose:
72
72
  return (
73
73
  <Popup onClose={onClose}>
74
74
  <div style={{ display: "flex", flexWrap: "wrap", width: "100%", gap: 8 }}>
75
- {hot.connectors.map((connector) =>
76
- connector.wallets.map((wallet) => (
77
- <WalletCard onClick={() => connector.disconnect()}>
78
- <ImageView src={wallet.icon} alt={connector.name} size={20} />
79
- <div>{formatter.truncateAddress(wallet.address, 8)}</div>
80
- <LogoutIcon width={20} height={20} />
81
- </WalletCard>
82
- ))
83
- )}
75
+ {hot.wallets.map((wallet) => (
76
+ <WalletCard onClick={() => wallet.disconnect()}>
77
+ <ImageView src={wallet.icon} alt={wallet.connector.name} size={20} />
78
+ <div>{formatter.truncateAddress(wallet.address, 8)}</div>
79
+ <LogoutIcon width={20} height={20} />
80
+ </WalletCard>
81
+ ))}
84
82
 
85
83
  {hot.wallets.length < 6 && (
86
84
  <WalletCard style={{ paddingLeft: 12, paddingRight: 12 }} onClick={() => openConnector(hot)}>
@@ -7,11 +7,11 @@ import { Token } from "../../core/token";
7
7
  import { HotConnector } from "../../HotConnector";
8
8
  import { OmniWallet } from "../../OmniWallet";
9
9
  import { Network, OmniToken } from "../../core/chains";
10
- import { tokens } from "../../core/tokens";
11
10
  import { PopupOption } from "../styles";
12
11
  import Popup from "../Popup";
13
12
 
14
13
  import { TokenCard, ImageView } from "./TokenCard";
14
+ import { tokens } from "../../core/tokens";
15
15
 
16
16
  interface SelectTokenPopupProps {
17
17
  hot: HotConnector;
@@ -58,35 +58,31 @@ export const TokenIcon = observer(({ token, wallet }: { token: Token; wallet?: O
58
58
  <div style={{ position: "relative", width: 40, height: 40 }}>
59
59
  <ImageView src={token.icon} alt={token.symbol} size={40} />
60
60
  <ImageView src={token.chainIcon} alt={token.symbol} size={14} style={{ position: "absolute", bottom: 0, right: 0 }} />
61
- {token.chain === -4 && wallet?.type && <ImageView src={wallet.icon} alt={chains.getByType(wallet.type)?.[0]?.name || ""} size={14} style={{ position: "absolute", bottom: 0, left: 0 }} />}
61
+ {token.chain === -4 && wallet?.type && <ImageView src={wallet.icon} alt={chains.get(wallet.type)?.name || ""} size={14} style={{ position: "absolute", bottom: 0, left: 0 }} />}
62
62
  </div>
63
63
  );
64
64
  });
65
65
 
66
- export const TokenCard = observer(
67
- ({ token, onSelect, amount, hot, wallet, rightControl }: { rightControl?: React.ReactNode; token: Token; onSelect?: (token: Token, wallet?: OmniWallet) => void; amount?: bigint; hot: HotConnector; wallet?: OmniWallet }) => {
68
- const balance = amount || hot.balance(wallet, token);
69
- const symbol = token.chain === -4 && !token.isMainOmni ? `${token.symbol} (${token.originalChainSymbol})` : token.symbol;
66
+ export const TokenCard = observer(({ token, onSelect, hot, wallet }: { token: Token; onSelect: (token: Token, wallet?: OmniWallet) => void; hot: HotConnector; wallet?: OmniWallet }) => {
67
+ const balance = hot.balance(wallet, token);
68
+ const symbol = token.chain === -4 && !token.isMainOmni ? `${token.originalChainSymbol}_${token.symbol}` : token.symbol;
70
69
 
71
- return (
72
- <PopupOption key={token.id} onClick={() => onSelect?.(token, wallet)}>
73
- <TokenIcon token={token} wallet={wallet} />
70
+ return (
71
+ <PopupOption key={token.id} onClick={() => onSelect(token, wallet)}>
72
+ <TokenIcon token={token} wallet={wallet} />
74
73
 
75
- <TokenWrap style={{ marginTop: -2, textAlign: "left" }}>
76
- <p style={{ textAlign: "left", fontSize: 20, fontWeight: "bold" }}>{symbol}</p>
77
- <p style={{ textAlign: "left", fontSize: 14, color: "#c6c6c6" }}>${formatter.amount(token.usd)}</p>
78
- </TokenWrap>
74
+ <TokenWrap style={{ marginTop: -2, textAlign: "left" }}>
75
+ <p style={{ textAlign: "left", fontSize: 20, fontWeight: "bold" }}>{symbol}</p>
76
+ <p style={{ textAlign: "left", fontSize: 14, color: "#c6c6c6" }}>${formatter.amount(token.usd)}</p>
77
+ </TokenWrap>
79
78
 
80
- {rightControl || (
81
- <TokenWrap style={{ paddingRight: 4, marginLeft: "auto", alignItems: "flex-end" }}>
82
- <p style={{ textAlign: "right", fontSize: 20 }}>{token.readable(balance)}</p>
83
- <p style={{ textAlign: "right", fontSize: 14, color: "#c6c6c6" }}>${token.readable(balance, token.usd)}</p>
84
- </TokenWrap>
85
- )}
86
- </PopupOption>
87
- );
88
- }
89
- );
79
+ <TokenWrap style={{ paddingRight: 4, marginLeft: "auto", alignItems: "flex-end" }}>
80
+ <p style={{ textAlign: "right", fontSize: 20 }}>{token.readable(balance)}</p>
81
+ <p style={{ textAlign: "right", fontSize: 14, color: "#c6c6c6" }}>${token.readable(balance, token.usd)}</p>
82
+ </TokenWrap>
83
+ </PopupOption>
84
+ );
85
+ });
90
86
 
91
87
  const TokenWrap = styled.div`
92
88
  display: flex;
package/src/ui/router.tsx CHANGED
@@ -1,62 +1,34 @@
1
1
  import { HotConnector } from "../HotConnector";
2
2
  import { OmniConnector } from "../OmniConnector";
3
- import { OmniWallet } from "../OmniWallet";
4
-
5
3
  import { BridgeReview } from "../exchange";
4
+ import { Token } from "../core/token";
5
+ import { OmniWallet } from "../OmniWallet";
6
6
  import { WalletType } from "../core/chains";
7
7
  import { Recipient } from "../core/recipient";
8
- import { Intents } from "../core/Intents";
9
- import { Token } from "../core/token";
10
8
 
11
9
  import { present } from "./Popup";
12
- import { SelectTokenPopup } from "./payment/SelectToken";
13
- import { SelectRecipient } from "./payment/SelectRecipient";
14
- import { SelectSender } from "./payment/SelectSender";
15
- import { BridgeProps } from "./payment/Bridge";
16
10
  import { Payment } from "./payment/Payment";
17
- import { Profile } from "./payment/Profile";
18
- import { Bridge } from "./payment/Bridge";
19
-
20
- import ConnectPrimaryWallet from "./connect/PrimaryWallet";
21
11
  import { LogoutPopup } from "./connect/LogoutPopup";
12
+ import { Bridge } from "./payment/Bridge";
13
+ import { Profile } from "./payment/Profile";
14
+ import { SelectTokenPopup } from "./payment/SelectToken";
22
15
  import { WalletPicker } from "./connect/WalletPicker";
16
+ import { BridgeProps } from "./payment/Bridge";
23
17
  import { Connector } from "./connect/ConnectWallet";
18
+ import { SelectSender } from "./payment/SelectSender";
19
+ import { SelectRecipient } from "./payment/SelectRecipient";
24
20
  import { WCRequest } from "./connect/WCRequest";
25
- import Toast from "./Toast";
26
21
 
27
- export const openPayment = (
28
- connector: HotConnector,
29
- {
30
- intents,
31
- title,
32
- allowedTokens,
33
- prepaidAmount,
34
- payableToken,
35
- needAmount,
36
- onConfirm,
37
- }: {
38
- intents: Intents;
39
- title?: string;
40
- allowedTokens?: string[];
41
- prepaidAmount: bigint;
42
- payableToken: Token;
43
- needAmount: bigint;
44
- onConfirm: (args: { depositQoute?: BridgeReview; processing?: () => Promise<BridgeReview> }) => Promise<void>;
45
- }
46
- ) => {
47
- return new Promise<void>((resolve, reject) => {
22
+ export const openPayment = (connector: HotConnector, token: Token, amount: bigint, recipient?: Recipient) => {
23
+ return new Promise<Promise<BridgeReview>>((resolve, reject) => {
48
24
  present((close) => (
49
25
  <Payment //
50
- title={title}
51
- intents={intents}
26
+ onClose={() => (close(), reject(new Error("User rejected")))}
27
+ onProcess={(task) => (close(), resolve(task))}
52
28
  connector={connector}
53
- needAmount={needAmount}
54
- prepaidAmount={prepaidAmount}
55
- allowedTokens={allowedTokens}
56
- payableToken={payableToken}
57
- close={() => (close(), resolve())}
58
- onReject={() => (close(), reject(new Error("User rejected")))}
59
- onConfirm={onConfirm}
29
+ token={token}
30
+ amount={amount}
31
+ recipient={recipient}
60
32
  />
61
33
  ));
62
34
  });
@@ -90,15 +62,7 @@ export const openBridge = (hot: HotConnector, setup?: BridgeProps["setup"]) => {
90
62
  };
91
63
 
92
64
  export const openConnector = (hot: HotConnector) => {
93
- return new Promise<void>((resolve) => {
94
- present((close) => <Connector hot={hot} onClose={() => (resolve(), close())} />);
95
- });
96
- };
97
-
98
- export const openConnectPrimaryWallet = (hot: HotConnector) => {
99
- return new Promise<void>((resolve) => {
100
- present((close) => <ConnectPrimaryWallet hot={hot} onClose={() => (close(), resolve())} />);
101
- });
65
+ present((close) => <Connector hot={hot} onClose={close} />);
102
66
  };
103
67
 
104
68
  export const openProfile = (hot: HotConnector) => {
@@ -126,7 +90,3 @@ export const openWCRequest = <T,>(args: { task: () => Promise<T>; deeplink?: str
126
90
  present((close) => <WCRequest deeplink={args.deeplink} name={args.name} icon={args.icon} onClose={close} task={taskPromise} />);
127
91
  return taskPromise;
128
92
  };
129
-
130
- export const openToast = (message: string) => {
131
- return present(() => <Toast message={message} />);
132
- };
package/src/ui/styles.ts CHANGED
@@ -195,7 +195,6 @@ export const PopupOption = styled.button`
195
195
  outline: none;
196
196
  border: none;
197
197
  background: transparent;
198
- width: 100%;
199
198
  gap: 12px;
200
199
 
201
200
  img {
@@ -265,7 +264,6 @@ export const PopupButton = styled.button`
265
264
 
266
265
  export const PopupRoot = styled.div`
267
266
  height: 100%;
268
- width: 100%;
269
267
 
270
268
  h1,
271
269
  h2,
@@ -1,13 +0,0 @@
1
- import { HotConnector } from "../HotConnector";
2
- export declare class Telemetry {
3
- readonly wibe3: HotConnector;
4
- events: {
5
- event: string;
6
- value_str?: string;
7
- value_float?: number;
8
- ts: number;
9
- }[];
10
- constructor(wibe3: HotConnector);
11
- flush(): Promise<void>;
12
- log(event: string, value: string | number): void;
13
- }
@@ -1,27 +0,0 @@
1
- import { api } from "./api";
2
- import { formatter } from "./utils";
3
- export class Telemetry {
4
- wibe3;
5
- events = [];
6
- constructor(wibe3) {
7
- this.wibe3 = wibe3;
8
- this.flush();
9
- }
10
- async flush() {
11
- await formatter.wait(5000);
12
- if (this.events.length > 0) {
13
- await api
14
- .publishTelemetry(this.events, this.wibe3.priorityWallet?.address ?? "")
15
- .then(() => (this.events = []))
16
- .catch(() => { });
17
- }
18
- await this.flush();
19
- }
20
- log(event, value) {
21
- if (typeof value === "string")
22
- this.events.push({ event, value_str: value, ts: Date.now() });
23
- else
24
- this.events.push({ event, value_float: value, ts: Date.now() });
25
- }
26
- }
27
- //# sourceMappingURL=telemetry.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"telemetry.js","sourceRoot":"","sources":["../../src/core/telemetry.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,OAAO,CAAC;AAE5B,OAAO,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAEpC,MAAM,OAAO,SAAS;IAEC;IADrB,MAAM,GAA8E,EAAE,CAAC;IACvF,YAAqB,KAAmB;QAAnB,UAAK,GAAL,KAAK,CAAc;QACtC,IAAI,CAAC,KAAK,EAAE,CAAC;IACf,CAAC;IAED,KAAK,CAAC,KAAK;QACT,MAAM,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAE3B,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC3B,MAAM,GAAG;iBACN,gBAAgB,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,KAAK,CAAC,cAAc,EAAE,OAAO,IAAI,EAAE,CAAC;iBACvE,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC,CAAC;iBAC9B,KAAK,CAAC,GAAG,EAAE,GAAE,CAAC,CAAC,CAAC;QACrB,CAAC;QAED,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC;IACrB,CAAC;IAED,GAAG,CAAC,KAAa,EAAE,KAAsB;QACvC,IAAI,OAAO,KAAK,KAAK,QAAQ;YAAE,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,EAAE,EAAE,IAAI,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;;YACxF,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,WAAW,EAAE,KAAK,EAAE,EAAE,EAAE,IAAI,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;IACvE,CAAC;CACF"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"rpc.js","sourceRoot":"","sources":["../../src/near/rpc.ts"],"names":[],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"WalletStandard.js","sourceRoot":"","sources":["../../src/solana/WalletStandard.ts"],"names":[],"mappings":"AAUA,MAAM,oBAAoB;IACH;IAAyB;IAA9C,YAAqB,MAAc,EAAW,OAAe;QAAxC,WAAM,GAAN,MAAM,CAAQ;QAAW,YAAO,GAAP,OAAO,CAAQ;IAAG,CAAC;IAEjE,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,MAAc,EAAE,EAAE,MAAM,GAAG,KAAK,KAA2B,EAAE;QAChF,MAAM,CAAC,GAAG,IAAI,oBAAoB,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;QAC/C,MAAM,OAAO,GAAG,MAAM,CAAC,CAAC,UAAU,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;QAC/C,OAAO,IAAI,oBAAoB,CAAC,MAAM,EAAE,OAAO,CAAC,OAAO,CAAC,CAAC;IAC3D,CAAC;IAED,KAAK,CAAC,UAAU,CAAC,EAAE,MAAM,GAAG,KAAK,KAA2B,EAAE;QAC5D,IAAI,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,IAAI,EAAE,CAAC;QAE1C,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC;YACrB,MAAM,OAAO,GAAI,IAAI,CAAC,MAAM,CAAC,QAAgB,CAAC,kBAAkB,CAAC,EAAE,OAAO,CAAC;YAC3E,IAAI,CAAC,OAAO;gBAAE,MAAM,IAAI,KAAK,CAAC,0CAA0C,CAAC,CAAC;YAC1E,MAAM,EAAE,QAAQ,EAAE,iBAAiB,EAAE,GAAG,MAAM,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;YAClE,QAAQ,GAAG,iBAAiB,IAAI,EAAE,CAAC;QACrC,CAAC;QAED,IAAI,CAAC,QAAQ,CAAC,MAAM;YAAE,MAAM,IAAI,KAAK,CAAC,kBAAkB,CAAC,CAAC;QAC1D,OAAO,QAAQ,CAAC,CAAC,CAAC,CAAC;IACrB,CAAC;IAED,KAAK,CAAC,UAAU;QACd,MAAM,UAAU,GAAI,IAAI,CAAC,MAAM,CAAC,QAAgB,CAAC,qBAAqB,CAAC,EAAE,UAA+C,CAAC;QACzH,IAAI,UAAU;YAAE,MAAM,UAAU,EAAE,CAAC;IACrC,CAAC;IAED,KAAK,CAAC,eAAe,CAAC,WAA+C,EAAE,UAAsB,EAAE,OAAa;QAC1G,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,UAAU,EAAE,CAAC;QACxC,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,QAAe,CAAC;QAC7C,MAAM,MAAM,GAAG,QAAQ,CAAC,wBAAwB,CAAC,EAAE,eAAe,CAAC;QACnE,MAAM,CAAC,MAAM,CAAC,GAAG,MAAM,MAAM,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,WAAW,EAAE,WAAW,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;QAC3G,MAAM,QAAQ,GAAG,MAAM,CAAC,iBAAoE,CAAC;QAC7F,MAAM,GAAG,GAAG,QAAQ,YAAY,UAAU,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAE,QAAgB,CAAC,SAAS,EAAE,CAAC;QACtF,MAAM,GAAG,GAAG,MAAM,UAAU,CAAC,kBAAkB,CAAC,GAAiB,EAAE,OAAc,CAAC,CAAC;QACnF,OAAO,GAAG,CAAC;IACb,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,OAAe;QAC/B,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,UAAU,EAAE,CAAC;QACxC,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,QAAe,CAAC;QAC7C,MAAM,kBAAkB,GAAG,QAAQ,CAAC,oBAAoB,CAAC,EAAE,WAAW,CAAC;QAEvE,IAAI,CAAC,kBAAkB;YAAE,MAAM,IAAI,KAAK,CAAC,4CAA4C,CAAC,CAAC;QACvF,MAAM,CAAC,MAAM,CAAC,GAAG,MAAM,kBAAkB,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAEnG,IAAI,MAAM,CAAC,SAAS;YAAE,OAAO,MAAM,CAAC,SAAS,CAAC;QAC9C,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,EAAE,SAAS;YAAE,OAAO,MAAM,CAAC,CAAC,CAAC,CAAC,SAAuB,CAAC;QAC5F,MAAM,IAAI,KAAK,CAAC,+BAA+B,CAAC,CAAC;IACnD,CAAC;CACF;AAED,eAAe,oBAAoB,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"walletStandartList.js","sourceRoot":"","sources":["../../src/solana/walletStandartList.ts"],"names":[],"mappings":"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"}