@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.
Files changed (165) hide show
  1. package/dist/components/TokenIcon.d.ts +5 -12
  2. package/dist/components/TokenIcon.js +34 -32
  3. package/dist/components/TokenIcon.js.map +1 -1
  4. package/dist/{config-CJfcVohD.js → config-DQMHUj5z.js} +678 -681
  5. package/dist/config-DQMHUj5z.js.map +1 -0
  6. package/dist/config.d.ts +1 -1
  7. package/dist/config.js +1 -1
  8. package/dist/constants/chains.d.ts +0 -1
  9. package/dist/constants/chains.js +44 -65
  10. package/dist/constants/chains.js.map +1 -1
  11. package/dist/constants/tokens.d.ts +1 -1
  12. package/dist/constants/tokens.js +3 -50
  13. package/dist/constants/tokens.js.map +1 -1
  14. package/dist/errors.js +1 -1
  15. package/dist/ext/alchemy/index.js +1 -1
  16. package/dist/ext/index.js +1 -1
  17. package/dist/features/BalanceRpcLoader/TokenBalanceLoader.js +1 -1
  18. package/dist/features/BalanceRpcLoader/index.js +1 -1
  19. package/dist/features/BalanceRpcLoader/useTokenBalanceRpc.js +1 -1
  20. package/dist/features/ChainsDropdown/index.js +32 -32
  21. package/dist/features/ChainsDropdown/index.js.map +1 -1
  22. package/dist/features/DepositMethodSwitcher.js +1 -1
  23. package/dist/features/ErrorBoundary.js +1 -1
  24. package/dist/features/ExternalDeposit.js +1 -1
  25. package/dist/features/SendAddress/index.js +1 -1
  26. package/dist/features/SendAddress/useNotification.js +1 -1
  27. package/dist/features/SubmitButton/index.js +1 -1
  28. package/dist/features/SuccessScreen/index.js +1 -1
  29. package/dist/features/SwapDirectionSwitcher.js +1 -1
  30. package/dist/features/SwapQuote/SwapQuote.js +1 -1
  31. package/dist/features/SwapQuote/index.js +1 -1
  32. package/dist/features/TokenInput/TokenInput.js +1 -1
  33. package/dist/features/TokenInput/TokenInputEmpty.js +1 -1
  34. package/dist/features/TokenInput/TokenInputSource.js +1 -1
  35. package/dist/features/TokenInput/TokenInputTarget.js +1 -1
  36. package/dist/features/TokenInput/WalletBalance.js +1 -1
  37. package/dist/features/TokenInput/hooks/index.js +1 -1
  38. package/dist/features/TokenInput/hooks/useTokenInputBalance.js +1 -1
  39. package/dist/features/TokenInput/index.js +1 -1
  40. package/dist/features/TokensList/TokenItem.js +1 -1
  41. package/dist/features/TokensList/TokensList.js +1 -1
  42. package/dist/features/TokensList/index.js +1 -1
  43. package/dist/features/TokensModal.js +1 -1
  44. package/dist/features/WalletCompatibilityCheck/WalletCompatibilityModal.js +1 -1
  45. package/dist/features/WalletCompatibilityCheck/index.js +1 -1
  46. package/dist/features/index.js +1 -1
  47. package/dist/hooks/index.js +1 -1
  48. package/dist/hooks/useAllTokens.js +1 -1
  49. package/dist/hooks/useChains.js +1 -1
  50. package/dist/hooks/useCompatibilityCheck.js +1 -1
  51. package/dist/hooks/useDefaultToken.js +1 -1
  52. package/dist/hooks/useExternalDepositStatus/index.js +1 -1
  53. package/dist/hooks/useExternalDepositStatus/usePoaExternalDepositStatus.js +1 -1
  54. package/dist/hooks/useIntentsBalance.js +1 -1
  55. package/dist/hooks/useIsCompatibilityCheckRequired.js +1 -1
  56. package/dist/hooks/useMakeDepositAddress.js +1 -1
  57. package/dist/hooks/useMakeIntentsTransfer.js +1 -1
  58. package/dist/hooks/useMakeNEARFtTransferCall.js +1 -1
  59. package/dist/hooks/useMakeQuote.js +1 -1
  60. package/dist/hooks/useMakeQuoteTransfer.js +1 -1
  61. package/dist/hooks/useMakeTransfer.js +1 -1
  62. package/dist/hooks/useMergedBalance.js +1 -1
  63. package/dist/hooks/useSwitchChain.js +1 -1
  64. package/dist/hooks/useTheme.js +1 -1
  65. package/dist/hooks/useTokenInputPair.js +1 -1
  66. package/dist/hooks/useTokens.js +2 -2
  67. package/dist/hooks/useTokensFiltered.js +1 -1
  68. package/dist/hooks/useTokensIntentsUnique.js +1 -1
  69. package/dist/icons/index.d.ts +4 -0
  70. package/dist/icons/index.js +392 -0
  71. package/dist/icons/index.js.map +1 -0
  72. package/dist/index.js +1 -1
  73. package/dist/machine/effects/index.js +1 -1
  74. package/dist/machine/effects/useAlchemyBalanceEffect.js +1 -1
  75. package/dist/machine/effects/useBalancesUpdateEffect.js +1 -1
  76. package/dist/machine/effects/useMakeQuoteEffect.js +1 -1
  77. package/dist/machine/effects/useSelectedTokensEffect.d.ts +0 -2
  78. package/dist/machine/effects/useSelectedTokensEffect.js +1 -1
  79. package/dist/machine/effects/useSetTokenBalanceEffect.js +1 -1
  80. package/dist/machine/effects/useSetTokenIntentsTargetEffect.js +1 -1
  81. package/dist/machine/effects/useWalletConnEffect.js +1 -1
  82. package/dist/machine/events/index.js +1 -1
  83. package/dist/machine/events/tokenSelect.js +1 -1
  84. package/dist/machine/events/validateInputAndMoveTo.js +1 -1
  85. package/dist/machine/events/validateInputs.js +1 -1
  86. package/dist/machine/index.js +1 -1
  87. package/dist/machine/snap.d.ts +0 -18
  88. package/dist/machine/snap.js +1 -1
  89. package/dist/machine/subscriptions/checkers/isSendAddressAsConnected.js +1 -1
  90. package/dist/machine/subscriptions/index.js +1 -1
  91. package/dist/styles.css +1 -1
  92. package/dist/tailwind.css +0 -4
  93. package/dist/theme/ThemeProvider.js +1 -1
  94. package/dist/theme.css +5 -4
  95. package/dist/types/chain.d.ts +0 -1
  96. package/dist/types/config.d.ts +1 -1
  97. package/dist/types/token.d.ts +0 -1
  98. package/dist/utils/intents/signers/near.js +1 -1
  99. package/dist/utils/intents/signers/privy.js +1 -1
  100. package/dist/utils/near/getNearNep141StorageBalance.js +1 -1
  101. package/dist/widgets/WidgetDeposit/WidgetDepositContent.js +3 -3
  102. package/dist/widgets/WidgetDeposit/WidgetDepositContent.js.map +1 -1
  103. package/dist/widgets/WidgetDeposit/WidgetDepositSkeleton.js +1 -1
  104. package/dist/widgets/WidgetSwap/WidgetSwapContent.js +1 -1
  105. package/dist/widgets/WidgetSwap/WidgetSwapSkeleton.js +1 -1
  106. package/dist/widgets/WidgetWithdraw/WidgetWithdrawContent.js +1 -1
  107. package/dist/widgets/WidgetWithdraw/WidgetWithdrawSkeleton.js +1 -1
  108. package/package.json +1 -1
  109. package/src/components/TokenIcon.tsx +35 -38
  110. package/src/config.tsx +0 -2
  111. package/src/constants/chains.ts +0 -23
  112. package/src/constants/tokens.ts +1 -48
  113. package/src/features/ChainsDropdown/index.tsx +5 -5
  114. package/src/features/TokenInput/TokenInput.tsx +1 -1
  115. package/src/features/TokensList/TokenItem.tsx +1 -1
  116. package/src/hooks/useTokens.ts +1 -8
  117. package/src/icons/abg.svg +11 -0
  118. package/src/icons/arb.svg +22 -0
  119. package/src/icons/aster.svg +1 -0
  120. package/src/icons/aurora.svg +14 -0
  121. package/src/icons/avax.svg +12 -0
  122. package/src/icons/base.svg +11 -0
  123. package/src/icons/bera.svg +20 -0
  124. package/src/icons/bsc.svg +14 -0
  125. package/src/icons/btc.svg +11 -0
  126. package/src/icons/cardano.svg +40 -0
  127. package/src/icons/doge.svg +15 -0
  128. package/src/icons/eth.svg +16 -0
  129. package/src/icons/frax.svg +26 -0
  130. package/src/icons/gnear.svg +1 -0
  131. package/src/icons/gnosis.svg +16 -0
  132. package/src/icons/index.tsx +111 -0
  133. package/src/icons/itlx.svg +12 -0
  134. package/src/icons/jambo.svg +10 -0
  135. package/src/icons/knc.svg +1 -0
  136. package/src/icons/loud.svg +7 -0
  137. package/src/icons/ltc.svg +1 -0
  138. package/src/icons/mon.svg +1 -0
  139. package/src/icons/mpdao.svg +1 -0
  140. package/src/icons/near.svg +16 -0
  141. package/src/icons/noear.svg +10 -0
  142. package/src/icons/op.svg +12 -0
  143. package/src/icons/pol.svg +11 -0
  144. package/src/icons/public.svg +1 -0
  145. package/src/icons/purge.svg +10 -0
  146. package/src/icons/rhea.svg +10 -0
  147. package/src/icons/sol.svg +21 -0
  148. package/src/icons/sui.svg +16 -0
  149. package/src/icons/ton.svg +11 -0
  150. package/src/icons/tron.svg +11 -0
  151. package/src/icons/unknown.svg +4 -0
  152. package/src/icons/usd1.svg +10 -0
  153. package/src/icons/usdf.svg +10 -0
  154. package/src/icons/wif.svg +10 -0
  155. package/src/icons/xdai.svg +22 -0
  156. package/src/icons/xrp.svg +17 -0
  157. package/src/icons/zec.svg +16 -0
  158. package/src/tailwind.css +0 -4
  159. package/src/theme/ThemeProvider.tsx +3 -1
  160. package/src/theme.css +5 -4
  161. package/src/types/chain.ts +0 -1
  162. package/src/types/config.ts +1 -1
  163. package/src/types/token.ts +0 -1
  164. package/src/widgets/WidgetDeposit/WidgetDepositContent.tsx +1 -1
  165. 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-CJfcVohD.js";
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-CJfcVohD.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-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-CJfcVohD.js";
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-CJfcVohD.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-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-CJfcVohD.js";
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,6 +1,6 @@
1
1
  {
2
2
  "name": "@aurora-is-near/intents-swap-widget",
3
- "version": "3.15.2",
3
+ "version": "3.16.0",
4
4
  "description": "Provides components and hooks to build your own Intents swap widget",
5
5
  "author": "Maksim Vashchuk",
6
6
  "license": "MIT",
@@ -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
- icon: string;
7
- name: string;
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
- icon,
26
- name,
27
- chainName,
28
- chainIcon,
17
+ token,
29
18
  chainShowIcon,
30
19
  className,
31
- }: TokenItemProps) => (
32
- <div className="relative flex items-center">
33
- <Icon icon={icon} label={name} />
34
- {chainShowIcon && (
35
- <div
36
- className={cn(
37
- 'absolute top-[19px] right-[-4px] flex h-[16px] w-[16px] items-center justify-center overflow-hidden border-2',
38
- className,
39
- )}
40
- style={{ borderRadius: BORDER_RADIUS }}>
41
- <Icon
42
- size={16}
43
- radius={BORDER_RADIUS}
44
- icon={chainIcon}
45
- label={chainName}
46
- />
47
- </div>
48
- )}
49
- </div>
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',
@@ -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
 
@@ -1,7 +1,7 @@
1
1
  export const DEFAULT_TOKEN_ICON = '/icons/widget/unknown-token.png';
2
2
 
3
3
  type TokenAdditionalData = {
4
- icon: string | undefined;
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={CHAINS_LIST[selected].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={`${appName} account`}
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={CHAINS_LIST[chain.id].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">
@@ -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>