@relayprotocol/relay-kit-ui 5.1.2 → 6.0.0
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.
- package/_cjs/src/components/common/BalanceDisplay.js +4 -3
- package/_cjs/src/components/common/BalanceDisplay.js.map +1 -1
- package/_cjs/src/components/common/MultiWalletDropdown.js +5 -4
- package/_cjs/src/components/common/MultiWalletDropdown.js.map +1 -1
- package/_cjs/src/components/common/PercentageButtons.js +9 -9
- package/_cjs/src/components/common/PercentageButtons.js.map +1 -1
- package/_cjs/src/components/common/SlippageToleranceConfig.js +30 -17
- package/_cjs/src/components/common/SlippageToleranceConfig.js.map +1 -1
- package/_cjs/src/components/common/TokenSelector/ChainFilter.js +21 -19
- package/_cjs/src/components/common/TokenSelector/ChainFilter.js.map +1 -1
- package/_cjs/src/components/common/TokenSelector/ChainFilterRow.js +117 -0
- package/_cjs/src/components/common/TokenSelector/ChainFilterRow.js.map +1 -0
- package/_cjs/src/components/common/TokenSelector/ChainFilterSidebar.js +2 -13
- package/_cjs/src/components/common/TokenSelector/ChainFilterSidebar.js.map +1 -1
- package/_cjs/src/components/common/TokenSelector/CompactChainFilter.js +180 -0
- package/_cjs/src/components/common/TokenSelector/CompactChainFilter.js.map +1 -0
- package/_cjs/src/components/common/TokenSelector/PaymentMethod.js +456 -0
- package/_cjs/src/components/common/TokenSelector/PaymentMethod.js.map +1 -0
- package/_cjs/src/components/common/TokenSelector/PaymentTokenList.js +83 -0
- package/_cjs/src/components/common/TokenSelector/PaymentTokenList.js.map +1 -0
- package/_cjs/src/components/common/TokenSelector/triggers/PaymentMethodTrigger.js +77 -0
- package/_cjs/src/components/common/TokenSelector/triggers/PaymentMethodTrigger.js.map +1 -0
- package/_cjs/src/components/primitives/ChainTokenIcon.js +3 -2
- package/_cjs/src/components/primitives/ChainTokenIcon.js.map +1 -1
- package/_cjs/src/components/primitives/SlippageButton.js +40 -0
- package/_cjs/src/components/primitives/SlippageButton.js.map +1 -0
- package/_cjs/src/components/primitives/Tabs.js +4 -2
- package/_cjs/src/components/primitives/Tabs.js.map +1 -1
- package/_cjs/src/components/widgets/SwapButton.js +35 -7
- package/_cjs/src/components/widgets/SwapButton.js.map +1 -1
- package/_cjs/src/components/widgets/TokenWidget/AmountModeToggle.js +31 -0
- package/_cjs/src/components/widgets/TokenWidget/AmountModeToggle.js.map +1 -0
- package/_cjs/src/components/widgets/TokenWidget/AmountSectionHeader.js +8 -0
- package/_cjs/src/components/widgets/TokenWidget/AmountSectionHeader.js.map +1 -0
- package/_cjs/src/components/widgets/TokenWidget/BuyTabContent.js +218 -0
- package/_cjs/src/components/widgets/TokenWidget/BuyTabContent.js.map +1 -0
- package/_cjs/src/components/widgets/TokenWidget/DestinationWalletSelector.js +20 -0
- package/_cjs/src/components/widgets/TokenWidget/DestinationWalletSelector.js.map +1 -0
- package/_cjs/src/components/widgets/TokenWidget/FeeBreakdownInfo.js +26 -0
- package/_cjs/src/components/widgets/TokenWidget/FeeBreakdownInfo.js.map +1 -0
- package/_cjs/src/components/widgets/TokenWidget/FeeBreakdownTooltip.js +40 -0
- package/_cjs/src/components/widgets/TokenWidget/FeeBreakdownTooltip.js.map +1 -0
- package/_cjs/src/components/widgets/TokenWidget/SectionContainer.js +22 -0
- package/_cjs/src/components/widgets/TokenWidget/SectionContainer.js.map +1 -0
- package/_cjs/src/components/widgets/TokenWidget/SellTabContent.js +280 -0
- package/_cjs/src/components/widgets/TokenWidget/SellTabContent.js.map +1 -0
- package/_cjs/src/components/widgets/TokenWidget/TransactionDetailsFooter.js +28 -0
- package/_cjs/src/components/widgets/TokenWidget/TransactionDetailsFooter.js.map +1 -0
- package/_cjs/src/components/widgets/TokenWidget/hooks/useWalletGuards.js +108 -0
- package/_cjs/src/components/widgets/TokenWidget/hooks/useWalletGuards.js.map +1 -0
- package/_cjs/src/components/widgets/TokenWidget/index.js +9 -0
- package/_cjs/src/components/widgets/TokenWidget/index.js.map +1 -0
- package/_cjs/src/components/widgets/TokenWidget/widget/TokenWidgetRenderer.js +770 -0
- package/_cjs/src/components/widgets/TokenWidget/widget/TokenWidgetRenderer.js.map +1 -0
- package/_cjs/src/components/widgets/TokenWidget/widget/index.js +1005 -0
- package/_cjs/src/components/widgets/TokenWidget/widget/index.js.map +1 -0
- package/_cjs/src/hooks/index.js +3 -1
- package/_cjs/src/hooks/index.js.map +1 -1
- package/_cjs/src/hooks/useDuneBalances.js +2 -1
- package/_cjs/src/hooks/useDuneBalances.js.map +1 -1
- package/_cjs/src/hooks/useEOADetection.js +3 -0
- package/_cjs/src/hooks/useEOADetection.js.map +1 -1
- package/_cjs/src/hooks/useMultiWalletBalances.js +119 -0
- package/_cjs/src/hooks/useMultiWalletBalances.js.map +1 -0
- package/_cjs/src/index.js.map +1 -1
- package/_cjs/src/styles.css +251 -88
- package/_cjs/src/utils/numbers.js +39 -1
- package/_cjs/src/utils/numbers.js.map +1 -1
- package/_cjs/src/utils/tokenSelector.js +4 -1
- package/_cjs/src/utils/tokenSelector.js.map +1 -1
- package/_cjs/src/utils/tokens.js +20 -1
- package/_cjs/src/utils/tokens.js.map +1 -1
- package/_cjs/src/version.js +1 -1
- package/_cjs/tsconfig.build.tsbuildinfo +1 -1
- package/_esm/src/components/common/BalanceDisplay.js +4 -3
- package/_esm/src/components/common/BalanceDisplay.js.map +1 -1
- package/_esm/src/components/common/MultiWalletDropdown.js +5 -4
- package/_esm/src/components/common/MultiWalletDropdown.js.map +1 -1
- package/_esm/src/components/common/PercentageButtons.js +10 -10
- package/_esm/src/components/common/PercentageButtons.js.map +1 -1
- package/_esm/src/components/common/SlippageToleranceConfig.js +31 -23
- package/_esm/src/components/common/SlippageToleranceConfig.js.map +1 -1
- package/_esm/src/components/common/TokenSelector/ChainFilter.js +25 -23
- package/_esm/src/components/common/TokenSelector/ChainFilter.js.map +1 -1
- package/_esm/src/components/common/TokenSelector/ChainFilterRow.js +112 -0
- package/_esm/src/components/common/TokenSelector/ChainFilterRow.js.map +1 -0
- package/_esm/src/components/common/TokenSelector/ChainFilterSidebar.js +4 -15
- package/_esm/src/components/common/TokenSelector/ChainFilterSidebar.js.map +1 -1
- package/_esm/src/components/common/TokenSelector/CompactChainFilter.js +176 -0
- package/_esm/src/components/common/TokenSelector/CompactChainFilter.js.map +1 -0
- package/_esm/src/components/common/TokenSelector/PaymentMethod.js +461 -0
- package/_esm/src/components/common/TokenSelector/PaymentMethod.js.map +1 -0
- package/_esm/src/components/common/TokenSelector/PaymentTokenList.js +79 -0
- package/_esm/src/components/common/TokenSelector/PaymentTokenList.js.map +1 -0
- package/_esm/src/components/common/TokenSelector/triggers/PaymentMethodTrigger.js +72 -0
- package/_esm/src/components/common/TokenSelector/triggers/PaymentMethodTrigger.js.map +1 -0
- package/_esm/src/components/primitives/ChainTokenIcon.js +3 -2
- package/_esm/src/components/primitives/ChainTokenIcon.js.map +1 -1
- package/_esm/src/components/primitives/SlippageButton.js +36 -0
- package/_esm/src/components/primitives/SlippageButton.js.map +1 -0
- package/_esm/src/components/primitives/Tabs.js +4 -2
- package/_esm/src/components/primitives/Tabs.js.map +1 -1
- package/_esm/src/components/widgets/SwapButton.js +35 -7
- package/_esm/src/components/widgets/SwapButton.js.map +1 -1
- package/_esm/src/components/widgets/TokenWidget/AmountModeToggle.js +30 -0
- package/_esm/src/components/widgets/TokenWidget/AmountModeToggle.js.map +1 -0
- package/_esm/src/components/widgets/TokenWidget/AmountSectionHeader.js +7 -0
- package/_esm/src/components/widgets/TokenWidget/AmountSectionHeader.js.map +1 -0
- package/_esm/src/components/widgets/TokenWidget/BuyTabContent.js +215 -0
- package/_esm/src/components/widgets/TokenWidget/BuyTabContent.js.map +1 -0
- package/_esm/src/components/widgets/TokenWidget/DestinationWalletSelector.js +16 -0
- package/_esm/src/components/widgets/TokenWidget/DestinationWalletSelector.js.map +1 -0
- package/_esm/src/components/widgets/TokenWidget/FeeBreakdownInfo.js +21 -0
- package/_esm/src/components/widgets/TokenWidget/FeeBreakdownInfo.js.map +1 -0
- package/_esm/src/components/widgets/TokenWidget/FeeBreakdownTooltip.js +39 -0
- package/_esm/src/components/widgets/TokenWidget/FeeBreakdownTooltip.js.map +1 -0
- package/_esm/src/components/widgets/TokenWidget/SectionContainer.js +22 -0
- package/_esm/src/components/widgets/TokenWidget/SectionContainer.js.map +1 -0
- package/_esm/src/components/widgets/TokenWidget/SellTabContent.js +283 -0
- package/_esm/src/components/widgets/TokenWidget/SellTabContent.js.map +1 -0
- package/_esm/src/components/widgets/TokenWidget/TransactionDetailsFooter.js +27 -0
- package/_esm/src/components/widgets/TokenWidget/TransactionDetailsFooter.js.map +1 -0
- package/_esm/src/components/widgets/TokenWidget/hooks/useWalletGuards.js +104 -0
- package/_esm/src/components/widgets/TokenWidget/hooks/useWalletGuards.js.map +1 -0
- package/_esm/src/components/widgets/TokenWidget/index.js +2 -0
- package/_esm/src/components/widgets/TokenWidget/index.js.map +1 -0
- package/_esm/src/components/widgets/TokenWidget/widget/TokenWidgetRenderer.js +795 -0
- package/_esm/src/components/widgets/TokenWidget/widget/TokenWidgetRenderer.js.map +1 -0
- package/_esm/src/components/widgets/TokenWidget/widget/index.js +1073 -0
- package/_esm/src/components/widgets/TokenWidget/widget/index.js.map +1 -0
- package/_esm/src/hooks/index.js +2 -1
- package/_esm/src/hooks/index.js.map +1 -1
- package/_esm/src/hooks/useDuneBalances.js +2 -1
- package/_esm/src/hooks/useDuneBalances.js.map +1 -1
- package/_esm/src/hooks/useEOADetection.js +3 -0
- package/_esm/src/hooks/useEOADetection.js.map +1 -1
- package/_esm/src/hooks/useMultiWalletBalances.js +122 -0
- package/_esm/src/hooks/useMultiWalletBalances.js.map +1 -0
- package/_esm/src/index.js.map +1 -1
- package/_esm/src/styles.css +251 -88
- package/_esm/src/utils/numbers.js +44 -1
- package/_esm/src/utils/numbers.js.map +1 -1
- package/_esm/src/utils/tokenSelector.js +4 -1
- package/_esm/src/utils/tokenSelector.js.map +1 -1
- package/_esm/src/utils/tokens.js +25 -0
- package/_esm/src/utils/tokens.js.map +1 -1
- package/_esm/src/version.js +1 -1
- package/_esm/tsconfig.build.tsbuildinfo +1 -1
- package/_types/src/components/common/BalanceDisplay.d.ts +2 -0
- package/_types/src/components/common/BalanceDisplay.d.ts.map +1 -1
- package/_types/src/components/common/MultiWalletDropdown.d.ts +2 -1
- package/_types/src/components/common/MultiWalletDropdown.d.ts.map +1 -1
- package/_types/src/components/common/PercentageButtons.d.ts +3 -1
- package/_types/src/components/common/PercentageButtons.d.ts.map +1 -1
- package/_types/src/components/common/SlippageToleranceConfig.d.ts +7 -0
- package/_types/src/components/common/SlippageToleranceConfig.d.ts.map +1 -1
- package/_types/src/components/common/TokenSelector/ChainFilter.d.ts.map +1 -1
- package/_types/src/components/common/TokenSelector/ChainFilterRow.d.ts +19 -0
- package/_types/src/components/common/TokenSelector/ChainFilterRow.d.ts.map +1 -0
- package/_types/src/components/common/TokenSelector/ChainFilterSidebar.d.ts.map +1 -1
- package/_types/src/components/common/TokenSelector/CompactChainFilter.d.ts +14 -0
- package/_types/src/components/common/TokenSelector/CompactChainFilter.d.ts.map +1 -0
- package/_types/src/components/common/TokenSelector/PaymentMethod.d.ts +24 -0
- package/_types/src/components/common/TokenSelector/PaymentMethod.d.ts.map +1 -0
- package/_types/src/components/common/TokenSelector/PaymentTokenList.d.ts +15 -0
- package/_types/src/components/common/TokenSelector/PaymentTokenList.d.ts.map +1 -0
- package/_types/src/components/common/TokenSelector/triggers/PaymentMethodTrigger.d.ts +13 -0
- package/_types/src/components/common/TokenSelector/triggers/PaymentMethodTrigger.d.ts.map +1 -0
- package/_types/src/components/primitives/ChainTokenIcon.d.ts +1 -0
- package/_types/src/components/primitives/ChainTokenIcon.d.ts.map +1 -1
- package/_types/src/components/primitives/SlippageButton.d.ts +8 -0
- package/_types/src/components/primitives/SlippageButton.d.ts.map +1 -0
- package/_types/src/components/primitives/Tabs.d.ts.map +1 -1
- package/_types/src/components/widgets/SwapButton.d.ts +5 -2
- package/_types/src/components/widgets/SwapButton.d.ts.map +1 -1
- package/_types/src/components/widgets/TokenWidget/AmountModeToggle.d.ts +12 -0
- package/_types/src/components/widgets/TokenWidget/AmountModeToggle.d.ts.map +1 -0
- package/_types/src/components/widgets/TokenWidget/AmountSectionHeader.d.ts +11 -0
- package/_types/src/components/widgets/TokenWidget/AmountSectionHeader.d.ts.map +1 -0
- package/_types/src/components/widgets/TokenWidget/BuyTabContent.d.ts +52 -0
- package/_types/src/components/widgets/TokenWidget/BuyTabContent.d.ts.map +1 -0
- package/_types/src/components/widgets/TokenWidget/DestinationWalletSelector.d.ts +17 -0
- package/_types/src/components/widgets/TokenWidget/DestinationWalletSelector.d.ts.map +1 -0
- package/_types/src/components/widgets/TokenWidget/FeeBreakdownInfo.d.ts +16 -0
- package/_types/src/components/widgets/TokenWidget/FeeBreakdownInfo.d.ts.map +1 -0
- package/_types/src/components/widgets/TokenWidget/FeeBreakdownTooltip.d.ts +15 -0
- package/_types/src/components/widgets/TokenWidget/FeeBreakdownTooltip.d.ts.map +1 -0
- package/_types/src/components/widgets/TokenWidget/SectionContainer.d.ts +8 -0
- package/_types/src/components/widgets/TokenWidget/SectionContainer.d.ts.map +1 -0
- package/_types/src/components/widgets/TokenWidget/SellTabContent.d.ts +61 -0
- package/_types/src/components/widgets/TokenWidget/SellTabContent.d.ts.map +1 -0
- package/_types/src/components/widgets/TokenWidget/TransactionDetailsFooter.d.ts +14 -0
- package/_types/src/components/widgets/TokenWidget/TransactionDetailsFooter.d.ts.map +1 -0
- package/_types/src/components/widgets/TokenWidget/hooks/useWalletGuards.d.ts +28 -0
- package/_types/src/components/widgets/TokenWidget/hooks/useWalletGuards.d.ts.map +1 -0
- package/_types/src/components/widgets/TokenWidget/index.d.ts +3 -0
- package/_types/src/components/widgets/TokenWidget/index.d.ts.map +1 -0
- package/_types/src/components/widgets/TokenWidget/widget/TokenWidgetRenderer.d.ts +125 -0
- package/_types/src/components/widgets/TokenWidget/widget/TokenWidgetRenderer.d.ts.map +1 -0
- package/_types/src/components/widgets/TokenWidget/widget/index.d.ts +57 -0
- package/_types/src/components/widgets/TokenWidget/widget/index.d.ts.map +1 -0
- package/_types/src/hooks/index.d.ts +2 -1
- package/_types/src/hooks/index.d.ts.map +1 -1
- package/_types/src/hooks/useDuneBalances.d.ts.map +1 -1
- package/_types/src/hooks/useEOADetection.d.ts.map +1 -1
- package/_types/src/hooks/useMultiWalletBalances.d.ts +26 -0
- package/_types/src/hooks/useMultiWalletBalances.d.ts.map +1 -0
- package/_types/src/index.d.ts +1 -0
- package/_types/src/index.d.ts.map +1 -1
- package/_types/src/utils/numbers.d.ts +8 -1
- package/_types/src/utils/numbers.d.ts.map +1 -1
- package/_types/src/utils/tokenSelector.d.ts +1 -1
- package/_types/src/utils/tokenSelector.d.ts.map +1 -1
- package/_types/src/utils/tokens.d.ts +17 -0
- package/_types/src/utils/tokens.d.ts.map +1 -1
- package/_types/src/version.d.ts +1 -1
- package/_types/tsconfig.build.tsbuildinfo +1 -1
- package/dist/panda.buildinfo.json +74 -33
- package/dist/styles.css +251 -88
- package/package.json +8 -3
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.PaymentMethodTrigger = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
6
|
+
const index_js_1 = require("../../../primitives/index.js");
|
|
7
|
+
const react_fontawesome_1 = require("@fortawesome/react-fontawesome");
|
|
8
|
+
const free_solid_svg_icons_1 = require("@fortawesome/free-solid-svg-icons");
|
|
9
|
+
const useRelayClient_js_1 = tslib_1.__importDefault(require("../../../../hooks/useRelayClient.js"));
|
|
10
|
+
const index_js_2 = require("../../../../hooks/index.js");
|
|
11
|
+
const numbers_js_1 = require("../../../../utils/numbers.js");
|
|
12
|
+
const relay_sdk_1 = require("@relayprotocol/relay-sdk");
|
|
13
|
+
const normalizeAddress = (address) => {
|
|
14
|
+
if (!address ||
|
|
15
|
+
address === relay_sdk_1.evmDeadAddress ||
|
|
16
|
+
address === relay_sdk_1.solDeadAddress ||
|
|
17
|
+
address === relay_sdk_1.bitcoinDeadAddress) {
|
|
18
|
+
return undefined;
|
|
19
|
+
}
|
|
20
|
+
return address.startsWith('0x') ? address.toLowerCase() : address;
|
|
21
|
+
};
|
|
22
|
+
const PaymentMethodTrigger = ({ token, locked, address, testId, balanceLabel = 'available', placeholderText = 'Select Token' }) => {
|
|
23
|
+
const relayClient = (0, useRelayClient_js_1.default)();
|
|
24
|
+
const normalizedAddress = normalizeAddress(address);
|
|
25
|
+
const chain = relayClient?.chains?.find((c) => c.id === token?.chainId);
|
|
26
|
+
const { value: currencyBalanceValue, isLoading: isLoadingCurrencyBalance } = (0, index_js_2.useCurrencyBalance)({
|
|
27
|
+
chain,
|
|
28
|
+
address: normalizedAddress,
|
|
29
|
+
currency: token?.address,
|
|
30
|
+
enabled: Boolean(token && chain && normalizedAddress)
|
|
31
|
+
});
|
|
32
|
+
const showSkeleton = normalizedAddress && isLoadingCurrencyBalance && !currencyBalanceValue;
|
|
33
|
+
let balanceText = '';
|
|
34
|
+
if (currencyBalanceValue && token) {
|
|
35
|
+
const formattedBalance = (0, numbers_js_1.formatBN)(currencyBalanceValue, 4, token.decimals, false);
|
|
36
|
+
balanceText = `${formattedBalance} ${token.symbol} ${balanceLabel}`;
|
|
37
|
+
}
|
|
38
|
+
return token ? ((0, jsx_runtime_1.jsx)(index_js_1.Button, { color: "white", corners: "pill", disabled: locked, css: {
|
|
39
|
+
height: 50,
|
|
40
|
+
minHeight: 50,
|
|
41
|
+
width: '248px',
|
|
42
|
+
flexShrink: 0,
|
|
43
|
+
overflow: 'hidden',
|
|
44
|
+
borderRadius: '12px',
|
|
45
|
+
padding: '12px',
|
|
46
|
+
backgroundColor: 'widget-selector-background',
|
|
47
|
+
border: 'none',
|
|
48
|
+
_hover: {
|
|
49
|
+
backgroundColor: 'widget-selector-hover-background'
|
|
50
|
+
},
|
|
51
|
+
_disabled: {
|
|
52
|
+
backgroundColor: 'widget-selector-background'
|
|
53
|
+
}
|
|
54
|
+
}, "data-testid": testId, children: (0, jsx_runtime_1.jsxs)(index_js_1.Flex, { align: "center", justify: "between", css: { width: '100%' }, children: [(0, jsx_runtime_1.jsxs)(index_js_1.Flex, { align: "center", css: { gap: '2' }, children: [(0, jsx_runtime_1.jsx)(index_js_1.ChainTokenIcon, { chainId: token.chainId, tokenlogoURI: token.logoURI, tokenSymbol: token.symbol, chainIconSize: 14, css: { width: 32, height: 32 } }), (0, jsx_runtime_1.jsxs)(index_js_1.Flex, { direction: "column", align: "start", css: { maxWidth: 150, minWidth: 60, flex: 1 }, children: [(0, jsx_runtime_1.jsx)(index_js_1.Text, { style: "h6", ellipsify: true, css: { maxWidth: '100%' }, children: token.symbol }), showSkeleton ? ((0, jsx_runtime_1.jsx)(index_js_1.Skeleton, { css: {
|
|
55
|
+
width: 70,
|
|
56
|
+
height: 12,
|
|
57
|
+
borderRadius: 4
|
|
58
|
+
} })) : ((0, jsx_runtime_1.jsx)(index_js_1.Text, { style: "subtitle3", color: "subtle", css: {
|
|
59
|
+
lineHeight: '15px',
|
|
60
|
+
maxWidth: '100%',
|
|
61
|
+
whiteSpace: 'nowrap',
|
|
62
|
+
overflow: 'hidden',
|
|
63
|
+
textOverflow: 'ellipsis'
|
|
64
|
+
}, children: balanceText }))] })] }), locked ? null : ((0, jsx_runtime_1.jsx)(index_js_1.Box, { css: { color: 'gray9', width: 14, flexShrink: 0 }, children: (0, jsx_runtime_1.jsx)(react_fontawesome_1.FontAwesomeIcon, { icon: free_solid_svg_icons_1.faChevronRight, width: 14 }) }))] }) })) : ((0, jsx_runtime_1.jsxs)(index_js_1.Button, { color: address ? 'primary' : 'secondary', corners: "pill", cta: true, css: {
|
|
65
|
+
height: 50,
|
|
66
|
+
minHeight: 50,
|
|
67
|
+
width: 'max-content',
|
|
68
|
+
flexShrink: 0,
|
|
69
|
+
overflow: 'hidden',
|
|
70
|
+
px: '3',
|
|
71
|
+
py: '2',
|
|
72
|
+
fontWeight: 700,
|
|
73
|
+
fontSize: '16px'
|
|
74
|
+
}, children: [placeholderText, (0, jsx_runtime_1.jsx)(index_js_1.Box, { css: { width: 14 }, children: (0, jsx_runtime_1.jsx)(react_fontawesome_1.FontAwesomeIcon, { icon: free_solid_svg_icons_1.faChevronRight, width: 14 }) })] }));
|
|
75
|
+
};
|
|
76
|
+
exports.PaymentMethodTrigger = PaymentMethodTrigger;
|
|
77
|
+
//# sourceMappingURL=PaymentMethodTrigger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PaymentMethodTrigger.js","sourceRoot":"","sources":["../../../../../../src/components/common/TokenSelector/triggers/PaymentMethodTrigger.tsx"],"names":[],"mappings":"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"}
|
|
@@ -25,9 +25,10 @@ const SIZES = {
|
|
|
25
25
|
chain: 18
|
|
26
26
|
}
|
|
27
27
|
};
|
|
28
|
-
const ChainTokenIcon = ({ chainId, tokenlogoURI, tokenSymbol, css = {}, size = 'md', chainRadius = 4 }) => {
|
|
28
|
+
const ChainTokenIcon = ({ chainId, tokenlogoURI, tokenSymbol, css = {}, size = 'md', chainRadius = 4, chainIconSize }) => {
|
|
29
29
|
const isValidTokenLogo = tokenlogoURI && tokenlogoURI !== 'missing.png';
|
|
30
30
|
const dimensions = SIZES[size];
|
|
31
|
+
const chainSize = chainIconSize ?? dimensions.chain;
|
|
31
32
|
return chainId ? ((0, jsx_runtime_1.jsxs)(Flex_js_1.default, { css: {
|
|
32
33
|
position: 'relative',
|
|
33
34
|
flexShrink: 0,
|
|
@@ -48,7 +49,7 @@ const ChainTokenIcon = ({ chainId, tokenlogoURI, tokenSymbol, css = {}, size = '
|
|
|
48
49
|
display: 'flex',
|
|
49
50
|
alignItems: 'center',
|
|
50
51
|
justifyContent: 'center'
|
|
51
|
-
}, children: (0, jsx_runtime_1.jsx)(Text_js_1.default, { style: "h6", children: tokenSymbol?.charAt(0).toUpperCase() }) })) : null, (0, jsx_runtime_1.jsx)(ChainIcon_js_1.default, { chainId: chainId, width:
|
|
52
|
+
}, children: (0, jsx_runtime_1.jsx)(Text_js_1.default, { style: "h6", children: tokenSymbol?.charAt(0).toUpperCase() }) })) : null, (0, jsx_runtime_1.jsx)(ChainIcon_js_1.default, { chainId: chainId, width: chainSize, height: chainSize, borderRadius: chainRadius, css: {
|
|
52
53
|
position: 'absolute',
|
|
53
54
|
right: 0,
|
|
54
55
|
bottom: 0,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ChainTokenIcon.js","sourceRoot":"","sources":["../../../../src/components/primitives/ChainTokenIcon.tsx"],"names":[],"mappings":";;;;;AACA,gEAA4B;AAC5B,0EAAsC;AACtC,8DAA0B;AAC1B,gEAA4B;
|
|
1
|
+
{"version":3,"file":"ChainTokenIcon.js","sourceRoot":"","sources":["../../../../src/components/primitives/ChainTokenIcon.tsx"],"names":[],"mappings":";;;;;AACA,gEAA4B;AAC5B,0EAAsC;AACtC,8DAA0B;AAC1B,gEAA4B;AAe5B,MAAM,KAAK,GAAG;IACZ,EAAE,EAAE;QACF,KAAK,EAAE,EAAE;QACT,KAAK,EAAE,EAAE;KACV;IACD,IAAI,EAAE;QACJ,KAAK,EAAE,EAAE;QACT,KAAK,EAAE,EAAE;KACV;IACD,EAAE,EAAE;QACF,KAAK,EAAE,EAAE;QACT,KAAK,EAAE,EAAE;KACV;IACD,EAAE,EAAE;QACF,KAAK,EAAE,EAAE;QACT,KAAK,EAAE,EAAE;KACV;CACO,CAAA;AAEH,MAAM,cAAc,GAAwB,CAAC,EAClD,OAAO,EACP,YAAY,EACZ,WAAW,EACX,GAAG,GAAG,EAAE,EACR,IAAI,GAAG,IAAI,EACX,WAAW,GAAG,CAAC,EACf,aAAa,EACd,EAAE,EAAE;IACH,MAAM,gBAAgB,GAAG,YAAY,IAAI,YAAY,KAAK,aAAa,CAAA;IACvE,MAAM,UAAU,GAAG,KAAK,CAAC,IAAI,CAAC,CAAA;IAC9B,MAAM,SAAS,GAAG,aAAa,IAAI,UAAU,CAAC,KAAK,CAAA;IAEnD,OAAO,OAAO,CAAC,CAAC,CAAC,CACf,wBAAC,iBAAI,IACH,GAAG,EAAE;YACH,QAAQ,EAAE,UAAU;YACpB,UAAU,EAAE,CAAC;YACb,KAAK,EAAE,UAAU,CAAC,KAAK;YACvB,MAAM,EAAE,UAAU,CAAC,KAAK;YACxB,QAAQ,EAAE,QAAQ;YAClB,YAAY,EAAE,WAAW;YACzB,GAAG,GAAG;SACP,aAEA,gBAAgB,CAAC,CAAC,CAAC,CAClB,gCACE,GAAG,EAAE,OAAO,EACZ,GAAG,EAAE,YAAY,EACjB,KAAK,EAAE,UAAU,CAAC,KAAK,EACvB,MAAM,EAAE,UAAU,CAAC,KAAK,EACxB,KAAK,EAAE;oBACL,YAAY,EAAE,IAAI;oBAClB,QAAQ,EAAE,QAAQ;iBACnB,GACD,CACH,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAChB,uBAAC,gBAAG,IACF,GAAG,EAAE;oBACH,KAAK,EAAE,UAAU,CAAC,KAAK;oBACvB,MAAM,EAAE,UAAU,CAAC,KAAK;oBACxB,YAAY,EAAE,KAAK;oBACnB,eAAe,EAAE,UAAU;oBAC3B,KAAK,EAAE,UAAU;oBACjB,OAAO,EAAE,MAAM;oBACf,UAAU,EAAE,QAAQ;oBACpB,cAAc,EAAE,QAAQ;iBACzB,YAED,uBAAC,iBAAI,IAAC,KAAK,EAAC,IAAI,YAAE,WAAW,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,GAAQ,GAC1D,CACP,CAAC,CAAC,CAAC,IAAI,EACR,uBAAC,sBAAS,IACR,OAAO,EAAE,OAAO,EAChB,KAAK,EAAE,SAAS,EAChB,MAAM,EAAE,SAAS,EACjB,YAAY,EAAE,WAAW,EACzB,GAAG,EAAE;oBACH,QAAQ,EAAE,UAAU;oBACpB,KAAK,EAAE,CAAC;oBACR,MAAM,EAAE,CAAC;oBACT,QAAQ,EAAE,QAAQ;oBAClB,eAAe,EAAE,yBAAyB;oBAC1C,MAAM,EAAE,8BAA8B;oBACtC,eAAe,EAAE,kBAAkB;iBACpC,GACD,IACG,CACR,CAAC,CAAC,CAAC,IAAI,CAAA;AACV,CAAC,CAAA;AArEY,QAAA,cAAc,kBAqE1B"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SlippageButton = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
6
|
+
const Button_js_1 = tslib_1.__importDefault(require("./Button.js"));
|
|
7
|
+
const Text_js_1 = tslib_1.__importDefault(require("./Text.js"));
|
|
8
|
+
const convertBpsToPercent = (bps) => {
|
|
9
|
+
if (bps === undefined)
|
|
10
|
+
return undefined;
|
|
11
|
+
const numeric = Number(bps);
|
|
12
|
+
if (!Number.isFinite(numeric))
|
|
13
|
+
return undefined;
|
|
14
|
+
const percent = numeric / 100;
|
|
15
|
+
if (!Number.isFinite(percent))
|
|
16
|
+
return undefined;
|
|
17
|
+
const formatted = percent.toFixed(percent % 1 === 0 ? 0 : 2);
|
|
18
|
+
return formatted.replace(/\.0+$/, '').replace(/\.00$/, '');
|
|
19
|
+
};
|
|
20
|
+
const SlippageButton = ({ slippageTolerance, onOpenSlippageConfig }) => {
|
|
21
|
+
const resolvedValue = convertBpsToPercent(slippageTolerance);
|
|
22
|
+
const displayValue = resolvedValue ? `${resolvedValue}%` : 'Auto';
|
|
23
|
+
return ((0, jsx_runtime_1.jsxs)(Button_js_1.default, { "aria-label": "Slippage Settings", size: "none", color: "ghost", css: {
|
|
24
|
+
display: 'flex',
|
|
25
|
+
borderRadius: '8px',
|
|
26
|
+
alignItems: 'center',
|
|
27
|
+
gap: '4px',
|
|
28
|
+
justifyContent: 'center',
|
|
29
|
+
p: '1',
|
|
30
|
+
_hover: {
|
|
31
|
+
backgroundColor: 'gray2'
|
|
32
|
+
},
|
|
33
|
+
backgroundColor: 'gray3',
|
|
34
|
+
padding: '4px 6px'
|
|
35
|
+
}, onClick: () => {
|
|
36
|
+
onOpenSlippageConfig?.();
|
|
37
|
+
}, children: [(0, jsx_runtime_1.jsx)(Text_js_1.default, { style: "subtitle3", color: "subtle", children: "Slippage" }), (0, jsx_runtime_1.jsx)(Text_js_1.default, { style: "subtitle2", children: displayValue })] }));
|
|
38
|
+
};
|
|
39
|
+
exports.SlippageButton = SlippageButton;
|
|
40
|
+
//# sourceMappingURL=SlippageButton.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SlippageButton.js","sourceRoot":"","sources":["../../../../src/components/primitives/SlippageButton.tsx"],"names":[],"mappings":";;;;;AACA,oEAAgC;AAChC,gEAA4B;AAO5B,MAAM,mBAAmB,GAAG,CAAC,GAAY,EAAE,EAAE;IAC3C,IAAI,GAAG,KAAK,SAAS;QAAE,OAAO,SAAS,CAAA;IACvC,MAAM,OAAO,GAAG,MAAM,CAAC,GAAG,CAAC,CAAA;IAC3B,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC;QAAE,OAAO,SAAS,CAAA;IAE/C,MAAM,OAAO,GAAG,OAAO,GAAG,GAAG,CAAA;IAC7B,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC;QAAE,OAAO,SAAS,CAAA;IAE/C,MAAM,SAAS,GAAG,OAAO,CAAC,OAAO,CAAC,OAAO,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;IAC5D,OAAO,SAAS,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,CAAC,CAAA;AAC5D,CAAC,CAAA;AAEM,MAAM,cAAc,GAA4B,CAAC,EACtD,iBAAiB,EACjB,oBAAoB,EACrB,EAAE,EAAE;IACH,MAAM,aAAa,GAAG,mBAAmB,CAAC,iBAAiB,CAAC,CAAA;IAC5D,MAAM,YAAY,GAAG,aAAa,CAAC,CAAC,CAAC,GAAG,aAAa,GAAG,CAAC,CAAC,CAAC,MAAM,CAAA;IAEjE,OAAO,CACL,wBAAC,mBAAM,kBACM,mBAAmB,EAC9B,IAAI,EAAC,MAAM,EACX,KAAK,EAAC,OAAO,EACb,GAAG,EAAE;YACH,OAAO,EAAE,MAAM;YACf,YAAY,EAAE,KAAK;YACnB,UAAU,EAAE,QAAQ;YACpB,GAAG,EAAE,KAAK;YACV,cAAc,EAAE,QAAQ;YACxB,CAAC,EAAE,GAAG;YACN,MAAM,EAAE;gBACN,eAAe,EAAE,OAAO;aACzB;YACD,eAAe,EAAE,OAAO;YACxB,OAAO,EAAE,SAAS;SACnB,EACD,OAAO,EAAE,GAAG,EAAE;YACZ,oBAAoB,EAAE,EAAE,CAAA;QAC1B,CAAC,aAED,uBAAC,iBAAI,IAAC,KAAK,EAAC,WAAW,EAAC,KAAK,EAAC,QAAQ,yBAE/B,EAEP,uBAAC,iBAAI,IAAC,KAAK,EAAC,WAAW,YAAE,YAAY,GAAQ,IACtC,CACV,CAAA;AACH,CAAC,CAAA;AApCY,QAAA,cAAc,kBAoC1B"}
|
|
@@ -26,11 +26,13 @@ const TabsTriggerCss = (0, css_1.cva)({
|
|
|
26
26
|
color: 'gray12',
|
|
27
27
|
borderRadius: 8,
|
|
28
28
|
backgroundColor: 'transparent',
|
|
29
|
-
|
|
29
|
+
borderWidth: '1px',
|
|
30
|
+
borderStyle: 'solid',
|
|
31
|
+
borderColor: 'transparent',
|
|
30
32
|
'&[data-state="active"]': {
|
|
31
33
|
backgroundColor: 'subtle-background-color',
|
|
32
34
|
'--borderColor': 'colors.gray.5',
|
|
33
|
-
|
|
35
|
+
borderColor: 'var(--borderColor)'
|
|
34
36
|
}
|
|
35
37
|
}
|
|
36
38
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Tabs.js","sourceRoot":"","sources":["../../../../src/components/primitives/Tabs.tsx"],"names":[],"mappings":";;;;;AAAA,4EAAqD;AACrD,gEAI+C;AAC/C,iCAIc;AAEd,MAAM,WAAW,GAAG,IAAA,SAAG,EAAC;IACtB,IAAI,EAAE;QACJ,OAAO,EAAE,MAAM;QACf,UAAU,EAAE,QAAQ;QACpB,YAAY,EAAE,CAAC;QACf,CAAC,EAAE,GAAG;QACN,eAAe,EAAE,OAAO;QACxB,MAAM,EAAE,MAAM;KACf;CACF,CAAC,CAAA;AAEF,MAAM,cAAc,GAAG,IAAA,SAAG,EAAC;IACzB,IAAI,EAAE;QACJ,KAAK,EAAE,MAAM;QACb,UAAU,EAAE,KAAK;QACjB,QAAQ,EAAE,MAAM;QAChB,MAAM,EAAE,SAAS;QACjB,EAAE,EAAE,KAAK;QACT,KAAK,EAAE,QAAQ;QACf,YAAY,EAAE,CAAC;QACf,eAAe,EAAE,aAAa;QAC9B,
|
|
1
|
+
{"version":3,"file":"Tabs.js","sourceRoot":"","sources":["../../../../src/components/primitives/Tabs.tsx"],"names":[],"mappings":";;;;;AAAA,4EAAqD;AACrD,gEAI+C;AAC/C,iCAIc;AAEd,MAAM,WAAW,GAAG,IAAA,SAAG,EAAC;IACtB,IAAI,EAAE;QACJ,OAAO,EAAE,MAAM;QACf,UAAU,EAAE,QAAQ;QACpB,YAAY,EAAE,CAAC;QACf,CAAC,EAAE,GAAG;QACN,eAAe,EAAE,OAAO;QACxB,MAAM,EAAE,MAAM;KACf;CACF,CAAC,CAAA;AAEF,MAAM,cAAc,GAAG,IAAA,SAAG,EAAC;IACzB,IAAI,EAAE;QACJ,KAAK,EAAE,MAAM;QACb,UAAU,EAAE,KAAK;QACjB,QAAQ,EAAE,MAAM;QAChB,MAAM,EAAE,SAAS;QACjB,EAAE,EAAE,KAAK;QACT,KAAK,EAAE,QAAQ;QACf,YAAY,EAAE,CAAC;QACf,eAAe,EAAE,aAAa;QAC9B,WAAW,EAAE,KAAK;QAClB,WAAW,EAAE,OAAO;QACpB,WAAW,EAAE,aAAa;QAC1B,wBAAwB,EAAE;YACxB,eAAe,EAAE,yBAAyB;YAC1C,eAAe,EAAE,eAAe;YAChC,WAAW,EAAE,oBAAoB;SAClC;KACF;CACF,CAAC,CAAA;AAEF,MAAM,QAAQ,GAAG,IAAA,kBAAU,EAKzB,CAAC,EAAE,QAAQ,EAAE,GAAG,EAAE,GAAG,KAAK,EAAE,EAAE,YAAY,EAAE,EAAE;IAC9C,OAAO,CACL,uBAAC,aAAa,CAAC,IAAI,OACb,KAAK,EACT,GAAG,EAAE,YAAY,EACjB,SAAS,EAAE,IAAA,SAAS,EAAC,WAAW,CAAC,GAAG,EAAE,EAAE,SAAS,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,YAE1D,QAAQ,GACU,CACtB,CAAA;AACH,CAAC,CAAC,CAAA;AAqDiB,4BAAQ;AAnD3B,MAAM,WAAW,GAAG,IAAA,kBAAU,EAK5B,CAAC,EAAE,QAAQ,EAAE,GAAG,EAAE,GAAG,KAAK,EAAE,EAAE,YAAY,EAAE,EAAE;IAC9C,OAAO,CACL,uBAAC,aAAa,CAAC,OAAO,OAChB,KAAK,EACT,GAAG,EAAE,YAAY,EACjB,SAAS,EAAE,IAAA,SAAS,EAAC,cAAc,CAAC,GAAG,EAAE,EAAE,SAAS,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,YAE7D,QAAQ,GACa,CACzB,CAAA;AACH,CAAC,CAAC,CAAA;AAoC2B,kCAAW;AAlCxC,MAAM,WAAW,GAAG,IAAA,kBAAU,EAK5B,CAAC,EAAE,QAAQ,EAAE,GAAG,EAAE,GAAG,KAAK,EAAE,EAAE,YAAY,EAAE,EAAE;IAC9C,OAAO,CACL,uBAAC,aAAa,CAAC,OAAO,OAChB,KAAK,EACT,GAAG,EAAE,YAAY,EACjB,SAAS,EAAE,IAAA,SAAS,EAAC,SAAS,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,YAEvC,QAAQ,GACa,CACzB,CAAA;AACH,CAAC,CAAC,CAAA;AAmBwC,kCAAW;AAjBrD,MAAM,QAAQ,GAAG,IAAA,kBAAU,EAKzB,CAAC,EAAE,QAAQ,EAAE,GAAG,EAAE,GAAG,KAAK,EAAE,EAAE,YAAY,EAAE,EAAE;IAC9C,OAAO,CACL,uBAAC,aAAa,CAAC,IAAI,OACb,KAAK,EACT,GAAG,EAAE,YAAY,EACjB,SAAS,EAAE,IAAA,SAAS,EAAC,SAAS,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,YAEvC,QAAQ,GACU,CACtB,CAAA;AACH,CAAC,CAAC,CAAA;AAEO,4BAAQ"}
|
|
@@ -4,13 +4,20 @@ const jsx_runtime_1 = require("react/jsx-runtime");
|
|
|
4
4
|
const index_js_1 = require("../primitives/index.js");
|
|
5
5
|
const index_js_2 = require("../../hooks/index.js");
|
|
6
6
|
const events_js_1 = require("../../constants/events.js");
|
|
7
|
-
const SwapButton = ({ transactionModalOpen, depositAddressModalOpen, isValidFromAddress, isValidToAddress, context, showHighPriceImpactWarning, onConnectWallet, quote, address, hasInsufficientBalance, isInsufficientLiquidityError, debouncedInputAmountValue, debouncedOutputAmountValue, isSameCurrencySameRecipientSwap, fromChainWalletVMSupported, recipientWalletSupportsChain, onClick, ctaCopy, onAnalyticEvent, isFetchingQuote }) => {
|
|
7
|
+
const SwapButton = ({ transactionModalOpen, depositAddressModalOpen, isValidFromAddress, isValidToAddress, context, showHighPriceImpactWarning = false, disableSwapButton = false, tokenWidgetMode = false, hasValidAmount = true, onConnectWallet, quote, address, hasInsufficientBalance, isInsufficientLiquidityError, debouncedInputAmountValue, debouncedOutputAmountValue, isSameCurrencySameRecipientSwap, fromChainWalletVMSupported, recipientWalletSupportsChain, onClick, ctaCopy, onAnalyticEvent, isFetchingQuote }) => {
|
|
8
8
|
const isMounted = (0, index_js_2.useMounted)();
|
|
9
9
|
if (isMounted && (address || !fromChainWalletVMSupported)) {
|
|
10
10
|
const invalidAmount = !quote ||
|
|
11
11
|
Number(debouncedInputAmountValue) === 0 ||
|
|
12
12
|
Number(debouncedOutputAmountValue) === 0;
|
|
13
|
-
|
|
13
|
+
const isWalletSelectionPrompt = tokenWidgetMode && (ctaCopy.includes('Select') || ctaCopy.includes('Enter'));
|
|
14
|
+
const isSelectTokenPrompt = tokenWidgetMode && ctaCopy === 'Select a token';
|
|
15
|
+
const buttonDisabled = tokenWidgetMode
|
|
16
|
+
? (disableSwapButton ||
|
|
17
|
+
isFetchingQuote ||
|
|
18
|
+
isSelectTokenPrompt ||
|
|
19
|
+
(!isWalletSelectionPrompt && !hasValidAmount))
|
|
20
|
+
: (isFetchingQuote ||
|
|
14
21
|
(isValidToAddress &&
|
|
15
22
|
(isValidFromAddress || !fromChainWalletVMSupported) &&
|
|
16
23
|
(invalidAmount ||
|
|
@@ -19,11 +26,32 @@ const SwapButton = ({ transactionModalOpen, depositAddressModalOpen, isValidFrom
|
|
|
19
26
|
transactionModalOpen ||
|
|
20
27
|
depositAddressModalOpen ||
|
|
21
28
|
isSameCurrencySameRecipientSwap ||
|
|
22
|
-
!recipientWalletSupportsChain
|
|
23
|
-
|
|
24
|
-
|
|
29
|
+
!recipientWalletSupportsChain ||
|
|
30
|
+
disableSwapButton)));
|
|
31
|
+
const buttonLabel = tokenWidgetMode && isFetchingQuote && hasValidAmount
|
|
32
|
+
? 'Fetching quote'
|
|
33
|
+
: ctaCopy;
|
|
34
|
+
return ((0, jsx_runtime_1.jsx)(index_js_1.Button, { css: {
|
|
35
|
+
justifyContent: 'center',
|
|
36
|
+
width: tokenWidgetMode ? '100%' : undefined,
|
|
37
|
+
textTransform: tokenWidgetMode ? 'uppercase' : undefined,
|
|
38
|
+
fontFamily: tokenWidgetMode ? 'heading' : undefined,
|
|
39
|
+
fontWeight: tokenWidgetMode ? 700 : undefined,
|
|
40
|
+
fontStyle: tokenWidgetMode ? 'var(--relay-fonts-button-cta-font-style, italic)' : undefined
|
|
41
|
+
}, color: showHighPriceImpactWarning ? 'error' : 'primary', "aria-label": context, cta: true, disabled: buttonDisabled, "data-testid": tokenWidgetMode ? "token-action-button" : "swap-button", onClick: () => {
|
|
42
|
+
if (!buttonDisabled) {
|
|
43
|
+
onClick();
|
|
44
|
+
}
|
|
45
|
+
}, children: buttonLabel }));
|
|
25
46
|
}
|
|
26
|
-
return ((0, jsx_runtime_1.jsx)(index_js_1.Button, { cta: true, css: {
|
|
47
|
+
return ((0, jsx_runtime_1.jsx)(index_js_1.Button, { cta: true, css: {
|
|
48
|
+
justifyContent: 'center',
|
|
49
|
+
width: tokenWidgetMode ? '100%' : undefined,
|
|
50
|
+
textTransform: tokenWidgetMode ? 'uppercase' : undefined,
|
|
51
|
+
fontFamily: tokenWidgetMode ? 'heading' : undefined,
|
|
52
|
+
fontWeight: tokenWidgetMode ? 700 : undefined,
|
|
53
|
+
fontStyle: tokenWidgetMode ? 'var(--relay-fonts-button-cta-font-style, italic)' : undefined
|
|
54
|
+
}, "aria-label": "Connect wallet", onClick: () => {
|
|
27
55
|
if (!onConnectWallet) {
|
|
28
56
|
throw 'Missing onWalletConnect function';
|
|
29
57
|
}
|
|
@@ -31,7 +59,7 @@ const SwapButton = ({ transactionModalOpen, depositAddressModalOpen, isValidFrom
|
|
|
31
59
|
onAnalyticEvent?.(events_js_1.EventNames.CONNECT_WALLET_CLICKED, {
|
|
32
60
|
context
|
|
33
61
|
});
|
|
34
|
-
}, "data-testid": "widget-connect-wallet-button", children: "Connect Wallet" }));
|
|
62
|
+
}, "data-testid": tokenWidgetMode ? "token-widget-connect-wallet-button" : "widget-connect-wallet-button", children: "Connect Wallet" }));
|
|
35
63
|
};
|
|
36
64
|
exports.default = SwapButton;
|
|
37
65
|
//# sourceMappingURL=SwapButton.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SwapButton.js","sourceRoot":"","sources":["../../../../src/components/widgets/SwapButton.tsx"],"names":[],"mappings":";;;AACA,qDAA+C;AAC/C,mDAAiD;AAEjD,yDAAsD;
|
|
1
|
+
{"version":3,"file":"SwapButton.js","sourceRoot":"","sources":["../../../../src/components/widgets/SwapButton.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
4
|
+
const index_js_1 = require("../../primitives/index.js");
|
|
5
|
+
const index_js_2 = require("../../../icons/index.js");
|
|
6
|
+
const AmountModeToggle = ({ children, onToggle, textProps, buttonAriaLabel = 'Switch Input Mode' }) => {
|
|
7
|
+
const mergedTextProps = {
|
|
8
|
+
style: 'subtitle3',
|
|
9
|
+
color: 'subtleSecondary',
|
|
10
|
+
...textProps
|
|
11
|
+
};
|
|
12
|
+
return ((0, jsx_runtime_1.jsxs)(index_js_1.Flex, { align: "center", css: {
|
|
13
|
+
gap: '8px',
|
|
14
|
+
_hover: { cursor: 'pointer' }
|
|
15
|
+
}, onClick: () => {
|
|
16
|
+
onToggle();
|
|
17
|
+
}, children: [(0, jsx_runtime_1.jsx)(index_js_1.Text, { ...mergedTextProps, children: children }), (0, jsx_runtime_1.jsx)(index_js_1.Button, { "aria-label": buttonAriaLabel, size: "none", color: "ghost", css: {
|
|
18
|
+
color: 'gray11',
|
|
19
|
+
alignSelf: 'center',
|
|
20
|
+
justifyContent: 'center',
|
|
21
|
+
width: '20px',
|
|
22
|
+
height: '20px',
|
|
23
|
+
borderRadius: '100px',
|
|
24
|
+
padding: '4px',
|
|
25
|
+
backgroundColor: 'gray3'
|
|
26
|
+
}, onClick: () => {
|
|
27
|
+
onToggle();
|
|
28
|
+
}, children: (0, jsx_runtime_1.jsx)(index_js_2.SwitchIcon, { width: 16, height: 10 }) })] }));
|
|
29
|
+
};
|
|
30
|
+
exports.default = AmountModeToggle;
|
|
31
|
+
//# sourceMappingURL=AmountModeToggle.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AmountModeToggle.js","sourceRoot":"","sources":["../../../../../src/components/widgets/TokenWidget/AmountModeToggle.tsx"],"names":[],"mappings":";;;AACA,wDAA8D;AAC9D,sDAAoD;AAWpD,MAAM,gBAAgB,GAA8B,CAAC,EACnD,QAAQ,EACR,QAAQ,EACR,SAAS,EACT,eAAe,GAAG,mBAAmB,EACtC,EAAE,EAAE;IACH,MAAM,eAAe,GAAc;QACjC,KAAK,EAAE,WAAW;QAClB,KAAK,EAAE,iBAAiB;QACxB,GAAG,SAAS;KACb,CAAA;IAED,OAAO,CACL,wBAAC,eAAI,IACH,KAAK,EAAC,QAAQ,EACd,GAAG,EAAE;YACH,GAAG,EAAE,KAAK;YACV,MAAM,EAAE,EAAE,MAAM,EAAE,SAAS,EAAE;SAC9B,EACD,OAAO,EAAE,GAAG,EAAE;YACZ,QAAQ,EAAE,CAAA;QACZ,CAAC,aAED,uBAAC,eAAI,OAAK,eAAe,YAAG,QAAQ,GAAQ,EAC5C,uBAAC,iBAAM,kBACO,eAAe,EAC3B,IAAI,EAAC,MAAM,EACX,KAAK,EAAC,OAAO,EACb,GAAG,EAAE;oBACH,KAAK,EAAE,QAAQ;oBACf,SAAS,EAAE,QAAQ;oBACnB,cAAc,EAAE,QAAQ;oBACxB,KAAK,EAAE,MAAM;oBACb,MAAM,EAAE,MAAM;oBACd,YAAY,EAAE,OAAO;oBACrB,OAAO,EAAE,KAAK;oBACd,eAAe,EAAE,OAAO;iBACzB,EACD,OAAO,EAAE,GAAG,EAAE;oBACZ,QAAQ,EAAE,CAAA;gBACZ,CAAC,YAED,uBAAC,qBAAU,IAAC,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,GAAI,GAC9B,IACJ,CACR,CAAA;AACH,CAAC,CAAA;AAED,kBAAe,gBAAgB,CAAA"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
4
|
+
const index_js_1 = require("../../primitives/index.js");
|
|
5
|
+
const SlippageToleranceConfig_js_1 = require("../../common/SlippageToleranceConfig.js");
|
|
6
|
+
const AmountSectionHeader = ({ label, slippageTolerance, onSlippageToleranceChange, onAnalyticEvent, onOpenSlippageConfig }) => ((0, jsx_runtime_1.jsxs)(index_js_1.Flex, { align: "center", justify: "between", css: { gap: '2', width: '100%' }, children: [(0, jsx_runtime_1.jsx)(index_js_1.Text, { style: "subtitle2", children: label }), (0, jsx_runtime_1.jsx)(SlippageToleranceConfig_js_1.SlippageToleranceConfig, { label: "Slippage", showGearIcon: false, showLabel: true, currentSlippageTolerance: slippageTolerance, setSlippageTolerance: onSlippageToleranceChange ?? (() => { }), onAnalyticEvent: onAnalyticEvent, onOpenSlippageConfig: onOpenSlippageConfig, widgetType: "token" })] }));
|
|
7
|
+
exports.default = AmountSectionHeader;
|
|
8
|
+
//# sourceMappingURL=AmountSectionHeader.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AmountSectionHeader.js","sourceRoot":"","sources":["../../../../../src/components/widgets/TokenWidget/AmountSectionHeader.tsx"],"names":[],"mappings":";;;AACA,wDAAsD;AACtD,wFAAiF;AAUjF,MAAM,mBAAmB,GAAiC,CAAC,EACzD,KAAK,EACL,iBAAiB,EACjB,yBAAyB,EACzB,eAAe,EACf,oBAAoB,EACrB,EAAE,EAAE,CAAC,CACJ,wBAAC,eAAI,IAAC,KAAK,EAAC,QAAQ,EAAC,OAAO,EAAC,SAAS,EAAC,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,EAAE,aACrE,uBAAC,eAAI,IAAC,KAAK,EAAC,WAAW,YAAE,KAAK,GAAQ,EACtC,uBAAC,oDAAuB,IACtB,KAAK,EAAC,UAAU,EAChB,YAAY,EAAE,KAAK,EACnB,SAAS,EAAE,IAAI,EACf,wBAAwB,EAAE,iBAAiB,EAC3C,oBAAoB,EAAE,yBAAyB,IAAI,CAAC,GAAG,EAAE,GAAE,CAAC,CAAC,EAC7D,eAAe,EAAE,eAAe,EAChC,oBAAoB,EAAE,oBAAoB,EAC1C,UAAU,EAAC,OAAO,GAClB,IACG,CACR,CAAA;AAED,kBAAe,mBAAmB,CAAA"}
|
|
@@ -0,0 +1,218 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const tslib_1 = require("tslib");
|
|
4
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
5
|
+
const Tabs_js_1 = require("../../primitives/Tabs.js");
|
|
6
|
+
const index_js_1 = require("../../primitives/index.js");
|
|
7
|
+
const AmountInput_js_1 = tslib_1.__importDefault(require("../../common/AmountInput.js"));
|
|
8
|
+
const numbers_js_1 = require("../../../utils/numbers.js");
|
|
9
|
+
const PriceImpact_js_1 = require("../SwapWidget/PriceImpact.js");
|
|
10
|
+
const BalanceDisplay_js_1 = require("../../common/BalanceDisplay.js");
|
|
11
|
+
const jsx_1 = require("@relayprotocol/relay-design-system/jsx");
|
|
12
|
+
const MultiWalletDropdown_js_1 = require("../../common/MultiWalletDropdown.js");
|
|
13
|
+
const PaymentMethod_js_1 = tslib_1.__importDefault(require("../../common/TokenSelector/PaymentMethod.js"));
|
|
14
|
+
const events_js_1 = require("../../../constants/events.js");
|
|
15
|
+
const tokenSelector_js_1 = require("../../../utils/tokenSelector.js");
|
|
16
|
+
const relay_sdk_1 = require("@relayprotocol/relay-sdk");
|
|
17
|
+
const SwapButton_js_1 = tslib_1.__importDefault(require("../SwapButton.js"));
|
|
18
|
+
const PaymentMethodTrigger_js_1 = require("../../common/TokenSelector/triggers/PaymentMethodTrigger.js");
|
|
19
|
+
const AmountSectionHeader_js_1 = tslib_1.__importDefault(require("./AmountSectionHeader.js"));
|
|
20
|
+
const AmountModeToggle_js_1 = tslib_1.__importDefault(require("./AmountModeToggle.js"));
|
|
21
|
+
const TransactionDetailsFooter_js_1 = tslib_1.__importDefault(require("./TransactionDetailsFooter.js"));
|
|
22
|
+
const SectionContainer_js_1 = tslib_1.__importDefault(require("./SectionContainer.js"));
|
|
23
|
+
const WidgetErrorWell_js_1 = require("../WidgetErrorWell.js");
|
|
24
|
+
const FeeBreakdownInfo_js_1 = require("./FeeBreakdownInfo.js");
|
|
25
|
+
const DestinationWalletSelector_js_1 = require("./DestinationWalletSelector.js");
|
|
26
|
+
const BuyTabContent = ({ slippageTolerance, onOpenSlippageConfig, onSlippageToleranceChange, isUsdInputMode, usdOutputValue, tradeType, amountOutputValue, amountInputValue, toToken, fromToken, quote, isFetchingQuote, isLoadingToTokenPrice, outputAmountUsd, toTokenPriceData, setUsdOutputValue, setTradeType, setAmountOutputValue, setAmountInputValue, setUsdInputValue, debouncedAmountOutputControls, onAnalyticEvent, feeBreakdown, isLoadingFromBalance, fromBalance, fromBalancePending, toBalance, isLoadingToBalance, toBalancePending, address, timeEstimate, multiWalletSupportEnabled, toChainWalletVMSupported, fromChain, disablePasteWalletAddressOption, recipient, setCustomToAddress, setDestinationAddressOverride, onConnectWallet, onLinkNewWallet, linkedWallets, toChain, isValidToAddress, isRecipientLinked, setAddressModalOpen, toDisplayName, isValidFromAddress, fromChainWalletVMSupported, supportedWalletVMs, handleSetFromToken, handleSetToToken, onSetPrimaryWallet, setOriginAddressOverride, lockToToken, lockFromToken, isSingleChainLocked, lockChainId, popularChainIds, transactionModalOpen, depositAddressModalOpen, hasInsufficientBalance, isInsufficientLiquidityError, recipientWalletSupportsChain, isSameCurrencySameRecipientSwap, debouncedInputAmountValue, debouncedOutputAmountValue, showHighPriceImpactWarning, disableSwapButton, toggleInputMode, onPrimaryAction, error, relayerFeeProportion, highRelayerServiceFee, isCapacityExceededError, isCouldNotExecuteError, supportsExternalLiquidity, recipientLinkedWallet, toChainVmType, ctaCopy }) => {
|
|
27
|
+
const displayCta = [
|
|
28
|
+
'Swap',
|
|
29
|
+
'Confirm',
|
|
30
|
+
'Bridge',
|
|
31
|
+
'Send',
|
|
32
|
+
'Wrap',
|
|
33
|
+
'Unwrap'
|
|
34
|
+
].includes(ctaCopy)
|
|
35
|
+
? 'Buy'
|
|
36
|
+
: ctaCopy;
|
|
37
|
+
const fromChainId = fromToken?.chainId;
|
|
38
|
+
const lockedChainIds = isSingleChainLocked
|
|
39
|
+
? lockChainId !== undefined
|
|
40
|
+
? [lockChainId]
|
|
41
|
+
: undefined
|
|
42
|
+
: (0, tokenSelector_js_1.isChainLocked)(fromChainId, lockChainId, toToken?.chainId, lockFromToken) && fromChainId !== undefined
|
|
43
|
+
? [fromChainId]
|
|
44
|
+
: undefined;
|
|
45
|
+
const hasSelectedTokens = Boolean(fromToken && toToken);
|
|
46
|
+
const invalidAmount = !quote ||
|
|
47
|
+
Number(debouncedInputAmountValue) === 0 ||
|
|
48
|
+
Number(debouncedOutputAmountValue) === 0 ||
|
|
49
|
+
!hasSelectedTokens;
|
|
50
|
+
const hasValidOutputAmount = toToken && amountOutputValue && Number(amountOutputValue) > 0;
|
|
51
|
+
const currencyInAmountUsd = quote?.details?.currencyIn?.amountUsd;
|
|
52
|
+
const currencyInAmountFormatted = quote?.details?.currencyIn?.amountFormatted;
|
|
53
|
+
const isLoadingPayWith = hasValidOutputAmount && isFetchingQuote && fromToken && !currencyInAmountUsd;
|
|
54
|
+
return ((0, jsx_runtime_1.jsx)(Tabs_js_1.TabsContent, { value: "buy", children: (0, jsx_runtime_1.jsxs)(SectionContainer_js_1.default, { css: {
|
|
55
|
+
backgroundColor: 'widget-background',
|
|
56
|
+
border: '1px solid',
|
|
57
|
+
borderColor: 'slate.4'
|
|
58
|
+
}, id: 'buy-token-section', children: [(0, jsx_runtime_1.jsx)(AmountSectionHeader_js_1.default, { label: "Amount", slippageTolerance: slippageTolerance, onOpenSlippageConfig: onOpenSlippageConfig, onSlippageToleranceChange: onSlippageToleranceChange, onAnalyticEvent: onAnalyticEvent }), (0, jsx_runtime_1.jsx)(index_js_1.Flex, { align: "center", justify: "between", css: { width: '100%' }, children: (0, jsx_runtime_1.jsx)(AmountInput_js_1.default, { prefixSymbol: isUsdInputMode ? '$' : undefined, value: isUsdInputMode
|
|
59
|
+
? usdOutputValue
|
|
60
|
+
: tradeType === 'EXPECTED_OUTPUT'
|
|
61
|
+
? amountOutputValue
|
|
62
|
+
: amountOutputValue
|
|
63
|
+
? (0, numbers_js_1.formatFixedLength)(amountOutputValue, 8)
|
|
64
|
+
: amountOutputValue, setValue: (value) => {
|
|
65
|
+
if (isUsdInputMode) {
|
|
66
|
+
setUsdOutputValue(value);
|
|
67
|
+
setTradeType('EXPECTED_OUTPUT');
|
|
68
|
+
if (Number(value) === 0) {
|
|
69
|
+
setAmountInputValue('');
|
|
70
|
+
setUsdInputValue('');
|
|
71
|
+
debouncedAmountOutputControls.flush();
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
setAmountOutputValue(value);
|
|
76
|
+
setTradeType('EXPECTED_OUTPUT');
|
|
77
|
+
if (Number(value) === 0) {
|
|
78
|
+
setAmountInputValue('');
|
|
79
|
+
debouncedAmountOutputControls.flush();
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
}, disabled: !toToken || !fromChainWalletVMSupported, onClick: () => {
|
|
83
|
+
onAnalyticEvent?.(events_js_1.EventNames.SWAP_OUTPUT_FOCUSED);
|
|
84
|
+
}, css: {
|
|
85
|
+
fontWeight: '700',
|
|
86
|
+
fontSize: 32,
|
|
87
|
+
lineHeight: '32px',
|
|
88
|
+
py: 0,
|
|
89
|
+
color: isFetchingQuote && tradeType === 'EXACT_INPUT'
|
|
90
|
+
? 'text-subtle'
|
|
91
|
+
: 'input-color',
|
|
92
|
+
_placeholder: {
|
|
93
|
+
color: isFetchingQuote && tradeType === 'EXACT_INPUT'
|
|
94
|
+
? 'text-subtle'
|
|
95
|
+
: 'input-color'
|
|
96
|
+
},
|
|
97
|
+
_disabled: {
|
|
98
|
+
cursor: 'not-allowed',
|
|
99
|
+
_placeholder: {
|
|
100
|
+
color: 'gray10'
|
|
101
|
+
},
|
|
102
|
+
color: 'gray10'
|
|
103
|
+
}
|
|
104
|
+
} }) }), (0, jsx_runtime_1.jsxs)(index_js_1.Flex, { align: "center", justify: "between", css: { gap: '3', width: '100%' }, children: [(0, jsx_runtime_1.jsxs)(index_js_1.Flex, { align: "center", css: {
|
|
105
|
+
gap: '3',
|
|
106
|
+
minHeight: 18
|
|
107
|
+
}, children: [(0, jsx_runtime_1.jsx)(AmountModeToggle_js_1.default, { onToggle: toggleInputMode, children: isUsdInputMode
|
|
108
|
+
? toToken
|
|
109
|
+
? usdOutputValue && Number(usdOutputValue) > 0
|
|
110
|
+
? amountOutputValue && !isLoadingToTokenPrice
|
|
111
|
+
? `${(0, numbers_js_1.formatNumber)(amountOutputValue, 4, false)} ${toToken.symbol}`
|
|
112
|
+
: '...'
|
|
113
|
+
: `0 ${toToken.symbol}`
|
|
114
|
+
: null
|
|
115
|
+
: toToken &&
|
|
116
|
+
quote?.details?.currencyOut?.amountUsd &&
|
|
117
|
+
!isFetchingQuote
|
|
118
|
+
? (0, numbers_js_1.formatDollar)(Number(quote.details.currencyOut.amountUsd))
|
|
119
|
+
: toToken &&
|
|
120
|
+
isLoadingToTokenPrice &&
|
|
121
|
+
amountOutputValue &&
|
|
122
|
+
Number(amountOutputValue) > 0
|
|
123
|
+
? '...'
|
|
124
|
+
: toToken &&
|
|
125
|
+
outputAmountUsd &&
|
|
126
|
+
outputAmountUsd > 0 &&
|
|
127
|
+
toTokenPriceData?.price &&
|
|
128
|
+
toTokenPriceData.price > 0
|
|
129
|
+
? (0, numbers_js_1.formatDollar)(outputAmountUsd)
|
|
130
|
+
: '$0.00' }), (0, jsx_runtime_1.jsx)(PriceImpact_js_1.PriceImpact, { toToken: toToken, isFetchingQuote: isFetchingQuote, feeBreakdown: feeBreakdown, quote: quote })] }), (0, jsx_runtime_1.jsx)(index_js_1.Flex, { css: { marginLeft: 'auto' }, children: toToken ? ((0, jsx_runtime_1.jsx)(BalanceDisplay_js_1.BalanceDisplay, { hideBalanceLabel: true, displaySymbol: true, isLoading: isLoadingToBalance, balance: toBalance, decimals: toToken?.decimals, symbol: toToken?.symbol, isConnected: !(0, relay_sdk_1.isDeadAddress)(recipient) &&
|
|
131
|
+
recipient !== relay_sdk_1.tronDeadAddress &&
|
|
132
|
+
recipient !== undefined, pending: toBalancePending, size: "md" })) : ((0, jsx_runtime_1.jsx)(index_js_1.Flex, { css: { height: 18 } })) })] }), (0, jsx_runtime_1.jsx)(jsx_1.Divider, { color: "gray4" }), (0, jsx_runtime_1.jsxs)(index_js_1.Flex, { align: "center", css: { width: '100%', gap: '2' }, children: [(0, jsx_runtime_1.jsx)(index_js_1.Text, { style: "subtitle2", color: "subtle", children: "Pay with" }), multiWalletSupportEnabled && fromChainWalletVMSupported ? ((0, jsx_runtime_1.jsx)(MultiWalletDropdown_js_1.MultiWalletDropdown, { context: "origin", disablePasteWalletAddressOption: disablePasteWalletAddressOption, selectedWalletAddress: address, onSelect: (wallet) => {
|
|
133
|
+
setOriginAddressOverride(wallet.address);
|
|
134
|
+
onSetPrimaryWallet?.(wallet.address);
|
|
135
|
+
if (wallet.address !== address) {
|
|
136
|
+
handleSetFromToken(undefined);
|
|
137
|
+
}
|
|
138
|
+
}, chain: fromChain, disableWalletFiltering: true, onLinkNewWallet: () => {
|
|
139
|
+
if (!address && fromChainWalletVMSupported) {
|
|
140
|
+
onConnectWallet?.();
|
|
141
|
+
}
|
|
142
|
+
else {
|
|
143
|
+
onLinkNewWallet?.({
|
|
144
|
+
chain: fromChain,
|
|
145
|
+
direction: 'from'
|
|
146
|
+
})?.then((wallet) => {
|
|
147
|
+
if (wallet) {
|
|
148
|
+
setOriginAddressOverride(wallet.address);
|
|
149
|
+
onSetPrimaryWallet?.(wallet.address);
|
|
150
|
+
}
|
|
151
|
+
});
|
|
152
|
+
}
|
|
153
|
+
}, setAddressModalOpen: setAddressModalOpen, wallets: linkedWallets ?? [], onAnalyticEvent: onAnalyticEvent, testId: "origin-wallet-select-button" })) : null] }), (0, jsx_runtime_1.jsxs)(index_js_1.Flex, { justify: "between", css: { width: '100%' }, children: [(0, jsx_runtime_1.jsx)(PaymentMethod_js_1.default, { address: address, isValidAddress: isValidFromAddress, token: fromToken, onAnalyticEvent: onAnalyticEvent, fromChainWalletVMSupported: fromChainWalletVMSupported, supportedWalletVMs: supportedWalletVMs, linkedWallets: linkedWallets, multiWalletSupportEnabled: multiWalletSupportEnabled, context: "from", autoSelectToken: false, setToken: (token) => {
|
|
154
|
+
if (token?.address === toToken?.address &&
|
|
155
|
+
token?.chainId === toToken?.chainId &&
|
|
156
|
+
address === recipient &&
|
|
157
|
+
(!lockToToken || !fromToken)) {
|
|
158
|
+
handleSetFromToken(toToken);
|
|
159
|
+
handleSetToToken(fromToken);
|
|
160
|
+
}
|
|
161
|
+
else {
|
|
162
|
+
handleSetFromToken(token);
|
|
163
|
+
}
|
|
164
|
+
}, lockedChainIds: lockedChainIds, chainIdsFilter: !fromChainWalletVMSupported && toToken
|
|
165
|
+
? [toToken.chainId]
|
|
166
|
+
: undefined, popularChainIds: popularChainIds, trigger: (0, jsx_runtime_1.jsx)("div", { style: { width: 'max-content' }, children: (0, jsx_runtime_1.jsx)(PaymentMethodTrigger_js_1.PaymentMethodTrigger, { token: fromToken, locked: lockFromToken, address: address, testId: "origin-token-select-button", balanceLabel: "available" }) }) }), (0, jsx_runtime_1.jsx)(FeeBreakdownInfo_js_1.FeeBreakdownInfo, { isLoading: Boolean(isLoadingPayWith), amountUsd: currencyInAmountUsd, tokenAmountFormatted: currencyInAmountFormatted, fallbackTokenAmount: amountInputValue, quote: quote, feeBreakdown: feeBreakdown, token: fromToken })] }), (0, jsx_runtime_1.jsx)(jsx_1.Divider, { color: "gray4" }), (0, jsx_runtime_1.jsxs)(index_js_1.Flex, { direction: "column", css: { gap: '2', width: '100%' }, children: [(0, jsx_runtime_1.jsx)(DestinationWalletSelector_js_1.DestinationWalletSelector, { label: "Send to", isMultiWalletEnabled: multiWalletSupportEnabled, walletSupported: toChainWalletVMSupported, dropdownProps: {
|
|
167
|
+
disablePasteWalletAddressOption,
|
|
168
|
+
selectedWalletAddress: recipient,
|
|
169
|
+
onSelect: (wallet) => {
|
|
170
|
+
setDestinationAddressOverride(wallet.address);
|
|
171
|
+
setCustomToAddress(undefined);
|
|
172
|
+
},
|
|
173
|
+
chain: toChain,
|
|
174
|
+
disableWalletFiltering: false,
|
|
175
|
+
onLinkNewWallet: () => {
|
|
176
|
+
if (!address && toChainWalletVMSupported) {
|
|
177
|
+
onConnectWallet?.();
|
|
178
|
+
}
|
|
179
|
+
else {
|
|
180
|
+
onLinkNewWallet?.({
|
|
181
|
+
chain: toChain,
|
|
182
|
+
direction: 'to'
|
|
183
|
+
})?.then((wallet) => {
|
|
184
|
+
if (!wallet) {
|
|
185
|
+
return;
|
|
186
|
+
}
|
|
187
|
+
setDestinationAddressOverride(wallet.address);
|
|
188
|
+
setCustomToAddress(undefined);
|
|
189
|
+
});
|
|
190
|
+
}
|
|
191
|
+
},
|
|
192
|
+
setAddressModalOpen,
|
|
193
|
+
wallets: linkedWallets ?? [],
|
|
194
|
+
onAnalyticEvent,
|
|
195
|
+
testId: 'destination-wallet-select-button'
|
|
196
|
+
}, fallback: {
|
|
197
|
+
highlighted: Boolean(isValidToAddress &&
|
|
198
|
+
multiWalletSupportEnabled &&
|
|
199
|
+
!isRecipientLinked),
|
|
200
|
+
text: !isValidToAddress ? 'Enter Address' : (toDisplayName ?? ''),
|
|
201
|
+
onClick: () => {
|
|
202
|
+
setDestinationAddressOverride(undefined);
|
|
203
|
+
setAddressModalOpen(true);
|
|
204
|
+
onAnalyticEvent?.(events_js_1.EventNames.SWAP_ADDRESS_MODAL_CLICKED);
|
|
205
|
+
},
|
|
206
|
+
showClipboard: Boolean(isValidToAddress &&
|
|
207
|
+
multiWalletSupportEnabled &&
|
|
208
|
+
!isRecipientLinked)
|
|
209
|
+
} }), (0, jsx_runtime_1.jsx)(WidgetErrorWell_js_1.WidgetErrorWell, { hasInsufficientBalance: hasInsufficientBalance, error: error, quote: quote, currency: fromToken, relayerFeeProportion: relayerFeeProportion, isHighRelayerServiceFee: highRelayerServiceFee, isCapacityExceededError: isCapacityExceededError, isCouldNotExecuteError: isCouldNotExecuteError, supportsExternalLiquidity: supportsExternalLiquidity, recipientWalletSupportsChain: recipientWalletSupportsChain, recipient: recipient, toChainWalletVMSupported: toChainWalletVMSupported, recipientLinkedWallet: recipientLinkedWallet, toChainVmType: toChainVmType, containerCss: { width: '100%' } })] }), (0, jsx_runtime_1.jsx)(index_js_1.Flex, { css: { width: '100%' }, children: (0, jsx_runtime_1.jsx)(SwapButton_js_1.default, { context: "Buy", transactionModalOpen: transactionModalOpen, depositAddressModalOpen: depositAddressModalOpen, showHighPriceImpactWarning: showHighPriceImpactWarning, disableSwapButton: disableSwapButton, tokenWidgetMode: true, hasValidAmount: !invalidAmount, quote: quote, address: address, hasInsufficientBalance: hasInsufficientBalance, isInsufficientLiquidityError: isInsufficientLiquidityError, debouncedInputAmountValue: debouncedInputAmountValue, debouncedOutputAmountValue: debouncedOutputAmountValue, isSameCurrencySameRecipientSwap: isSameCurrencySameRecipientSwap, ctaCopy: displayCta, isValidFromAddress: isValidFromAddress, isValidToAddress: isValidToAddress, fromChainWalletVMSupported: fromChainWalletVMSupported, recipientWalletSupportsChain: recipientWalletSupportsChain, isFetchingQuote: isFetchingQuote, onClick: () => {
|
|
210
|
+
onAnalyticEvent?.('TOKEN_BUY_CLICKED', {
|
|
211
|
+
token: toToken,
|
|
212
|
+
amount: amountOutputValue
|
|
213
|
+
});
|
|
214
|
+
onPrimaryAction();
|
|
215
|
+
}, onConnectWallet: onConnectWallet, onAnalyticEvent: onAnalyticEvent }) }), (0, jsx_runtime_1.jsx)(TransactionDetailsFooter_js_1.default, { timeEstimate: timeEstimate, feeBreakdown: feeBreakdown, quote: quote })] }) }));
|
|
216
|
+
};
|
|
217
|
+
exports.default = BuyTabContent;
|
|
218
|
+
//# sourceMappingURL=BuyTabContent.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BuyTabContent.js","sourceRoot":"","sources":["../../../../../src/components/widgets/TokenWidget/BuyTabContent.tsx"],"names":[],"mappings":";;;;AAAA,sDAAsD;AACtD,wDAAsD;AACtD,yFAAqD;AACrD,0DAIkC;AAClC,iEAA0D;AAC1D,sEAA+D;AAC/D,gEAAgE;AAChE,gFAAyE;AACzE,2GAAuE;AACvE,4DAAyD;AACzD,sEAA+D;AAK/D,wDAAyE;AACzE,6EAAyC;AACzC,yGAAkG;AAClG,8FAA0D;AAC1D,wFAAoD;AACpD,wGAAoE;AACpE,wFAAoD;AACpD,8DAAuD;AACvD,+DAAwD;AACxD,iFAA0E;AA8G1E,MAAM,aAAa,GAA2B,CAAC,EAC7C,iBAAiB,EACjB,oBAAoB,EACpB,yBAAyB,EACzB,cAAc,EACd,cAAc,EACd,SAAS,EACT,iBAAiB,EACjB,gBAAgB,EAChB,OAAO,EACP,SAAS,EACT,KAAK,EACL,eAAe,EACf,qBAAqB,EACrB,eAAe,EACf,gBAAgB,EAChB,iBAAiB,EACjB,YAAY,EACZ,oBAAoB,EACpB,mBAAmB,EACnB,gBAAgB,EAChB,6BAA6B,EAC7B,eAAe,EACf,YAAY,EACZ,oBAAoB,EACpB,WAAW,EACX,kBAAkB,EAClB,SAAS,EACT,kBAAkB,EAClB,gBAAgB,EAChB,OAAO,EACP,YAAY,EACZ,yBAAyB,EACzB,wBAAwB,EACxB,SAAS,EACT,+BAA+B,EAC/B,SAAS,EACT,kBAAkB,EAClB,6BAA6B,EAC7B,eAAe,EACf,eAAe,EACf,aAAa,EACb,OAAO,EACP,gBAAgB,EAChB,iBAAiB,EACjB,mBAAmB,EACnB,aAAa,EACb,kBAAkB,EAClB,0BAA0B,EAC1B,kBAAkB,EAClB,kBAAkB,EAClB,gBAAgB,EAChB,kBAAkB,EAClB,wBAAwB,EACxB,WAAW,EACX,aAAa,EACb,mBAAmB,EACnB,WAAW,EACX,eAAe,EACf,oBAAoB,EACpB,uBAAuB,EACvB,sBAAsB,EACtB,4BAA4B,EAC5B,4BAA4B,EAC5B,+BAA+B,EAC/B,yBAAyB,EACzB,0BAA0B,EAC1B,0BAA0B,EAC1B,iBAAiB,EACjB,eAAe,EACf,eAAe,EACf,KAAK,EACL,oBAAoB,EACpB,qBAAqB,EACrB,uBAAuB,EACvB,sBAAsB,EACtB,yBAAyB,EACzB,qBAAqB,EACrB,aAAa,EACb,OAAO,EACR,EAAE,EAAE;IACH,MAAM,UAAU,GAAG;QACjB,MAAM;QACN,SAAS;QACT,QAAQ;QACR,MAAM;QACN,MAAM;QACN,QAAQ;KACT,CAAC,QAAQ,CAAC,OAAO,CAAC;QACjB,CAAC,CAAC,KAAK;QACP,CAAC,CAAC,OAAO,CAAA;IAEX,MAAM,WAAW,GAAG,SAAS,EAAE,OAAO,CAAA;IACtC,MAAM,cAAc,GAAG,mBAAmB;QACxC,CAAC,CAAC,WAAW,KAAK,SAAS;YACzB,CAAC,CAAC,CAAC,WAAW,CAAC;YACf,CAAC,CAAC,SAAS;QACb,CAAC,CAAC,IAAA,gCAAa,EACT,WAAW,EACX,WAAW,EACX,OAAO,EAAE,OAAO,EAChB,aAAa,CACd,IAAI,WAAW,KAAK,SAAS;YAChC,CAAC,CAAC,CAAC,WAAW,CAAC;YACf,CAAC,CAAC,SAAS,CAAA;IAEf,MAAM,iBAAiB,GAAG,OAAO,CAAC,SAAS,IAAI,OAAO,CAAC,CAAA;IACvD,MAAM,aAAa,GACjB,CAAC,KAAK;QACN,MAAM,CAAC,yBAAyB,CAAC,KAAK,CAAC;QACvC,MAAM,CAAC,0BAA0B,CAAC,KAAK,CAAC;QACxC,CAAC,iBAAiB,CAAA;IAEpB,MAAM,oBAAoB,GACxB,OAAO,IAAI,iBAAiB,IAAI,MAAM,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAA;IAE/D,MAAM,mBAAmB,GAAG,KAAK,EAAE,OAAO,EAAE,UAAU,EAAE,SAAS,CAAA;IACjE,MAAM,yBAAyB,GAAG,KAAK,EAAE,OAAO,EAAE,UAAU,EAAE,eAAe,CAAA;IAE7E,MAAM,gBAAgB,GACpB,oBAAoB,IAAI,eAAe,IAAI,SAAS,IAAI,CAAC,mBAAmB,CAAA;IAE9E,OAAO,CACL,uBAAC,qBAAW,IAAC,KAAK,EAAC,KAAK,YACtB,wBAAC,6BAAgB,IACf,GAAG,EAAE;gBACH,eAAe,EAAE,mBAAmB;gBACpC,MAAM,EAAE,WAAW;gBACnB,WAAW,EAAE,SAAS;aACvB,EACD,EAAE,EAAE,mBAAmB,aAEvB,uBAAC,gCAAmB,IAClB,KAAK,EAAC,QAAQ,EACd,iBAAiB,EAAE,iBAAiB,EACpC,oBAAoB,EAAE,oBAAoB,EAC1C,yBAAyB,EAAE,yBAAyB,EACpD,eAAe,EAAE,eAAe,GAChC,EACF,uBAAC,eAAI,IAAC,KAAK,EAAC,QAAQ,EAAC,OAAO,EAAC,SAAS,EAAC,GAAG,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,YAC3D,uBAAC,wBAAW,IACV,YAAY,EAAE,cAAc,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,EAC9C,KAAK,EACH,cAAc;4BACZ,CAAC,CAAC,cAAc;4BAChB,CAAC,CAAC,SAAS,KAAK,iBAAiB;gCAC/B,CAAC,CAAC,iBAAiB;gCACnB,CAAC,CAAC,iBAAiB;oCACjB,CAAC,CAAC,IAAA,8BAAiB,EAAC,iBAAiB,EAAE,CAAC,CAAC;oCACzC,CAAC,CAAC,iBAAiB,EAE3B,QAAQ,EAAE,CAAC,KAAK,EAAE,EAAE;4BAClB,IAAI,cAAc,EAAE,CAAC;gCACnB,iBAAiB,CAAC,KAAK,CAAC,CAAA;gCACxB,YAAY,CAAC,iBAAiB,CAAC,CAAA;gCAC/B,IAAI,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC;oCACxB,mBAAmB,CAAC,EAAE,CAAC,CAAA;oCACvB,gBAAgB,CAAC,EAAE,CAAC,CAAA;oCACpB,6BAA6B,CAAC,KAAK,EAAE,CAAA;gCACvC,CAAC;4BACH,CAAC;iCAAM,CAAC;gCACN,oBAAoB,CAAC,KAAK,CAAC,CAAA;gCAC3B,YAAY,CAAC,iBAAiB,CAAC,CAAA;gCAC/B,IAAI,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC;oCACxB,mBAAmB,CAAC,EAAE,CAAC,CAAA;oCACvB,6BAA6B,CAAC,KAAK,EAAE,CAAA;gCACvC,CAAC;4BACH,CAAC;wBACH,CAAC,EACD,QAAQ,EAAE,CAAC,OAAO,IAAI,CAAC,0BAA0B,EACjD,OAAO,EAAE,GAAG,EAAE;4BACZ,eAAe,EAAE,CAAC,sBAAU,CAAC,mBAAmB,CAAC,CAAA;wBACnD,CAAC,EACD,GAAG,EAAE;4BACH,UAAU,EAAE,KAAK;4BACjB,QAAQ,EAAE,EAAE;4BACZ,UAAU,EAAE,MAAM;4BAClB,EAAE,EAAE,CAAC;4BACL,KAAK,EACH,eAAe,IAAI,SAAS,KAAK,aAAa;gCAC5C,CAAC,CAAC,aAAa;gCACf,CAAC,CAAC,aAAa;4BACnB,YAAY,EAAE;gCACZ,KAAK,EACH,eAAe,IAAI,SAAS,KAAK,aAAa;oCAC5C,CAAC,CAAC,aAAa;oCACf,CAAC,CAAC,aAAa;6BACpB;4BACD,SAAS,EAAE;gCACT,MAAM,EAAE,aAAa;gCACrB,YAAY,EAAE;oCACZ,KAAK,EAAE,QAAQ;iCAChB;gCACD,KAAK,EAAE,QAAQ;6BAChB;yBACF,GACD,GACG,EACP,wBAAC,eAAI,IACH,KAAK,EAAC,QAAQ,EACd,OAAO,EAAC,SAAS,EACjB,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,EAAE,aAEhC,wBAAC,eAAI,IACH,KAAK,EAAC,QAAQ,EACd,GAAG,EAAE;gCACH,GAAG,EAAE,GAAG;gCACR,SAAS,EAAE,EAAE;6BACd,aAED,uBAAC,6BAAgB,IAAC,QAAQ,EAAE,eAAe,YACxC,cAAc;wCACb,CAAC,CAAC,OAAO;4CACP,CAAC,CAAC,cAAc,IAAI,MAAM,CAAC,cAAc,CAAC,GAAG,CAAC;gDAC5C,CAAC,CAAC,iBAAiB,IAAI,CAAC,qBAAqB;oDAC3C,CAAC,CAAC,GAAG,IAAA,yBAAY,EAAC,iBAAiB,EAAE,CAAC,EAAE,KAAK,CAAC,IAAI,OAAO,CAAC,MAAM,EAAE;oDAClE,CAAC,CAAC,KAAK;gDACT,CAAC,CAAC,KAAK,OAAO,CAAC,MAAM,EAAE;4CACzB,CAAC,CAAC,IAAI;wCACR,CAAC,CAAC,OAAO;4CACL,KAAK,EAAE,OAAO,EAAE,WAAW,EAAE,SAAS;4CACtC,CAAC,eAAe;4CAClB,CAAC,CAAC,IAAA,yBAAY,EAAC,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC;4CAC3D,CAAC,CAAC,OAAO;gDACL,qBAAqB;gDACrB,iBAAiB;gDACjB,MAAM,CAAC,iBAAiB,CAAC,GAAG,CAAC;gDAC/B,CAAC,CAAC,KAAK;gDACP,CAAC,CAAC,OAAO;oDACL,eAAe;oDACf,eAAe,GAAG,CAAC;oDACnB,gBAAgB,EAAE,KAAK;oDACvB,gBAAgB,CAAC,KAAK,GAAG,CAAC;oDAC5B,CAAC,CAAC,IAAA,yBAAY,EAAC,eAAe,CAAC;oDAC/B,CAAC,CAAC,OAAO,GACA,EACnB,uBAAC,4BAAW,IACV,OAAO,EAAE,OAAO,EAChB,eAAe,EAAE,eAAe,EAChC,YAAY,EAAE,YAAY,EAC1B,KAAK,EAAE,KAAK,GACZ,IACG,EACP,uBAAC,eAAI,IAAC,GAAG,EAAE,EAAE,UAAU,EAAE,MAAM,EAAE,YAC9B,OAAO,CAAC,CAAC,CAAC,CACT,uBAAC,kCAAc,IACb,gBAAgB,EAAE,IAAI,EACtB,aAAa,EAAE,IAAI,EACnB,SAAS,EAAE,kBAAkB,EAC7B,OAAO,EAAE,SAAS,EAClB,QAAQ,EAAE,OAAO,EAAE,QAAQ,EAC3B,MAAM,EAAE,OAAO,EAAE,MAAM,EACvB,WAAW,EACT,CAAC,IAAA,yBAAa,EAAC,SAAS,CAAC;oCACzB,SAAS,KAAK,2BAAe;oCAC7B,SAAS,KAAK,SAAS,EAEzB,OAAO,EAAE,gBAAgB,EACzB,IAAI,EAAC,IAAI,GACT,CACH,CAAC,CAAC,CAAC,CACF,uBAAC,eAAI,IAAC,GAAG,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,GAAI,CAC9B,GACI,IACF,EAEP,uBAAC,aAAO,IAAC,KAAK,EAAC,OAAO,GAAG,EAEzB,wBAAC,eAAI,IAAC,KAAK,EAAC,QAAQ,EAAC,GAAG,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,EAAE,GAAG,EAAE,aACnD,uBAAC,eAAI,IAAC,KAAK,EAAC,WAAW,EAAC,KAAK,EAAC,QAAQ,yBAE/B,EACN,yBAAyB,IAAI,0BAA0B,CAAC,CAAC,CAAC,CACzD,uBAAC,4CAAmB,IAClB,OAAO,EAAC,QAAQ,EAChB,+BAA+B,EAAE,+BAA+B,EAChE,qBAAqB,EAAE,OAAO,EAC9B,QAAQ,EAAE,CAAC,MAAM,EAAE,EAAE;gCACnB,wBAAwB,CAAC,MAAM,CAAC,OAAO,CAAC,CAAA;gCACxC,kBAAkB,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,CAAA;gCAEpC,IAAI,MAAM,CAAC,OAAO,KAAK,OAAO,EAAE,CAAC;oCAC/B,kBAAkB,CAAC,SAAS,CAAC,CAAA;gCAC/B,CAAC;4BACH,CAAC,EACD,KAAK,EAAE,SAAS,EAChB,sBAAsB,EAAE,IAAI,EAC5B,eAAe,EAAE,GAAG,EAAE;gCACpB,IAAI,CAAC,OAAO,IAAI,0BAA0B,EAAE,CAAC;oCAC3C,eAAe,EAAE,EAAE,CAAA;gCACrB,CAAC;qCAAM,CAAC;oCACN,eAAe,EAAE,CAAC;wCAChB,KAAK,EAAE,SAAS;wCAChB,SAAS,EAAE,MAAM;qCAClB,CAAC,EAAE,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE;wCAClB,IAAI,MAAM,EAAE,CAAC;4CACX,wBAAwB,CAAC,MAAM,CAAC,OAAO,CAAC,CAAA;4CACxC,kBAAkB,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,CAAA;wCACtC,CAAC;oCACH,CAAC,CAAC,CAAA;gCACJ,CAAC;4BACH,CAAC,EACD,mBAAmB,EAAE,mBAAmB,EACxC,OAAO,EAAE,aAAa,IAAI,EAAE,EAC5B,eAAe,EAAE,eAAe,EAChC,MAAM,EAAC,6BAA6B,GACpC,CACH,CAAC,CAAC,CAAC,IAAI,IACH,EAEP,wBAAC,eAAI,IAAC,OAAO,EAAC,SAAS,EAAC,GAAG,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,aAC5C,uBAAC,0BAAa,IACZ,OAAO,EAAE,OAAO,EAChB,cAAc,EAAE,kBAAkB,EAClC,KAAK,EAAE,SAAS,EAChB,eAAe,EAAE,eAAe,EAChC,0BAA0B,EAAE,0BAA0B,EACtD,kBAAkB,EAAE,kBAAkB,EACtC,aAAa,EAAE,aAAa,EAC5B,yBAAyB,EAAE,yBAAyB,EACpD,OAAO,EAAC,MAAM,EACd,eAAe,EAAE,KAAK,EACtB,QAAQ,EAAE,CAAC,KAAK,EAAE,EAAE;gCAClB,IACE,KAAK,EAAE,OAAO,KAAK,OAAO,EAAE,OAAO;oCACnC,KAAK,EAAE,OAAO,KAAK,OAAO,EAAE,OAAO;oCACnC,OAAO,KAAK,SAAS;oCACrB,CAAC,CAAC,WAAW,IAAI,CAAC,SAAS,CAAC,EAC5B,CAAC;oCACD,kBAAkB,CAAC,OAAO,CAAC,CAAA;oCAC3B,gBAAgB,CAAC,SAAS,CAAC,CAAA;gCAC7B,CAAC;qCAAM,CAAC;oCACN,kBAAkB,CAAC,KAAK,CAAC,CAAA;gCAC3B,CAAC;4BACH,CAAC,EACD,cAAc,EAAE,cAAc,EAC9B,cAAc,EACZ,CAAC,0BAA0B,IAAI,OAAO;gCACpC,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC;gCACnB,CAAC,CAAC,SAAS,EAEf,eAAe,EAAE,eAAe,EAChC,OAAO,EACL,gCAAK,KAAK,EAAE,EAAE,KAAK,EAAE,aAAa,EAAE,YAClC,uBAAC,8CAAoB,IACnB,KAAK,EAAE,SAAS,EAChB,MAAM,EAAE,aAAa,EACrB,OAAO,EAAE,OAAO,EAChB,MAAM,EAAC,4BAA4B,EACnC,YAAY,EAAC,WAAW,GACxB,GACE,GAER,EACF,uBAAC,sCAAgB,IACf,SAAS,EAAE,OAAO,CAAC,gBAAgB,CAAC,EACpC,SAAS,EAAE,mBAAmB,EAC9B,oBAAoB,EAAE,yBAAyB,EAC/C,mBAAmB,EAAE,gBAAgB,EACrC,KAAK,EAAE,KAAK,EACZ,YAAY,EAAE,YAAY,EAC1B,KAAK,EAAE,SAAS,GAChB,IACG,EAEP,uBAAC,aAAO,IAAC,KAAK,EAAC,OAAO,GAAG,EAEzB,wBAAC,eAAI,IAAC,SAAS,EAAC,QAAQ,EAAC,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,EAAE,aACvD,uBAAC,wDAAyB,IACxB,KAAK,EAAC,SAAS,EACf,oBAAoB,EAAE,yBAAyB,EAC/C,eAAe,EAAE,wBAAwB,EACzC,aAAa,EAAE;gCACb,+BAA+B;gCAC/B,qBAAqB,EAAE,SAAS;gCAChC,QAAQ,EAAE,CAAC,MAAM,EAAE,EAAE;oCACnB,6BAA6B,CAAC,MAAM,CAAC,OAAO,CAAC,CAAA;oCAC7C,kBAAkB,CAAC,SAAS,CAAC,CAAA;gCAC/B,CAAC;gCACD,KAAK,EAAE,OAAO;gCACd,sBAAsB,EAAE,KAAK;gCAC7B,eAAe,EAAE,GAAG,EAAE;oCACpB,IAAI,CAAC,OAAO,IAAI,wBAAwB,EAAE,CAAC;wCACzC,eAAe,EAAE,EAAE,CAAA;oCACrB,CAAC;yCAAM,CAAC;wCACN,eAAe,EAAE,CAAC;4CAChB,KAAK,EAAE,OAAO;4CACd,SAAS,EAAE,IAAI;yCAChB,CAAC,EAAE,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE;4CAClB,IAAI,CAAC,MAAM,EAAE,CAAC;gDACZ,OAAM;4CACR,CAAC;4CACD,6BAA6B,CAAC,MAAM,CAAC,OAAO,CAAC,CAAA;4CAC7C,kBAAkB,CAAC,SAAS,CAAC,CAAA;wCAC/B,CAAC,CAAC,CAAA;oCACJ,CAAC;gCACH,CAAC;gCACD,mBAAmB;gCACnB,OAAO,EAAE,aAAa,IAAI,EAAE;gCAC5B,eAAe;gCACf,MAAM,EAAE,kCAAkC;6BAC3C,EACD,QAAQ,EAAE;gCACR,WAAW,EAAE,OAAO,CAClB,gBAAgB;oCACd,yBAAyB;oCACzB,CAAC,iBAAiB,CACrB;gCACD,IAAI,EAAE,CAAC,gBAAgB,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,aAAa,IAAI,EAAE,CAAC;gCACjE,OAAO,EAAE,GAAG,EAAE;oCACZ,6BAA6B,CAAC,SAAS,CAAC,CAAA;oCACxC,mBAAmB,CAAC,IAAI,CAAC,CAAA;oCACzB,eAAe,EAAE,CAAC,sBAAU,CAAC,0BAA0B,CAAC,CAAA;gCAC1D,CAAC;gCACD,aAAa,EAAE,OAAO,CACpB,gBAAgB;oCACd,yBAAyB;oCACzB,CAAC,iBAAiB,CACrB;6BACF,GACD,EACF,uBAAC,oCAAe,IACd,sBAAsB,EAAE,sBAAsB,EAC9C,KAAK,EAAE,KAAK,EACZ,KAAK,EAAE,KAAK,EACZ,QAAQ,EAAE,SAAS,EACnB,oBAAoB,EAAE,oBAAoB,EAC1C,uBAAuB,EAAE,qBAAqB,EAC9C,uBAAuB,EAAE,uBAAuB,EAChD,sBAAsB,EAAE,sBAAsB,EAC9C,yBAAyB,EAAE,yBAAyB,EACpD,4BAA4B,EAAE,4BAA4B,EAC1D,SAAS,EAAE,SAAS,EACpB,wBAAwB,EAAE,wBAAwB,EAClD,qBAAqB,EAAE,qBAAqB,EAC5C,aAAa,EAAE,aAAa,EAC5B,YAAY,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,GAC/B,IACG,EAEP,uBAAC,eAAI,IAAC,GAAG,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,YAC1B,uBAAC,uBAAU,IACT,OAAO,EAAC,KAAK,EACb,oBAAoB,EAAE,oBAAoB,EAC1C,uBAAuB,EAAE,uBAAuB,EAChD,0BAA0B,EAAE,0BAA0B,EACtD,iBAAiB,EAAE,iBAAiB,EACpC,eAAe,EAAE,IAAI,EACrB,cAAc,EAAE,CAAC,aAAa,EAC9B,KAAK,EAAE,KAAK,EACZ,OAAO,EAAE,OAAO,EAChB,sBAAsB,EAAE,sBAAsB,EAC9C,4BAA4B,EAAE,4BAA4B,EAC1D,yBAAyB,EAAE,yBAAyB,EACpD,0BAA0B,EAAE,0BAA0B,EACtD,+BAA+B,EAAE,+BAA+B,EAChE,OAAO,EAAE,UAAU,EACnB,kBAAkB,EAAE,kBAAkB,EACtC,gBAAgB,EAAE,gBAAgB,EAClC,0BAA0B,EAAE,0BAA0B,EACtD,4BAA4B,EAAE,4BAA4B,EAC1D,eAAe,EAAE,eAAe,EAChC,OAAO,EAAE,GAAG,EAAE;4BACZ,eAAe,EAAE,CAAC,mBAAmB,EAAE;gCACrC,KAAK,EAAE,OAAO;gCACd,MAAM,EAAE,iBAAiB;6BAC1B,CAAC,CAAA;4BACF,eAAe,EAAE,CAAA;wBACnB,CAAC,EACD,eAAe,EAAE,eAAe,EAChC,eAAe,EAAE,eAAe,GAChC,GACG,EAEP,uBAAC,qCAAwB,IACvB,YAAY,EAAE,YAAY,EAC1B,YAAY,EAAE,YAAY,EAC1B,KAAK,EAAE,KAAK,GACZ,IACe,GACP,CACf,CAAA;AACH,CAAC,CAAA;AAED,kBAAe,aAAa,CAAA"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DestinationWalletSelector = void 0;
|
|
4
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
5
|
+
const index_js_1 = require("../../primitives/index.js");
|
|
6
|
+
const MultiWalletDropdown_js_1 = require("../../common/MultiWalletDropdown.js");
|
|
7
|
+
const react_fontawesome_1 = require("@fortawesome/react-fontawesome");
|
|
8
|
+
const free_solid_svg_icons_1 = require("@fortawesome/free-solid-svg-icons");
|
|
9
|
+
const DestinationWalletSelector = ({ label, isMultiWalletEnabled, walletSupported, dropdownProps, fallback }) => {
|
|
10
|
+
return ((0, jsx_runtime_1.jsxs)(index_js_1.Flex, { align: "center", css: { width: '100%', gap: '2' }, children: [(0, jsx_runtime_1.jsx)(index_js_1.Text, { style: "subtitle2", color: "subtle", children: label }), isMultiWalletEnabled && walletSupported ? ((0, jsx_runtime_1.jsx)(MultiWalletDropdown_js_1.MultiWalletDropdown, { context: "destination", ...dropdownProps })) : ((0, jsx_runtime_1.jsxs)(index_js_1.Button, { color: fallback.highlighted ? 'warning' : 'secondary', corners: "pill", size: "none", css: {
|
|
11
|
+
display: 'flex',
|
|
12
|
+
alignItems: 'center',
|
|
13
|
+
px: '2',
|
|
14
|
+
py: '1'
|
|
15
|
+
}, onClick: fallback.onClick, children: [fallback.showClipboard ? ((0, jsx_runtime_1.jsx)(index_js_1.Box, { css: { color: 'amber11' }, children: (0, jsx_runtime_1.jsx)(react_fontawesome_1.FontAwesomeIcon, { icon: free_solid_svg_icons_1.faClipboard, width: 16, height: 16 }) })) : null, (0, jsx_runtime_1.jsx)(index_js_1.Text, { style: "subtitle2", css: {
|
|
16
|
+
color: fallback.highlighted ? 'amber11' : 'anchor-color'
|
|
17
|
+
}, children: fallback.text })] }))] }));
|
|
18
|
+
};
|
|
19
|
+
exports.DestinationWalletSelector = DestinationWalletSelector;
|
|
20
|
+
//# sourceMappingURL=DestinationWalletSelector.js.map
|