@aurora-is-near/intents-swap-widget 3.15.2 → 3.16.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/dist/components/TokenIcon.d.ts +5 -12
- package/dist/components/TokenIcon.js +34 -32
- package/dist/components/TokenIcon.js.map +1 -1
- package/dist/{config-CJfcVohD.js → config-DQMHUj5z.js} +678 -681
- package/dist/config-DQMHUj5z.js.map +1 -0
- package/dist/config.d.ts +1 -1
- package/dist/config.js +1 -1
- package/dist/constants/chains.d.ts +0 -1
- package/dist/constants/chains.js +44 -65
- package/dist/constants/chains.js.map +1 -1
- package/dist/constants/tokens.d.ts +1 -1
- package/dist/constants/tokens.js +3 -50
- package/dist/constants/tokens.js.map +1 -1
- package/dist/errors.js +1 -1
- package/dist/ext/alchemy/index.js +1 -1
- package/dist/ext/index.js +1 -1
- package/dist/features/BalanceRpcLoader/TokenBalanceLoader.js +1 -1
- package/dist/features/BalanceRpcLoader/index.js +1 -1
- package/dist/features/BalanceRpcLoader/useTokenBalanceRpc.js +1 -1
- package/dist/features/ChainsDropdown/index.js +32 -32
- package/dist/features/ChainsDropdown/index.js.map +1 -1
- package/dist/features/DepositMethodSwitcher.js +1 -1
- package/dist/features/ErrorBoundary.js +1 -1
- package/dist/features/ExternalDeposit.js +1 -1
- package/dist/features/SendAddress/index.js +1 -1
- package/dist/features/SendAddress/useNotification.js +1 -1
- package/dist/features/SubmitButton/index.js +1 -1
- package/dist/features/SuccessScreen/index.js +1 -1
- package/dist/features/SwapDirectionSwitcher.js +1 -1
- package/dist/features/SwapQuote/SwapQuote.js +1 -1
- package/dist/features/SwapQuote/index.js +1 -1
- package/dist/features/TokenInput/TokenInput.js +1 -1
- package/dist/features/TokenInput/TokenInputEmpty.js +1 -1
- package/dist/features/TokenInput/TokenInputSource.js +1 -1
- package/dist/features/TokenInput/TokenInputTarget.js +1 -1
- package/dist/features/TokenInput/WalletBalance.js +1 -1
- package/dist/features/TokenInput/hooks/index.js +1 -1
- package/dist/features/TokenInput/hooks/useTokenInputBalance.js +1 -1
- package/dist/features/TokenInput/index.js +1 -1
- package/dist/features/TokensList/TokenItem.js +1 -1
- package/dist/features/TokensList/TokensList.js +1 -1
- package/dist/features/TokensList/index.js +1 -1
- package/dist/features/TokensModal.js +1 -1
- package/dist/features/WalletCompatibilityCheck/WalletCompatibilityModal.js +1 -1
- package/dist/features/WalletCompatibilityCheck/index.js +1 -1
- package/dist/features/index.js +1 -1
- package/dist/hooks/index.js +1 -1
- package/dist/hooks/useAllTokens.js +1 -1
- package/dist/hooks/useChains.js +1 -1
- package/dist/hooks/useCompatibilityCheck.js +1 -1
- package/dist/hooks/useDefaultToken.js +1 -1
- package/dist/hooks/useExternalDepositStatus/index.js +1 -1
- package/dist/hooks/useExternalDepositStatus/usePoaExternalDepositStatus.js +1 -1
- package/dist/hooks/useIntentsBalance.js +1 -1
- package/dist/hooks/useIsCompatibilityCheckRequired.js +1 -1
- package/dist/hooks/useMakeDepositAddress.js +1 -1
- package/dist/hooks/useMakeIntentsTransfer.js +1 -1
- package/dist/hooks/useMakeNEARFtTransferCall.js +1 -1
- package/dist/hooks/useMakeQuote.js +1 -1
- package/dist/hooks/useMakeQuoteTransfer.js +1 -1
- package/dist/hooks/useMakeTransfer.js +1 -1
- package/dist/hooks/useMergedBalance.js +1 -1
- package/dist/hooks/useSwitchChain.js +1 -1
- package/dist/hooks/useTheme.js +1 -1
- package/dist/hooks/useTokenInputPair.js +1 -1
- package/dist/hooks/useTokens.js +2 -2
- package/dist/hooks/useTokensFiltered.js +1 -1
- package/dist/hooks/useTokensIntentsUnique.js +1 -1
- package/dist/icons/index.d.ts +4 -0
- package/dist/icons/index.js +392 -0
- package/dist/icons/index.js.map +1 -0
- package/dist/index.js +1 -1
- package/dist/machine/effects/index.js +1 -1
- package/dist/machine/effects/useAlchemyBalanceEffect.js +1 -1
- package/dist/machine/effects/useBalancesUpdateEffect.js +1 -1
- package/dist/machine/effects/useMakeQuoteEffect.js +1 -1
- package/dist/machine/effects/useSelectedTokensEffect.d.ts +0 -2
- package/dist/machine/effects/useSelectedTokensEffect.js +1 -1
- package/dist/machine/effects/useSetTokenBalanceEffect.js +1 -1
- package/dist/machine/effects/useSetTokenIntentsTargetEffect.js +1 -1
- package/dist/machine/effects/useWalletConnEffect.js +1 -1
- package/dist/machine/events/index.js +1 -1
- package/dist/machine/events/tokenSelect.js +1 -1
- package/dist/machine/events/validateInputAndMoveTo.js +1 -1
- package/dist/machine/events/validateInputs.js +1 -1
- package/dist/machine/index.js +1 -1
- package/dist/machine/snap.d.ts +0 -18
- package/dist/machine/snap.js +1 -1
- package/dist/machine/subscriptions/checkers/isSendAddressAsConnected.js +1 -1
- package/dist/machine/subscriptions/index.js +1 -1
- package/dist/styles.css +1 -1
- package/dist/tailwind.css +0 -4
- package/dist/theme/ThemeProvider.js +1 -1
- package/dist/theme.css +5 -4
- package/dist/types/chain.d.ts +0 -1
- package/dist/types/config.d.ts +1 -1
- package/dist/types/token.d.ts +0 -1
- package/dist/utils/intents/signers/near.js +1 -1
- package/dist/utils/intents/signers/privy.js +1 -1
- package/dist/utils/near/getNearNep141StorageBalance.js +1 -1
- package/dist/widgets/WidgetDeposit/WidgetDepositContent.js +3 -3
- package/dist/widgets/WidgetDeposit/WidgetDepositContent.js.map +1 -1
- package/dist/widgets/WidgetDeposit/WidgetDepositSkeleton.js +1 -1
- package/dist/widgets/WidgetSwap/WidgetSwapContent.js +1 -1
- package/dist/widgets/WidgetSwap/WidgetSwapSkeleton.js +1 -1
- package/dist/widgets/WidgetWithdraw/WidgetWithdrawContent.js +1 -1
- package/dist/widgets/WidgetWithdraw/WidgetWithdrawSkeleton.js +1 -1
- package/package.json +1 -1
- package/src/components/TokenIcon.tsx +35 -38
- package/src/config.tsx +0 -2
- package/src/constants/chains.ts +0 -23
- package/src/constants/tokens.ts +1 -48
- package/src/features/ChainsDropdown/index.tsx +5 -5
- package/src/features/TokenInput/TokenInput.tsx +1 -1
- package/src/features/TokensList/TokenItem.tsx +1 -1
- package/src/hooks/useTokens.ts +1 -8
- package/src/icons/abg.svg +11 -0
- package/src/icons/arb.svg +22 -0
- package/src/icons/aster.svg +1 -0
- package/src/icons/aurora.svg +14 -0
- package/src/icons/avax.svg +12 -0
- package/src/icons/base.svg +11 -0
- package/src/icons/bera.svg +20 -0
- package/src/icons/bsc.svg +14 -0
- package/src/icons/btc.svg +11 -0
- package/src/icons/cardano.svg +40 -0
- package/src/icons/doge.svg +15 -0
- package/src/icons/eth.svg +16 -0
- package/src/icons/frax.svg +26 -0
- package/src/icons/gnear.svg +1 -0
- package/src/icons/gnosis.svg +16 -0
- package/src/icons/index.tsx +111 -0
- package/src/icons/itlx.svg +12 -0
- package/src/icons/jambo.svg +10 -0
- package/src/icons/knc.svg +1 -0
- package/src/icons/loud.svg +7 -0
- package/src/icons/ltc.svg +1 -0
- package/src/icons/mon.svg +1 -0
- package/src/icons/mpdao.svg +1 -0
- package/src/icons/near.svg +16 -0
- package/src/icons/noear.svg +10 -0
- package/src/icons/op.svg +12 -0
- package/src/icons/pol.svg +11 -0
- package/src/icons/public.svg +1 -0
- package/src/icons/purge.svg +10 -0
- package/src/icons/rhea.svg +10 -0
- package/src/icons/sol.svg +21 -0
- package/src/icons/sui.svg +16 -0
- package/src/icons/ton.svg +11 -0
- package/src/icons/tron.svg +11 -0
- package/src/icons/unknown.svg +4 -0
- package/src/icons/usd1.svg +10 -0
- package/src/icons/usdf.svg +10 -0
- package/src/icons/wif.svg +10 -0
- package/src/icons/xdai.svg +22 -0
- package/src/icons/xrp.svg +17 -0
- package/src/icons/zec.svg +16 -0
- package/src/tailwind.css +0 -4
- package/src/theme/ThemeProvider.tsx +3 -1
- package/src/theme.css +5 -4
- package/src/types/chain.ts +0 -1
- package/src/types/config.ts +1 -1
- package/src/types/token.ts +0 -1
- package/src/widgets/WidgetDeposit/WidgetDepositContent.tsx +1 -1
- package/dist/config-CJfcVohD.js.map +0 -1
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { jsxs as o, jsx as e } from "react/jsx-runtime";
|
|
2
2
|
import a from "clsx";
|
|
3
3
|
import { SkeletonBox as s } from "../../components/SkeletonBox.js";
|
|
4
|
-
import { y as i } from "../../config-
|
|
4
|
+
import { y as i } from "../../config-DQMHUj5z.js";
|
|
5
5
|
const p = () => {
|
|
6
6
|
const { hideTokenInputHeadings: l } = i();
|
|
7
7
|
return /* @__PURE__ */ o("div", { className: "w-full gap-sw-xl relative flex flex-col", children: [
|
|
@@ -3,7 +3,7 @@ import { useState as b, useEffect as y } from "react";
|
|
|
3
3
|
import { useTokenModal as R } from "../../hooks/useTokenModal.js";
|
|
4
4
|
import { WidgetSwapSkeleton as S } from "./WidgetSwapSkeleton.js";
|
|
5
5
|
import { useTypedTranslation as D } from "../../localisation.js";
|
|
6
|
-
import { b as N, u as O, y as Q, n as j, c as q, p as w, o as F, S as U } from "../../config-
|
|
6
|
+
import { b as N, u as O, y as Q, n as j, c as q, p as w, o as F, S as U } from "../../config-DQMHUj5z.js";
|
|
7
7
|
import "@tanstack/react-query";
|
|
8
8
|
import "@headlessui/react";
|
|
9
9
|
import "framer-motion";
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { jsxs as a, jsx as l } from "react/jsx-runtime";
|
|
2
2
|
import o from "clsx";
|
|
3
3
|
import { SkeletonBox as s } from "../../components/SkeletonBox.js";
|
|
4
|
-
import { y as i } from "../../config-
|
|
4
|
+
import { y as i } from "../../config-DQMHUj5z.js";
|
|
5
5
|
const m = () => {
|
|
6
6
|
const { hideTokenInputHeadings: e } = i();
|
|
7
7
|
return /* @__PURE__ */ a("div", { className: "w-full gap-sw-lg relative flex flex-col", children: [
|
|
@@ -3,7 +3,7 @@ import { useState as w, useEffect as b } from "react";
|
|
|
3
3
|
import { useTokenModal as B } from "../../hooks/useTokenModal.js";
|
|
4
4
|
import { WidgetWithdrawSkeleton as y } from "./WidgetWithdrawSkeleton.js";
|
|
5
5
|
import { useTypedTranslation as D } from "../../localisation.js";
|
|
6
|
-
import { b as N, u as O, y as Q, n as j, c as q, p as S, o as F, S as U } from "../../config-
|
|
6
|
+
import { b as N, u as O, y as Q, n as j, c as q, p as S, o as F, S as U } from "../../config-DQMHUj5z.js";
|
|
7
7
|
import "@tanstack/react-query";
|
|
8
8
|
import "@headlessui/react";
|
|
9
9
|
import "framer-motion";
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { jsxs as a, jsx as e } from "react/jsx-runtime";
|
|
2
2
|
import o from "clsx";
|
|
3
3
|
import { SkeletonBox as l } from "../../components/SkeletonBox.js";
|
|
4
|
-
import { y as x } from "../../config-
|
|
4
|
+
import { y as x } from "../../config-DQMHUj5z.js";
|
|
5
5
|
const p = () => {
|
|
6
6
|
const { hideTokenInputHeadings: s } = x();
|
|
7
7
|
return /* @__PURE__ */ a("div", { className: "w-full gap-sw-xl relative flex flex-col", children: [
|
package/package.json
CHANGED
|
@@ -1,50 +1,47 @@
|
|
|
1
1
|
import { Icon } from './Icon';
|
|
2
2
|
|
|
3
3
|
import { cn } from '@/utils';
|
|
4
|
+
import { TOKENS_DATA } from '@/constants/tokens';
|
|
5
|
+
import { ASSET_ICONS, CHAIN_ICONS, UNKNOWN_ICON } from '@/icons';
|
|
6
|
+
import type { Token } from '@/types/token';
|
|
4
7
|
|
|
5
8
|
type TokenItemProps = {
|
|
6
|
-
|
|
7
|
-
|
|
9
|
+
token: Token;
|
|
10
|
+
chainShowIcon: boolean;
|
|
8
11
|
className?: string;
|
|
9
|
-
}
|
|
10
|
-
| {
|
|
11
|
-
chainShowIcon: true;
|
|
12
|
-
chainIcon: string;
|
|
13
|
-
chainName: string;
|
|
14
|
-
}
|
|
15
|
-
| {
|
|
16
|
-
chainShowIcon: false;
|
|
17
|
-
chainIcon?: string | undefined;
|
|
18
|
-
chainName?: string | undefined;
|
|
19
|
-
}
|
|
20
|
-
);
|
|
12
|
+
};
|
|
21
13
|
|
|
22
14
|
const BORDER_RADIUS = 4;
|
|
23
15
|
|
|
24
16
|
export const TokenIcon = ({
|
|
25
|
-
|
|
26
|
-
name,
|
|
27
|
-
chainName,
|
|
28
|
-
chainIcon,
|
|
17
|
+
token,
|
|
29
18
|
chainShowIcon,
|
|
30
19
|
className,
|
|
31
|
-
}: TokenItemProps) =>
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
20
|
+
}: TokenItemProps) => {
|
|
21
|
+
const tokenSymbolLowerCase = token.symbol.toLowerCase();
|
|
22
|
+
const chainIcon = CHAIN_ICONS[token.blockchain] ?? UNKNOWN_ICON;
|
|
23
|
+
const tokenIcon =
|
|
24
|
+
ASSET_ICONS[tokenSymbolLowerCase] ??
|
|
25
|
+
TOKENS_DATA[tokenSymbolLowerCase]?.icon;
|
|
26
|
+
|
|
27
|
+
return (
|
|
28
|
+
<div className="relative flex items-center">
|
|
29
|
+
<Icon icon={tokenIcon} label={token.name} />
|
|
30
|
+
{chainShowIcon && (
|
|
31
|
+
<div
|
|
32
|
+
className={cn(
|
|
33
|
+
'absolute top-[19px] right-[-4px] flex h-[16px] w-[16px] items-center justify-center overflow-hidden border-2',
|
|
34
|
+
className,
|
|
35
|
+
)}
|
|
36
|
+
style={{ borderRadius: BORDER_RADIUS }}>
|
|
37
|
+
<Icon
|
|
38
|
+
size={16}
|
|
39
|
+
radius={BORDER_RADIUS}
|
|
40
|
+
icon={chainIcon}
|
|
41
|
+
label={token.chainName}
|
|
42
|
+
/>
|
|
43
|
+
</div>
|
|
44
|
+
)}
|
|
45
|
+
</div>
|
|
46
|
+
);
|
|
47
|
+
};
|
package/src/config.tsx
CHANGED
|
@@ -33,8 +33,6 @@ const DISABLED_TOKENS = ['fms', 'abg', 'stjack', 'noear', 'testnebula'];
|
|
|
33
33
|
|
|
34
34
|
const DEFAULT_CONFIG: WidgetConfig = {
|
|
35
35
|
appName: 'Unknown',
|
|
36
|
-
appIcon:
|
|
37
|
-
'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/unknown.svg',
|
|
38
36
|
|
|
39
37
|
slippageTolerance: 100, // 1%
|
|
40
38
|
intentsAccountType: 'evm',
|
package/src/constants/chains.ts
CHANGED
|
@@ -75,9 +75,6 @@ export const NOT_EVM_CHAINS = [
|
|
|
75
75
|
|
|
76
76
|
export const CHAINS = [...EVM_CHAINS, ...NOT_EVM_CHAINS] as const;
|
|
77
77
|
|
|
78
|
-
export const DEFAULT_CHAIN_ICON =
|
|
79
|
-
'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/unknown.svg';
|
|
80
|
-
|
|
81
78
|
export const DRY_QUOTE_ZERO_ADDRESSES = {
|
|
82
79
|
evm: '0x0000000000000000000000000000000000000000',
|
|
83
80
|
sol: '11111111111111111111111111111111',
|
|
@@ -106,102 +103,82 @@ export const CHAINS_LIST: Record<Chains, Chain> = {
|
|
|
106
103
|
near: {
|
|
107
104
|
id: 'near',
|
|
108
105
|
label: 'NEAR',
|
|
109
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/near.svg',
|
|
110
106
|
},
|
|
111
107
|
eth: {
|
|
112
108
|
id: 'eth',
|
|
113
109
|
label: 'Ethereum',
|
|
114
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/eth.svg',
|
|
115
110
|
},
|
|
116
111
|
sol: {
|
|
117
112
|
id: 'sol',
|
|
118
113
|
label: 'Solana',
|
|
119
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/sol.svg',
|
|
120
114
|
},
|
|
121
115
|
base: {
|
|
122
116
|
id: 'base',
|
|
123
117
|
label: 'Base',
|
|
124
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/base.svg',
|
|
125
118
|
},
|
|
126
119
|
btc: {
|
|
127
120
|
id: 'btc',
|
|
128
121
|
label: 'Bitcoin',
|
|
129
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/btc.svg',
|
|
130
122
|
},
|
|
131
123
|
gnosis: {
|
|
132
124
|
id: 'gnosis',
|
|
133
125
|
label: 'Gnosis',
|
|
134
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/gnosis.svg',
|
|
135
126
|
},
|
|
136
127
|
xrp: {
|
|
137
128
|
id: 'xrp',
|
|
138
129
|
label: 'XRP',
|
|
139
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/xrp.svg',
|
|
140
130
|
},
|
|
141
131
|
bera: {
|
|
142
132
|
id: 'bera',
|
|
143
133
|
label: 'Bera',
|
|
144
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/bera.svg',
|
|
145
134
|
},
|
|
146
135
|
tron: {
|
|
147
136
|
id: 'tron',
|
|
148
137
|
label: 'Tron',
|
|
149
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/tron.svg',
|
|
150
138
|
},
|
|
151
139
|
zec: {
|
|
152
140
|
id: 'zec',
|
|
153
141
|
label: 'Zcash',
|
|
154
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/zec.svg',
|
|
155
142
|
},
|
|
156
143
|
doge: {
|
|
157
144
|
id: 'doge',
|
|
158
145
|
label: 'Dogecoin',
|
|
159
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/doge.svg',
|
|
160
146
|
},
|
|
161
147
|
arb: {
|
|
162
148
|
id: 'arb',
|
|
163
149
|
label: 'Arbitrum',
|
|
164
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/arb.svg',
|
|
165
150
|
},
|
|
166
151
|
ton: {
|
|
167
152
|
id: 'ton',
|
|
168
153
|
label: 'TON',
|
|
169
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/ton.svg',
|
|
170
154
|
},
|
|
171
155
|
op: {
|
|
172
156
|
id: 'op',
|
|
173
157
|
label: 'Optimism',
|
|
174
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/op.svg',
|
|
175
158
|
},
|
|
176
159
|
avax: {
|
|
177
160
|
id: 'avax',
|
|
178
161
|
label: 'Avalanche',
|
|
179
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/avax.svg',
|
|
180
162
|
},
|
|
181
163
|
pol: {
|
|
182
164
|
id: 'pol',
|
|
183
165
|
label: 'Polygon',
|
|
184
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/pol.svg',
|
|
185
166
|
},
|
|
186
167
|
bsc: {
|
|
187
168
|
id: 'bsc',
|
|
188
169
|
label: 'Binance Smart Chain',
|
|
189
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/bsc.svg',
|
|
190
170
|
},
|
|
191
171
|
sui: {
|
|
192
172
|
id: 'sui',
|
|
193
173
|
label: 'Sui',
|
|
194
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/sui.svg',
|
|
195
174
|
},
|
|
196
175
|
cardano: {
|
|
197
176
|
id: 'cardano',
|
|
198
177
|
label: 'Cardano',
|
|
199
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/cardano.svg',
|
|
200
178
|
},
|
|
201
179
|
ltc: {
|
|
202
180
|
id: 'ltc',
|
|
203
181
|
label: 'Litecoin',
|
|
204
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/ltc.svg',
|
|
205
182
|
},
|
|
206
183
|
};
|
|
207
184
|
|
package/src/constants/tokens.ts
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
export const DEFAULT_TOKEN_ICON = '/icons/widget/unknown-token.png';
|
|
2
2
|
|
|
3
3
|
type TokenAdditionalData = {
|
|
4
|
-
icon
|
|
4
|
+
icon?: string;
|
|
5
5
|
name: string;
|
|
6
6
|
};
|
|
7
7
|
|
|
@@ -98,19 +98,15 @@ export const TOKENS_DATA: Record<string, TokenAdditionalData> = {
|
|
|
98
98
|
name: 'Burrow',
|
|
99
99
|
},
|
|
100
100
|
abg: {
|
|
101
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/abg.png',
|
|
102
101
|
name: 'Asian Girl Boss',
|
|
103
102
|
},
|
|
104
103
|
noear: {
|
|
105
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/noear.png',
|
|
106
104
|
name: 'NOEAR',
|
|
107
105
|
},
|
|
108
106
|
ref: {
|
|
109
|
-
icon: undefined,
|
|
110
107
|
name: 'Ref Finance',
|
|
111
108
|
},
|
|
112
109
|
gnear: {
|
|
113
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/gnear.svg',
|
|
114
110
|
name: 'gNear',
|
|
115
111
|
},
|
|
116
112
|
gno: {
|
|
@@ -126,7 +122,6 @@ export const TOKENS_DATA: Record<string, TokenAdditionalData> = {
|
|
|
126
122
|
name: 'Safe',
|
|
127
123
|
},
|
|
128
124
|
score: {
|
|
129
|
-
icon: undefined,
|
|
130
125
|
name: 'Trust Score',
|
|
131
126
|
},
|
|
132
127
|
kaito: {
|
|
@@ -138,147 +133,111 @@ export const TOKENS_DATA: Record<string, TokenAdditionalData> = {
|
|
|
138
133
|
name: 'TRX',
|
|
139
134
|
},
|
|
140
135
|
arb: {
|
|
141
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/arb.svg',
|
|
142
136
|
name: 'Arbitrum',
|
|
143
137
|
},
|
|
144
138
|
avax: {
|
|
145
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/avax.svg',
|
|
146
139
|
name: 'Avalanche',
|
|
147
140
|
},
|
|
148
141
|
base: {
|
|
149
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/base.svg',
|
|
150
142
|
name: 'Base',
|
|
151
143
|
},
|
|
152
144
|
bera: {
|
|
153
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/bera.svg',
|
|
154
145
|
name: 'Bera',
|
|
155
146
|
},
|
|
156
147
|
bsc: {
|
|
157
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/bsc.svg',
|
|
158
148
|
name: 'Binance Smart Chain',
|
|
159
149
|
},
|
|
160
150
|
bnb: {
|
|
161
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/bsc.svg',
|
|
162
151
|
name: 'Binance Coin',
|
|
163
152
|
},
|
|
164
153
|
btc: {
|
|
165
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/btc.svg',
|
|
166
154
|
name: 'Bitcoin',
|
|
167
155
|
},
|
|
168
156
|
ada: {
|
|
169
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/cardano.svg',
|
|
170
157
|
name: 'Cardano',
|
|
171
158
|
},
|
|
172
159
|
doge: {
|
|
173
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/doge.svg',
|
|
174
160
|
name: 'Dogecoin',
|
|
175
161
|
},
|
|
176
162
|
eth: {
|
|
177
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/eth.svg',
|
|
178
163
|
name: 'Ethereum',
|
|
179
164
|
},
|
|
180
165
|
frax: {
|
|
181
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/frax.png',
|
|
182
166
|
name: 'FRAZ',
|
|
183
167
|
},
|
|
184
168
|
gnosis: {
|
|
185
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/gnosis.svg',
|
|
186
169
|
name: 'Gnosis',
|
|
187
170
|
},
|
|
188
171
|
jambo: {
|
|
189
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/jambo.png',
|
|
190
172
|
name: 'Jambo',
|
|
191
173
|
},
|
|
192
174
|
knc: {
|
|
193
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/knc.svg',
|
|
194
175
|
name: 'KNC',
|
|
195
176
|
},
|
|
196
177
|
loud: {
|
|
197
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/loud.svg',
|
|
198
178
|
name: 'Loud',
|
|
199
179
|
},
|
|
200
180
|
mpdao: {
|
|
201
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/mpdao.svg',
|
|
202
181
|
name: 'mpDAO',
|
|
203
182
|
},
|
|
204
183
|
near: {
|
|
205
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/near.svg',
|
|
206
184
|
name: 'Near',
|
|
207
185
|
},
|
|
208
186
|
op: {
|
|
209
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/op.svg',
|
|
210
187
|
name: 'Optimism',
|
|
211
188
|
},
|
|
212
189
|
pol: {
|
|
213
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/pol.svg',
|
|
214
190
|
name: 'Polygon',
|
|
215
191
|
},
|
|
216
192
|
public: {
|
|
217
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/public.svg',
|
|
218
193
|
name: 'Public',
|
|
219
194
|
},
|
|
220
195
|
purge: {
|
|
221
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/purge.png',
|
|
222
196
|
name: 'Forgive Me Father',
|
|
223
197
|
},
|
|
224
198
|
rhea: {
|
|
225
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/rhea.png',
|
|
226
199
|
name: 'Rhea',
|
|
227
200
|
},
|
|
228
201
|
sol: {
|
|
229
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/sol.svg',
|
|
230
202
|
name: 'Solana',
|
|
231
203
|
},
|
|
232
204
|
sui: {
|
|
233
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/sui.svg',
|
|
234
205
|
name: 'Sui',
|
|
235
206
|
},
|
|
236
207
|
ton: {
|
|
237
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/ton.svg',
|
|
238
208
|
name: 'Ton',
|
|
239
209
|
},
|
|
240
210
|
tron: {
|
|
241
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/tron.svg',
|
|
242
211
|
name: 'Tron',
|
|
243
212
|
},
|
|
244
213
|
usd1: {
|
|
245
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/usd1.png',
|
|
246
214
|
name: 'USD1',
|
|
247
215
|
},
|
|
248
216
|
usdf: {
|
|
249
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/usdf.png',
|
|
250
217
|
name: 'USDf',
|
|
251
218
|
},
|
|
252
219
|
$wif: {
|
|
253
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/wif.png',
|
|
254
220
|
name: 'WIF',
|
|
255
221
|
},
|
|
256
222
|
xdai: {
|
|
257
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/xdai.svg',
|
|
258
223
|
name: 'xDAI',
|
|
259
224
|
},
|
|
260
225
|
xrp: {
|
|
261
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/xrp.svg',
|
|
262
226
|
name: 'Ripple',
|
|
263
227
|
},
|
|
264
228
|
zec: {
|
|
265
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/zec.svg',
|
|
266
229
|
name: 'Zcash',
|
|
267
230
|
},
|
|
268
231
|
xbtc: {
|
|
269
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/btc.svg',
|
|
270
232
|
name: 'xBTC',
|
|
271
233
|
},
|
|
272
234
|
wbtc: {
|
|
273
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/btc.svg',
|
|
274
235
|
name: 'wBTC',
|
|
275
236
|
},
|
|
276
237
|
wnear: {
|
|
277
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/near.svg',
|
|
278
238
|
name: 'wNEAR',
|
|
279
239
|
},
|
|
280
240
|
weth: {
|
|
281
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/eth.svg',
|
|
282
241
|
name: 'wETH',
|
|
283
242
|
},
|
|
284
243
|
nearkat: {
|
|
@@ -286,27 +245,21 @@ export const TOKENS_DATA: Record<string, TokenAdditionalData> = {
|
|
|
286
245
|
name: 'NearKat',
|
|
287
246
|
},
|
|
288
247
|
itlx: {
|
|
289
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/itlx.svg',
|
|
290
248
|
name: 'ITLX',
|
|
291
249
|
},
|
|
292
250
|
ltc: {
|
|
293
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/ltc.svg',
|
|
294
251
|
name: 'LTC',
|
|
295
252
|
},
|
|
296
253
|
aster: {
|
|
297
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/aster.svg',
|
|
298
254
|
name: 'ASTER',
|
|
299
255
|
},
|
|
300
256
|
spx: {
|
|
301
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/spx.svg',
|
|
302
257
|
name: 'SPX',
|
|
303
258
|
},
|
|
304
259
|
eure: {
|
|
305
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/eure.svg',
|
|
306
260
|
name: 'EURe',
|
|
307
261
|
},
|
|
308
262
|
gbpe: {
|
|
309
|
-
icon: 'https://wtmcxrwapthiogjpxwfr.supabase.co/storage/v1/object/public/swap-widget/gbpe.svg',
|
|
310
263
|
name: 'GBPE',
|
|
311
264
|
},
|
|
312
265
|
};
|
|
@@ -9,9 +9,9 @@ import { useConfig } from '@/config';
|
|
|
9
9
|
import { Hr } from '@/components/Hr';
|
|
10
10
|
import { Icon } from '@/components/Icon';
|
|
11
11
|
import { useChains } from '@/hooks/useChains';
|
|
12
|
-
import { CHAINS_LIST } from '@/constants/chains';
|
|
13
12
|
import { notReachable } from '@/utils/notReachable';
|
|
14
13
|
import { useTypedTranslation } from '@/localisation';
|
|
14
|
+
import { ASSET_ICONS, UNKNOWN_ICON } from '@/icons';
|
|
15
15
|
import type { Chains, ChainsFilter } from '@/types/chain';
|
|
16
16
|
|
|
17
17
|
type Msg = { type: 'on_click_chain'; chain: 'all' | 'intents' | Chains };
|
|
@@ -72,7 +72,7 @@ export const ChainsDropdown = ({
|
|
|
72
72
|
<Icon
|
|
73
73
|
radius={10}
|
|
74
74
|
label={selectedChain.label}
|
|
75
|
-
icon={
|
|
75
|
+
icon={ASSET_ICONS[selected] ?? UNKNOWN_ICON}
|
|
76
76
|
/>
|
|
77
77
|
);
|
|
78
78
|
}
|
|
@@ -125,10 +125,10 @@ export const ChainsDropdown = ({
|
|
|
125
125
|
{({ focus }) => (
|
|
126
126
|
<ChainItem
|
|
127
127
|
chain="intents"
|
|
128
|
-
label={
|
|
128
|
+
label={appName}
|
|
129
129
|
isSelected={selected === 'intents'}
|
|
130
130
|
isFocused={focus}
|
|
131
|
-
icon={appIcon}
|
|
131
|
+
icon={appIcon ?? UNKNOWN_ICON}
|
|
132
132
|
onMsg={(msg) => {
|
|
133
133
|
switch (msg.type) {
|
|
134
134
|
case 'on_click_chain':
|
|
@@ -156,7 +156,7 @@ export const ChainsDropdown = ({
|
|
|
156
156
|
<ChainItem
|
|
157
157
|
chain={chain.id}
|
|
158
158
|
label={chain.label}
|
|
159
|
-
icon={
|
|
159
|
+
icon={ASSET_ICONS[chain.id] ?? UNKNOWN_ICON}
|
|
160
160
|
isSelected={selected === chain.id}
|
|
161
161
|
isFocused={focus}
|
|
162
162
|
onMsg={(msg) => {
|
|
@@ -96,9 +96,9 @@ export const TokenInputWithToken = ({
|
|
|
96
96
|
},
|
|
97
97
|
)}>
|
|
98
98
|
<TokenIcon
|
|
99
|
+
token={token}
|
|
99
100
|
chainShowIcon={!token.isIntent}
|
|
100
101
|
className="border-sw-gray-800 group-hover:border-sw-gray-700 transition-colors top-[14px]"
|
|
101
|
-
{...token}
|
|
102
102
|
/>
|
|
103
103
|
<span className="text-sw-label-md text-sw-gray-50">
|
|
104
104
|
{token.symbol}
|
|
@@ -50,9 +50,9 @@ export const TokenItem = ({
|
|
|
50
50
|
!isNotSelectable && onMsg({ type: 'on_select_token', token })
|
|
51
51
|
}>
|
|
52
52
|
<TokenIcon
|
|
53
|
+
token={token}
|
|
53
54
|
chainShowIcon={!token.isIntent}
|
|
54
55
|
className="border-sw-gray-900 group-hover:border-sw-gray-800 transition-colors"
|
|
55
|
-
{...token}
|
|
56
56
|
/>
|
|
57
57
|
|
|
58
58
|
<div className="gap-sw-xs mr-auto flex flex-col">
|
package/src/hooks/useTokens.ts
CHANGED
|
@@ -3,10 +3,9 @@ import { useQuery } from '@tanstack/react-query';
|
|
|
3
3
|
import { OneClickService } from '@defuse-protocol/one-click-sdk-typescript';
|
|
4
4
|
|
|
5
5
|
import { useConfig } from '@/config';
|
|
6
|
+
import { CHAINS_LIST } from '@/constants/chains';
|
|
6
7
|
import { NATIVE_NEAR_DUMB_ASSET_ID, TOKENS_DATA } from '@/constants/tokens';
|
|
7
|
-
import { CHAINS_LIST, DEFAULT_CHAIN_ICON } from '@/constants/chains';
|
|
8
8
|
import { isValidChain } from '@/utils/checkers/isValidChain';
|
|
9
|
-
import type { Chains } from '@/types/chain';
|
|
10
9
|
import type { SimpleToken, Token } from '@/types/token';
|
|
11
10
|
|
|
12
11
|
const getTokenIcon = (tokenSymbol: string): string => {
|
|
@@ -15,10 +14,6 @@ const getTokenIcon = (tokenSymbol: string): string => {
|
|
|
15
14
|
return TOKENS_DATA[symbol]?.icon ?? '';
|
|
16
15
|
};
|
|
17
16
|
|
|
18
|
-
const getChainIcon = (blockchain: Chains): string => {
|
|
19
|
-
return CHAINS_LIST[blockchain].icon ?? DEFAULT_CHAIN_ICON;
|
|
20
|
-
};
|
|
21
|
-
|
|
22
17
|
const capitalizeChainName = (blockchain: string) =>
|
|
23
18
|
`${blockchain?.charAt(0).toUpperCase()}${blockchain?.slice(1)}`;
|
|
24
19
|
|
|
@@ -94,7 +89,6 @@ export const useTokens = (variant?: 'source' | 'target') => {
|
|
|
94
89
|
isIntent: false,
|
|
95
90
|
icon: token.icon ?? getTokenIcon(token.symbol),
|
|
96
91
|
name: getTokenName(token.symbol),
|
|
97
|
-
chainIcon: getChainIcon(blockchain),
|
|
98
92
|
chainName:
|
|
99
93
|
CHAINS_LIST[token.blockchain]?.label ??
|
|
100
94
|
capitalizeChainName(token.blockchain),
|
|
@@ -120,7 +114,6 @@ export const useTokens = (variant?: 'source' | 'target') => {
|
|
|
120
114
|
chainName: 'Near',
|
|
121
115
|
blockchain: 'near',
|
|
122
116
|
assetId: NATIVE_NEAR_DUMB_ASSET_ID,
|
|
123
|
-
chainIcon: getChainIcon('near'),
|
|
124
117
|
icon: TOKENS_DATA.near?.icon ?? '',
|
|
125
118
|
price: wnearToken?.price ?? 0,
|
|
126
119
|
contractAddress: wnearToken?.contractAddress,
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
<svg xmlns="http://www.w3.org/2000/svg"
|
|
2
|
+
width="64"
|
|
3
|
+
height="64"
|
|
4
|
+
viewBox="0 0 64 64">
|
|
5
|
+
<image
|
|
6
|
+
width="64"
|
|
7
|
+
height="64"
|
|
8
|
+
preserveAspectRatio="xMidYMid meet"
|
|
9
|
+
href=""
|
|
10
|
+
/>
|
|
11
|
+
</svg>
|