@b3dotfun/sdk 0.0.40-alpha.2 → 0.0.40-alpha.20

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 (166) hide show
  1. package/dist/cjs/anyspend/react/components/AnySpend.d.ts +10 -1
  2. package/dist/cjs/anyspend/react/components/AnySpend.js +8 -4
  3. package/dist/cjs/anyspend/react/components/AnySpendBondKit.js +0 -1
  4. package/dist/cjs/anyspend/react/components/AnySpendBuySpin.js +0 -1
  5. package/dist/cjs/anyspend/react/components/AnySpendCustom.js +5 -7
  6. package/dist/cjs/anyspend/react/components/AnySpendStakeB3.js +0 -1
  7. package/dist/cjs/anyspend/react/components/AnyspendDepositHype.d.ts +8 -0
  8. package/dist/cjs/anyspend/react/components/AnyspendDepositHype.js +6 -3
  9. package/dist/cjs/anyspend/react/components/AnyspendSignatureMint.js +0 -1
  10. package/dist/cjs/anyspend/react/components/common/ConnectWalletPayment.js +5 -3
  11. package/dist/cjs/anyspend/react/components/common/CryptoPaySection.d.ts +4 -1
  12. package/dist/cjs/anyspend/react/components/common/CryptoPaySection.js +9 -9
  13. package/dist/cjs/anyspend/react/components/common/CryptoPaymentMethod.js +80 -10
  14. package/dist/cjs/anyspend/react/components/common/CryptoReceiveSection.d.ts +2 -1
  15. package/dist/cjs/anyspend/react/components/common/CryptoReceiveSection.js +39 -37
  16. package/dist/cjs/anyspend/react/components/common/OrderDetails.js +8 -8
  17. package/dist/cjs/anyspend/react/components/common/OrderTokenAmount.d.ts +4 -1
  18. package/dist/cjs/anyspend/react/components/common/OrderTokenAmount.js +23 -9
  19. package/dist/cjs/anyspend/react/components/common/PanelOnramp.d.ts +4 -1
  20. package/dist/cjs/anyspend/react/components/common/PanelOnramp.js +7 -6
  21. package/dist/cjs/anyspend/react/components/common/PointsDetailPanel.d.ts +6 -0
  22. package/dist/cjs/anyspend/react/components/common/PointsDetailPanel.js +14 -0
  23. package/dist/cjs/anyspend/react/contexts/FeatureFlagsContext.d.ts +11 -0
  24. package/dist/cjs/anyspend/react/contexts/FeatureFlagsContext.js +21 -0
  25. package/dist/cjs/anyspend/react/hooks/useAnyspendFlow.d.ts +4 -1
  26. package/dist/cjs/anyspend/react/hooks/useAnyspendFlow.js +1 -0
  27. package/dist/cjs/anyspend/react/providers/AnyspendProvider.d.ts +5 -2
  28. package/dist/cjs/anyspend/react/providers/AnyspendProvider.js +5 -3
  29. package/dist/cjs/anyspend/react/providers/index.d.ts +1 -0
  30. package/dist/cjs/anyspend/react/providers/index.js +3 -0
  31. package/dist/cjs/anyspend/types/api.d.ts +11 -1
  32. package/dist/cjs/anyspend/utils/orderPayload.js +1 -0
  33. package/dist/cjs/bondkit/bondkitToken.d.ts +37 -2
  34. package/dist/cjs/bondkit/bondkitToken.js +268 -2
  35. package/dist/cjs/bondkit/bondkitTokenFactory.d.ts +1 -1
  36. package/dist/cjs/bondkit/bondkitTokenFactory.js +2 -2
  37. package/dist/cjs/bondkit/config.d.ts +1 -1
  38. package/dist/cjs/bondkit/config.js +5 -2
  39. package/dist/cjs/bondkit/constants.d.ts +4 -0
  40. package/dist/cjs/bondkit/constants.js +6 -1
  41. package/dist/cjs/bondkit/index.d.ts +1 -0
  42. package/dist/cjs/bondkit/index.js +4 -1
  43. package/dist/cjs/bondkit/swapService.d.ts +43 -0
  44. package/dist/cjs/bondkit/swapService.js +373 -0
  45. package/dist/cjs/bondkit/types.d.ts +10 -4
  46. package/dist/cjs/bondkit/types.js +4 -5
  47. package/dist/cjs/global-account/react/components/B3Provider/B3Provider.d.ts +4 -3
  48. package/dist/cjs/global-account/react/components/B3Provider/B3Provider.js +35 -9
  49. package/dist/cjs/global-account/react/components/LinkAccount/LinkAccount.js +63 -3
  50. package/dist/cjs/global-account/react/components/ManageAccount/ManageAccount.js +35 -2
  51. package/dist/cjs/global-account/react/components/SignInWithB3/steps/LoginStepCustom.js +4 -3
  52. package/dist/cjs/global-account/react/hooks/useAuthentication.js +1 -2
  53. package/dist/cjs/global-account/react/hooks/useSimBalance.js +2 -2
  54. package/dist/cjs/global-account/react/hooks/useUnifiedChainSwitchAndExecute.js +22 -20
  55. package/dist/esm/anyspend/react/components/AnySpend.d.ts +10 -1
  56. package/dist/esm/anyspend/react/components/AnySpend.js +8 -4
  57. package/dist/esm/anyspend/react/components/AnySpendBondKit.js +0 -1
  58. package/dist/esm/anyspend/react/components/AnySpendBuySpin.js +0 -1
  59. package/dist/esm/anyspend/react/components/AnySpendCustom.js +5 -7
  60. package/dist/esm/anyspend/react/components/AnySpendStakeB3.js +0 -1
  61. package/dist/esm/anyspend/react/components/AnyspendDepositHype.d.ts +8 -0
  62. package/dist/esm/anyspend/react/components/AnyspendDepositHype.js +6 -3
  63. package/dist/esm/anyspend/react/components/AnyspendSignatureMint.js +0 -1
  64. package/dist/esm/anyspend/react/components/common/ConnectWalletPayment.js +6 -4
  65. package/dist/esm/anyspend/react/components/common/CryptoPaySection.d.ts +4 -1
  66. package/dist/esm/anyspend/react/components/common/CryptoPaySection.js +9 -9
  67. package/dist/esm/anyspend/react/components/common/CryptoPaymentMethod.js +80 -10
  68. package/dist/esm/anyspend/react/components/common/CryptoReceiveSection.d.ts +2 -1
  69. package/dist/esm/anyspend/react/components/common/CryptoReceiveSection.js +39 -37
  70. package/dist/esm/anyspend/react/components/common/OrderDetails.js +8 -8
  71. package/dist/esm/anyspend/react/components/common/OrderTokenAmount.d.ts +4 -1
  72. package/dist/esm/anyspend/react/components/common/OrderTokenAmount.js +23 -9
  73. package/dist/esm/anyspend/react/components/common/PanelOnramp.d.ts +4 -1
  74. package/dist/esm/anyspend/react/components/common/PanelOnramp.js +7 -6
  75. package/dist/esm/anyspend/react/components/common/PointsDetailPanel.d.ts +6 -0
  76. package/dist/esm/anyspend/react/components/common/PointsDetailPanel.js +8 -0
  77. package/dist/esm/anyspend/react/contexts/FeatureFlagsContext.d.ts +11 -0
  78. package/dist/esm/anyspend/react/contexts/FeatureFlagsContext.js +17 -0
  79. package/dist/esm/anyspend/react/hooks/useAnyspendFlow.d.ts +4 -1
  80. package/dist/esm/anyspend/react/hooks/useAnyspendFlow.js +1 -0
  81. package/dist/esm/anyspend/react/providers/AnyspendProvider.d.ts +5 -2
  82. package/dist/esm/anyspend/react/providers/AnyspendProvider.js +5 -3
  83. package/dist/esm/anyspend/react/providers/index.d.ts +1 -0
  84. package/dist/esm/anyspend/react/providers/index.js +1 -0
  85. package/dist/esm/anyspend/types/api.d.ts +11 -1
  86. package/dist/esm/anyspend/utils/orderPayload.js +1 -0
  87. package/dist/esm/bondkit/bondkitToken.d.ts +37 -2
  88. package/dist/esm/bondkit/bondkitToken.js +268 -2
  89. package/dist/esm/bondkit/bondkitTokenFactory.d.ts +1 -1
  90. package/dist/esm/bondkit/bondkitTokenFactory.js +2 -2
  91. package/dist/esm/bondkit/config.d.ts +1 -1
  92. package/dist/esm/bondkit/config.js +5 -2
  93. package/dist/esm/bondkit/constants.d.ts +4 -0
  94. package/dist/esm/bondkit/constants.js +5 -0
  95. package/dist/esm/bondkit/index.d.ts +1 -0
  96. package/dist/esm/bondkit/index.js +2 -0
  97. package/dist/esm/bondkit/swapService.d.ts +43 -0
  98. package/dist/esm/bondkit/swapService.js +369 -0
  99. package/dist/esm/bondkit/types.d.ts +10 -4
  100. package/dist/esm/bondkit/types.js +4 -5
  101. package/dist/esm/global-account/react/components/B3Provider/B3Provider.d.ts +4 -3
  102. package/dist/esm/global-account/react/components/B3Provider/B3Provider.js +36 -9
  103. package/dist/esm/global-account/react/components/LinkAccount/LinkAccount.js +65 -5
  104. package/dist/esm/global-account/react/components/ManageAccount/ManageAccount.js +35 -2
  105. package/dist/esm/global-account/react/components/SignInWithB3/steps/LoginStepCustom.js +3 -2
  106. package/dist/esm/global-account/react/hooks/useAuthentication.js +1 -2
  107. package/dist/esm/global-account/react/hooks/useSimBalance.js +2 -2
  108. package/dist/esm/global-account/react/hooks/useUnifiedChainSwitchAndExecute.js +22 -20
  109. package/dist/styles/index.css +1 -1
  110. package/dist/types/anyspend/react/components/AnySpend.d.ts +10 -1
  111. package/dist/types/anyspend/react/components/AnyspendDepositHype.d.ts +8 -0
  112. package/dist/types/anyspend/react/components/common/CryptoPaySection.d.ts +4 -1
  113. package/dist/types/anyspend/react/components/common/CryptoReceiveSection.d.ts +2 -1
  114. package/dist/types/anyspend/react/components/common/OrderTokenAmount.d.ts +4 -1
  115. package/dist/types/anyspend/react/components/common/PanelOnramp.d.ts +4 -1
  116. package/dist/types/anyspend/react/components/common/PointsDetailPanel.d.ts +6 -0
  117. package/dist/types/anyspend/react/contexts/FeatureFlagsContext.d.ts +11 -0
  118. package/dist/types/anyspend/react/hooks/useAnyspendFlow.d.ts +4 -1
  119. package/dist/types/anyspend/react/providers/AnyspendProvider.d.ts +5 -2
  120. package/dist/types/anyspend/react/providers/index.d.ts +1 -0
  121. package/dist/types/anyspend/types/api.d.ts +11 -1
  122. package/dist/types/bondkit/bondkitToken.d.ts +37 -2
  123. package/dist/types/bondkit/bondkitTokenFactory.d.ts +1 -1
  124. package/dist/types/bondkit/config.d.ts +1 -1
  125. package/dist/types/bondkit/constants.d.ts +4 -0
  126. package/dist/types/bondkit/index.d.ts +1 -0
  127. package/dist/types/bondkit/swapService.d.ts +43 -0
  128. package/dist/types/bondkit/types.d.ts +10 -4
  129. package/dist/types/global-account/react/components/B3Provider/B3Provider.d.ts +4 -3
  130. package/package.json +6 -5
  131. package/src/anyspend/react/components/AnySpend.tsx +24 -1
  132. package/src/anyspend/react/components/AnySpendBondKit.tsx +0 -1
  133. package/src/anyspend/react/components/AnySpendBuySpin.tsx +0 -1
  134. package/src/anyspend/react/components/AnySpendCustom.tsx +5 -7
  135. package/src/anyspend/react/components/AnySpendStakeB3.tsx +0 -1
  136. package/src/anyspend/react/components/AnyspendDepositHype.tsx +22 -0
  137. package/src/anyspend/react/components/AnyspendSignatureMint.tsx +0 -1
  138. package/src/anyspend/react/components/common/ConnectWalletPayment.tsx +7 -4
  139. package/src/anyspend/react/components/common/CryptoPaySection.tsx +13 -8
  140. package/src/anyspend/react/components/common/CryptoPaymentMethod.tsx +170 -44
  141. package/src/anyspend/react/components/common/CryptoReceiveSection.tsx +63 -45
  142. package/src/anyspend/react/components/common/OrderDetails.tsx +8 -9
  143. package/src/anyspend/react/components/common/OrderTokenAmount.tsx +28 -8
  144. package/src/anyspend/react/components/common/PanelOnramp.tsx +28 -15
  145. package/src/anyspend/react/components/common/PointsDetailPanel.tsx +55 -0
  146. package/src/anyspend/react/contexts/FeatureFlagsContext.tsx +34 -0
  147. package/src/anyspend/react/hooks/useAnyspendFlow.ts +1 -0
  148. package/src/anyspend/react/providers/AnyspendProvider.tsx +11 -6
  149. package/src/anyspend/react/providers/index.ts +1 -0
  150. package/src/anyspend/types/api.ts +11 -1
  151. package/src/anyspend/types/api_req_res.ts +6 -10
  152. package/src/anyspend/utils/orderPayload.ts +1 -0
  153. package/src/bondkit/bondkitToken.ts +323 -3
  154. package/src/bondkit/bondkitTokenFactory.ts +2 -2
  155. package/src/bondkit/config.ts +5 -2
  156. package/src/bondkit/constants.ts +7 -0
  157. package/src/bondkit/index.ts +3 -0
  158. package/src/bondkit/swapService.ts +461 -0
  159. package/src/bondkit/types.ts +12 -5
  160. package/src/global-account/react/components/B3Provider/B3Provider.tsx +51 -15
  161. package/src/global-account/react/components/LinkAccount/LinkAccount.tsx +106 -32
  162. package/src/global-account/react/components/ManageAccount/ManageAccount.tsx +60 -5
  163. package/src/global-account/react/components/SignInWithB3/steps/LoginStepCustom.tsx +4 -2
  164. package/src/global-account/react/hooks/useAuthentication.ts +1 -2
  165. package/src/global-account/react/hooks/useSimBalance.ts +2 -2
  166. package/src/global-account/react/hooks/useUnifiedChainSwitchAndExecute.ts +23 -21
@@ -3,11 +3,14 @@ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
3
  import { useAccountWallet } from "../../../../global-account/react/index.js";
4
4
  import { cn } from "../../../../shared/utils/cn.js";
5
5
  import { shortenAddress } from "../../../../shared/utils/formatAddress.js";
6
+ import { client } from "../../../../shared/utils/thirdweb.js";
6
7
  import { WalletCoinbase, WalletMetamask, WalletPhantom, WalletRainbow, WalletWalletConnect } from "@web3icons/react";
7
8
  import { ChevronLeft, ChevronRightCircle, Wallet, X, ZapIcon } from "lucide-react";
8
9
  import { useState } from "react";
9
10
  import { createPortal } from "react-dom";
10
11
  import { toast } from "sonner";
12
+ import { useSetActiveWallet, useWalletInfo } from "thirdweb/react";
13
+ import { createWallet } from "thirdweb/wallets";
11
14
  import { useAccount, useConnect, useDisconnect, useWalletClient } from "wagmi";
12
15
  export var CryptoPaymentMethodType;
13
16
  (function (CryptoPaymentMethodType) {
@@ -17,12 +20,58 @@ export var CryptoPaymentMethodType;
17
20
  CryptoPaymentMethodType["TRANSFER_CRYPTO"] = "transfer_crypto";
18
21
  })(CryptoPaymentMethodType || (CryptoPaymentMethodType = {}));
19
22
  export function CryptoPaymentMethod({ selectedPaymentMethod, setSelectedPaymentMethod, isCreatingOrder, onBack, onSelectPaymentMethod, }) {
20
- const { wallet: globalWallet, address: globalAddress } = useAccountWallet();
21
- const { address, isConnected, connector } = useAccount();
23
+ const { wallet: globalWallet, connectedEOAWallet: connectedEOAWallet, connectedSmartWallet: connectedSmartWallet, } = useAccountWallet();
24
+ const { connector, address, isConnected: wagmiWalletIsConnected } = useAccount();
22
25
  const { connect, connectors, isPending } = useConnect();
23
26
  const { disconnect } = useDisconnect();
24
27
  const { data: walletClient } = useWalletClient();
25
28
  const [showWalletModal, setShowWalletModal] = useState(false);
29
+ const setActiveWallet = useSetActiveWallet();
30
+ const { data: eoaWalletInfo } = useWalletInfo(connectedEOAWallet?.id);
31
+ const isConnected = !!connectedEOAWallet;
32
+ const globalAddress = connectedSmartWallet?.getAccount()?.address;
33
+ // Helper function to check if two addresses are the same
34
+ const isSameAddress = (addr1, addr2) => {
35
+ if (!addr1 || !addr2)
36
+ return false;
37
+ return addr1.toLowerCase() === addr2.toLowerCase();
38
+ };
39
+ // Check if connectedEOAWallet and wagmi wallet represent the same wallet
40
+ const connectedEOAAddress = connectedEOAWallet?.getAccount()?.address;
41
+ const wagmiAddress = address;
42
+ const isWalletDuplicated = isSameAddress(connectedEOAAddress, wagmiAddress);
43
+ // Determine which wallet to show (prefer connectedEOAWallet if both exist and are the same)
44
+ const shouldShowConnectedEOA = !!connectedEOAWallet;
45
+ const shouldShowWagmiWallet = wagmiWalletIsConnected && (!isWalletDuplicated || !connectedEOAWallet);
46
+ // Map wagmi connector names to thirdweb wallet IDs
47
+ const getThirdwebWalletId = (connectorName) => {
48
+ const walletMap = {
49
+ MetaMask: "io.metamask",
50
+ "Coinbase Wallet": "com.coinbase.wallet",
51
+ Rainbow: "me.rainbow",
52
+ WalletConnect: "walletConnect",
53
+ Phantom: "app.phantom",
54
+ };
55
+ return walletMap[connectorName] || null;
56
+ };
57
+ // Create thirdweb wallet from wagmi connector
58
+ const createThirdwebWalletFromConnector = async (connectorName) => {
59
+ const walletId = getThirdwebWalletId(connectorName);
60
+ if (!walletId) {
61
+ console.warn(`No thirdweb wallet ID found for connector: ${connectorName}`);
62
+ return null;
63
+ }
64
+ try {
65
+ const thirdwebWallet = createWallet(walletId);
66
+ // Connect the wallet to sync with the existing wagmi connection
67
+ await thirdwebWallet.connect({ client });
68
+ return thirdwebWallet;
69
+ }
70
+ catch (error) {
71
+ console.error(`Failed to create thirdweb wallet for ${connectorName}:`, error);
72
+ return null;
73
+ }
74
+ };
26
75
  // Define available wallet connectors
27
76
  const availableConnectors = connectors.filter(connector => ["MetaMask", "WalletConnect", "Coinbase Wallet", "Rainbow", "Phantom"].includes(connector.name));
28
77
  // Define wallet options with icons and info
@@ -117,15 +166,30 @@ export function CryptoPaymentMethod({ selectedPaymentMethod, setSelectedPaymentM
117
166
  }
118
167
  }
119
168
  };
120
- return (_jsxs("div", { className: "crypto-payment-method mx-auto h-fit w-[460px] max-w-full", children: [_jsxs("div", { className: cn("relative flex flex-col gap-10"), children: [_jsx("button", { onClick: onBack, className: "text-as-quaternary hover:text-as-primary absolute flex h-8 w-8 items-center justify-center rounded-lg transition-colors", children: _jsx(ChevronLeft, { className: "h-6 w-6" }) }), _jsx("div", { className: "flex items-center justify-around gap-4", children: _jsx("div", { className: "flex-1 text-center", children: _jsx("h2", { className: "text-as-primary text-lg font-semibold", children: "Select a payment method" }) }) }), _jsxs("div", { className: "crypto-payment-methods flex flex-col gap-6", children: [_jsxs("button", { onClick: () => {
121
- // Always show wallet selection modal first
122
- setShowWalletModal(true);
123
- }, className: "crypto-payment-method-connect-wallet bg-as-surface-primary border-as-border-secondary hover:border-as-secondary/80 group flex w-full items-center justify-between gap-4 rounded-xl border px-4 py-3.5 transition-all duration-200 hover:shadow-md", children: [_jsxs("div", { className: "flex items-center gap-3", children: [_jsx("div", { className: "wallet-icon flex h-8 w-8 items-center justify-center rounded-full bg-blue-100", children: _jsx(Wallet, { className: "h-4 w-4 text-blue-600" }) }), _jsx("div", { className: "flex flex-col items-start text-left", children: _jsx("h4", { className: "text-as-primary font-semibold", children: "Connect wallet" }) })] }), _jsx(ChevronRightCircle, { className: "text-as-primary/40 group-hover:text-as-primary/60 h-5 w-5 transition-colors" })] }), _jsxs("button", { onClick: () => {
124
- setSelectedPaymentMethod(CryptoPaymentMethodType.TRANSFER_CRYPTO);
125
- onSelectPaymentMethod(CryptoPaymentMethodType.TRANSFER_CRYPTO);
126
- }, disabled: isCreatingOrder, className: "crypto-payment-method-transfer bg-as-surface-primary border-as-border-secondary hover:border-as-secondary/80 group flex w-full items-center justify-between gap-4 rounded-xl border px-4 py-3.5 transition-all duration-200 hover:shadow-md", children: [_jsxs("div", { className: "flex items-center gap-3", children: [_jsx("div", { className: "wallet-icon flex h-8 w-8 items-center justify-center rounded-full bg-orange-100", children: _jsx(ZapIcon, { className: "h-4 w-4" }) }), _jsx("div", { className: "flex flex-col items-start text-left", children: _jsx("h4", { className: "text-as-primary font-semibold", children: "Transfer crypto" }) })] }), _jsx(ChevronRightCircle, { className: "text-as-primary/40 group-hover:text-as-primary/60 h-5 w-5 transition-colors" })] }), (isConnected || globalAddress) && (_jsxs("div", { className: "installed-wallets", children: [_jsx("h3", { className: "text-as-primary/80 mb-3 text-sm font-medium", children: "Connected wallets" }), _jsxs("div", { className: "space-y-2", children: [isConnected && (_jsx("button", { onClick: () => {
169
+ return (_jsxs("div", { className: "crypto-payment-method mx-auto h-fit w-[460px] max-w-full", children: [_jsxs("div", { className: cn("relative flex flex-col gap-10"), children: [_jsx("button", { onClick: onBack, className: "text-as-quaternary hover:text-as-primary absolute flex h-8 w-8 items-center justify-center rounded-lg transition-colors", children: _jsx(ChevronLeft, { className: "h-6 w-6" }) }), _jsx("div", { className: "flex items-center justify-around gap-4", children: _jsx("div", { className: "flex-1 text-center", children: _jsx("h2", { className: "text-as-primary text-lg font-semibold", children: "Select a payment method" }) }) }), _jsxs("div", { className: "crypto-payment-methods flex flex-col gap-4", children: [(shouldShowConnectedEOA || shouldShowWagmiWallet || globalAddress) && (_jsxs("div", { className: "installed-wallets", children: [_jsx("h3", { className: "text-as-primary/80 mb-3 text-sm font-medium", children: "Connected wallets" }), _jsxs("div", { className: "space-y-2", children: [shouldShowConnectedEOA && (_jsx("button", { onClick: () => {
170
+ setSelectedPaymentMethod(CryptoPaymentMethodType.CONNECT_WALLET);
171
+ onSelectPaymentMethod(CryptoPaymentMethodType.CONNECT_WALLET);
172
+ setActiveWallet(connectedEOAWallet);
173
+ toast.success(`Selected ${eoaWalletInfo?.name || connector?.name || "wallet"}`);
174
+ }, className: cn("crypto-payment-method-connect-wallet w-full rounded-xl border p-4 text-left transition-all hover:shadow-md", selectedPaymentMethod === CryptoPaymentMethodType.CONNECT_WALLET
175
+ ? "connected-wallet border-as-brand bg-as-brand/5"
176
+ : "border-as-border-secondary bg-as-surface-primary hover:border-as-secondary/80"), children: _jsxs("div", { className: "flex items-center justify-between", children: [_jsxs("div", { className: "flex items-center gap-3", children: [_jsx("div", { className: "wallet-icon flex h-10 w-10 items-center justify-center rounded-full bg-blue-100", children: _jsx(Wallet, { className: "h-5 w-5 text-blue-600" }) }), _jsxs("div", { className: "flex flex-col", children: [_jsx("span", { className: "text-as-primary font-semibold", children: eoaWalletInfo?.name || connector?.name || "Connected Wallet" }), _jsx("span", { className: "text-as-primary/60 text-sm", children: shortenAddress(connectedEOAWallet?.getAccount()?.address || "") })] })] }), _jsxs("div", { className: "flex items-center gap-2", children: [selectedPaymentMethod === CryptoPaymentMethodType.CONNECT_WALLET && (_jsx("div", { className: "h-2 w-2 rounded-full bg-green-500" })), _jsx("button", { onClick: e => {
177
+ e.stopPropagation();
178
+ disconnect();
179
+ toast.success("Wallet disconnected");
180
+ if (selectedPaymentMethod === CryptoPaymentMethodType.CONNECT_WALLET) {
181
+ setSelectedPaymentMethod(CryptoPaymentMethodType.NONE);
182
+ }
183
+ }, className: "text-as-primary/60 hover:text-as-primary/80 rounded-lg p-1.5 transition-colors", children: _jsx(X, { className: "h-4 w-4" }) })] })] }) })), shouldShowWagmiWallet && (_jsx("button", { onClick: async () => {
127
184
  setSelectedPaymentMethod(CryptoPaymentMethodType.CONNECT_WALLET);
128
185
  onSelectPaymentMethod(CryptoPaymentMethodType.CONNECT_WALLET);
186
+ // Create thirdweb wallet from wagmi connector
187
+ if (connector?.name) {
188
+ const thirdwebWallet = await createThirdwebWalletFromConnector(connector.name);
189
+ if (thirdwebWallet) {
190
+ setActiveWallet(thirdwebWallet);
191
+ }
192
+ }
129
193
  toast.success(`Selected ${connector?.name || "wallet"}`);
130
194
  }, className: cn("crypto-payment-method-connect-wallet w-full rounded-xl border p-4 text-left transition-all hover:shadow-md", selectedPaymentMethod === CryptoPaymentMethodType.CONNECT_WALLET
131
195
  ? "connected-wallet border-as-brand bg-as-brand/5"
@@ -142,7 +206,13 @@ export function CryptoPaymentMethod({ selectedPaymentMethod, setSelectedPaymentM
142
206
  toast.success("Selected B3 Account");
143
207
  }, className: cn("crypto-payment-method-global-wallet w-full rounded-xl border p-4 text-left transition-all hover:shadow-md", selectedPaymentMethod === CryptoPaymentMethodType.GLOBAL_WALLET
144
208
  ? "connected-wallet border-as-brand bg-as-brand/5"
145
- : "border-as-border-secondary bg-as-surface-primary hover:border-as-secondary/80"), children: _jsxs("div", { className: "flex items-center justify-between", children: [_jsxs("div", { className: "flex items-center gap-3", children: [globalWallet?.meta?.icon ? (_jsx("img", { src: globalWallet.meta.icon, alt: "Global Account", className: "h-10 w-10 rounded-full" })) : (_jsx("div", { className: "wallet-icon flex h-10 w-10 items-center justify-center rounded-full bg-purple-100", children: _jsx(Wallet, { className: "h-5 w-5 text-purple-600" }) })), _jsxs("div", { className: "flex flex-col", children: [_jsx("span", { className: "text-as-primary font-semibold", children: "Global Account" }), _jsx("span", { className: "text-as-primary/60 text-sm", children: shortenAddress(globalAddress || "") })] })] }), _jsx("div", { className: "flex items-center gap-2", children: selectedPaymentMethod === CryptoPaymentMethodType.GLOBAL_WALLET && (_jsx("div", { className: "h-2 w-2 rounded-full bg-green-500" })) })] }) }))] })] }))] })] }), showWalletModal &&
209
+ : "border-as-border-secondary bg-as-surface-primary hover:border-as-secondary/80"), children: _jsxs("div", { className: "flex items-center justify-between", children: [_jsxs("div", { className: "flex items-center gap-3", children: [globalWallet?.meta?.icon ? (_jsx("img", { src: globalWallet.meta.icon, alt: "Global Account", className: "h-10 w-10 rounded-full" })) : (_jsx("div", { className: "wallet-icon flex h-10 w-10 items-center justify-center rounded-full bg-purple-100", children: _jsx(Wallet, { className: "h-5 w-5 text-purple-600" }) })), _jsxs("div", { className: "flex flex-col", children: [_jsx("span", { className: "text-as-primary font-semibold", children: "Global Account" }), _jsx("span", { className: "text-as-primary/60 text-sm", children: shortenAddress(globalAddress || "") })] })] }), _jsx("div", { className: "flex items-center gap-2", children: selectedPaymentMethod === CryptoPaymentMethodType.GLOBAL_WALLET && (_jsx("div", { className: "h-2 w-2 rounded-full bg-green-500" })) })] }) }))] })] })), _jsxs("div", { className: "other-payment-methods", children: [_jsx("h3", { className: "text-as-primary/80 mb-3 text-sm font-medium", children: "Payment methods" }), _jsxs("div", { className: "space-y-3", children: [_jsxs("button", { onClick: () => {
210
+ // Always show wallet selection modal first
211
+ setShowWalletModal(true);
212
+ }, className: "crypto-payment-method-connect-wallet bg-as-surface-primary border-as-border-secondary hover:border-as-secondary/80 group flex w-full items-center justify-between gap-4 rounded-xl border px-4 py-3.5 transition-all duration-200 hover:shadow-md", children: [_jsxs("div", { className: "flex items-center gap-3", children: [_jsx("div", { className: "wallet-icon flex h-8 w-8 items-center justify-center rounded-full bg-blue-100", children: _jsx(Wallet, { className: "h-4 w-4 text-blue-600" }) }), _jsx("div", { className: "flex flex-col items-start text-left", children: _jsx("h4", { className: "text-as-primary font-semibold", children: "Connect wallet" }) })] }), _jsx(ChevronRightCircle, { className: "text-as-primary/40 group-hover:text-as-primary/60 h-5 w-5 transition-colors" })] }), _jsxs("button", { onClick: () => {
213
+ setSelectedPaymentMethod(CryptoPaymentMethodType.TRANSFER_CRYPTO);
214
+ onSelectPaymentMethod(CryptoPaymentMethodType.TRANSFER_CRYPTO);
215
+ }, disabled: isCreatingOrder, className: "crypto-payment-method-transfer bg-as-surface-primary border-as-border-secondary hover:border-as-secondary/80 group flex w-full items-center justify-between gap-4 rounded-xl border px-4 py-3.5 transition-all duration-200 hover:shadow-md", children: [_jsxs("div", { className: "flex items-center gap-3", children: [_jsx("div", { className: "wallet-icon flex h-8 w-8 items-center justify-center rounded-full bg-orange-100", children: _jsx(ZapIcon, { className: "h-4 w-4" }) }), _jsx("div", { className: "flex flex-col items-start text-left", children: _jsx("h4", { className: "text-as-primary font-semibold", children: "Transfer crypto" }) })] }), _jsx(ChevronRightCircle, { className: "text-as-primary/40 group-hover:text-as-primary/60 h-5 w-5 transition-colors" })] })] })] })] })] }), showWalletModal &&
146
216
  createPortal(_jsx("div", { className: "wallet-connection-modal pointer-events-auto fixed inset-0 z-[9999] flex items-center justify-center bg-black/50", children: _jsxs("div", { className: "max-h-[80vh] w-[400px] max-w-[90vw] overflow-auto rounded-xl bg-white p-6 dark:bg-gray-900", children: [_jsxs("div", { className: "mb-4 flex items-center justify-between", children: [_jsx("h3", { className: "text-lg font-semibold text-gray-900 dark:text-white", children: isConnected ? "Switch wallet or account" : "Choose wallet to connect" }), _jsx("button", { onClick: handleCloseModal, className: "text-gray-500 hover:text-gray-700 dark:text-gray-400 dark:hover:text-gray-200", children: _jsx(X, { className: "h-5 w-5" }) })] }), _jsx("div", { className: "space-y-4", children: _jsx("div", { className: "space-y-3", children: walletOptions.map(walletOption => {
147
217
  const isCurrentWallet = isConnected && connector?.name === walletOption.connector?.name;
148
218
  return (_jsx("button", { onClick: async () => {
@@ -14,6 +14,7 @@ interface CryptoReceiveSectionProps {
14
14
  anyspendQuote?: any;
15
15
  dstTokenSymbol?: string;
16
16
  dstTokenLogoURI?: string;
17
+ onShowPointsDetail?: () => void;
17
18
  }
18
- export declare function CryptoReceiveSection({ isDepositMode, isBuyMode, selectedRecipientAddress, recipientName, onSelectRecipient, dstAmount, dstToken, selectedDstChainId, setSelectedDstChainId, setSelectedDstToken, onChangeDstAmount, anyspendQuote, dstTokenSymbol, dstTokenLogoURI, }: CryptoReceiveSectionProps): import("react/jsx-runtime").JSX.Element;
19
+ export declare function CryptoReceiveSection({ isDepositMode, isBuyMode, selectedRecipientAddress, recipientName, onSelectRecipient, dstAmount, dstToken, selectedDstChainId, setSelectedDstChainId, setSelectedDstToken, onChangeDstAmount, anyspendQuote, dstTokenSymbol, dstTokenLogoURI, onShowPointsDetail, }: CryptoReceiveSectionProps): import("react/jsx-runtime").JSX.Element;
19
20
  export {};
@@ -5,46 +5,48 @@ import { shortenAddress } from "../../../../shared/utils/formatAddress.js";
5
5
  import { formatDisplayNumber } from "../../../../shared/utils/number.js";
6
6
  import { ChevronRight } from "lucide-react";
7
7
  import { motion } from "motion/react";
8
+ import { useFeatureFlags } from "../../contexts/FeatureFlagsContext.js";
8
9
  import { OrderTokenAmount } from "./OrderTokenAmount.js";
9
- export function CryptoReceiveSection({ isDepositMode = false, isBuyMode = false, selectedRecipientAddress, recipientName, onSelectRecipient, dstAmount, dstToken, selectedDstChainId, setSelectedDstChainId, setSelectedDstToken, onChangeDstAmount, anyspendQuote, dstTokenSymbol, dstTokenLogoURI, }) {
10
+ export function CryptoReceiveSection({ isDepositMode = false, isBuyMode = false, selectedRecipientAddress, recipientName, onSelectRecipient, dstAmount, dstToken, selectedDstChainId, setSelectedDstChainId, setSelectedDstToken, onChangeDstAmount, anyspendQuote, dstTokenSymbol, dstTokenLogoURI, onShowPointsDetail, }) {
11
+ const featureFlags = useFeatureFlags();
10
12
  return (_jsxs(motion.div, { initial: { opacity: 0, y: 20, filter: "blur(10px)" }, animate: { opacity: 1, y: 0, filter: "blur(0px)" }, transition: { duration: 0.3, delay: 0.1, ease: "easeInOut" }, className: "receive-section bg-as-surface-secondary border-as-border-secondary relative flex w-full flex-col gap-2 rounded-2xl border p-4 sm:p-6", children: [_jsxs("div", { className: "flex w-full items-center justify-between", children: [_jsx("div", { className: "text-as-primary/50 flex h-7 items-center text-sm", children: isDepositMode ? "Deposit" : "Receive" }), selectedRecipientAddress ? (_jsx("button", { className: cn("text-as-tertiarry flex h-7 items-center gap-2 rounded-lg"), onClick: onSelectRecipient, children: _jsxs(_Fragment, { children: [_jsx("span", { className: "text-as-tertiarry flex items-center gap-1 text-sm", children: recipientName ? formatUsername(recipientName) : shortenAddress(selectedRecipientAddress || "") }), _jsx(ChevronRight, { className: "h-4 w-4" })] }) })) : (_jsx("button", { className: "text-as-primary/70 flex items-center gap-1 rounded-lg", onClick: onSelectRecipient, children: _jsx("div", { className: "text-sm font-medium", children: "Select recipient" }) }))] }), isBuyMode || isDepositMode ? (
11
13
  // Fixed destination token display for buy mode and deposit mode
12
14
  _jsxs("div", { className: "flex items-center justify-between", children: [_jsx("div", { className: "text-as-primary text-2xl font-bold", children: dstAmount || "0" }), _jsxs("div", { className: "bg-as-brand/10 border-as-brand/30 flex items-center gap-3 rounded-xl border px-4 py-3", children: [(dstTokenLogoURI || dstToken.metadata?.logoURI) && (_jsx("img", { src: dstTokenLogoURI || dstToken.metadata?.logoURI, alt: dstTokenSymbol || dstToken.symbol, className: "h-8 w-8 rounded-full" })), _jsx("span", { className: "text-as-brand text-lg font-bold", children: dstTokenSymbol || dstToken.symbol })] })] })) : (
13
15
  // Token selection for regular swap mode
14
- _jsx(OrderTokenAmount, { address: selectedRecipientAddress, context: "to", inputValue: dstAmount, onChangeInput: onChangeDstAmount || (() => { }), chainId: selectedDstChainId || dstToken.chainId, setChainId: setSelectedDstChainId || (() => { }), token: dstToken, setToken: setSelectedDstToken || (() => { }) })), _jsxs("div", { className: "text-as-primary/50 flex h-5 items-center text-sm", children: [formatDisplayNumber(anyspendQuote?.data?.currencyOut?.amountUsd, {
15
- style: "currency",
16
- fallback: "",
17
- }), anyspendQuote?.data?.currencyIn?.amountUsd &&
18
- anyspendQuote?.data?.currencyOut?.amountUsd &&
19
- (() => {
20
- const calculatePriceImpact = (inputUsd, outputUsd) => {
21
- if (!inputUsd || !outputUsd) {
22
- return { percentage: "0.00", isNegative: false };
23
- }
24
- const input = Number(inputUsd);
25
- const output = Number(outputUsd);
26
- // Handle edge cases
27
- if (input === 0 || isNaN(input) || isNaN(output) || input <= output) {
28
- return { percentage: "0.00", isNegative: false };
29
- }
30
- const percentageValue = ((output - input) / input) * 100;
31
- // Handle the -0.00% case
32
- if (percentageValue > -0.005 && percentageValue < 0) {
33
- return { percentage: "0.00", isNegative: false };
34
- }
35
- return {
36
- percentage: Math.abs(percentageValue).toFixed(2),
37
- isNegative: percentageValue < 0,
38
- };
39
- };
40
- const { percentage, isNegative } = calculatePriceImpact(anyspendQuote.data.currencyIn.amountUsd, anyspendQuote.data.currencyOut.amountUsd);
41
- // Parse the percentage as a number for comparison
42
- const percentageNum = parseFloat(percentage);
43
- // Don't show if less than 1%
44
- if (percentageNum < 1) {
45
- return null;
46
- }
47
- // Using inline style to ensure color displays
48
- return (_jsxs("span", { className: "ml-2", style: { color: percentageNum >= 10 ? "red" : "#FFD700" }, children: ["(", isNegative ? "-" : "", percentage, "%)"] }));
49
- })()] })] }));
16
+ _jsx(OrderTokenAmount, { address: selectedRecipientAddress, context: "to", inputValue: dstAmount, onChangeInput: onChangeDstAmount || (() => { }), chainId: selectedDstChainId || dstToken.chainId, setChainId: setSelectedDstChainId || (() => { }), token: dstToken, setToken: setSelectedDstToken || (() => { }) })), _jsxs("div", { className: "text-as-primary/50 flex h-5 items-center justify-start gap-2 text-sm", children: [_jsxs("div", { className: "flex items-center gap-2", children: [formatDisplayNumber(anyspendQuote?.data?.currencyOut?.amountUsd, {
17
+ style: "currency",
18
+ fallback: "",
19
+ }), anyspendQuote?.data?.currencyIn?.amountUsd &&
20
+ anyspendQuote?.data?.currencyOut?.amountUsd &&
21
+ (() => {
22
+ const calculatePriceImpact = (inputUsd, outputUsd) => {
23
+ if (!inputUsd || !outputUsd) {
24
+ return { percentage: "0.00", isNegative: false };
25
+ }
26
+ const input = Number(inputUsd);
27
+ const output = Number(outputUsd);
28
+ // Handle edge cases
29
+ if (input === 0 || isNaN(input) || isNaN(output) || input <= output) {
30
+ return { percentage: "0.00", isNegative: false };
31
+ }
32
+ const percentageValue = ((output - input) / input) * 100;
33
+ // Handle the -0.00% case
34
+ if (percentageValue > -0.005 && percentageValue < 0) {
35
+ return { percentage: "0.00", isNegative: false };
36
+ }
37
+ return {
38
+ percentage: Math.abs(percentageValue).toFixed(2),
39
+ isNegative: percentageValue < 0,
40
+ };
41
+ };
42
+ const { percentage, isNegative } = calculatePriceImpact(anyspendQuote.data.currencyIn.amountUsd, anyspendQuote.data.currencyOut.amountUsd);
43
+ // Parse the percentage as a number for comparison
44
+ const percentageNum = parseFloat(percentage);
45
+ // Don't show if less than 1%
46
+ if (percentageNum < 1) {
47
+ return null;
48
+ }
49
+ // Using inline style to ensure color displays
50
+ return (_jsxs("span", { className: "ml-2", style: { color: percentageNum >= 10 ? "red" : "#FFD700" }, children: ["(", isNegative ? "-" : "", percentage, "%)"] }));
51
+ })()] }), featureFlags.showPoints && anyspendQuote?.data?.pointsAmount && anyspendQuote.data.pointsAmount > 0 && (_jsxs("button", { className: "bg-as-brand hover:scale-102 active:scale-98 active:scale-98 relative flex cursor-pointer items-center gap-1 rounded-lg px-2 py-1 transition-all", onClick: () => onShowPointsDetail?.(), children: [_jsx("div", { className: "pointer-events-none absolute inset-0 h-full w-full rounded-lg border border-white/10 border-t-white/20 bg-gradient-to-b from-white/10 to-white/0" }), _jsxs("span", { className: "text-xs text-white", children: ["+", anyspendQuote.data.pointsAmount.toLocaleString(), " pts"] })] }, `points-${anyspendQuote.data.pointsAmount}`))] })] }));
50
52
  }
@@ -133,9 +133,9 @@ export const OrderDetails = memo(function OrderDetails({ mode = "modal", order,
133
133
  const colorMode = theme || "light";
134
134
  // Read crypto payment method from URL parameters
135
135
  const cryptoPaymentMethodFromUrl = searchParams.get("cryptoPaymentMethod");
136
- const effectiveCryptoPaymentMethod = cryptoPaymentMethod || cryptoPaymentMethodFromUrl || CryptoPaymentMethodType.NONE;
137
- // Use selectedCryptoPaymentMethod for OrderStatus if provided, otherwise fall back to effective method
138
- const orderStatusPaymentMethod = selectedCryptoPaymentMethod || effectiveCryptoPaymentMethod;
136
+ const effectiveCryptoPaymentMethod = selectedCryptoPaymentMethod !== CryptoPaymentMethodType.NONE
137
+ ? selectedCryptoPaymentMethod
138
+ : cryptoPaymentMethod || cryptoPaymentMethodFromUrl || CryptoPaymentMethodType.NONE;
139
139
  const setB3ModalOpen = useModalStore((state) => state.setB3ModalOpen);
140
140
  const srcToken = order.metadata.srcToken;
141
141
  const dstToken = order.metadata.dstToken;
@@ -416,7 +416,7 @@ export const OrderDetails = memo(function OrderDetails({ mode = "modal", order,
416
416
  }
417
417
  };
418
418
  if (refundTxs.length > 0) {
419
- return (_jsxs(_Fragment, { children: [_jsx(OrderStatus, { order: order, selectedCryptoPaymentMethod: orderStatusPaymentMethod }), _jsx(OrderDetailsCollapsible, { order: order, dstToken: dstToken, tournament: tournament, nft: nft, recipientName: recipientName, formattedExpectedDstAmount: formattedExpectedDstAmount }), _jsx(Accordion, { type: "single", collapsible: true, className: "order-details-accordion w-full", children: _jsxs(AccordionItem, { value: "refund-details", className: "order-details-refund-item", children: [_jsx(AccordionTrigger, { className: "accordion-trigger", children: "Transaction Details" }), _jsx(AccordionContent, { className: "accordion-content pl-2", children: _jsxs("div", { className: "relative flex w-full flex-col gap-4", children: [_jsx("div", { className: "bg-as-surface-secondary absolute bottom-2 left-4 top-2 z-[5] w-2", children: _jsx(motion.div, { className: "bg-as-border-primary absolute left-[2px] top-0 z-10 w-[3px]", initial: { height: "0%" }, animate: { height: "100%" }, transition: { duration: 1.5, ease: "easeInOut" } }) }), depositTxs
419
+ return (_jsxs(_Fragment, { children: [_jsx(OrderStatus, { order: order, selectedCryptoPaymentMethod: effectiveCryptoPaymentMethod }), _jsx(OrderDetailsCollapsible, { order: order, dstToken: dstToken, tournament: tournament, nft: nft, recipientName: recipientName, formattedExpectedDstAmount: formattedExpectedDstAmount }), _jsx(Accordion, { type: "single", collapsible: true, className: "order-details-accordion w-full", children: _jsxs(AccordionItem, { value: "refund-details", className: "order-details-refund-item", children: [_jsx(AccordionTrigger, { className: "accordion-trigger", children: "Transaction Details" }), _jsx(AccordionContent, { className: "accordion-content pl-2", children: _jsxs("div", { className: "relative flex w-full flex-col gap-4", children: [_jsx("div", { className: "bg-as-surface-secondary absolute bottom-2 left-4 top-2 z-[5] w-2", children: _jsx(motion.div, { className: "bg-as-border-primary absolute left-[2px] top-0 z-10 w-[3px]", initial: { height: "0%" }, animate: { height: "100%" }, transition: { duration: 1.5, ease: "easeInOut" } }) }), depositTxs
420
420
  ? depositTxs.map(dTx => (_jsx(TransactionDetails, { title: order.onrampMetadata?.vendor === "stripe-web2"
421
421
  ? `Received payment`
422
422
  : `Received ${formatTokenAmount(BigInt(dTx.amount), srcToken.decimals)} ${srcToken.symbol}`, chainId: order.srcChain, tx: dTx, isProcessing: false }, dTx.txHash)))
@@ -425,7 +425,7 @@ export const OrderDetails = memo(function OrderDetails({ mode = "modal", order,
425
425
  : null] }) })] }) }), order.errorDetails && (_jsx("div", { className: "flex justify-center", children: _jsx("span", { className: "text-as-primary/50 text-center text-sm", style: { maxWidth: "40ch" }, children: getErrorDisplay(order.errorDetails) }) })), _jsx("button", { className: "order-close-button order-details-close-btn bg-as-brand flex w-full items-center justify-center gap-2 rounded-lg p-2 font-semibold text-white", onClick: mode === "page" ? handleBack : handleCloseModal, children: mode === "page" ? (_jsxs(_Fragment, { children: ["Return to Home ", _jsx(Home, { className: "ml-2 h-4 w-4" })] })) : ("Close") })] }));
426
426
  }
427
427
  if (executeTx) {
428
- return (_jsxs(_Fragment, { children: [_jsx(OrderStatus, { order: order, selectedCryptoPaymentMethod: orderStatusPaymentMethod }), _jsx(OrderDetailsCollapsible, { order: order, dstToken: dstToken, tournament: tournament, nft: nft, recipientName: recipientName, formattedExpectedDstAmount: formattedExpectedDstAmount }), _jsx(Accordion, { type: "single", collapsible: true, className: "order-details-accordion w-full", children: _jsxs(AccordionItem, { value: "execute-details", className: "order-details-execute-item", children: [_jsx(AccordionTrigger, { className: "accordion-trigger", children: "Transaction Details" }), _jsx(AccordionContent, { className: "accordion-content pl-2", children: _jsxs("div", { className: "relative flex w-full flex-col gap-4", children: [_jsx("div", { className: "bg-as-surface-secondary absolute bottom-2 left-4 top-2 z-[5] w-2", children: _jsx(motion.div, { className: "bg-as-border-primary absolute left-[2px] top-0 z-10 w-[3px]", initial: { height: "0%" }, animate: { height: "100%" }, transition: { duration: 1.5, ease: "easeInOut" } }) }), depositTxs
428
+ return (_jsxs(_Fragment, { children: [_jsx(OrderStatus, { order: order, selectedCryptoPaymentMethod: effectiveCryptoPaymentMethod }), _jsx(OrderDetailsCollapsible, { order: order, dstToken: dstToken, tournament: tournament, nft: nft, recipientName: recipientName, formattedExpectedDstAmount: formattedExpectedDstAmount }), _jsx(Accordion, { type: "single", collapsible: true, className: "order-details-accordion w-full", children: _jsxs(AccordionItem, { value: "execute-details", className: "order-details-execute-item", children: [_jsx(AccordionTrigger, { className: "accordion-trigger", children: "Transaction Details" }), _jsx(AccordionContent, { className: "accordion-content pl-2", children: _jsxs("div", { className: "relative flex w-full flex-col gap-4", children: [_jsx("div", { className: "bg-as-surface-secondary absolute bottom-2 left-4 top-2 z-[5] w-2", children: _jsx(motion.div, { className: "bg-as-border-primary absolute left-[2px] top-0 z-10 w-[3px]", initial: { height: "0%" }, animate: { height: "100%" }, transition: { duration: 1.5, ease: "easeInOut" } }) }), depositTxs
429
429
  ? depositTxs.map(dTxs => (_jsx(TransactionDetails, { title: order.onrampMetadata?.vendor === "stripe-web2"
430
430
  ? `Received payment`
431
431
  : `Received ${formatTokenAmount(BigInt(dTxs.amount), srcToken.decimals)} ${srcToken.symbol}`, chainId: order.srcChain, tx: dTxs, isProcessing: false }, dTxs.txHash)))
@@ -450,7 +450,7 @@ export const OrderDetails = memo(function OrderDetails({ mode = "modal", order,
450
450
  }), _jsx(ExternalLink, { className: "ml-2 h-4 w-4" })] }) }) }), order.type === "join_tournament" && order.status === "executed" && (_jsxs(ShinyButton, { accentColor: "hsl(var(--as-brand))", textColor: "text-white", className: "flex w-full items-center gap-2", disabled: txLoading || isSwitchingOrExecuting, onClick: handleCloseModal, children: [_jsx("span", { className: "pl-4", children: "Continue to Tournament" }), _jsx(ChevronRight, { className: "h-4 w-4" })] })), order.status === "executed" && (_jsx("button", { className: "order-close-button order-details-close-btn bg-as-brand flex w-full items-center justify-center gap-2 rounded-lg p-2 font-semibold text-white", onClick: mode === "page" ? handleBack : handleCloseModal, children: mode === "page" ? (_jsxs(_Fragment, { children: ["Return to Home ", _jsx(Home, { className: "ml-2 h-4 w-4" })] })) : ("Close") }))] }));
451
451
  }
452
452
  if (relayTxs.length > 0 && relayTxs.every(tx => tx.status === "success")) {
453
- return (_jsxs(_Fragment, { children: [_jsx(OrderStatus, { order: order, selectedCryptoPaymentMethod: orderStatusPaymentMethod }), _jsx(OrderDetailsCollapsible, { order: order, dstToken: dstToken, tournament: tournament, nft: nft, recipientName: recipientName, formattedExpectedDstAmount: formattedExpectedDstAmount }), _jsx(Accordion, { type: "single", collapsible: true, className: "order-details-accordion w-full", children: _jsxs(AccordionItem, { value: "more-details", className: "order-details-more-item", children: [_jsx(AccordionTrigger, { className: "accordion-trigger", children: "More Details" }), _jsx(AccordionContent, { className: "accordion-content pl-2", children: _jsxs("div", { className: "relative flex w-full flex-col gap-4", children: [_jsx("div", { className: "bg-as-surface-secondary absolute bottom-2 left-4 top-2 z-[5] w-2", children: _jsx(motion.div, { className: "bg-as-border-primary absolute left-[2px] top-0 z-10 w-[3px]", initial: { height: "0%" }, animate: { height: "100%" }, transition: { duration: 1.5, ease: "easeInOut" } }) }), depositTxs
453
+ return (_jsxs(_Fragment, { children: [_jsx(OrderStatus, { order: order, selectedCryptoPaymentMethod: effectiveCryptoPaymentMethod }), _jsx(OrderDetailsCollapsible, { order: order, dstToken: dstToken, tournament: tournament, nft: nft, recipientName: recipientName, formattedExpectedDstAmount: formattedExpectedDstAmount }), _jsx(Accordion, { type: "single", collapsible: true, className: "order-details-accordion w-full", children: _jsxs(AccordionItem, { value: "more-details", className: "order-details-more-item", children: [_jsx(AccordionTrigger, { className: "accordion-trigger", children: "More Details" }), _jsx(AccordionContent, { className: "accordion-content pl-2", children: _jsxs("div", { className: "relative flex w-full flex-col gap-4", children: [_jsx("div", { className: "bg-as-surface-secondary absolute bottom-2 left-4 top-2 z-[5] w-2", children: _jsx(motion.div, { className: "bg-as-border-primary absolute left-[2px] top-0 z-10 w-[3px]", initial: { height: "0%" }, animate: { height: "100%" }, transition: { duration: 1.5, ease: "easeInOut" } }) }), depositTxs
454
454
  ? depositTxs.map(dTxs => (_jsx(TransactionDetails, { title: order.onrampMetadata?.vendor === "stripe-web2"
455
455
  ? `Received payment`
456
456
  : `Received ${formatTokenAmount(BigInt(dTxs.amount), srcToken.decimals)} ${srcToken.symbol}`, chainId: order.srcChain, tx: dTxs, isProcessing: false }, dTxs.txHash)))
@@ -469,7 +469,7 @@ export const OrderDetails = memo(function OrderDetails({ mode = "modal", order,
469
469
  // This boolean indicates that user finish payment, and waiting for the deposit to be confirmed. We get this from query params (waitingForDeposit=true)
470
470
  const waitingForDeposit = new URLSearchParams(window.location.search).get("waitingForDeposit") === "true";
471
471
  if (depositTxs?.length || waitingForDeposit) {
472
- return (_jsxs(_Fragment, { children: [_jsx(OrderStatus, { order: order, selectedCryptoPaymentMethod: orderStatusPaymentMethod }), _jsx(OrderDetailsCollapsible, { order: order, dstToken: dstToken, tournament: tournament, nft: nft, recipientName: recipientName, formattedExpectedDstAmount: formattedExpectedDstAmount }), _jsx(Accordion, { type: "single", collapsible: true, className: "order-details-accordion w-full", children: _jsxs(AccordionItem, { value: "deposit-details", className: "order-details-deposit-item", children: [_jsx(AccordionTrigger, { className: "accordion-trigger", children: "Transaction Details" }), _jsx(AccordionContent, { className: "accordion-content pl-2", children: _jsxs("div", { className: "relative flex w-full flex-col gap-6", children: [_jsx("div", { className: "bg-as-surface-secondary absolute bottom-2 left-4 top-2 z-[5] w-2", children: _jsx(motion.div, { className: "from-as-brand/50 absolute left-[2px] top-0 z-10 w-[3px] bg-gradient-to-b from-20% via-purple-500/50 via-80% to-transparent", initial: { height: "0%" }, animate: { height: "100%" }, transition: { duration: 1, ease: "easeInOut" } }) }), (depositTxs || []).map((dTxs, index) => (_jsx(TransactionDetails, { title: order.onrampMetadata?.vendor === "stripe-web2"
472
+ return (_jsxs(_Fragment, { children: [_jsx(OrderStatus, { order: order, selectedCryptoPaymentMethod: effectiveCryptoPaymentMethod }), _jsx(OrderDetailsCollapsible, { order: order, dstToken: dstToken, tournament: tournament, nft: nft, recipientName: recipientName, formattedExpectedDstAmount: formattedExpectedDstAmount }), _jsx(Accordion, { type: "single", collapsible: true, className: "order-details-accordion w-full", children: _jsxs(AccordionItem, { value: "deposit-details", className: "order-details-deposit-item", children: [_jsx(AccordionTrigger, { className: "accordion-trigger", children: "Transaction Details" }), _jsx(AccordionContent, { className: "accordion-content pl-2", children: _jsxs("div", { className: "relative flex w-full flex-col gap-6", children: [_jsx("div", { className: "bg-as-surface-secondary absolute bottom-2 left-4 top-2 z-[5] w-2", children: _jsx(motion.div, { className: "from-as-brand/50 absolute left-[2px] top-0 z-10 w-[3px] bg-gradient-to-b from-20% via-purple-500/50 via-80% to-transparent", initial: { height: "0%" }, animate: { height: "100%" }, transition: { duration: 1, ease: "easeInOut" } }) }), (depositTxs || []).map((dTxs, index) => (_jsx(TransactionDetails, { title: order.onrampMetadata?.vendor === "stripe-web2"
473
473
  ? `Received payment`
474
474
  : `Received ${formatTokenAmount(BigInt(dTxs.amount), srcToken.decimals)} ${srcToken.symbol}`, chainId: order.srcChain, tx: dTxs, isProcessing: index < (depositTxs || []).length - 1 ? false : !depositEnoughAmount }, dTxs.txHash))), statusDisplay === "failure" ? (_jsx(TransactionDetails, { title: statusText, chainId: order.srcChain, tx: null, isProcessing: false, delay: 0.5 })) : depositEnoughAmount ? (_jsx(TransactionDetails, { title: order.type === "swap"
475
475
  ? "Processing Swap"
@@ -483,7 +483,7 @@ export const OrderDetails = memo(function OrderDetails({ mode = "modal", order,
483
483
  ? `Waiting for payment`
484
484
  : `Waiting for deposit ${formattedDepositDeficit} ${srcToken.symbol}`, chainId: order.srcChain, tx: null, isProcessing: true, delay: 0.5 }))] }) })] }) }), !depositEnoughAmount && order.status !== "expired" && (_jsx(InsufficientDepositPayment, { order: order, srcToken: srcToken, depositDeficit: depositDeficit, phantomWalletAddress: phantomWalletAddress, txLoading: txLoading, isSwitchingOrExecuting: isSwitchingOrExecuting, onPayment: handlePayment }))] }));
485
485
  }
486
- return (_jsxs(_Fragment, { children: [_jsx(OrderStatus, { order: order, selectedCryptoPaymentMethod: orderStatusPaymentMethod }), statusDisplay === "processing" && (_jsx(_Fragment, { children: order.onrampMetadata ? (_jsx(PaymentVendorUI, { order: order, dstTokenSymbol: dstToken.symbol })) : effectiveCryptoPaymentMethod === CryptoPaymentMethodType.CONNECT_WALLET ||
486
+ return (_jsxs(_Fragment, { children: [_jsx(OrderStatus, { order: order, selectedCryptoPaymentMethod: effectiveCryptoPaymentMethod }), statusDisplay === "processing" && (_jsx(_Fragment, { children: order.onrampMetadata ? (_jsx(PaymentVendorUI, { order: order, dstTokenSymbol: dstToken.symbol })) : effectiveCryptoPaymentMethod === CryptoPaymentMethodType.CONNECT_WALLET ||
487
487
  effectiveCryptoPaymentMethod === CryptoPaymentMethodType.GLOBAL_WALLET ? (_jsx(ConnectWalletPayment, { order: order, onPayment: handlePayment, onCancel: handleBack, txLoading: txLoading, isSwitchingOrExecuting: isSwitchingOrExecuting, phantomWalletAddress: phantomWalletAddress, tournament: tournament, nft: nft, cryptoPaymentMethod: effectiveCryptoPaymentMethod, onPaymentMethodChange: onPaymentMethodChange })) : effectiveCryptoPaymentMethod === CryptoPaymentMethodType.TRANSFER_CRYPTO ? (
488
488
  // Transfer Crypto Payment Method - Show new card-based UI
489
489
  _jsx(TransferCryptoDetails, { order: order, recipientName: recipientName, srcToken: srcToken, dstToken: dstToken, tournament: tournament, nft: nft, onBack: handleBack, onPaymentMethodChange: onPaymentMethodChange })) : (_jsxs("div", { className: "order-details-payment-section relative flex w-full flex-1 flex-col", children: [_jsxs("div", { className: "order-details-amount-section flex flex-col gap-1", children: [_jsx("span", { className: "text-as-primary/50 order-details-amount-label", children: "Please send" }), _jsxs("div", { className: "order-details-amount-container flex w-full flex-wrap items-center gap-6 sm:justify-between sm:gap-0", children: [_jsx(CopyToClipboard, { text: roundedUpSrcAmount, onCopy: () => {
@@ -1,5 +1,5 @@
1
1
  import { components } from "../../../../anyspend/types/api";
2
- export declare function OrderTokenAmount({ disabled, inputValue, onChangeInput, context, address, chainId, setChainId, token, setToken, hideTokenSelect, canEditAmount, className, innerClassName, amountClassName, tokenSelectClassName, }: {
2
+ export declare function OrderTokenAmount({ disabled, inputValue, onChangeInput, context, address, chainId, setChainId, token, setToken, hideTokenSelect, canEditAmount, className, innerClassName, amountClassName, tokenSelectClassName, onTokenSelect, }: {
3
3
  disabled?: boolean;
4
4
  inputValue: string;
5
5
  onChangeInput: (value: string) => void;
@@ -15,4 +15,7 @@ export declare function OrderTokenAmount({ disabled, inputValue, onChangeInput,
15
15
  innerClassName?: string;
16
16
  amountClassName?: string;
17
17
  tokenSelectClassName?: string;
18
+ onTokenSelect?: (token: components["schemas"]["Token"], event: {
19
+ preventDefault: () => void;
20
+ }) => void;
18
21
  }): import("react/jsx-runtime").JSX.Element;
@@ -8,7 +8,7 @@ import { Button } from "../../../../global-account/react/index.js";
8
8
  import { cn } from "../../../../shared/utils/index.js";
9
9
  import { TokenSelector } from "@reservoir0x/relay-kit-ui";
10
10
  import { ChainTokenIcon } from "./ChainTokenIcon.js";
11
- export function OrderTokenAmount({ disabled, inputValue, onChangeInput, context, address, chainId, setChainId, token, setToken, hideTokenSelect = false, canEditAmount = true, className, innerClassName, amountClassName, tokenSelectClassName, }) {
11
+ export function OrderTokenAmount({ disabled, inputValue, onChangeInput, context, address, chainId, setChainId, token, setToken, hideTokenSelect = false, canEditAmount = true, className, innerClassName, amountClassName, tokenSelectClassName, onTokenSelect, }) {
12
12
  // Track previous token to detect changes
13
13
  const prevTokenRef = useRef(token.address);
14
14
  useEffect(() => {
@@ -25,19 +25,33 @@ export function OrderTokenAmount({ disabled, inputValue, onChangeInput, context,
25
25
  }
26
26
  }, [token.address, chainId, context, onChangeInput]);
27
27
  const handleTokenSelect = (newToken) => {
28
- // Mark that we're about to change tokens
29
- prevTokenRef.current = "changing"; // Temporary value to force effect
30
- // Set the chain ID first
31
- setChainId(newToken.chainId);
32
- // Then set the new token
33
- setToken({
28
+ const token = {
34
29
  address: newToken.address,
35
- chainId: newToken.chainId, // Use the new chain ID
30
+ chainId: newToken.chainId,
36
31
  decimals: newToken.decimals,
37
32
  metadata: { logoURI: newToken.logoURI },
38
33
  name: newToken.name,
39
34
  symbol: newToken.symbol,
40
- });
35
+ };
36
+ // Call the onTokenSelect callback if provided
37
+ if (onTokenSelect) {
38
+ let isDefaultPrevented = false;
39
+ const event = {
40
+ preventDefault: () => {
41
+ isDefaultPrevented = true;
42
+ },
43
+ };
44
+ onTokenSelect(token, event);
45
+ if (isDefaultPrevented) {
46
+ return; // Early return if callback prevented default behavior
47
+ }
48
+ }
49
+ // Mark that we're about to change tokens
50
+ prevTokenRef.current = "changing"; // Temporary value to force effect
51
+ // Set the chain ID first
52
+ setChainId(newToken.chainId);
53
+ // Then set the new token
54
+ setToken(token);
41
55
  // If this is the source token, reset the amount immediately
42
56
  if (context === "from") {
43
57
  onChangeInput("0.01");
@@ -1,6 +1,7 @@
1
1
  import { components } from "../../../../anyspend/types/api";
2
+ import { GetQuoteResponse } from "../../../../anyspend/types/api_req_res";
2
3
  import { FiatPaymentMethod } from "./FiatPaymentMethod";
3
- export declare function PanelOnramp({ srcAmountOnRamp, setSrcAmountOnRamp, selectedPaymentMethod, setActivePanel, _recipientAddress, destinationToken, destinationChainId, destinationAmount, onDestinationTokenChange, onDestinationChainChange, fiatPaymentMethodIndex, recipientSelectionPanelIndex, dstTokenSymbol, hideDstToken, }: {
4
+ export declare function PanelOnramp({ srcAmountOnRamp, setSrcAmountOnRamp, selectedPaymentMethod, setActivePanel, _recipientAddress, destinationToken, destinationChainId, destinationAmount, onDestinationTokenChange, onDestinationChainChange, fiatPaymentMethodIndex, recipientSelectionPanelIndex, dstTokenSymbol, hideDstToken, anyspendQuote, onShowPointsDetail, }: {
4
5
  srcAmountOnRamp: string;
5
6
  setSrcAmountOnRamp: (amount: string) => void;
6
7
  selectedPaymentMethod?: FiatPaymentMethod;
@@ -15,4 +16,6 @@ export declare function PanelOnramp({ srcAmountOnRamp, setSrcAmountOnRamp, selec
15
16
  recipientSelectionPanelIndex: number;
16
17
  dstTokenSymbol?: string;
17
18
  hideDstToken?: boolean;
19
+ anyspendQuote?: GetQuoteResponse;
20
+ onShowPointsDetail?: () => void;
18
21
  }): import("react/jsx-runtime").JSX.Element;
@@ -7,9 +7,11 @@ import { formatAddress } from "../../../../shared/utils/formatAddress.js";
7
7
  import { ChevronRight, Wallet } from "lucide-react";
8
8
  import { useRef } from "react";
9
9
  import { toast } from "sonner";
10
+ import { useFeatureFlags } from "../../contexts/FeatureFlagsContext.js";
10
11
  import { FiatPaymentMethod } from "./FiatPaymentMethod.js";
11
12
  import { OrderTokenAmountFiat } from "./OrderTokenAmountFiat.js";
12
- export function PanelOnramp({ srcAmountOnRamp, setSrcAmountOnRamp, selectedPaymentMethod, setActivePanel, _recipientAddress, destinationToken, destinationChainId, destinationAmount, onDestinationTokenChange, onDestinationChainChange, fiatPaymentMethodIndex, recipientSelectionPanelIndex, dstTokenSymbol, hideDstToken = false, }) {
13
+ export function PanelOnramp({ srcAmountOnRamp, setSrcAmountOnRamp, selectedPaymentMethod, setActivePanel, _recipientAddress, destinationToken, destinationChainId, destinationAmount, onDestinationTokenChange, onDestinationChainChange, fiatPaymentMethodIndex, recipientSelectionPanelIndex, dstTokenSymbol, hideDstToken = false, anyspendQuote, onShowPointsDetail, }) {
14
+ const featureFlags = useFeatureFlags();
13
15
  // Get geo-based onramp options to access fee information
14
16
  const { stripeWeb2Support } = useGeoOnrampOptions(srcAmountOnRamp);
15
17
  // Helper function to get fees from API data
@@ -70,9 +72,8 @@ export function PanelOnramp({ srcAmountOnRamp, setSrcAmountOnRamp, selectedPayme
70
72
  width: `${Math.max(50, srcAmountOnRamp.length * 34)}px`,
71
73
  } })] }) }), _jsx("div", { className: cn("mx-auto mb-6 inline-grid grid-cols-4 gap-2", hideDstToken && "mb-0"), children: ["5", "10", "20", "25"].map(value => (_jsxs("button", { onClick: () => handleQuickAmount(value), className: `bg-as-surface-secondary border-as-border-secondary hover:border-as-border-secondary h-7 w-14 rounded-lg border text-sm font-medium transition-all duration-200 ${srcAmountOnRamp === value
72
74
  ? "border-as-border-secondary bg-as-surface-secondary"
73
- : "bg-as-surface-secondary hover:bg-as-surface-secondary"}`, children: ["$", value] }, value))) }), destinationToken && destinationChainId && !hideDstToken && (_jsx(OrderTokenAmountFiat, { address: _recipientAddress, context: "to", inputValue: destinationAmount || "0", onChangeInput: () => { }, chainId: destinationChainId, setChainId: onDestinationChainChange || (() => { }), token: destinationToken, setToken: onDestinationTokenChange || (() => { }) }))] }), _jsxs("div", { className: "border-as-border-secondary bg-as-surface-secondary mt-4 flex w-full flex-col gap-3 rounded-xl border p-4", children: [_jsxs("div", { className: "flex w-full items-center justify-between gap-2", children: [_jsx("span", { className: "text-as-tertiarry flex items-center text-sm", children: "Recipient" }), _recipientAddress ? (_jsxs("button", { className: "text-as-tertiarry flex h-7 items-center gap-1 text-sm transition-colors hover:text-blue-700", onClick: () => setActivePanel(recipientSelectionPanelIndex), children: [_jsx("span", { className: "text-sm", children: recipientName ? formatUsername(recipientName) : formatAddress(_recipientAddress) }), _jsx(ChevronRight, { size: 16 })] })) : (_jsxs("button", { className: "text-as-tertiarry flex h-7 items-center gap-1 text-sm transition-colors hover:text-blue-700", onClick: () => setActivePanel(5), children: [_jsx(Wallet, { className: "text-as-brand", size: 16 }), "Select recipient", _jsx(ChevronRight, { size: 16 })] }))] }), _jsx("div", { className: "divider w-full" }), _jsxs("div", { className: "flex items-center justify-between", children: [_jsx("span", { className: "text-as-tertiarry text-sm", children: "Expected to receive" }), _jsxs("div", { className: "flex items-center gap-2", children: [_jsxs("span", { className: "text-as-primary font-semibold", children: [destinationAmount || "0", " ", dstTokenSymbol || destinationToken?.symbol || ""] }), _jsxs("span", { className: "text-as-tertiarry text-sm", children: ["on ", destinationChainId ? ALL_CHAINS[destinationChainId]?.name : ""] }), destinationToken && destinationChainId && destinationToken.metadata?.logoURI && (_jsx("img", { src: ALL_CHAINS[destinationChainId]?.logoUrl, alt: "Chain", className: "h-4 w-4 rounded-full" }))] })] }), _jsx("div", { className: "divider w-full" }), _jsx("div", { className: "", children: _jsx("div", { className: "flex items-center justify-between", children: (() => {
74
- const currentPaymentMethod = selectedPaymentMethod || FiatPaymentMethod.NONE;
75
- const fee = getFeeFromApi(currentPaymentMethod);
76
- return (_jsxs(_Fragment, { children: [_jsx("span", { className: "text-as-tertiarry text-sm", children: fee !== null ? `Total (included $${fee.toFixed(2)} fee)` : "Total" }), _jsxs("span", { className: "text-as-primary font-semibold", children: ["$", getTotalAmount(currentPaymentMethod).toFixed(2)] })] }));
77
- })() }) })] })] }));
75
+ : "bg-as-surface-secondary hover:bg-as-surface-secondary"}`, children: ["$", value] }, value))) }), destinationToken && destinationChainId && !hideDstToken && (_jsx(OrderTokenAmountFiat, { address: _recipientAddress, context: "to", inputValue: destinationAmount || "0", onChangeInput: () => { }, chainId: destinationChainId, setChainId: onDestinationChainChange || (() => { }), token: destinationToken, setToken: onDestinationTokenChange || (() => { }) }))] }), _jsxs("div", { className: "border-as-border-secondary bg-as-surface-secondary mt-4 flex w-full flex-col gap-3 rounded-xl border p-4", children: [_jsxs("div", { className: "flex w-full items-center justify-between gap-2", children: [_jsx("span", { className: "text-as-tertiarry flex items-center text-sm", children: "Recipient" }), _recipientAddress ? (_jsxs("button", { className: "text-as-tertiarry flex h-7 items-center gap-1 text-sm transition-colors hover:text-blue-700", onClick: () => setActivePanel(recipientSelectionPanelIndex), children: [_jsx("span", { className: "text-sm", children: recipientName ? formatUsername(recipientName) : formatAddress(_recipientAddress) }), _jsx(ChevronRight, { size: 16 })] })) : (_jsxs("button", { className: "text-as-tertiarry flex h-7 items-center gap-1 text-sm transition-colors hover:text-blue-700", onClick: () => setActivePanel(5), children: [_jsx(Wallet, { className: "text-as-brand", size: 16 }), "Select recipient", _jsx(ChevronRight, { size: 16 })] }))] }), _jsx("div", { className: "divider w-full" }), _jsxs("div", { className: "flex items-center justify-between", children: [_jsx("span", { className: "text-as-tertiarry text-sm", children: "Expected to receive" }), _jsxs("div", { className: "flex items-center gap-2", children: [_jsxs("span", { className: "text-as-primary font-semibold", children: [destinationAmount || "0", " ", dstTokenSymbol || destinationToken?.symbol || ""] }), _jsxs("span", { className: "text-as-tertiarry text-sm", children: ["on ", destinationChainId ? ALL_CHAINS[destinationChainId]?.name : ""] }), destinationToken && destinationChainId && destinationToken.metadata?.logoURI && (_jsx("img", { src: ALL_CHAINS[destinationChainId]?.logoUrl, alt: "Chain", className: "h-4 w-4 rounded-full" }))] })] }), _jsx("div", { className: "divider w-full" }), _jsx("div", { className: "", children: _jsxs("div", { className: "flex items-center justify-between", children: [_jsxs("div", { className: "flex items-center gap-2", children: [_jsx("span", { className: "text-as-tertiarry text-sm", children: (() => {
76
+ const fee = getFeeFromApi(selectedPaymentMethod || FiatPaymentMethod.NONE);
77
+ return fee !== null ? `Total (included $${fee.toFixed(2)} fee)` : "Total";
78
+ })() }), featureFlags.showPoints && anyspendQuote?.data?.pointsAmount && anyspendQuote.data.pointsAmount > 0 && (_jsxs("button", { className: "bg-as-brand hover:scale-102 active:scale-98 relative flex cursor-pointer items-center gap-1 rounded-lg px-2 py-1 transition-all", onClick: () => onShowPointsDetail?.(), children: [_jsx("div", { className: "pointer-events-none absolute inset-0 h-full w-full rounded-lg border border-white/10 border-t-white/20 bg-gradient-to-b from-white/10 to-white/0" }), _jsxs("span", { className: "text-xs text-white", children: ["+", anyspendQuote.data.pointsAmount.toLocaleString(), " pts"] })] }, `points-${anyspendQuote.data.pointsAmount}`))] }), _jsxs("span", { className: "text-as-primary font-semibold", children: ["$", getTotalAmount(selectedPaymentMethod || FiatPaymentMethod.NONE).toFixed(2)] })] }) })] })] }));
78
79
  }
@@ -0,0 +1,6 @@
1
+ interface PointsDetailPanelProps {
2
+ pointsAmount?: number;
3
+ onBack: () => void;
4
+ }
5
+ export declare function PointsDetailPanel({ pointsAmount, onBack }: PointsDetailPanelProps): import("react/jsx-runtime").JSX.Element;
6
+ export {};
@@ -0,0 +1,8 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Button, ShinyButton } from "../../../../global-account/react/index.js";
3
+ import { cn } from "../../../../shared/utils/cn.js";
4
+ import { ArrowDown } from "lucide-react";
5
+ import Link from "next/link";
6
+ export function PointsDetailPanel({ pointsAmount = 0, onBack }) {
7
+ return (_jsxs("div", { className: "mx-auto flex w-[460px] max-w-full flex-col items-center gap-4", children: [_jsx("div", { className: "flex w-full items-center justify-between", children: _jsxs(Button, { variant: "ghost", onClick: onBack, className: "text-as-primary/70 hover:text-as-primary flex items-center gap-2", children: [_jsx(ArrowDown, { className: "h-4 w-4 rotate-90" }), "Back"] }) }), _jsxs("div", { className: "flex flex-col items-center gap-4 text-center", children: [_jsx("h3", { className: "text-as-primary text-xl font-bold", children: "Earn Points with Every Swap" }), _jsxs("p", { className: "text-as-primary/70 text-balance text-sm leading-relaxed", children: ["You'll earn ", _jsxs("span", { className: "text-as-brand font-semibold", children: ["+", pointsAmount.toLocaleString(), " points"] }), " ", "towards the", " ", _jsx(Link, { href: "https://anyspend.com/points", target: "_blank", className: "text-as-brand underline", children: "next AnySpend airdrop" }), " ", "when you complete this transaction."] }), _jsxs("div", { className: "bg-as-surface-primary border-as-border-secondary mt-2 w-full rounded-lg border p-4 text-left", children: [_jsx("h4", { className: "text-as-primary mb-2 font-semibold", children: "How it works:" }), _jsxs("ul", { className: "text-as-primary/70 space-y-1 text-sm", children: [_jsx("li", { children: "\u2022 Points are earned based on transaction volume" }), _jsx("li", { children: "\u2022 Higher volume = more points" }), _jsx("li", { children: "\u2022 Points contribute to future airdrops" }), _jsx("li", { children: "\u2022 Keep swapping to maximize your rewards" })] })] }), _jsx(ShinyButton, { accentColor: "hsl(var(--as-brand))", onClick: onBack, className: cn("as-main-button !bg-as-brand relative w-full"), textClassName: cn("text-white"), children: "Back to Swap" })] })] }));
8
+ }
@@ -0,0 +1,11 @@
1
+ import { ReactNode } from "react";
2
+ export interface FeatureFlags {
3
+ showPoints?: boolean;
4
+ }
5
+ interface FeatureFlagsProviderProps {
6
+ children: ReactNode;
7
+ featureFlags?: FeatureFlags;
8
+ }
9
+ export declare function FeatureFlagsProvider({ children, featureFlags }: FeatureFlagsProviderProps): import("react/jsx-runtime").JSX.Element;
10
+ export declare function useFeatureFlags(): FeatureFlags;
11
+ export {};
@@ -0,0 +1,17 @@
1
+ "use client";
2
+ import { jsx as _jsx } from "react/jsx-runtime";
3
+ import { createContext, useContext } from "react";
4
+ const FeatureFlagsContext = createContext(undefined);
5
+ const defaultFeatureFlags = {
6
+ showPoints: false,
7
+ };
8
+ export function FeatureFlagsProvider({ children, featureFlags = defaultFeatureFlags }) {
9
+ return _jsx(FeatureFlagsContext.Provider, { value: { featureFlags }, children: children });
10
+ }
11
+ export function useFeatureFlags() {
12
+ const context = useContext(FeatureFlagsContext);
13
+ if (!context) {
14
+ return defaultFeatureFlags;
15
+ }
16
+ return context.featureFlags;
17
+ }
@@ -7,7 +7,8 @@ export declare enum PanelView {
7
7
  FIAT_PAYMENT_METHOD = 2,
8
8
  RECIPIENT_SELECTION = 3,
9
9
  ORDER_DETAILS = 4,
10
- LOADING = 5
10
+ LOADING = 5,
11
+ POINTS_DETAIL = 6
11
12
  }
12
13
  interface UseAnyspendFlowProps {
13
14
  paymentType?: "crypto" | "fiat";
@@ -140,6 +141,8 @@ export declare function useAnyspendFlow({ paymentType, recipientAddress, loadOrd
140
141
  };
141
142
  timeEstimate?: number;
142
143
  userBalance?: string;
144
+ pointsAmount?: number;
145
+ pointsMultiplier?: number;
143
146
  };
144
147
  statusCode: number;
145
148
  } | undefined;
@@ -18,6 +18,7 @@ export var PanelView;
18
18
  PanelView[PanelView["RECIPIENT_SELECTION"] = 3] = "RECIPIENT_SELECTION";
19
19
  PanelView[PanelView["ORDER_DETAILS"] = 4] = "ORDER_DETAILS";
20
20
  PanelView[PanelView["LOADING"] = 5] = "LOADING";
21
+ PanelView[PanelView["POINTS_DETAIL"] = 6] = "POINTS_DETAIL";
21
22
  })(PanelView || (PanelView = {}));
22
23
  export function useAnyspendFlow({ paymentType = "crypto", recipientAddress, loadOrder, isDepositMode = false, onOrderSuccess, onTransactionSuccess, sourceTokenAddress, sourceTokenChainId, slippage = 0, disableUrlParamManagement = false, }) {
23
24
  const searchParams = useSearchParamsSSR();
@@ -1,6 +1,8 @@
1
1
  import { ReactNode } from "react";
2
+ import { FeatureFlags } from "../contexts/FeatureFlagsContext";
2
3
  interface AnyspendProviderProps {
3
4
  children: ReactNode;
5
+ featureFlags?: FeatureFlags;
4
6
  }
5
7
  /**
6
8
  * AnyspendProvider is a top-level provider that wraps your application to provide
@@ -12,17 +14,18 @@ interface AnyspendProviderProps {
12
14
  * - Safe to use at the application root
13
15
  * - Configures sensible defaults for query caching
14
16
  * - Handles Stripe payment redirects and modal state
17
+ * - Provides feature flags configuration
15
18
  *
16
19
  * @example
17
20
  * ```tsx
18
21
  * function App() {
19
22
  * return (
20
- * <AnyspendProvider>
23
+ * <AnyspendProvider featureFlags={{ showPoints: true }}>
21
24
  * <YourApp />
22
25
  * </AnyspendProvider>
23
26
  * );
24
27
  * }
25
28
  * ```
26
29
  */
27
- export declare const AnyspendProvider: ({ children }: AnyspendProviderProps) => import("react/jsx-runtime").JSX.Element;
30
+ export declare const AnyspendProvider: ({ children, featureFlags }: AnyspendProviderProps) => import("react/jsx-runtime").JSX.Element;
28
31
  export {};