@lifi/widget 3.0.0-alpha.17 → 3.0.0-alpha.19

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 (529) hide show
  1. package/AppRoutes.tsx +22 -0
  2. package/_cjs/AppRoutes.js +17 -0
  3. package/_cjs/AppRoutes.js.map +1 -1
  4. package/_cjs/components/AccountAvatar.d.ts +7 -0
  5. package/_cjs/components/AccountAvatar.js +20 -0
  6. package/_cjs/components/AccountAvatar.js.map +1 -0
  7. package/_cjs/components/ActiveTransactions/ActiveTransactions.style.d.ts +2 -2
  8. package/_cjs/components/AlertMessage/AlertMessage.d.ts +11 -0
  9. package/_cjs/components/AlertMessage/AlertMessage.js +8 -0
  10. package/_cjs/components/AlertMessage/AlertMessage.js.map +1 -0
  11. package/_cjs/components/AlertMessage/AlertMessage.style.d.ts +12 -0
  12. package/_cjs/components/AlertMessage/AlertMessage.style.js +35 -0
  13. package/_cjs/components/AlertMessage/AlertMessage.style.js.map +1 -0
  14. package/_cjs/components/AlertMessage/index.d.ts +3 -0
  15. package/_cjs/components/AlertMessage/index.js +20 -0
  16. package/_cjs/components/AlertMessage/index.js.map +1 -0
  17. package/_cjs/components/AlertMessage/types.d.ts +1 -0
  18. package/_cjs/components/AlertMessage/types.js +3 -0
  19. package/_cjs/components/AlertMessage/types.js.map +1 -0
  20. package/_cjs/components/BaseTransactionButton/BaseTransactionButton.js +6 -3
  21. package/_cjs/components/BaseTransactionButton/BaseTransactionButton.js.map +1 -1
  22. package/_cjs/{pages/SettingsPage/SettingsCard/SettingCardButton.d.ts → components/Card/CardButton.d.ts} +2 -2
  23. package/_cjs/components/Card/CardButton.js +9 -0
  24. package/_cjs/components/Card/CardButton.js.map +1 -0
  25. package/_cjs/components/Card/CardButton.style.d.ts +13 -0
  26. package/_cjs/components/Card/CardButton.style.js +36 -0
  27. package/_cjs/components/Card/CardButton.style.js.map +1 -0
  28. package/_cjs/components/Card/index.d.ts +2 -0
  29. package/_cjs/components/Card/index.js +2 -0
  30. package/_cjs/components/Card/index.js.map +1 -1
  31. package/_cjs/components/ChainSelect/useChainSelect.js +4 -15
  32. package/_cjs/components/ChainSelect/useChainSelect.js.map +1 -1
  33. package/_cjs/components/GasMessage/FundsSufficiencyMessage.js +13 -5
  34. package/_cjs/components/GasMessage/FundsSufficiencyMessage.js.map +1 -1
  35. package/_cjs/components/GasMessage/GasMessage.style.d.ts +1 -14
  36. package/_cjs/components/GasMessage/GasMessage.style.js +1 -24
  37. package/_cjs/components/GasMessage/GasMessage.style.js.map +1 -1
  38. package/_cjs/components/GasMessage/GasRefuelMessage.js +4 -5
  39. package/_cjs/components/GasMessage/GasRefuelMessage.js.map +1 -1
  40. package/_cjs/components/GasMessage/GasSufficiencyMessage.js +2 -6
  41. package/_cjs/components/GasMessage/GasSufficiencyMessage.js.map +1 -1
  42. package/_cjs/components/Header/NavigationHeader.js +11 -2
  43. package/_cjs/components/Header/NavigationHeader.js.map +1 -1
  44. package/_cjs/components/ListItem/ListItem.d.ts +6 -0
  45. package/_cjs/components/ListItem/ListItem.js +27 -0
  46. package/_cjs/components/ListItem/ListItem.js.map +1 -0
  47. package/_cjs/components/ListItem/ListItemButton.d.ts +4 -0
  48. package/_cjs/components/ListItem/ListItemButton.js +12 -0
  49. package/_cjs/components/ListItem/ListItemButton.js.map +1 -0
  50. package/_cjs/components/ListItem/index.d.ts +2 -0
  51. package/_cjs/components/ListItem/index.js +19 -0
  52. package/_cjs/components/ListItem/index.js.map +1 -0
  53. package/_cjs/components/ListItemButton.d.ts +1 -1
  54. package/_cjs/components/ListItemButton.js +3 -2
  55. package/_cjs/components/ListItemButton.js.map +1 -1
  56. package/_cjs/components/Menu.d.ts +1 -0
  57. package/_cjs/components/Menu.js +25 -0
  58. package/_cjs/components/Menu.js.map +1 -0
  59. package/_cjs/components/PageContainer.d.ts +1 -2
  60. package/_cjs/components/PoweredBy/PoweredBy.style.d.ts +1 -1
  61. package/_cjs/components/ReverseTokensButton/ReverseTokensButton.js +11 -3
  62. package/_cjs/components/ReverseTokensButton/ReverseTokensButton.js.map +1 -1
  63. package/_cjs/components/Routes/Routes.js +1 -3
  64. package/_cjs/components/Routes/Routes.js.map +1 -1
  65. package/_cjs/components/Routes/RoutesExpanded.js +4 -7
  66. package/_cjs/components/Routes/RoutesExpanded.js.map +1 -1
  67. package/_cjs/components/SendToWallet/SendToWallet.style.d.ts +4 -3
  68. package/_cjs/components/SendToWallet/SendToWallet.style.js +26 -15
  69. package/_cjs/components/SendToWallet/SendToWallet.style.js.map +1 -1
  70. package/_cjs/components/SendToWallet/SendToWalletButton.d.ts +1 -2
  71. package/_cjs/components/SendToWallet/SendToWalletButton.js +55 -23
  72. package/_cjs/components/SendToWallet/SendToWalletButton.js.map +1 -1
  73. package/_cjs/components/SendToWallet/SendToWalletExpandButton.d.ts +2 -0
  74. package/_cjs/components/SendToWallet/SendToWalletExpandButton.js +41 -0
  75. package/_cjs/components/SendToWallet/SendToWalletExpandButton.js.map +1 -0
  76. package/_cjs/components/SendToWallet/index.d.ts +2 -1
  77. package/_cjs/components/SendToWallet/index.js +2 -1
  78. package/_cjs/components/SendToWallet/index.js.map +1 -1
  79. package/_cjs/components/SettingsListItemButton.d.ts +1 -1
  80. package/_cjs/components/Step/StepProcess.style.d.ts +1 -1
  81. package/_cjs/components/TokenList/TokenList.style.d.ts +2 -5
  82. package/_cjs/components/TokenList/TokenList.style.js +3 -28
  83. package/_cjs/components/TokenList/TokenList.style.js.map +1 -1
  84. package/_cjs/components/TokenList/TokenListItem.js +3 -2
  85. package/_cjs/components/TokenList/TokenListItem.js.map +1 -1
  86. package/_cjs/components/TokenList/VirtualizedTokenList.js +2 -2
  87. package/_cjs/components/TokenList/VirtualizedTokenList.js.map +1 -1
  88. package/_cjs/config/version.d.ts +1 -1
  89. package/_cjs/config/version.js +1 -1
  90. package/_cjs/hooks/index.d.ts +3 -1
  91. package/_cjs/hooks/index.js +3 -1
  92. package/_cjs/hooks/index.js.map +1 -1
  93. package/_cjs/hooks/useAccount.d.ts +14 -3
  94. package/_cjs/hooks/useAccount.js +24 -6
  95. package/_cjs/hooks/useAccount.js.map +1 -1
  96. package/_cjs/hooks/useAddressValidation.d.ts +17 -0
  97. package/_cjs/hooks/useAddressValidation.js +59 -0
  98. package/_cjs/hooks/useAddressValidation.js.map +1 -0
  99. package/_cjs/hooks/useFromTokenSufficiency.js +3 -4
  100. package/_cjs/hooks/useFromTokenSufficiency.js.map +1 -1
  101. package/_cjs/hooks/useGasSufficiency.js +6 -5
  102. package/_cjs/hooks/useGasSufficiency.js.map +1 -1
  103. package/_cjs/hooks/useRouteExecution.js +7 -5
  104. package/_cjs/hooks/useRouteExecution.js.map +1 -1
  105. package/_cjs/hooks/useRoutes.d.ts +2 -2
  106. package/_cjs/hooks/useRoutes.js +17 -29
  107. package/_cjs/hooks/useRoutes.js.map +1 -1
  108. package/_cjs/hooks/useToAddressRequirements.d.ts +4 -0
  109. package/_cjs/hooks/{useRequiredToAddress.js → useToAddressRequirements.js} +11 -8
  110. package/_cjs/hooks/useToAddressRequirements.js.map +1 -0
  111. package/_cjs/hooks/useToAddressReset.d.ts +4 -0
  112. package/_cjs/hooks/useToAddressReset.js +32 -0
  113. package/_cjs/hooks/useToAddressReset.js.map +1 -0
  114. package/_cjs/hooks/useTokenAddressBalance.d.ts +1 -1
  115. package/_cjs/hooks/useTokenBalance.d.ts +1 -1
  116. package/_cjs/hooks/useTokenBalance.js +4 -7
  117. package/_cjs/hooks/useTokenBalance.js.map +1 -1
  118. package/_cjs/hooks/useTokenBalances.d.ts +1 -1
  119. package/_cjs/hooks/useTokenBalances.js +3 -4
  120. package/_cjs/hooks/useTokenBalances.js.map +1 -1
  121. package/_cjs/hooks/useTransactionDetails.js +24 -22
  122. package/_cjs/hooks/useTransactionDetails.js.map +1 -1
  123. package/_cjs/i18n/en.json +27 -6
  124. package/_cjs/pages/MainPage/MainPage.js +1 -1
  125. package/_cjs/pages/MainPage/MainPage.js.map +1 -1
  126. package/_cjs/pages/MainPage/ReviewButton.js +3 -2
  127. package/_cjs/pages/MainPage/ReviewButton.js.map +1 -1
  128. package/_cjs/pages/SendToWallet/BookmarkAddressSheet.d.ts +9 -0
  129. package/_cjs/pages/SendToWallet/BookmarkAddressSheet.js +111 -0
  130. package/_cjs/pages/SendToWallet/BookmarkAddressSheet.js.map +1 -0
  131. package/_cjs/pages/SendToWallet/BookmarksPage.d.ts +1 -0
  132. package/_cjs/pages/SendToWallet/BookmarksPage.js +88 -0
  133. package/_cjs/pages/SendToWallet/BookmarksPage.js.map +1 -0
  134. package/_cjs/pages/SendToWallet/ConfirmAddressSheet.d.ts +9 -0
  135. package/_cjs/pages/SendToWallet/ConfirmAddressSheet.js +35 -0
  136. package/_cjs/pages/SendToWallet/ConfirmAddressSheet.js.map +1 -0
  137. package/_cjs/pages/SendToWallet/ConnectedWalletsPage.d.ts +1 -0
  138. package/_cjs/pages/SendToWallet/ConnectedWalletsPage.js +84 -0
  139. package/_cjs/pages/SendToWallet/ConnectedWalletsPage.js.map +1 -0
  140. package/_cjs/pages/SendToWallet/EmptyListIndicator.d.ts +6 -0
  141. package/_cjs/pages/SendToWallet/EmptyListIndicator.js +8 -0
  142. package/_cjs/pages/SendToWallet/EmptyListIndicator.js.map +1 -0
  143. package/_cjs/pages/SendToWallet/RecentWalletsPage.d.ts +1 -0
  144. package/_cjs/pages/SendToWallet/RecentWalletsPage.js +105 -0
  145. package/_cjs/pages/SendToWallet/RecentWalletsPage.js.map +1 -0
  146. package/_cjs/pages/SendToWallet/SendToWalletPage.d.ts +1 -0
  147. package/_cjs/pages/SendToWallet/SendToWalletPage.js +131 -0
  148. package/_cjs/pages/SendToWallet/SendToWalletPage.js.map +1 -0
  149. package/_cjs/pages/SendToWallet/SendToWalletPage.style.d.ts +61 -0
  150. package/_cjs/pages/SendToWallet/SendToWalletPage.style.js +146 -0
  151. package/_cjs/pages/SendToWallet/SendToWalletPage.style.js.map +1 -0
  152. package/_cjs/pages/SendToWallet/index.d.ts +4 -0
  153. package/_cjs/pages/SendToWallet/index.js +21 -0
  154. package/_cjs/pages/SendToWallet/index.js.map +1 -0
  155. package/_cjs/pages/SettingsPage/BridgeAndExchangeSettings.js +2 -1
  156. package/_cjs/pages/SettingsPage/BridgeAndExchangeSettings.js.map +1 -1
  157. package/_cjs/pages/SettingsPage/LanguageSetting.js +2 -2
  158. package/_cjs/pages/SettingsPage/LanguageSetting.js.map +1 -1
  159. package/_cjs/pages/SettingsPage/SendToWalletOptionSetting.js +2 -2
  160. package/_cjs/pages/SettingsPage/SendToWalletOptionSetting.js.map +1 -1
  161. package/_cjs/pages/SettingsPage/SettingsCard/BadgedValue.js +2 -1
  162. package/_cjs/pages/SettingsPage/SettingsCard/BadgedValue.js.map +1 -1
  163. package/_cjs/pages/SettingsPage/SettingsCard/SettingCard.style.d.ts +0 -9
  164. package/_cjs/pages/SettingsPage/SettingsCard/SettingCard.style.js +2 -24
  165. package/_cjs/pages/SettingsPage/SettingsCard/SettingCard.style.js.map +1 -1
  166. package/_cjs/pages/SettingsPage/SettingsCard/SettingCardExpandable.js +2 -3
  167. package/_cjs/pages/SettingsPage/SettingsCard/SettingCardExpandable.js.map +1 -1
  168. package/_cjs/pages/SettingsPage/SettingsCard/index.d.ts +0 -2
  169. package/_cjs/pages/SettingsPage/SettingsCard/index.js +0 -2
  170. package/_cjs/pages/SettingsPage/SettingsCard/index.js.map +1 -1
  171. package/_cjs/pages/SettingsPage/SlippageSettings/SlippageSettings.js.map +1 -1
  172. package/_cjs/pages/SettingsPage/ThemeSettings.js +2 -1
  173. package/_cjs/pages/SettingsPage/ThemeSettings.js.map +1 -1
  174. package/_cjs/providers/I18nProvider/I18nProvider.js +1 -1
  175. package/_cjs/providers/I18nProvider/I18nProvider.js.map +1 -1
  176. package/_cjs/providers/WalletProvider/SDKProviders.js.map +1 -1
  177. package/_cjs/stores/StoreProvider.js +2 -1
  178. package/_cjs/stores/StoreProvider.js.map +1 -1
  179. package/_cjs/stores/bookmarks/BookmarkStore.d.ts +7 -0
  180. package/_cjs/stores/bookmarks/BookmarkStore.js +25 -0
  181. package/_cjs/stores/bookmarks/BookmarkStore.js.map +1 -0
  182. package/_cjs/stores/bookmarks/createBookmarkStore.d.ts +3 -0
  183. package/_cjs/stores/bookmarks/createBookmarkStore.js +49 -0
  184. package/_cjs/stores/bookmarks/createBookmarkStore.js.map +1 -0
  185. package/_cjs/stores/bookmarks/index.d.ts +5 -0
  186. package/_cjs/stores/bookmarks/index.js +22 -0
  187. package/_cjs/stores/bookmarks/index.js.map +1 -0
  188. package/_cjs/stores/bookmarks/types.d.ts +24 -0
  189. package/_cjs/stores/bookmarks/types.js +3 -0
  190. package/_cjs/stores/bookmarks/types.js.map +1 -0
  191. package/_cjs/stores/bookmarks/useBookmarkActions.d.ts +2 -0
  192. package/_cjs/stores/bookmarks/useBookmarkActions.js +18 -0
  193. package/_cjs/stores/bookmarks/useBookmarkActions.js.map +1 -0
  194. package/_cjs/stores/bookmarks/useBookmarks.d.ts +2 -0
  195. package/_cjs/stores/bookmarks/useBookmarks.js +15 -0
  196. package/_cjs/stores/bookmarks/useBookmarks.js.map +1 -0
  197. package/_cjs/stores/form/FormStore.js +16 -3
  198. package/_cjs/stores/form/FormStore.js.map +1 -1
  199. package/_cjs/stores/form/types.js.map +1 -1
  200. package/_cjs/stores/form/useTouchedFields.d.ts +4 -4
  201. package/_cjs/stores/index.d.ts +1 -0
  202. package/_cjs/stores/index.js +1 -0
  203. package/_cjs/stores/index.js.map +1 -1
  204. package/_cjs/utils/chainType.d.ts +6 -0
  205. package/_cjs/utils/chainType.js +24 -0
  206. package/_cjs/utils/chainType.js.map +1 -0
  207. package/_cjs/utils/index.d.ts +1 -0
  208. package/_cjs/utils/index.js +1 -0
  209. package/_cjs/utils/index.js.map +1 -1
  210. package/_cjs/utils/navigationRoutes.d.ts +4 -0
  211. package/_cjs/utils/navigationRoutes.js +12 -0
  212. package/_cjs/utils/navigationRoutes.js.map +1 -1
  213. package/_esm/AppRoutes.js +17 -0
  214. package/_esm/AppRoutes.js.map +1 -1
  215. package/_esm/components/AccountAvatar.d.ts +7 -0
  216. package/_esm/components/AccountAvatar.js +16 -0
  217. package/_esm/components/AccountAvatar.js.map +1 -0
  218. package/_esm/components/ActiveTransactions/ActiveTransactions.style.d.ts +2 -2
  219. package/_esm/components/AlertMessage/AlertMessage.d.ts +11 -0
  220. package/_esm/components/AlertMessage/AlertMessage.js +4 -0
  221. package/_esm/components/AlertMessage/AlertMessage.js.map +1 -0
  222. package/_esm/components/AlertMessage/AlertMessage.style.d.ts +12 -0
  223. package/_esm/components/AlertMessage/AlertMessage.style.js +32 -0
  224. package/_esm/components/AlertMessage/AlertMessage.style.js.map +1 -0
  225. package/_esm/components/AlertMessage/index.d.ts +3 -0
  226. package/_esm/components/AlertMessage/index.js +4 -0
  227. package/_esm/components/AlertMessage/index.js.map +1 -0
  228. package/_esm/components/AlertMessage/types.d.ts +1 -0
  229. package/_esm/components/AlertMessage/types.js +2 -0
  230. package/_esm/components/AlertMessage/types.js.map +1 -0
  231. package/_esm/components/BaseTransactionButton/BaseTransactionButton.js +7 -4
  232. package/_esm/components/BaseTransactionButton/BaseTransactionButton.js.map +1 -1
  233. package/_esm/{pages/SettingsPage/SettingsCard/SettingCardButton.d.ts → components/Card/CardButton.d.ts} +2 -2
  234. package/_esm/components/Card/CardButton.js +5 -0
  235. package/_esm/components/Card/CardButton.js.map +1 -0
  236. package/_esm/components/Card/CardButton.style.d.ts +13 -0
  237. package/_esm/components/Card/CardButton.style.js +33 -0
  238. package/_esm/components/Card/CardButton.style.js.map +1 -0
  239. package/_esm/components/Card/index.d.ts +2 -0
  240. package/_esm/components/Card/index.js +2 -0
  241. package/_esm/components/Card/index.js.map +1 -1
  242. package/_esm/components/ChainSelect/useChainSelect.js +5 -16
  243. package/_esm/components/ChainSelect/useChainSelect.js.map +1 -1
  244. package/_esm/components/GasMessage/FundsSufficiencyMessage.js +14 -6
  245. package/_esm/components/GasMessage/FundsSufficiencyMessage.js.map +1 -1
  246. package/_esm/components/GasMessage/GasMessage.style.d.ts +1 -14
  247. package/_esm/components/GasMessage/GasMessage.style.js +1 -24
  248. package/_esm/components/GasMessage/GasMessage.style.js.map +1 -1
  249. package/_esm/components/GasMessage/GasRefuelMessage.js +5 -6
  250. package/_esm/components/GasMessage/GasRefuelMessage.js.map +1 -1
  251. package/_esm/components/GasMessage/GasSufficiencyMessage.js +2 -6
  252. package/_esm/components/GasMessage/GasSufficiencyMessage.js.map +1 -1
  253. package/_esm/components/Header/NavigationHeader.js +11 -2
  254. package/_esm/components/Header/NavigationHeader.js.map +1 -1
  255. package/_esm/components/ListItem/ListItem.d.ts +6 -0
  256. package/_esm/components/ListItem/ListItem.js +24 -0
  257. package/_esm/components/ListItem/ListItem.js.map +1 -0
  258. package/_esm/components/ListItem/ListItemButton.d.ts +4 -0
  259. package/_esm/components/ListItem/ListItemButton.js +9 -0
  260. package/_esm/components/ListItem/ListItemButton.js.map +1 -0
  261. package/_esm/components/ListItem/index.d.ts +2 -0
  262. package/_esm/components/ListItem/index.js +3 -0
  263. package/_esm/components/ListItem/index.js.map +1 -0
  264. package/_esm/components/ListItemButton.d.ts +1 -1
  265. package/_esm/components/ListItemButton.js +3 -2
  266. package/_esm/components/ListItemButton.js.map +1 -1
  267. package/_esm/components/Menu.d.ts +1 -0
  268. package/_esm/components/Menu.js +22 -0
  269. package/_esm/components/Menu.js.map +1 -0
  270. package/_esm/components/PageContainer.d.ts +1 -2
  271. package/_esm/components/PoweredBy/PoweredBy.style.d.ts +1 -1
  272. package/_esm/components/ReverseTokensButton/ReverseTokensButton.js +11 -3
  273. package/_esm/components/ReverseTokensButton/ReverseTokensButton.js.map +1 -1
  274. package/_esm/components/Routes/Routes.js +1 -3
  275. package/_esm/components/Routes/Routes.js.map +1 -1
  276. package/_esm/components/Routes/RoutesExpanded.js +5 -8
  277. package/_esm/components/Routes/RoutesExpanded.js.map +1 -1
  278. package/_esm/components/SendToWallet/SendToWallet.style.d.ts +4 -3
  279. package/_esm/components/SendToWallet/SendToWallet.style.js +25 -14
  280. package/_esm/components/SendToWallet/SendToWallet.style.js.map +1 -1
  281. package/_esm/components/SendToWallet/SendToWalletButton.d.ts +1 -2
  282. package/_esm/components/SendToWallet/SendToWalletButton.js +59 -27
  283. package/_esm/components/SendToWallet/SendToWalletButton.js.map +1 -1
  284. package/_esm/components/SendToWallet/SendToWalletExpandButton.d.ts +2 -0
  285. package/_esm/components/SendToWallet/SendToWalletExpandButton.js +37 -0
  286. package/_esm/components/SendToWallet/SendToWalletExpandButton.js.map +1 -0
  287. package/_esm/components/SendToWallet/index.d.ts +2 -1
  288. package/_esm/components/SendToWallet/index.js +2 -1
  289. package/_esm/components/SendToWallet/index.js.map +1 -1
  290. package/_esm/components/SettingsListItemButton.d.ts +1 -1
  291. package/_esm/components/Step/StepProcess.style.d.ts +1 -1
  292. package/_esm/components/TokenList/TokenList.style.d.ts +2 -5
  293. package/_esm/components/TokenList/TokenList.style.js +3 -28
  294. package/_esm/components/TokenList/TokenList.style.js.map +1 -1
  295. package/_esm/components/TokenList/TokenListItem.js +3 -2
  296. package/_esm/components/TokenList/TokenListItem.js.map +1 -1
  297. package/_esm/components/TokenList/VirtualizedTokenList.js +2 -2
  298. package/_esm/components/TokenList/VirtualizedTokenList.js.map +1 -1
  299. package/_esm/config/version.d.ts +1 -1
  300. package/_esm/config/version.js +1 -1
  301. package/_esm/hooks/index.d.ts +3 -1
  302. package/_esm/hooks/index.js +3 -1
  303. package/_esm/hooks/index.js.map +1 -1
  304. package/_esm/hooks/useAccount.d.ts +14 -3
  305. package/_esm/hooks/useAccount.js +24 -6
  306. package/_esm/hooks/useAccount.js.map +1 -1
  307. package/_esm/hooks/useAddressValidation.d.ts +17 -0
  308. package/_esm/hooks/useAddressValidation.js +55 -0
  309. package/_esm/hooks/useAddressValidation.js.map +1 -0
  310. package/_esm/hooks/useFromTokenSufficiency.js +3 -4
  311. package/_esm/hooks/useFromTokenSufficiency.js.map +1 -1
  312. package/_esm/hooks/useGasSufficiency.js +6 -5
  313. package/_esm/hooks/useGasSufficiency.js.map +1 -1
  314. package/_esm/hooks/useRouteExecution.js +7 -5
  315. package/_esm/hooks/useRouteExecution.js.map +1 -1
  316. package/_esm/hooks/useRoutes.d.ts +2 -2
  317. package/_esm/hooks/useRoutes.js +19 -31
  318. package/_esm/hooks/useRoutes.js.map +1 -1
  319. package/_esm/hooks/useToAddressRequirements.d.ts +4 -0
  320. package/_esm/hooks/{useRequiredToAddress.js → useToAddressRequirements.js} +9 -6
  321. package/_esm/hooks/useToAddressRequirements.js.map +1 -0
  322. package/_esm/hooks/useToAddressReset.d.ts +4 -0
  323. package/_esm/hooks/useToAddressReset.js +28 -0
  324. package/_esm/hooks/useToAddressReset.js.map +1 -0
  325. package/_esm/hooks/useTokenAddressBalance.d.ts +1 -1
  326. package/_esm/hooks/useTokenBalance.d.ts +1 -1
  327. package/_esm/hooks/useTokenBalance.js +4 -7
  328. package/_esm/hooks/useTokenBalance.js.map +1 -1
  329. package/_esm/hooks/useTokenBalances.d.ts +1 -1
  330. package/_esm/hooks/useTokenBalances.js +3 -4
  331. package/_esm/hooks/useTokenBalances.js.map +1 -1
  332. package/_esm/hooks/useTransactionDetails.js +24 -22
  333. package/_esm/hooks/useTransactionDetails.js.map +1 -1
  334. package/_esm/i18n/en.json +27 -6
  335. package/_esm/pages/MainPage/MainPage.js +2 -2
  336. package/_esm/pages/MainPage/MainPage.js.map +1 -1
  337. package/_esm/pages/MainPage/ReviewButton.js +5 -4
  338. package/_esm/pages/MainPage/ReviewButton.js.map +1 -1
  339. package/_esm/pages/SendToWallet/BookmarkAddressSheet.d.ts +9 -0
  340. package/_esm/pages/SendToWallet/BookmarkAddressSheet.js +108 -0
  341. package/_esm/pages/SendToWallet/BookmarkAddressSheet.js.map +1 -0
  342. package/_esm/pages/SendToWallet/BookmarksPage.d.ts +1 -0
  343. package/_esm/pages/SendToWallet/BookmarksPage.js +84 -0
  344. package/_esm/pages/SendToWallet/BookmarksPage.js.map +1 -0
  345. package/_esm/pages/SendToWallet/ConfirmAddressSheet.d.ts +9 -0
  346. package/_esm/pages/SendToWallet/ConfirmAddressSheet.js +32 -0
  347. package/_esm/pages/SendToWallet/ConfirmAddressSheet.js.map +1 -0
  348. package/_esm/pages/SendToWallet/ConnectedWalletsPage.d.ts +1 -0
  349. package/_esm/pages/SendToWallet/ConnectedWalletsPage.js +80 -0
  350. package/_esm/pages/SendToWallet/ConnectedWalletsPage.js.map +1 -0
  351. package/_esm/pages/SendToWallet/EmptyListIndicator.d.ts +6 -0
  352. package/_esm/pages/SendToWallet/EmptyListIndicator.js +4 -0
  353. package/_esm/pages/SendToWallet/EmptyListIndicator.js.map +1 -0
  354. package/_esm/pages/SendToWallet/RecentWalletsPage.d.ts +1 -0
  355. package/_esm/pages/SendToWallet/RecentWalletsPage.js +101 -0
  356. package/_esm/pages/SendToWallet/RecentWalletsPage.js.map +1 -0
  357. package/_esm/pages/SendToWallet/SendToWalletPage.d.ts +1 -0
  358. package/_esm/pages/SendToWallet/SendToWalletPage.js +127 -0
  359. package/_esm/pages/SendToWallet/SendToWalletPage.js.map +1 -0
  360. package/_esm/pages/SendToWallet/SendToWalletPage.style.d.ts +61 -0
  361. package/_esm/pages/SendToWallet/SendToWalletPage.style.js +143 -0
  362. package/_esm/pages/SendToWallet/SendToWalletPage.style.js.map +1 -0
  363. package/_esm/pages/SendToWallet/index.d.ts +4 -0
  364. package/_esm/pages/SendToWallet/index.js +5 -0
  365. package/_esm/pages/SendToWallet/index.js.map +1 -0
  366. package/_esm/pages/SettingsPage/BridgeAndExchangeSettings.js +3 -2
  367. package/_esm/pages/SettingsPage/BridgeAndExchangeSettings.js.map +1 -1
  368. package/_esm/pages/SettingsPage/LanguageSetting.js +2 -2
  369. package/_esm/pages/SettingsPage/LanguageSetting.js.map +1 -1
  370. package/_esm/pages/SettingsPage/SendToWalletOptionSetting.js +2 -2
  371. package/_esm/pages/SettingsPage/SendToWalletOptionSetting.js.map +1 -1
  372. package/_esm/pages/SettingsPage/SettingsCard/BadgedValue.js +3 -2
  373. package/_esm/pages/SettingsPage/SettingsCard/BadgedValue.js.map +1 -1
  374. package/_esm/pages/SettingsPage/SettingsCard/SettingCard.style.d.ts +0 -9
  375. package/_esm/pages/SettingsPage/SettingsCard/SettingCard.style.js +2 -24
  376. package/_esm/pages/SettingsPage/SettingsCard/SettingCard.style.js.map +1 -1
  377. package/_esm/pages/SettingsPage/SettingsCard/SettingCardExpandable.js +2 -3
  378. package/_esm/pages/SettingsPage/SettingsCard/SettingCardExpandable.js.map +1 -1
  379. package/_esm/pages/SettingsPage/SettingsCard/index.d.ts +0 -2
  380. package/_esm/pages/SettingsPage/SettingsCard/index.js +0 -2
  381. package/_esm/pages/SettingsPage/SettingsCard/index.js.map +1 -1
  382. package/_esm/pages/SettingsPage/SlippageSettings/SlippageSettings.js.map +1 -1
  383. package/_esm/pages/SettingsPage/ThemeSettings.js +3 -2
  384. package/_esm/pages/SettingsPage/ThemeSettings.js.map +1 -1
  385. package/_esm/providers/I18nProvider/I18nProvider.js +2 -2
  386. package/_esm/providers/I18nProvider/I18nProvider.js.map +1 -1
  387. package/_esm/providers/WalletProvider/SDKProviders.js.map +1 -1
  388. package/_esm/stores/StoreProvider.js +2 -1
  389. package/_esm/stores/StoreProvider.js.map +1 -1
  390. package/_esm/stores/bookmarks/BookmarkStore.d.ts +7 -0
  391. package/_esm/stores/bookmarks/BookmarkStore.js +20 -0
  392. package/_esm/stores/bookmarks/BookmarkStore.js.map +1 -0
  393. package/_esm/stores/bookmarks/createBookmarkStore.d.ts +3 -0
  394. package/_esm/stores/bookmarks/createBookmarkStore.js +45 -0
  395. package/_esm/stores/bookmarks/createBookmarkStore.js.map +1 -0
  396. package/_esm/stores/bookmarks/index.d.ts +5 -0
  397. package/_esm/stores/bookmarks/index.js +6 -0
  398. package/_esm/stores/bookmarks/index.js.map +1 -0
  399. package/_esm/stores/bookmarks/types.d.ts +24 -0
  400. package/_esm/stores/bookmarks/types.js +2 -0
  401. package/_esm/stores/bookmarks/types.js.map +1 -0
  402. package/_esm/stores/bookmarks/useBookmarkActions.d.ts +2 -0
  403. package/_esm/stores/bookmarks/useBookmarkActions.js +14 -0
  404. package/_esm/stores/bookmarks/useBookmarkActions.js.map +1 -0
  405. package/_esm/stores/bookmarks/useBookmarks.d.ts +2 -0
  406. package/_esm/stores/bookmarks/useBookmarks.js +11 -0
  407. package/_esm/stores/bookmarks/useBookmarks.js.map +1 -0
  408. package/_esm/stores/form/FormStore.js +16 -3
  409. package/_esm/stores/form/FormStore.js.map +1 -1
  410. package/_esm/stores/form/types.js.map +1 -1
  411. package/_esm/stores/form/useTouchedFields.d.ts +4 -4
  412. package/_esm/stores/index.d.ts +1 -0
  413. package/_esm/stores/index.js +1 -0
  414. package/_esm/stores/index.js.map +1 -1
  415. package/_esm/utils/chainType.d.ts +6 -0
  416. package/_esm/utils/chainType.js +20 -0
  417. package/_esm/utils/chainType.js.map +1 -0
  418. package/_esm/utils/index.d.ts +1 -0
  419. package/_esm/utils/index.js +1 -0
  420. package/_esm/utils/index.js.map +1 -1
  421. package/_esm/utils/navigationRoutes.d.ts +4 -0
  422. package/_esm/utils/navigationRoutes.js +12 -0
  423. package/_esm/utils/navigationRoutes.js.map +1 -1
  424. package/components/AccountAvatar.tsx +55 -0
  425. package/components/AlertMessage/AlertMessage.style.tsx +40 -0
  426. package/components/AlertMessage/AlertMessage.tsx +31 -0
  427. package/components/AlertMessage/index.ts +3 -0
  428. package/components/AlertMessage/types.ts +1 -0
  429. package/components/BaseTransactionButton/BaseTransactionButton.tsx +7 -4
  430. package/components/Card/CardButton.style.tsx +36 -0
  431. package/components/Card/CardButton.tsx +26 -0
  432. package/components/Card/index.ts +2 -0
  433. package/components/ChainSelect/useChainSelect.ts +5 -23
  434. package/components/GasMessage/FundsSufficiencyMessage.tsx +18 -17
  435. package/components/GasMessage/GasMessage.style.ts +1 -31
  436. package/components/GasMessage/GasRefuelMessage.tsx +21 -22
  437. package/components/GasMessage/GasSufficiencyMessage.tsx +9 -21
  438. package/components/Header/NavigationHeader.tsx +11 -2
  439. package/components/ListItem/ListItem.tsx +24 -0
  440. package/components/ListItem/ListItemButton.tsx +9 -0
  441. package/components/ListItem/index.ts +2 -0
  442. package/components/ListItemButton.tsx +12 -8
  443. package/components/Menu.tsx +27 -0
  444. package/components/PageContainer.ts +1 -1
  445. package/components/ReverseTokensButton/ReverseTokensButton.tsx +12 -3
  446. package/components/Routes/Routes.tsx +1 -7
  447. package/components/Routes/RoutesExpanded.tsx +5 -8
  448. package/components/SendToWallet/SendToWallet.style.tsx +25 -15
  449. package/components/SendToWallet/SendToWalletButton.tsx +107 -43
  450. package/components/SendToWallet/SendToWalletExpandButton.tsx +65 -0
  451. package/components/SendToWallet/index.ts +2 -1
  452. package/components/TokenList/TokenList.style.tsx +3 -32
  453. package/components/TokenList/TokenListItem.tsx +4 -3
  454. package/components/TokenList/VirtualizedTokenList.tsx +2 -2
  455. package/config/version.ts +1 -1
  456. package/hooks/index.ts +3 -1
  457. package/hooks/useAccount.ts +37 -9
  458. package/hooks/useAddressValidation.ts +79 -0
  459. package/hooks/useFromTokenSufficiency.ts +3 -8
  460. package/hooks/useGasSufficiency.ts +6 -10
  461. package/hooks/useRouteExecution.ts +9 -5
  462. package/hooks/useRoutes.ts +20 -30
  463. package/hooks/{useRequiredToAddress.ts → useToAddressRequirements.ts} +8 -5
  464. package/hooks/useToAddressReset.ts +36 -0
  465. package/hooks/useTokenBalance.ts +5 -8
  466. package/hooks/useTokenBalances.ts +3 -6
  467. package/hooks/useTransactionDetails.ts +30 -30
  468. package/i18n/en.json +27 -6
  469. package/package.json +12 -12
  470. package/pages/MainPage/MainPage.tsx +3 -3
  471. package/pages/MainPage/ReviewButton.tsx +5 -5
  472. package/pages/SendToWallet/BookmarkAddressSheet.tsx +219 -0
  473. package/pages/SendToWallet/BookmarksPage.tsx +182 -0
  474. package/pages/SendToWallet/ConfirmAddressSheet.tsx +90 -0
  475. package/pages/SendToWallet/ConnectedWalletsPage.tsx +165 -0
  476. package/pages/SendToWallet/EmptyListIndicator.tsx +19 -0
  477. package/pages/SendToWallet/RecentWalletsPage.tsx +215 -0
  478. package/pages/SendToWallet/SendToWalletPage.style.tsx +182 -0
  479. package/pages/SendToWallet/SendToWalletPage.tsx +246 -0
  480. package/pages/SendToWallet/index.ts +4 -0
  481. package/pages/SettingsPage/BridgeAndExchangeSettings.tsx +4 -3
  482. package/pages/SettingsPage/LanguageSetting.tsx +4 -4
  483. package/pages/SettingsPage/SendToWalletOptionSetting.tsx +12 -12
  484. package/pages/SettingsPage/SettingsCard/BadgedValue.tsx +4 -3
  485. package/pages/SettingsPage/SettingsCard/SettingCard.style.tsx +2 -27
  486. package/pages/SettingsPage/SettingsCard/SettingCardExpandable.tsx +13 -12
  487. package/pages/SettingsPage/SettingsCard/index.ts +0 -2
  488. package/pages/SettingsPage/SlippageSettings/SlippageSettings.tsx +1 -1
  489. package/pages/SettingsPage/ThemeSettings.tsx +3 -2
  490. package/providers/I18nProvider/I18nProvider.tsx +2 -2
  491. package/providers/WalletProvider/SDKProviders.tsx +2 -1
  492. package/stores/StoreProvider.tsx +8 -5
  493. package/stores/bookmarks/BookmarkStore.tsx +39 -0
  494. package/stores/bookmarks/createBookmarkStore.ts +63 -0
  495. package/stores/bookmarks/index.ts +5 -0
  496. package/stores/bookmarks/types.ts +31 -0
  497. package/stores/bookmarks/useBookmarkActions.ts +19 -0
  498. package/stores/bookmarks/useBookmarks.ts +16 -0
  499. package/stores/form/FormStore.tsx +25 -4
  500. package/stores/form/types.ts +2 -3
  501. package/stores/index.ts +1 -0
  502. package/utils/chainType.ts +25 -0
  503. package/utils/index.ts +1 -0
  504. package/utils/navigationRoutes.ts +12 -0
  505. package/_cjs/components/SendToWallet/SendToWallet.d.ts +0 -4
  506. package/_cjs/components/SendToWallet/SendToWallet.js +0 -94
  507. package/_cjs/components/SendToWallet/SendToWallet.js.map +0 -1
  508. package/_cjs/hooks/useRequiredToAddress.d.ts +0 -1
  509. package/_cjs/hooks/useRequiredToAddress.js.map +0 -1
  510. package/_cjs/pages/SettingsPage/SettingsCard/SettingCard.d.ts +0 -2
  511. package/_cjs/pages/SettingsPage/SettingsCard/SettingCard.js +0 -12
  512. package/_cjs/pages/SettingsPage/SettingsCard/SettingCard.js.map +0 -1
  513. package/_cjs/pages/SettingsPage/SettingsCard/SettingCardButton.js +0 -9
  514. package/_cjs/pages/SettingsPage/SettingsCard/SettingCardButton.js.map +0 -1
  515. package/_esm/components/SendToWallet/SendToWallet.d.ts +0 -4
  516. package/_esm/components/SendToWallet/SendToWallet.js +0 -90
  517. package/_esm/components/SendToWallet/SendToWallet.js.map +0 -1
  518. package/_esm/hooks/useRequiredToAddress.d.ts +0 -1
  519. package/_esm/hooks/useRequiredToAddress.js.map +0 -1
  520. package/_esm/pages/SettingsPage/SettingsCard/SettingCard.d.ts +0 -2
  521. package/_esm/pages/SettingsPage/SettingsCard/SettingCard.js +0 -8
  522. package/_esm/pages/SettingsPage/SettingsCard/SettingCard.js.map +0 -1
  523. package/_esm/pages/SettingsPage/SettingsCard/SettingCardButton.js +0 -5
  524. package/_esm/pages/SettingsPage/SettingsCard/SettingCardButton.js.map +0 -1
  525. package/components/SendToWallet/SendToWallet.tsx +0 -144
  526. package/i18n/i18next.d.ts +0 -10
  527. package/pages/SettingsPage/SettingsCard/SettingCard.tsx +0 -16
  528. package/pages/SettingsPage/SettingsCard/SettingCardButton.tsx +0 -26
  529. package/react-app-env.d.ts +0 -1
@@ -10,11 +10,11 @@ import {
10
10
  } from '../../stores';
11
11
  import { HiddenUI } from '../../types';
12
12
  import {
13
- SettingCard,
14
- SummaryRowContainer,
15
- SummaryTitleContainer,
16
- SummaryValue,
17
- } from './SettingsCard';
13
+ Card,
14
+ CardRowContainer,
15
+ CardTitleContainer,
16
+ CardValue,
17
+ } from '../../components/Card';
18
18
 
19
19
  export const SendToWalletOptionSetting = () => {
20
20
  const { t } = useTranslation();
@@ -35,14 +35,14 @@ export const SendToWalletOptionSetting = () => {
35
35
  };
36
36
 
37
37
  return (
38
- <SettingCard>
39
- <SummaryRowContainer>
40
- <SummaryTitleContainer>
38
+ <Card>
39
+ <CardRowContainer>
40
+ <CardTitleContainer>
41
41
  <WalletIcon />
42
- <SummaryValue>{t(`settings.sendToWalletOption`)}</SummaryValue>
43
- </SummaryTitleContainer>
42
+ <CardValue>{t(`settings.sendToWalletOption`)}</CardValue>
43
+ </CardTitleContainer>
44
44
  <Switch checked={showDestinationWallet} onChange={onChange} />
45
- </SummaryRowContainer>
46
- </SettingCard>
45
+ </CardRowContainer>
46
+ </Card>
47
47
  );
48
48
  };
@@ -1,6 +1,7 @@
1
1
  import type { PropsWithChildren } from 'react';
2
2
  import type { BadgeProps } from '@mui/material';
3
- import { SummaryValue, Badge } from './SettingCard.style';
3
+ import { CardValue } from '../../../components/Card';
4
+ import { Badge } from './SettingCard.style';
4
5
 
5
6
  interface BadgedValueProps {
6
7
  showBadge: boolean;
@@ -14,8 +15,8 @@ export const BadgedValue: React.FC<PropsWithChildren<BadgedValueProps>> = ({
14
15
  }) =>
15
16
  showBadge && badgeColor ? (
16
17
  <Badge variant="dot" color={badgeColor}>
17
- <SummaryValue>{children}</SummaryValue>
18
+ <CardValue>{children}</CardValue>
18
19
  </Badge>
19
20
  ) : (
20
- <SummaryValue>{children}</SummaryValue>
21
+ <CardValue>{children}</CardValue>
21
22
  );
@@ -1,4 +1,4 @@
1
- import { Box, ButtonBase, Badge as MuiBadge, Typography } from '@mui/material';
1
+ import { Box, Badge as MuiBadge } from '@mui/material';
2
2
  import { badgeClasses } from '@mui/material/Badge';
3
3
  import { styled } from '@mui/material/styles';
4
4
 
@@ -9,39 +9,14 @@ export const SettingsList = styled(Box)(({ theme }) => ({
9
9
  padding: theme.spacing(1, 0, 1),
10
10
  }));
11
11
 
12
- export const SummaryTitleContainer = styled(Box)(({ theme }) => ({
13
- display: 'flex',
14
- alignItems: 'center',
15
- gap: theme.spacing(1.5),
16
- }));
17
-
18
12
  export const SummaryRowContainer = styled(Box)(({ theme }) => ({
19
13
  display: 'flex',
20
14
  width: '100%',
21
15
  justifyContent: 'space-between',
22
16
  alignItems: 'center',
23
- padding: theme.spacing(1),
17
+ padding: theme.spacing(2),
24
18
  }));
25
19
 
26
- export const SummaryRowButton = styled(ButtonBase)(({ theme }) => ({
27
- background: 'none',
28
- color: 'inherit',
29
- border: 'none',
30
- font: 'inherit',
31
- cursor: 'pointer',
32
- outline: 'inherit',
33
- display: 'flex',
34
- width: '100%',
35
- justifyContent: 'space-between',
36
- alignItems: 'center',
37
- padding: theme.spacing(1),
38
- }));
39
-
40
- export const SummaryValue = styled(Typography)({
41
- lineHeight: '1.25',
42
- fontWeight: 500,
43
- });
44
-
45
20
  export const Badge = styled(MuiBadge)(({ theme }) => ({
46
21
  display: 'flex',
47
22
  alignItems: 'center',
@@ -2,12 +2,12 @@ import type { PropsWithChildren, ReactNode } from 'react';
2
2
  import { useId } from 'react';
3
3
  import { Collapse } from '@mui/material';
4
4
  import type { SettingCardTitle } from './types';
5
- import { SettingCard } from './SettingCard';
6
5
  import {
7
- SummaryRowButton,
8
- SummaryValue,
9
- SummaryTitleContainer,
10
- } from './SettingCard.style';
6
+ Card,
7
+ CardRowButton,
8
+ CardValue,
9
+ CardTitleContainer,
10
+ } from '../../../components/Card';
11
11
  import { useSettingsCardExpandable } from './SettingsAccordian';
12
12
 
13
13
  interface SettingCardExpandableProps extends SettingCardTitle {
@@ -22,20 +22,21 @@ export const SettingCardExpandable: React.FC<
22
22
  const collapseId = useId();
23
23
 
24
24
  return (
25
- <SettingCard>
26
- <SummaryRowButton
25
+ <Card sx={{ p: 1 }}>
26
+ <CardRowButton
27
27
  id={buttonId}
28
28
  aria-expanded={expanded}
29
29
  aria-controls={collapseId}
30
30
  onClick={toggleExpanded}
31
31
  disableRipple
32
+ sx={{ p: 1 }}
32
33
  >
33
- <SummaryTitleContainer>
34
+ <CardTitleContainer>
34
35
  {icon}
35
- <SummaryValue>{title}</SummaryValue>
36
- </SummaryTitleContainer>
36
+ <CardValue>{title}</CardValue>
37
+ </CardTitleContainer>
37
38
  {!expanded && value}
38
- </SummaryRowButton>
39
+ </CardRowButton>
39
40
  <Collapse
40
41
  id={collapseId}
41
42
  role="region"
@@ -44,6 +45,6 @@ export const SettingCardExpandable: React.FC<
44
45
  >
45
46
  {children}
46
47
  </Collapse>
47
- </SettingCard>
48
+ </Card>
48
49
  );
49
50
  };
@@ -1,6 +1,4 @@
1
- export * from './SettingCard';
2
1
  export * from './SettingCard.style';
3
- export * from './SettingCardButton';
4
2
  export * from './SettingCardExpandable';
5
3
  export * from './BadgedValue';
6
4
  export * from './SettingsAccordian';
@@ -26,7 +26,7 @@ export const SlippageSettings: React.FC = () => {
26
26
  const { slippage } = useSettings(['slippage']);
27
27
  const setValue = useSettingsStore((state) => state.setValue);
28
28
  const defaultValue = useRef(slippage);
29
- const [focused, setFocused] = useState<'input' | 'button' | undefined>();
29
+ const [focused, setFocused] = useState<'input' | 'button'>();
30
30
 
31
31
  const handleDefaultClick = () => {
32
32
  setValue('slippage', formatSlippage(defaultSlippage, defaultValue.current));
@@ -4,11 +4,12 @@ import NightlightIcon from '@mui/icons-material/Nightlight';
4
4
  import { Tooltip } from '@mui/material';
5
5
  import { useTranslation } from 'react-i18next';
6
6
  import { Tab, Tabs } from '../../components/Tabs';
7
+ import { CardValue } from '../../components/Card';
7
8
  import { useWidgetConfig } from '../../providers';
8
9
  import { useAppearance } from '../../stores';
9
10
  import type { Appearance } from '../../types';
10
11
  import { HiddenUI } from '../../types';
11
- import { SettingCardExpandable, SummaryValue } from './SettingsCard';
12
+ import { SettingCardExpandable } from './SettingsCard';
12
13
 
13
14
  const themeIcons = {
14
15
  light: LightModeIcon,
@@ -55,7 +56,7 @@ export const ThemeSettings: React.FC = () => {
55
56
 
56
57
  return (
57
58
  <SettingCardExpandable
58
- value={<SummaryValue>{t(`button.${appearance}`)} </SummaryValue>}
59
+ value={<CardValue>{t(`button.${appearance}`)} </CardValue>}
59
60
  icon={<ThemeIcon />}
60
61
  title={t('settings.theme')}
61
62
  >
@@ -1,7 +1,7 @@
1
1
  import type { i18n } from 'i18next';
2
2
  import { createInstance } from 'i18next';
3
3
  import { useMemo } from 'react';
4
- import { I18nextProvider, initReactI18next } from 'react-i18next';
4
+ import { I18nextProvider } from 'react-i18next';
5
5
  import * as supportedLanguages from '../../i18n';
6
6
  import { useSettings } from '../../stores';
7
7
  import { deepMerge, isItemAllowed } from '../../utils';
@@ -58,7 +58,7 @@ export const I18nProvider: React.FC<React.PropsWithChildren> = ({
58
58
  returnEmptyString: false,
59
59
  });
60
60
 
61
- i18n.use(initReactI18next).init();
61
+ i18n.init();
62
62
 
63
63
  return i18n;
64
64
  }, [language, languageResources, languages]);
@@ -1,4 +1,5 @@
1
- import { EVM, SDKProvider, Solana, config } from '@lifi/sdk';
1
+ import type { SDKProvider } from '@lifi/sdk';
2
+ import { EVM, Solana, config } from '@lifi/sdk';
2
3
  import type { WalletAdapter } from '@solana/wallet-adapter-base';
3
4
  import { useWallet } from '@solana/wallet-adapter-react';
4
5
  import { getWalletClient, switchChain } from '@wagmi/core';
@@ -5,6 +5,7 @@ import { FormStoreProvider } from './form';
5
5
  import { HeaderStoreProvider } from './header';
6
6
  import { RouteExecutionStoreProvider } from './routes';
7
7
  import { SplitSubvariantStoreProvider } from './settings';
8
+ import { BookmarkStoreProvider } from './bookmarks';
8
9
 
9
10
  export const StoreProvider: React.FC<PropsWithChildren<WidgetConfigProps>> = ({
10
11
  children,
@@ -20,11 +21,13 @@ export const StoreProvider: React.FC<PropsWithChildren<WidgetConfigProps>> = ({
20
21
  >
21
22
  <HeaderStoreProvider namePrefix={config?.keyPrefix}>
22
23
  <FormStoreProvider>
23
- <ChainOrderStoreProvider namePrefix={config?.keyPrefix}>
24
- <RouteExecutionStoreProvider namePrefix={config?.keyPrefix}>
25
- {children}
26
- </RouteExecutionStoreProvider>
27
- </ChainOrderStoreProvider>
24
+ <BookmarkStoreProvider namePrefix={config?.keyPrefix}>
25
+ <ChainOrderStoreProvider namePrefix={config?.keyPrefix}>
26
+ <RouteExecutionStoreProvider namePrefix={config?.keyPrefix}>
27
+ {children}
28
+ </RouteExecutionStoreProvider>
29
+ </ChainOrderStoreProvider>
30
+ </BookmarkStoreProvider>
28
31
  </FormStoreProvider>
29
32
  </HeaderStoreProvider>
30
33
  </SplitSubvariantStoreProvider>
@@ -0,0 +1,39 @@
1
+ import { createContext, useContext, useRef } from 'react';
2
+ import { shallow } from 'zustand/shallow';
3
+ import type { PersistStoreProviderProps } from '../types';
4
+ import { createBookmarksStore } from './createBookmarkStore';
5
+ import type { BookmarkState, BookmarkStore } from './types';
6
+
7
+ export const BookmarkStoreContext = createContext<BookmarkStore | null>(null);
8
+
9
+ export const BookmarkStoreProvider: React.FC<PersistStoreProviderProps> = ({
10
+ children,
11
+ ...props
12
+ }) => {
13
+ const storeRef = useRef<BookmarkStore>();
14
+
15
+ if (!storeRef.current) {
16
+ storeRef.current = createBookmarksStore(props);
17
+ }
18
+
19
+ return (
20
+ <BookmarkStoreContext.Provider value={storeRef.current}>
21
+ {children}
22
+ </BookmarkStoreContext.Provider>
23
+ );
24
+ };
25
+
26
+ export function useBookmarkStore<T>(
27
+ selector: (store: BookmarkState) => T,
28
+ equalityFunction = shallow,
29
+ ) {
30
+ const useStore = useContext(BookmarkStoreContext);
31
+
32
+ if (!useStore) {
33
+ throw new Error(
34
+ `You forgot to wrap your component in <${BookmarkStoreProvider.name}>.`,
35
+ );
36
+ }
37
+
38
+ return useStore(selector, equalityFunction);
39
+ }
@@ -0,0 +1,63 @@
1
+ import type { StateCreator } from 'zustand';
2
+ import { persist } from 'zustand/middleware';
3
+ import { createWithEqualityFn } from 'zustand/traditional';
4
+ import type { PersistStoreProps } from '../types';
5
+ import type { BookmarkState } from './types';
6
+
7
+ const recentWalletsLimit = 5;
8
+
9
+ export const createBookmarksStore = ({ namePrefix }: PersistStoreProps) =>
10
+ createWithEqualityFn<BookmarkState>(
11
+ persist(
12
+ (set, get) => ({
13
+ selectedBookmark: undefined,
14
+ bookmarks: [],
15
+ recentWallets: [],
16
+ getBookmark: (address) =>
17
+ get().bookmarks.find((bookmark) => bookmark.address === address),
18
+ addBookmark: (bookmark) => {
19
+ set((state) => ({
20
+ bookmarks: [bookmark, ...state.bookmarks],
21
+ }));
22
+ },
23
+ removeBookmark: (address) => {
24
+ set((state) => ({
25
+ bookmarks: state.bookmarks.filter(
26
+ (storedBookmark) => storedBookmark.address !== address,
27
+ ),
28
+ }));
29
+ },
30
+ setSelectedBookmark: (bookmark) => {
31
+ set((state) => ({
32
+ selectedBookmark: bookmark,
33
+ }));
34
+ },
35
+ addRecentWallet: (bookmark) => {
36
+ set((state) => ({
37
+ recentWallets: [
38
+ bookmark,
39
+ ...state.recentWallets.filter(
40
+ (recentWallet) => recentWallet.address !== bookmark.address,
41
+ ),
42
+ ].slice(0, recentWalletsLimit),
43
+ }));
44
+ },
45
+ removeRecentWallet: (address) => {
46
+ set((state) => ({
47
+ recentWallets: state.recentWallets.filter(
48
+ (storedRecent) => storedRecent.address !== address,
49
+ ),
50
+ }));
51
+ },
52
+ }),
53
+ {
54
+ name: `${namePrefix || 'li.fi'}-bookmarks`,
55
+ version: 0,
56
+ partialize: (state) => ({
57
+ bookmarks: state.bookmarks,
58
+ recentWallets: state.recentWallets,
59
+ }),
60
+ },
61
+ ) as StateCreator<BookmarkState, [], [], BookmarkState>,
62
+ Object.is,
63
+ );
@@ -0,0 +1,5 @@
1
+ export * from './BookmarkStore';
2
+ export * from './createBookmarkStore';
3
+ export * from './types';
4
+ export * from './useBookmarkActions';
5
+ export * from './useBookmarks';
@@ -0,0 +1,31 @@
1
+ import type { ChainType } from '@lifi/sdk';
2
+ import type { StoreApi } from 'zustand';
3
+ import type { UseBoundStoreWithEqualityFn } from 'zustand/esm/traditional';
4
+
5
+ export interface Bookmark {
6
+ address: string;
7
+ chainType: ChainType;
8
+ name?: string;
9
+ isConnectedAccount?: boolean;
10
+ }
11
+
12
+ export interface BookmarkProps {
13
+ selectedBookmark?: Bookmark;
14
+ bookmarks: Bookmark[];
15
+ recentWallets: Bookmark[];
16
+ }
17
+
18
+ export interface BookmarkActions {
19
+ getBookmark: (address: string) => Bookmark | undefined;
20
+ addBookmark: (bookmark: Bookmark) => void;
21
+ removeBookmark: (address: string) => void;
22
+ setSelectedBookmark: (bookmark?: Bookmark) => void;
23
+ addRecentWallet: (bookmark: Bookmark) => void;
24
+ removeRecentWallet: (address: string) => void;
25
+ }
26
+
27
+ export type BookmarkState = BookmarkProps & BookmarkActions;
28
+
29
+ export type BookmarkStore = UseBoundStoreWithEqualityFn<
30
+ StoreApi<BookmarkState>
31
+ >;
@@ -0,0 +1,19 @@
1
+ import { shallow } from 'zustand/shallow';
2
+ import { useBookmarkStore } from './BookmarkStore';
3
+ import type { BookmarkActions } from './types';
4
+
5
+ export const useBookmarkActions = () => {
6
+ const actions = useBookmarkStore<BookmarkActions>(
7
+ (store) => ({
8
+ getBookmark: store.getBookmark,
9
+ addBookmark: store.addBookmark,
10
+ removeBookmark: store.removeBookmark,
11
+ setSelectedBookmark: store.setSelectedBookmark,
12
+ addRecentWallet: store.addRecentWallet,
13
+ removeRecentWallet: store.removeRecentWallet,
14
+ }),
15
+ shallow,
16
+ );
17
+
18
+ return actions;
19
+ };
@@ -0,0 +1,16 @@
1
+ import { shallow } from 'zustand/shallow';
2
+ import { useBookmarkStore } from './BookmarkStore';
3
+ import type { BookmarkProps } from './types';
4
+
5
+ export const useBookmarks = (): BookmarkProps => {
6
+ const [bookmarks, selectedBookmark, recentWallets] = useBookmarkStore(
7
+ (store) => [store.bookmarks, store.selectedBookmark, store.recentWallets],
8
+ shallow,
9
+ );
10
+
11
+ return {
12
+ bookmarks,
13
+ selectedBookmark,
14
+ recentWallets,
15
+ };
16
+ };
@@ -2,6 +2,7 @@ import type { PropsWithChildren } from 'react';
2
2
  import { createContext, useContext, useMemo, useRef } from 'react';
3
3
  import { shallow } from 'zustand/shallow';
4
4
  import { useWidgetConfig } from '../../providers';
5
+ import { HiddenUI } from '../../types';
5
6
  import { FormUpdater } from './FormUpdater';
6
7
  import { createFormStore, formDefaultValues } from './createFormStore';
7
8
  import type { FormStoreStore, FormValuesState } from './types';
@@ -11,10 +12,19 @@ export const FormStoreContext = createContext<FormStoreStore | null>(null);
11
12
  export const FormStoreProvider: React.FC<PropsWithChildren> = ({
12
13
  children,
13
14
  }) => {
14
- const { fromChain, fromToken, fromAmount, toChain, toToken, toAddress } =
15
- useWidgetConfig();
15
+ const {
16
+ fromChain,
17
+ fromToken,
18
+ fromAmount,
19
+ toChain,
20
+ toToken,
21
+ toAddress,
22
+ hiddenUI,
23
+ } = useWidgetConfig();
16
24
  const storeRef = useRef<FormStoreStore>();
17
25
 
26
+ const hiddenToAddress = hiddenUI?.includes(HiddenUI.ToAddress);
27
+
18
28
  const defaultValues = useMemo(
19
29
  () => ({
20
30
  ...formDefaultValues,
@@ -26,9 +36,20 @@ export const FormStoreProvider: React.FC<PropsWithChildren> = ({
26
36
  (typeof fromAmount === 'number'
27
37
  ? fromAmount?.toPrecision()
28
38
  : fromAmount) || formDefaultValues.fromAmount,
29
- toAddress: toAddress || formDefaultValues.toAddress,
39
+ // Prevent setting address when the field is hidden
40
+ toAddress: hiddenToAddress
41
+ ? formDefaultValues.toAddress
42
+ : toAddress || formDefaultValues.toAddress,
30
43
  }),
31
- [fromAmount, fromChain, fromToken, toAddress, toChain, toToken],
44
+ [
45
+ fromAmount,
46
+ fromChain,
47
+ fromToken,
48
+ hiddenToAddress,
49
+ toAddress,
50
+ toChain,
51
+ toToken,
52
+ ],
32
53
  );
33
54
 
34
55
  if (!storeRef.current) {
@@ -39,9 +39,8 @@ export interface FormValues {
39
39
  }
40
40
 
41
41
  export type FormFieldNames = keyof FormValues;
42
- export type ExtractValueType<T> = T extends FormValueControl<infer U>
43
- ? U
44
- : never;
42
+ export type ExtractValueType<T> =
43
+ T extends FormValueControl<infer U> ? U : never;
45
44
  export type FormFieldArray<T extends FormFieldNames[]> = {
46
45
  [K in keyof T]: ExtractValueType<FormValues[T[K]]>;
47
46
  };
package/stores/index.ts CHANGED
@@ -4,3 +4,4 @@ export * from './header';
4
4
  export * from './routes';
5
5
  export * from './settings';
6
6
  export * from './form';
7
+ export * from './bookmarks';
@@ -0,0 +1,25 @@
1
+ import { ChainId, ChainType } from '@lifi/sdk';
2
+ import { isAddress as isEVMAddress } from 'viem';
3
+ import { isSVMAddress } from './svm';
4
+
5
+ const chainTypeAddressValidation = {
6
+ [ChainType.EVM]: isEVMAddress,
7
+ [ChainType.SVM]: isSVMAddress,
8
+ };
9
+
10
+ export const getChainTypeFromAddress = (
11
+ address: string,
12
+ ): ChainType | undefined => {
13
+ for (const chainType in chainTypeAddressValidation) {
14
+ const isChainType =
15
+ chainTypeAddressValidation[chainType as ChainType](address);
16
+ if (isChainType) {
17
+ return chainType as ChainType;
18
+ }
19
+ }
20
+ };
21
+
22
+ export const defaultChainIdsByType = {
23
+ [ChainType.EVM]: ChainId.ETH,
24
+ [ChainType.SVM]: ChainId.SOL,
25
+ };
package/utils/index.ts CHANGED
@@ -4,6 +4,7 @@ export * from './elements';
4
4
  export * from './enum';
5
5
  export * from './fees';
6
6
  export * from './format';
7
+ export * from './chainType';
7
8
  export * from './input';
8
9
  export * from './item';
9
10
  export * from './navigationRoutes';
@@ -15,6 +15,10 @@ export const navigationRoutes = {
15
15
  transactionDetails: 'transaction-details',
16
16
  transactionExecution: 'transaction-execution',
17
17
  transactionHistory: 'transaction-history',
18
+ sendToWallet: 'send-to-wallet',
19
+ bookmarks: 'bookmarks',
20
+ recentWallets: 'recent-wallets',
21
+ connectedWallets: 'connected-wallets',
18
22
  };
19
23
 
20
24
  export const navigationRoutesValues = Object.values(navigationRoutes);
@@ -33,6 +37,10 @@ export const stickyHeaderRoutes = [
33
37
  navigationRoutes.transactionDetails,
34
38
  navigationRoutes.transactionExecution,
35
39
  navigationRoutes.transactionHistory,
40
+ navigationRoutes.sendToWallet,
41
+ navigationRoutes.bookmarks,
42
+ navigationRoutes.recentWallets,
43
+ navigationRoutes.connectedWallets,
36
44
  ];
37
45
 
38
46
  export const backButtonRoutes = [
@@ -51,6 +59,10 @@ export const backButtonRoutes = [
51
59
  navigationRoutes.transactionDetails,
52
60
  navigationRoutes.transactionExecution,
53
61
  navigationRoutes.transactionHistory,
62
+ navigationRoutes.sendToWallet,
63
+ navigationRoutes.bookmarks,
64
+ navigationRoutes.recentWallets,
65
+ navigationRoutes.connectedWallets,
54
66
  ];
55
67
 
56
68
  export type NavigationRouteType = keyof typeof navigationRoutes;
@@ -1,4 +0,0 @@
1
- /// <reference types="react" />
2
- import type { BoxProps } from '@mui/material';
3
- export declare const SendToWallet: React.FC<BoxProps>;
4
- export declare const SendToWalletFormHelperText: React.FC;