@0xsequence/wallet-widget 0.0.0-20250314205219

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 (514) hide show
  1. package/LICENSE +219 -0
  2. package/README.md +53 -0
  3. package/dist/cjs/components/Alert.js +15 -0
  4. package/dist/cjs/components/Alert.js.map +1 -0
  5. package/dist/cjs/components/CoinRow.js +19 -0
  6. package/dist/cjs/components/CoinRow.js.map +1 -0
  7. package/dist/cjs/components/CollectibleTileImage.js +10 -0
  8. package/dist/cjs/components/CollectibleTileImage.js.map +1 -0
  9. package/dist/cjs/components/CopyButton.js +25 -0
  10. package/dist/cjs/components/CopyButton.js.map +1 -0
  11. package/dist/cjs/components/DefaultIcon.js +13 -0
  12. package/dist/cjs/components/DefaultIcon.js.map +1 -0
  13. package/dist/cjs/components/FeeOptionSelector.js +48 -0
  14. package/dist/cjs/components/FeeOptionSelector.js.map +1 -0
  15. package/dist/cjs/components/InfiniteScroll.js +42 -0
  16. package/dist/cjs/components/InfiniteScroll.js.map +1 -0
  17. package/dist/cjs/components/Loader.js +10 -0
  18. package/dist/cjs/components/Loader.js.map +1 -0
  19. package/dist/cjs/components/NavigationHeader/index.js +26 -0
  20. package/dist/cjs/components/NavigationHeader/index.js.map +1 -0
  21. package/dist/cjs/components/NetworkBadge.js +18 -0
  22. package/dist/cjs/components/NetworkBadge.js.map +1 -0
  23. package/dist/cjs/components/SelectButton/SelectButton.js +12 -0
  24. package/dist/cjs/components/SelectButton/SelectButton.js.map +1 -0
  25. package/dist/cjs/components/SelectButton/SelectedIndicator.js +12 -0
  26. package/dist/cjs/components/SelectButton/SelectedIndicator.js.map +1 -0
  27. package/dist/cjs/components/SelectButton/index.js +6 -0
  28. package/dist/cjs/components/SelectButton/index.js.map +1 -0
  29. package/dist/cjs/components/SendItemInfo.js +21 -0
  30. package/dist/cjs/components/SendItemInfo.js.map +1 -0
  31. package/dist/cjs/components/SequenceWalletProvider/SequenceWalletProvider.js +55 -0
  32. package/dist/cjs/components/SequenceWalletProvider/SequenceWalletProvider.js.map +1 -0
  33. package/dist/cjs/components/SequenceWalletProvider/index.js +18 -0
  34. package/dist/cjs/components/SequenceWalletProvider/index.js.map +1 -0
  35. package/dist/cjs/components/SequenceWalletProvider/utils/index.js +84 -0
  36. package/dist/cjs/components/SequenceWalletProvider/utils/index.js.map +1 -0
  37. package/dist/cjs/components/TransactionConfirmation.js +65 -0
  38. package/dist/cjs/components/TransactionConfirmation.js.map +1 -0
  39. package/dist/cjs/components/TransactionHistoryList/TransactionHistoryItem.js +117 -0
  40. package/dist/cjs/components/TransactionHistoryList/TransactionHistoryItem.js.map +1 -0
  41. package/dist/cjs/components/TransactionHistoryList/TransactionHistorySkeleton.js +17 -0
  42. package/dist/cjs/components/TransactionHistoryList/TransactionHistorySkeleton.js.map +1 -0
  43. package/dist/cjs/components/TransactionHistoryList/index.js +97 -0
  44. package/dist/cjs/components/TransactionHistoryList/index.js.map +1 -0
  45. package/dist/cjs/components/WalletHeader/components/AccountInformation.js +15 -0
  46. package/dist/cjs/components/WalletHeader/components/AccountInformation.js.map +1 -0
  47. package/dist/cjs/components/WalletHeader/components/WalletDropdownContent.js +57 -0
  48. package/dist/cjs/components/WalletHeader/components/WalletDropdownContent.js.map +1 -0
  49. package/dist/cjs/components/WalletHeader/index.js +87 -0
  50. package/dist/cjs/components/WalletHeader/index.js.map +1 -0
  51. package/dist/cjs/constants/abi.js +92 -0
  52. package/dist/cjs/constants/abi.js.map +1 -0
  53. package/dist/cjs/constants/currency.js +29 -0
  54. package/dist/cjs/constants/currency.js.map +1 -0
  55. package/dist/cjs/constants/index.js +20 -0
  56. package/dist/cjs/constants/index.js.map +1 -0
  57. package/dist/cjs/constants/sizing.js +5 -0
  58. package/dist/cjs/constants/sizing.js.map +1 -0
  59. package/dist/cjs/contexts/Navigation.js +8 -0
  60. package/dist/cjs/contexts/Navigation.js.map +1 -0
  61. package/dist/cjs/contexts/WalletModal.js +8 -0
  62. package/dist/cjs/contexts/WalletModal.js.map +1 -0
  63. package/dist/cjs/contexts/genericContext.js +20 -0
  64. package/dist/cjs/contexts/genericContext.js.map +1 -0
  65. package/dist/cjs/contexts/index.js +19 -0
  66. package/dist/cjs/contexts/index.js.map +1 -0
  67. package/dist/cjs/hooks/index.js +20 -0
  68. package/dist/cjs/hooks/index.js.map +1 -0
  69. package/dist/cjs/hooks/useNavigation.js +23 -0
  70. package/dist/cjs/hooks/useNavigation.js.map +1 -0
  71. package/dist/cjs/hooks/useOpenWalletModal.js +10 -0
  72. package/dist/cjs/hooks/useOpenWalletModal.js.map +1 -0
  73. package/dist/cjs/hooks/useScrollbarWidth.js +13 -0
  74. package/dist/cjs/hooks/useScrollbarWidth.js.map +1 -0
  75. package/dist/cjs/hooks/useSettings.js +100 -0
  76. package/dist/cjs/hooks/useSettings.js.map +1 -0
  77. package/dist/cjs/index.js +12 -0
  78. package/dist/cjs/index.js.map +1 -0
  79. package/dist/cjs/utils/helpers.js +49 -0
  80. package/dist/cjs/utils/helpers.js.map +1 -0
  81. package/dist/cjs/utils/index.js +19 -0
  82. package/dist/cjs/utils/index.js.map +1 -0
  83. package/dist/cjs/utils/tokens.js +78 -0
  84. package/dist/cjs/utils/tokens.js.map +1 -0
  85. package/dist/cjs/views/CoinDetails/Skeleton.js +13 -0
  86. package/dist/cjs/views/CoinDetails/Skeleton.js.map +1 -0
  87. package/dist/cjs/views/CoinDetails/index.js +90 -0
  88. package/dist/cjs/views/CoinDetails/index.js.map +1 -0
  89. package/dist/cjs/views/CollectibleDetails/Skeleton.js +14 -0
  90. package/dist/cjs/views/CollectibleDetails/Skeleton.js.map +1 -0
  91. package/dist/cjs/views/CollectibleDetails/index.js +83 -0
  92. package/dist/cjs/views/CollectibleDetails/index.js.map +1 -0
  93. package/dist/cjs/views/CollectionDetails/Skeleton.js +15 -0
  94. package/dist/cjs/views/CollectionDetails/Skeleton.js.map +1 -0
  95. package/dist/cjs/views/CollectionDetails/index.js +50 -0
  96. package/dist/cjs/views/CollectionDetails/index.js.map +1 -0
  97. package/dist/cjs/views/History.js +19 -0
  98. package/dist/cjs/views/History.js.map +1 -0
  99. package/dist/cjs/views/Home/components/AssetSummary/CoinTile/CoinTileContent.js +14 -0
  100. package/dist/cjs/views/Home/components/AssetSummary/CoinTile/CoinTileContent.js.map +1 -0
  101. package/dist/cjs/views/Home/components/AssetSummary/CoinTile/index.js +60 -0
  102. package/dist/cjs/views/Home/components/AssetSummary/CoinTile/index.js.map +1 -0
  103. package/dist/cjs/views/Home/components/AssetSummary/CollectibleTile/index.js +17 -0
  104. package/dist/cjs/views/Home/components/AssetSummary/CollectibleTile/index.js.map +1 -0
  105. package/dist/cjs/views/Home/components/AssetSummary/SkeletonTiles.js +14 -0
  106. package/dist/cjs/views/Home/components/AssetSummary/SkeletonTiles.js.map +1 -0
  107. package/dist/cjs/views/Home/components/AssetSummary/index.js +98 -0
  108. package/dist/cjs/views/Home/components/AssetSummary/index.js.map +1 -0
  109. package/dist/cjs/views/Home/index.js +10 -0
  110. package/dist/cjs/views/Home/index.js.map +1 -0
  111. package/dist/cjs/views/Receive.js +42 -0
  112. package/dist/cjs/views/Receive.js.map +1 -0
  113. package/dist/cjs/views/Search/SearchWallet.js +112 -0
  114. package/dist/cjs/views/Search/SearchWallet.js.map +1 -0
  115. package/dist/cjs/views/Search/SearchWalletViewAll.js +169 -0
  116. package/dist/cjs/views/Search/SearchWalletViewAll.js.map +1 -0
  117. package/dist/cjs/views/Search/components/BalanceItem.js +52 -0
  118. package/dist/cjs/views/Search/components/BalanceItem.js.map +1 -0
  119. package/dist/cjs/views/Search/components/CoinsTab.js +49 -0
  120. package/dist/cjs/views/Search/components/CoinsTab.js.map +1 -0
  121. package/dist/cjs/views/Search/components/CollectionsTab.js +49 -0
  122. package/dist/cjs/views/Search/components/CollectionsTab.js.map +1 -0
  123. package/dist/cjs/views/Search/components/WalletLink.js +15 -0
  124. package/dist/cjs/views/Search/components/WalletLink.js.map +1 -0
  125. package/dist/cjs/views/Search/index.js +19 -0
  126. package/dist/cjs/views/Search/index.js.map +1 -0
  127. package/dist/cjs/views/SendCoin.js +198 -0
  128. package/dist/cjs/views/SendCoin.js.map +1 -0
  129. package/dist/cjs/views/SendCollectible.js +237 -0
  130. package/dist/cjs/views/SendCollectible.js.map +1 -0
  131. package/dist/cjs/views/Settings/Currency.js +16 -0
  132. package/dist/cjs/views/Settings/Currency.js.map +1 -0
  133. package/dist/cjs/views/Settings/General.js +23 -0
  134. package/dist/cjs/views/Settings/General.js.map +1 -0
  135. package/dist/cjs/views/Settings/Menu.js +28 -0
  136. package/dist/cjs/views/Settings/Menu.js.map +1 -0
  137. package/dist/cjs/views/Settings/Network.js +35 -0
  138. package/dist/cjs/views/Settings/Network.js.map +1 -0
  139. package/dist/cjs/views/Settings/index.js +21 -0
  140. package/dist/cjs/views/Settings/index.js.map +1 -0
  141. package/dist/cjs/views/SwapCoin/SwapList.js +190 -0
  142. package/dist/cjs/views/SwapCoin/SwapList.js.map +1 -0
  143. package/dist/cjs/views/SwapCoin/index.js +89 -0
  144. package/dist/cjs/views/SwapCoin/index.js.map +1 -0
  145. package/dist/cjs/views/TransactionDetails/index.js +88 -0
  146. package/dist/cjs/views/TransactionDetails/index.js.map +1 -0
  147. package/dist/cjs/views/index.js +30 -0
  148. package/dist/cjs/views/index.js.map +1 -0
  149. package/dist/esm/components/Alert.js +11 -0
  150. package/dist/esm/components/Alert.js.map +1 -0
  151. package/dist/esm/components/CoinRow.js +14 -0
  152. package/dist/esm/components/CoinRow.js.map +1 -0
  153. package/dist/esm/components/CollectibleTileImage.js +6 -0
  154. package/dist/esm/components/CollectibleTileImage.js.map +1 -0
  155. package/dist/esm/components/CopyButton.js +21 -0
  156. package/dist/esm/components/CopyButton.js.map +1 -0
  157. package/dist/esm/components/DefaultIcon.js +9 -0
  158. package/dist/esm/components/DefaultIcon.js.map +1 -0
  159. package/dist/esm/components/FeeOptionSelector.js +41 -0
  160. package/dist/esm/components/FeeOptionSelector.js.map +1 -0
  161. package/dist/esm/components/InfiniteScroll.js +37 -0
  162. package/dist/esm/components/InfiniteScroll.js.map +1 -0
  163. package/dist/esm/components/Loader.js +6 -0
  164. package/dist/esm/components/Loader.js.map +1 -0
  165. package/dist/esm/components/NavigationHeader/index.js +22 -0
  166. package/dist/esm/components/NavigationHeader/index.js.map +1 -0
  167. package/dist/esm/components/NetworkBadge.js +14 -0
  168. package/dist/esm/components/NetworkBadge.js.map +1 -0
  169. package/dist/esm/components/SelectButton/SelectButton.js +8 -0
  170. package/dist/esm/components/SelectButton/SelectButton.js.map +1 -0
  171. package/dist/esm/components/SelectButton/SelectedIndicator.js +8 -0
  172. package/dist/esm/components/SelectButton/SelectedIndicator.js.map +1 -0
  173. package/dist/esm/components/SelectButton/index.js +2 -0
  174. package/dist/esm/components/SelectButton/index.js.map +1 -0
  175. package/dist/esm/components/SendItemInfo.js +16 -0
  176. package/dist/esm/components/SendItemInfo.js.map +1 -0
  177. package/dist/esm/components/SequenceWalletProvider/SequenceWalletProvider.js +50 -0
  178. package/dist/esm/components/SequenceWalletProvider/SequenceWalletProvider.js.map +1 -0
  179. package/dist/esm/components/SequenceWalletProvider/index.js +2 -0
  180. package/dist/esm/components/SequenceWalletProvider/index.js.map +1 -0
  181. package/dist/esm/components/SequenceWalletProvider/utils/index.js +79 -0
  182. package/dist/esm/components/SequenceWalletProvider/utils/index.js.map +1 -0
  183. package/dist/esm/components/TransactionConfirmation.js +61 -0
  184. package/dist/esm/components/TransactionConfirmation.js.map +1 -0
  185. package/dist/esm/components/TransactionHistoryList/TransactionHistoryItem.js +110 -0
  186. package/dist/esm/components/TransactionHistoryList/TransactionHistoryItem.js.map +1 -0
  187. package/dist/esm/components/TransactionHistoryList/TransactionHistorySkeleton.js +13 -0
  188. package/dist/esm/components/TransactionHistoryList/TransactionHistorySkeleton.js.map +1 -0
  189. package/dist/esm/components/TransactionHistoryList/index.js +93 -0
  190. package/dist/esm/components/TransactionHistoryList/index.js.map +1 -0
  191. package/dist/esm/components/WalletHeader/components/AccountInformation.js +12 -0
  192. package/dist/esm/components/WalletHeader/components/AccountInformation.js.map +1 -0
  193. package/dist/esm/components/WalletHeader/components/WalletDropdownContent.js +54 -0
  194. package/dist/esm/components/WalletHeader/components/WalletDropdownContent.js.map +1 -0
  195. package/dist/esm/components/WalletHeader/index.js +50 -0
  196. package/dist/esm/components/WalletHeader/index.js.map +1 -0
  197. package/dist/esm/constants/abi.js +89 -0
  198. package/dist/esm/constants/abi.js.map +1 -0
  199. package/dist/esm/constants/currency.js +26 -0
  200. package/dist/esm/constants/currency.js.map +1 -0
  201. package/dist/esm/constants/index.js +4 -0
  202. package/dist/esm/constants/index.js.map +1 -0
  203. package/dist/esm/constants/sizing.js +2 -0
  204. package/dist/esm/constants/sizing.js.map +1 -0
  205. package/dist/esm/contexts/Navigation.js +4 -0
  206. package/dist/esm/contexts/Navigation.js.map +1 -0
  207. package/dist/esm/contexts/WalletModal.js +4 -0
  208. package/dist/esm/contexts/WalletModal.js.map +1 -0
  209. package/dist/esm/contexts/genericContext.js +16 -0
  210. package/dist/esm/contexts/genericContext.js.map +1 -0
  211. package/dist/esm/contexts/index.js +3 -0
  212. package/dist/esm/contexts/index.js.map +1 -0
  213. package/dist/esm/hooks/index.js +4 -0
  214. package/dist/esm/hooks/index.js.map +1 -0
  215. package/dist/esm/hooks/useNavigation.js +19 -0
  216. package/dist/esm/hooks/useNavigation.js.map +1 -0
  217. package/dist/esm/hooks/useOpenWalletModal.js +6 -0
  218. package/dist/esm/hooks/useOpenWalletModal.js.map +1 -0
  219. package/dist/esm/hooks/useScrollbarWidth.js +9 -0
  220. package/dist/esm/hooks/useScrollbarWidth.js.map +1 -0
  221. package/dist/esm/hooks/useSettings.js +96 -0
  222. package/dist/esm/hooks/useSettings.js.map +1 -0
  223. package/dist/esm/index.js +6 -0
  224. package/dist/esm/index.js.map +1 -0
  225. package/dist/esm/utils/helpers.js +41 -0
  226. package/dist/esm/utils/helpers.js.map +1 -0
  227. package/dist/esm/utils/index.js +3 -0
  228. package/dist/esm/utils/index.js.map +1 -0
  229. package/dist/esm/utils/tokens.js +70 -0
  230. package/dist/esm/utils/tokens.js.map +1 -0
  231. package/dist/esm/views/CoinDetails/Skeleton.js +9 -0
  232. package/dist/esm/views/CoinDetails/Skeleton.js.map +1 -0
  233. package/dist/esm/views/CoinDetails/index.js +86 -0
  234. package/dist/esm/views/CoinDetails/index.js.map +1 -0
  235. package/dist/esm/views/CollectibleDetails/Skeleton.js +10 -0
  236. package/dist/esm/views/CollectibleDetails/Skeleton.js.map +1 -0
  237. package/dist/esm/views/CollectibleDetails/index.js +79 -0
  238. package/dist/esm/views/CollectibleDetails/index.js.map +1 -0
  239. package/dist/esm/views/CollectionDetails/Skeleton.js +11 -0
  240. package/dist/esm/views/CollectionDetails/Skeleton.js.map +1 -0
  241. package/dist/esm/views/CollectionDetails/index.js +46 -0
  242. package/dist/esm/views/CollectionDetails/index.js.map +1 -0
  243. package/dist/esm/views/History.js +15 -0
  244. package/dist/esm/views/History.js.map +1 -0
  245. package/dist/esm/views/Home/components/AssetSummary/CoinTile/CoinTileContent.js +10 -0
  246. package/dist/esm/views/Home/components/AssetSummary/CoinTile/CoinTileContent.js.map +1 -0
  247. package/dist/esm/views/Home/components/AssetSummary/CoinTile/index.js +56 -0
  248. package/dist/esm/views/Home/components/AssetSummary/CoinTile/index.js.map +1 -0
  249. package/dist/esm/views/Home/components/AssetSummary/CollectibleTile/index.js +13 -0
  250. package/dist/esm/views/Home/components/AssetSummary/CollectibleTile/index.js.map +1 -0
  251. package/dist/esm/views/Home/components/AssetSummary/SkeletonTiles.js +10 -0
  252. package/dist/esm/views/Home/components/AssetSummary/SkeletonTiles.js.map +1 -0
  253. package/dist/esm/views/Home/components/AssetSummary/index.js +94 -0
  254. package/dist/esm/views/Home/components/AssetSummary/index.js.map +1 -0
  255. package/dist/esm/views/Home/index.js +6 -0
  256. package/dist/esm/views/Home/index.js.map +1 -0
  257. package/dist/esm/views/Receive.js +38 -0
  258. package/dist/esm/views/Receive.js.map +1 -0
  259. package/dist/esm/views/Search/SearchWallet.js +105 -0
  260. package/dist/esm/views/Search/SearchWallet.js.map +1 -0
  261. package/dist/esm/views/Search/SearchWalletViewAll.js +162 -0
  262. package/dist/esm/views/Search/SearchWalletViewAll.js.map +1 -0
  263. package/dist/esm/views/Search/components/BalanceItem.js +48 -0
  264. package/dist/esm/views/Search/components/BalanceItem.js.map +1 -0
  265. package/dist/esm/views/Search/components/CoinsTab.js +45 -0
  266. package/dist/esm/views/Search/components/CoinsTab.js.map +1 -0
  267. package/dist/esm/views/Search/components/CollectionsTab.js +45 -0
  268. package/dist/esm/views/Search/components/CollectionsTab.js.map +1 -0
  269. package/dist/esm/views/Search/components/WalletLink.js +11 -0
  270. package/dist/esm/views/Search/components/WalletLink.js.map +1 -0
  271. package/dist/esm/views/Search/index.js +3 -0
  272. package/dist/esm/views/Search/index.js.map +1 -0
  273. package/dist/esm/views/SendCoin.js +194 -0
  274. package/dist/esm/views/SendCoin.js.map +1 -0
  275. package/dist/esm/views/SendCollectible.js +233 -0
  276. package/dist/esm/views/SendCollectible.js.map +1 -0
  277. package/dist/esm/views/Settings/Currency.js +12 -0
  278. package/dist/esm/views/Settings/Currency.js.map +1 -0
  279. package/dist/esm/views/Settings/General.js +19 -0
  280. package/dist/esm/views/Settings/General.js.map +1 -0
  281. package/dist/esm/views/Settings/Menu.js +24 -0
  282. package/dist/esm/views/Settings/Menu.js.map +1 -0
  283. package/dist/esm/views/Settings/Network.js +31 -0
  284. package/dist/esm/views/Settings/Network.js.map +1 -0
  285. package/dist/esm/views/Settings/index.js +5 -0
  286. package/dist/esm/views/Settings/index.js.map +1 -0
  287. package/dist/esm/views/SwapCoin/SwapList.js +186 -0
  288. package/dist/esm/views/SwapCoin/SwapList.js.map +1 -0
  289. package/dist/esm/views/SwapCoin/index.js +85 -0
  290. package/dist/esm/views/SwapCoin/index.js.map +1 -0
  291. package/dist/esm/views/TransactionDetails/index.js +81 -0
  292. package/dist/esm/views/TransactionDetails/index.js.map +1 -0
  293. package/dist/esm/views/index.js +14 -0
  294. package/dist/esm/views/index.js.map +1 -0
  295. package/dist/types/components/Alert.d.ts +12 -0
  296. package/dist/types/components/Alert.d.ts.map +1 -0
  297. package/dist/types/components/CoinRow.d.ts +13 -0
  298. package/dist/types/components/CoinRow.d.ts.map +1 -0
  299. package/dist/types/components/CollectibleTileImage.d.ts +6 -0
  300. package/dist/types/components/CollectibleTileImage.d.ts.map +1 -0
  301. package/dist/types/components/CopyButton.d.ts +10 -0
  302. package/dist/types/components/CopyButton.d.ts.map +1 -0
  303. package/dist/types/components/DefaultIcon.d.ts +6 -0
  304. package/dist/types/components/DefaultIcon.d.ts.map +1 -0
  305. package/dist/types/components/FeeOptionSelector.d.ts +29 -0
  306. package/dist/types/components/FeeOptionSelector.d.ts.map +1 -0
  307. package/dist/types/components/InfiniteScroll.d.ts +9 -0
  308. package/dist/types/components/InfiniteScroll.d.ts.map +1 -0
  309. package/dist/types/components/Loader.d.ts +2 -0
  310. package/dist/types/components/Loader.d.ts.map +1 -0
  311. package/dist/types/components/NavigationHeader/index.d.ts +7 -0
  312. package/dist/types/components/NavigationHeader/index.d.ts.map +1 -0
  313. package/dist/types/components/NetworkBadge.d.ts +6 -0
  314. package/dist/types/components/NetworkBadge.d.ts.map +1 -0
  315. package/dist/types/components/SelectButton/SelectButton.d.ts +13 -0
  316. package/dist/types/components/SelectButton/SelectButton.d.ts.map +1 -0
  317. package/dist/types/components/SelectButton/SelectedIndicator.d.ts +8 -0
  318. package/dist/types/components/SelectButton/SelectedIndicator.d.ts.map +1 -0
  319. package/dist/types/components/SelectButton/index.d.ts +2 -0
  320. package/dist/types/components/SelectButton/index.d.ts.map +1 -0
  321. package/dist/types/components/SendItemInfo.d.ts +15 -0
  322. package/dist/types/components/SendItemInfo.d.ts.map +1 -0
  323. package/dist/types/components/SequenceWalletProvider/SequenceWalletProvider.d.ts +7 -0
  324. package/dist/types/components/SequenceWalletProvider/SequenceWalletProvider.d.ts.map +1 -0
  325. package/dist/types/components/SequenceWalletProvider/index.d.ts +2 -0
  326. package/dist/types/components/SequenceWalletProvider/index.d.ts.map +1 -0
  327. package/dist/types/components/SequenceWalletProvider/utils/index.d.ts +4 -0
  328. package/dist/types/components/SequenceWalletProvider/utils/index.d.ts.map +1 -0
  329. package/dist/types/components/TransactionConfirmation.d.ts +24 -0
  330. package/dist/types/components/TransactionConfirmation.d.ts.map +1 -0
  331. package/dist/types/components/TransactionHistoryList/TransactionHistoryItem.d.ts +7 -0
  332. package/dist/types/components/TransactionHistoryList/TransactionHistoryItem.d.ts.map +1 -0
  333. package/dist/types/components/TransactionHistoryList/TransactionHistorySkeleton.d.ts +2 -0
  334. package/dist/types/components/TransactionHistoryList/TransactionHistorySkeleton.d.ts.map +1 -0
  335. package/dist/types/components/TransactionHistoryList/index.d.ts +9 -0
  336. package/dist/types/components/TransactionHistoryList/index.d.ts.map +1 -0
  337. package/dist/types/components/WalletHeader/components/AccountInformation.d.ts +7 -0
  338. package/dist/types/components/WalletHeader/components/AccountInformation.d.ts.map +1 -0
  339. package/dist/types/components/WalletHeader/components/WalletDropdownContent.d.ts +7 -0
  340. package/dist/types/components/WalletHeader/components/WalletDropdownContent.d.ts.map +1 -0
  341. package/dist/types/components/WalletHeader/index.d.ts +2 -0
  342. package/dist/types/components/WalletHeader/index.d.ts.map +1 -0
  343. package/dist/types/constants/abi.d.ts +40 -0
  344. package/dist/types/constants/abi.d.ts.map +1 -0
  345. package/dist/types/constants/currency.d.ts +11 -0
  346. package/dist/types/constants/currency.d.ts.map +1 -0
  347. package/dist/types/constants/index.d.ts +4 -0
  348. package/dist/types/constants/index.d.ts.map +1 -0
  349. package/dist/types/constants/sizing.d.ts +2 -0
  350. package/dist/types/constants/sizing.d.ts.map +1 -0
  351. package/dist/types/contexts/Navigation.d.ts +88 -0
  352. package/dist/types/contexts/Navigation.d.ts.map +1 -0
  353. package/dist/types/contexts/WalletModal.d.ts +11 -0
  354. package/dist/types/contexts/WalletModal.d.ts.map +1 -0
  355. package/dist/types/contexts/genericContext.d.ts +2 -0
  356. package/dist/types/contexts/genericContext.d.ts.map +1 -0
  357. package/dist/types/contexts/index.d.ts +3 -0
  358. package/dist/types/contexts/index.d.ts.map +1 -0
  359. package/dist/types/hooks/index.d.ts +4 -0
  360. package/dist/types/hooks/index.d.ts.map +1 -0
  361. package/dist/types/hooks/useNavigation.d.ts +10 -0
  362. package/dist/types/hooks/useNavigation.d.ts.map +1 -0
  363. package/dist/types/hooks/useOpenWalletModal.d.ts +5 -0
  364. package/dist/types/hooks/useOpenWalletModal.d.ts.map +1 -0
  365. package/dist/types/hooks/useScrollbarWidth.d.ts +2 -0
  366. package/dist/types/hooks/useScrollbarWidth.d.ts.map +1 -0
  367. package/dist/types/hooks/useSettings.d.ts +14 -0
  368. package/dist/types/hooks/useSettings.d.ts.map +1 -0
  369. package/dist/types/index.d.ts +4 -0
  370. package/dist/types/index.d.ts.map +1 -0
  371. package/dist/types/utils/helpers.d.ts +6 -0
  372. package/dist/types/utils/helpers.d.ts.map +1 -0
  373. package/dist/types/utils/index.d.ts +3 -0
  374. package/dist/types/utils/index.d.ts.map +1 -0
  375. package/dist/types/utils/tokens.d.ts +21 -0
  376. package/dist/types/utils/tokens.d.ts.map +1 -0
  377. package/dist/types/views/CoinDetails/Skeleton.d.ts +7 -0
  378. package/dist/types/views/CoinDetails/Skeleton.d.ts.map +1 -0
  379. package/dist/types/views/CoinDetails/index.d.ts +6 -0
  380. package/dist/types/views/CoinDetails/index.d.ts.map +1 -0
  381. package/dist/types/views/CollectibleDetails/Skeleton.d.ts +6 -0
  382. package/dist/types/views/CollectibleDetails/Skeleton.d.ts.map +1 -0
  383. package/dist/types/views/CollectibleDetails/index.d.ts +7 -0
  384. package/dist/types/views/CollectibleDetails/index.d.ts.map +1 -0
  385. package/dist/types/views/CollectionDetails/Skeleton.d.ts +6 -0
  386. package/dist/types/views/CollectionDetails/Skeleton.d.ts.map +1 -0
  387. package/dist/types/views/CollectionDetails/index.d.ts +7 -0
  388. package/dist/types/views/CollectionDetails/index.d.ts.map +1 -0
  389. package/dist/types/views/History.d.ts +2 -0
  390. package/dist/types/views/History.d.ts.map +1 -0
  391. package/dist/types/views/Home/components/AssetSummary/CoinTile/CoinTileContent.d.ts +12 -0
  392. package/dist/types/views/Home/components/AssetSummary/CoinTile/CoinTileContent.d.ts.map +1 -0
  393. package/dist/types/views/Home/components/AssetSummary/CoinTile/index.d.ts +7 -0
  394. package/dist/types/views/Home/components/AssetSummary/CoinTile/index.d.ts.map +1 -0
  395. package/dist/types/views/Home/components/AssetSummary/CollectibleTile/index.d.ts +7 -0
  396. package/dist/types/views/Home/components/AssetSummary/CollectibleTile/index.d.ts.map +1 -0
  397. package/dist/types/views/Home/components/AssetSummary/SkeletonTiles.d.ts +2 -0
  398. package/dist/types/views/Home/components/AssetSummary/SkeletonTiles.d.ts.map +1 -0
  399. package/dist/types/views/Home/components/AssetSummary/index.d.ts +2 -0
  400. package/dist/types/views/Home/components/AssetSummary/index.d.ts.map +1 -0
  401. package/dist/types/views/Home/index.d.ts +2 -0
  402. package/dist/types/views/Home/index.d.ts.map +1 -0
  403. package/dist/types/views/Receive.d.ts +2 -0
  404. package/dist/types/views/Receive.d.ts.map +1 -0
  405. package/dist/types/views/Search/SearchWallet.d.ts +2 -0
  406. package/dist/types/views/Search/SearchWallet.d.ts.map +1 -0
  407. package/dist/types/views/Search/SearchWalletViewAll.d.ts +10 -0
  408. package/dist/types/views/Search/SearchWalletViewAll.d.ts.map +1 -0
  409. package/dist/types/views/Search/components/BalanceItem.d.ts +7 -0
  410. package/dist/types/views/Search/components/BalanceItem.d.ts.map +1 -0
  411. package/dist/types/views/Search/components/CoinsTab.d.ts +16 -0
  412. package/dist/types/views/Search/components/CoinsTab.d.ts.map +1 -0
  413. package/dist/types/views/Search/components/CollectionsTab.d.ts +16 -0
  414. package/dist/types/views/Search/components/CollectionsTab.d.ts.map +1 -0
  415. package/dist/types/views/Search/components/WalletLink.d.ts +8 -0
  416. package/dist/types/views/Search/components/WalletLink.d.ts.map +1 -0
  417. package/dist/types/views/Search/index.d.ts +3 -0
  418. package/dist/types/views/Search/index.d.ts.map +1 -0
  419. package/dist/types/views/SendCoin.d.ts +7 -0
  420. package/dist/types/views/SendCoin.d.ts.map +1 -0
  421. package/dist/types/views/SendCollectible.d.ts +8 -0
  422. package/dist/types/views/SendCollectible.d.ts.map +1 -0
  423. package/dist/types/views/Settings/Currency.d.ts +2 -0
  424. package/dist/types/views/Settings/Currency.d.ts.map +1 -0
  425. package/dist/types/views/Settings/General.d.ts +2 -0
  426. package/dist/types/views/Settings/General.d.ts.map +1 -0
  427. package/dist/types/views/Settings/Menu.d.ts +2 -0
  428. package/dist/types/views/Settings/Menu.d.ts.map +1 -0
  429. package/dist/types/views/Settings/Network.d.ts +2 -0
  430. package/dist/types/views/Settings/Network.d.ts.map +1 -0
  431. package/dist/types/views/Settings/index.d.ts +5 -0
  432. package/dist/types/views/Settings/index.d.ts.map +1 -0
  433. package/dist/types/views/SwapCoin/SwapList.d.ts +8 -0
  434. package/dist/types/views/SwapCoin/SwapList.d.ts.map +1 -0
  435. package/dist/types/views/SwapCoin/index.d.ts +6 -0
  436. package/dist/types/views/SwapCoin/index.d.ts.map +1 -0
  437. package/dist/types/views/TransactionDetails/index.d.ts +7 -0
  438. package/dist/types/views/TransactionDetails/index.d.ts.map +1 -0
  439. package/dist/types/views/index.d.ts +14 -0
  440. package/dist/types/views/index.d.ts.map +1 -0
  441. package/package.json +69 -0
  442. package/src/components/Alert.tsx +51 -0
  443. package/src/components/CoinRow.tsx +62 -0
  444. package/src/components/CollectibleTileImage.tsx +14 -0
  445. package/src/components/CopyButton.tsx +41 -0
  446. package/src/components/DefaultIcon.tsx +22 -0
  447. package/src/components/FeeOptionSelector.tsx +133 -0
  448. package/src/components/InfiniteScroll.tsx +56 -0
  449. package/src/components/Loader.tsx +12 -0
  450. package/src/components/NavigationHeader/index.tsx +59 -0
  451. package/src/components/NetworkBadge.tsx +35 -0
  452. package/src/components/SelectButton/SelectButton.tsx +33 -0
  453. package/src/components/SelectButton/SelectedIndicator.tsx +34 -0
  454. package/src/components/SelectButton/index.ts +1 -0
  455. package/src/components/SendItemInfo.tsx +83 -0
  456. package/src/components/SequenceWalletProvider/SequenceWalletProvider.tsx +96 -0
  457. package/src/components/SequenceWalletProvider/index.ts +1 -0
  458. package/src/components/SequenceWalletProvider/utils/index.tsx +119 -0
  459. package/src/components/TransactionConfirmation.tsx +183 -0
  460. package/src/components/TransactionHistoryList/TransactionHistoryItem.tsx +190 -0
  461. package/src/components/TransactionHistoryList/TransactionHistorySkeleton.tsx +36 -0
  462. package/src/components/TransactionHistoryList/index.tsx +160 -0
  463. package/src/components/WalletHeader/components/AccountInformation.tsx +31 -0
  464. package/src/components/WalletHeader/components/WalletDropdownContent.tsx +96 -0
  465. package/src/components/WalletHeader/index.tsx +84 -0
  466. package/src/constants/abi.ts +90 -0
  467. package/src/constants/currency.ts +35 -0
  468. package/src/constants/index.ts +3 -0
  469. package/src/constants/sizing.ts +1 -0
  470. package/src/contexts/Navigation.ts +132 -0
  471. package/src/contexts/WalletModal.ts +15 -0
  472. package/src/contexts/genericContext.ts +19 -0
  473. package/src/contexts/index.ts +2 -0
  474. package/src/hooks/index.ts +3 -0
  475. package/src/hooks/useNavigation.ts +30 -0
  476. package/src/hooks/useOpenWalletModal.ts +7 -0
  477. package/src/hooks/useScrollbarWidth.ts +11 -0
  478. package/src/hooks/useSettings.ts +121 -0
  479. package/src/index.ts +6 -0
  480. package/src/utils/helpers.ts +51 -0
  481. package/src/utils/index.ts +2 -0
  482. package/src/utils/tokens.ts +98 -0
  483. package/src/views/CoinDetails/Skeleton.tsx +46 -0
  484. package/src/views/CoinDetails/index.tsx +153 -0
  485. package/src/views/CollectibleDetails/Skeleton.tsx +50 -0
  486. package/src/views/CollectibleDetails/index.tsx +184 -0
  487. package/src/views/CollectionDetails/Skeleton.tsx +36 -0
  488. package/src/views/CollectionDetails/index.tsx +98 -0
  489. package/src/views/History.tsx +28 -0
  490. package/src/views/Home/components/AssetSummary/CoinTile/CoinTileContent.tsx +60 -0
  491. package/src/views/Home/components/AssetSummary/CoinTile/index.tsx +93 -0
  492. package/src/views/Home/components/AssetSummary/CollectibleTile/index.tsx +20 -0
  493. package/src/views/Home/components/AssetSummary/SkeletonTiles.tsx +21 -0
  494. package/src/views/Home/components/AssetSummary/index.tsx +128 -0
  495. package/src/views/Home/index.tsx +11 -0
  496. package/src/views/Receive.tsx +83 -0
  497. package/src/views/Search/SearchWallet.tsx +177 -0
  498. package/src/views/Search/SearchWalletViewAll.tsx +265 -0
  499. package/src/views/Search/components/BalanceItem.tsx +76 -0
  500. package/src/views/Search/components/CoinsTab.tsx +89 -0
  501. package/src/views/Search/components/CollectionsTab.tsx +88 -0
  502. package/src/views/Search/components/WalletLink.tsx +32 -0
  503. package/src/views/Search/index.ts +2 -0
  504. package/src/views/SendCoin.tsx +397 -0
  505. package/src/views/SendCollectible.tsx +447 -0
  506. package/src/views/Settings/Currency.tsx +34 -0
  507. package/src/views/Settings/General.tsx +55 -0
  508. package/src/views/Settings/Menu.tsx +60 -0
  509. package/src/views/Settings/Network.tsx +60 -0
  510. package/src/views/Settings/index.ts +4 -0
  511. package/src/views/SwapCoin/SwapList.tsx +320 -0
  512. package/src/views/SwapCoin/index.tsx +150 -0
  513. package/src/views/TransactionDetails/index.tsx +213 -0
  514. package/src/views/index.ts +13 -0
@@ -0,0 +1,8 @@
1
+ interface SendCollectibleProps {
2
+ chainId: number;
3
+ contractAddress: string;
4
+ tokenId: string;
5
+ }
6
+ export declare const SendCollectible: ({ chainId, contractAddress, tokenId }: SendCollectibleProps) => import("react/jsx-runtime").JSX.Element | null;
7
+ export {};
8
+ //# sourceMappingURL=SendCollectible.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SendCollectible.d.ts","sourceRoot":"","sources":["../../../src/views/SendCollectible.tsx"],"names":[],"mappings":"AAmCA,UAAU,oBAAoB;IAC5B,OAAO,EAAE,MAAM,CAAA;IACf,eAAe,EAAE,MAAM,CAAA;IACvB,OAAO,EAAE,MAAM,CAAA;CAChB;AAED,eAAO,MAAM,eAAe,GAAI,uCAAuC,oBAAoB,mDAqZ1F,CAAA"}
@@ -0,0 +1,2 @@
1
+ export declare const SettingsCurrency: () => import("react/jsx-runtime").JSX.Element;
2
+ //# sourceMappingURL=Currency.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Currency.d.ts","sourceRoot":"","sources":["../../../../src/views/Settings/Currency.tsx"],"names":[],"mappings":"AAOA,eAAO,MAAM,gBAAgB,+CA0B5B,CAAA"}
@@ -0,0 +1,2 @@
1
+ export declare const SettingsGeneral: () => import("react/jsx-runtime").JSX.Element;
2
+ //# sourceMappingURL=General.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"General.d.ts","sourceRoot":"","sources":["../../../../src/views/Settings/General.tsx"],"names":[],"mappings":"AAOA,eAAO,MAAM,eAAe,+CA+C3B,CAAA"}
@@ -0,0 +1,2 @@
1
+ export declare const SettingsMenu: () => import("react/jsx-runtime").JSX.Element;
2
+ //# sourceMappingURL=Menu.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Menu.d.ts","sourceRoot":"","sources":["../../../../src/views/Settings/Menu.tsx"],"names":[],"mappings":"AAMA,eAAO,MAAM,YAAY,+CAqDxB,CAAA"}
@@ -0,0 +1,2 @@
1
+ export declare const SettingsNetwork: () => import("react/jsx-runtime").JSX.Element;
2
+ //# sourceMappingURL=Network.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Network.d.ts","sourceRoot":"","sources":["../../../../src/views/Settings/Network.tsx"],"names":[],"mappings":"AASA,eAAO,MAAM,eAAe,+CAkD3B,CAAA"}
@@ -0,0 +1,5 @@
1
+ export * from './Menu';
2
+ export * from './General';
3
+ export * from './Currency';
4
+ export * from './Network';
5
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/views/Settings/index.ts"],"names":[],"mappings":"AAAA,cAAc,QAAQ,CAAA;AACtB,cAAc,WAAW,CAAA;AACzB,cAAc,YAAY,CAAA;AAC1B,cAAc,WAAW,CAAA"}
@@ -0,0 +1,8 @@
1
+ interface SwapListProps {
2
+ chainId: number;
3
+ contractAddress: string;
4
+ amount: string;
5
+ }
6
+ export declare const SwapList: ({ chainId, contractAddress, amount }: SwapListProps) => import("react/jsx-runtime").JSX.Element;
7
+ export {};
8
+ //# sourceMappingURL=SwapList.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SwapList.d.ts","sourceRoot":"","sources":["../../../../src/views/SwapCoin/SwapList.tsx"],"names":[],"mappings":"AAuBA,UAAU,aAAa;IACrB,OAAO,EAAE,MAAM,CAAA;IACf,eAAe,EAAE,MAAM,CAAA;IACvB,MAAM,EAAE,MAAM,CAAA;CACf;AAED,eAAO,MAAM,QAAQ,GAAI,sCAAsC,aAAa,4CAkS3E,CAAA"}
@@ -0,0 +1,6 @@
1
+ export interface SwapCoinProps {
2
+ contractAddress: string;
3
+ chainId: number;
4
+ }
5
+ export declare const SwapCoin: ({ contractAddress, chainId }: SwapCoinProps) => import("react/jsx-runtime").JSX.Element | null;
6
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/views/SwapCoin/index.tsx"],"names":[],"mappings":"AAaA,MAAM,WAAW,aAAa;IAC5B,eAAe,EAAE,MAAM,CAAA;IACvB,OAAO,EAAE,MAAM,CAAA;CAChB;AAED,eAAO,MAAM,QAAQ,GAAI,8BAA8B,aAAa,mDAmInE,CAAA"}
@@ -0,0 +1,7 @@
1
+ import { Transaction } from '@0xsequence/indexer';
2
+ interface TransactionDetailProps {
3
+ transaction: Transaction;
4
+ }
5
+ export declare const TransactionDetails: ({ transaction }: TransactionDetailProps) => import("react/jsx-runtime").JSX.Element;
6
+ export {};
7
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/views/TransactionDetails/index.tsx"],"names":[],"mappings":"AAaA,OAAO,EAAE,WAAW,EAAe,MAAM,qBAAqB,CAAA;AAU9D,UAAU,sBAAsB;IAC9B,WAAW,EAAE,WAAW,CAAA;CACzB;AAED,eAAO,MAAM,kBAAkB,GAAI,iBAAiB,sBAAsB,4CAyLzE,CAAA"}
@@ -0,0 +1,14 @@
1
+ export * from './Home';
2
+ export * from './Receive';
3
+ export * from './SendCoin';
4
+ export * from './SendCollectible';
5
+ export * from './History';
6
+ export * from './Search';
7
+ export * from './Settings';
8
+ export * from './CoinDetails';
9
+ export * from './CollectionDetails';
10
+ export * from './CollectibleDetails';
11
+ export * from './TransactionDetails';
12
+ export * from './SwapCoin';
13
+ export * from './SwapCoin/SwapList';
14
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/views/index.ts"],"names":[],"mappings":"AAAA,cAAc,QAAQ,CAAA;AACtB,cAAc,WAAW,CAAA;AACzB,cAAc,YAAY,CAAA;AAC1B,cAAc,mBAAmB,CAAA;AACjC,cAAc,WAAW,CAAA;AACzB,cAAc,UAAU,CAAA;AACxB,cAAc,YAAY,CAAA;AAC1B,cAAc,eAAe,CAAA;AAC7B,cAAc,qBAAqB,CAAA;AACnC,cAAc,sBAAsB,CAAA;AACpC,cAAc,sBAAsB,CAAA;AACpC,cAAc,YAAY,CAAA;AAC1B,cAAc,qBAAqB,CAAA"}
package/package.json ADDED
@@ -0,0 +1,69 @@
1
+ {
2
+ "name": "@0xsequence/wallet-widget",
3
+ "version": "0.0.0-20250314205219",
4
+ "description": "Wallet UI for Sequence Web SDK",
5
+ "repository": "https://github.com/0xsequence/web-sdk/tree/master/packages/wallet-widget",
6
+ "author": "Horizon Blockchain Games",
7
+ "license": "Apache-2.0",
8
+ "main": "dist/cjs/index.js",
9
+ "module": "dist/esm/index.js",
10
+ "types": "dist/types/index.d.ts",
11
+ "exports": {
12
+ ".": {
13
+ "types": "./dist/types/index.d.ts",
14
+ "require": "./dist/cjs/index.js",
15
+ "import": "./dist/esm/index.js",
16
+ "default": "./dist/esm/index.js"
17
+ }
18
+ },
19
+ "files": [
20
+ "src",
21
+ "dist"
22
+ ],
23
+ "dependencies": {
24
+ "@radix-ui/react-popover": "^1.0.7",
25
+ "dayjs": "^1.11.11",
26
+ "fuse.js": "^6.6.2",
27
+ "qrcode.react": "^4.0.1",
28
+ "react-copy-to-clipboard": "^5.1.0"
29
+ },
30
+ "peerDependencies": {
31
+ "@0xsequence/api": ">= 2.2.13",
32
+ "@0xsequence/design-system": ">= 2.0.4",
33
+ "@0xsequence/indexer": ">= 2.2.13",
34
+ "@0xsequence/metadata": ">= 2.2.13",
35
+ "@0xsequence/network": ">= 2.2.13",
36
+ "@tanstack/react-query": ">= 5",
37
+ "ethers": ">= 6.13.0",
38
+ "motion": ">= 12",
39
+ "react": ">= 17",
40
+ "react-dom": ">= 17",
41
+ "viem": ">= 2.0.0",
42
+ "wagmi": ">= ^2.14.13",
43
+ "@0xsequence/react-hooks": "0.0.0-20250314205219",
44
+ "@0xsequence/connect": "0.0.0-20250314205219"
45
+ },
46
+ "devDependencies": {
47
+ "@0xsequence/design-system": "^2.0.9",
48
+ "@tanstack/react-query": "^5.62.0",
49
+ "@types/react-copy-to-clipboard": "^5.0.7",
50
+ "ethers": "^6.13.0",
51
+ "motion": "^12.3.1",
52
+ "react": "^19.0.0",
53
+ "react-dom": "^19.0.0",
54
+ "viem": "^2.23.10",
55
+ "wagmi": "^2.14.13",
56
+ "@0xsequence/connect": "0.0.0-20250314205219",
57
+ "@0xsequence/react-hooks": "0.0.0-20250314205219"
58
+ },
59
+ "scripts": {
60
+ "build": "pnpm build:clean && pnpm build:esm && pnpm build:cjs && pnpm build:types",
61
+ "build:cjs": "tsc --module commonjs --outDir dist/cjs/",
62
+ "build:esm": "tsc --module es2022 --outDir dist/esm/",
63
+ "build:types": "tsc --declaration --declarationMap --emitDeclarationOnly --declarationDir dist/types/",
64
+ "build:clean": "rimraf -g ./dist",
65
+ "dev": "tsc --watch --module es2022 --declaration --declarationMap --outDir dist/esm/ --declarationDir dist/types/",
66
+ "test": "echo",
67
+ "typecheck": "tsc --noEmit"
68
+ }
69
+ }
@@ -0,0 +1,51 @@
1
+ import { Button, cn, Text } from '@0xsequence/design-system'
2
+ import React, { ComponentProps } from 'react'
3
+
4
+ export type AlertProps = {
5
+ title: string
6
+ description: string
7
+ secondaryDescription?: string
8
+ variant: 'negative' | 'warning' | 'positive'
9
+ buttonProps?: ComponentProps<typeof Button>
10
+ children?: React.ReactNode
11
+ }
12
+
13
+ const variants = {
14
+ negative: 'bg-negative',
15
+ warning: 'bg-warning',
16
+ positive: 'bg-positive'
17
+ }
18
+
19
+ export const Alert = ({ title, description, secondaryDescription, variant, buttonProps, children }: AlertProps) => {
20
+ return (
21
+ <div className={cn('rounded-xl', variants[variant])}>
22
+ <div className="flex bg-background-overlay rounded-xl py-4 w-full flex-col gap-3">
23
+ <div className="flex w-full gap-2 justify-between">
24
+ <div className="flex flex-col gap-1">
25
+ <Text variant="normal" color="primary" fontWeight="medium">
26
+ {title}
27
+ </Text>
28
+
29
+ <Text variant="normal" color="muted" fontWeight="medium">
30
+ {description}
31
+ </Text>
32
+
33
+ {secondaryDescription && (
34
+ <Text variant="normal" color="secondary" fontWeight="medium">
35
+ {secondaryDescription}
36
+ </Text>
37
+ )}
38
+ </div>
39
+
40
+ {buttonProps ? (
41
+ <div className="rounded-lg w-min h-min">
42
+ <Button className="shrink-0" variant="emphasis" shape="square" {...buttonProps} />
43
+ </div>
44
+ ) : null}
45
+ </div>
46
+
47
+ {children}
48
+ </div>
49
+ </div>
50
+ )
51
+ }
@@ -0,0 +1,62 @@
1
+ import { formatDisplay } from '@0xsequence/connect'
2
+ import { Skeleton, Text, TokenImage } from '@0xsequence/design-system'
3
+ import React from 'react'
4
+ import { formatUnits } from 'viem'
5
+
6
+ import { getPercentageColor } from '../utils'
7
+
8
+ interface CoinRowProps {
9
+ name: string
10
+ symbol: string
11
+ decimals: number
12
+ balance: string
13
+ imageUrl?: string
14
+ fiatValue: string
15
+ priceChangePercentage: number
16
+ }
17
+
18
+ export const CoinRowSkeleton = () => {
19
+ return (
20
+ <div className="flex h-14 items-center justify-between bg-background-secondary rounded-xl py-2 px-3">
21
+ <div className="flex justify-center items-center gap-2">
22
+ <Skeleton className="rounded-full" style={{ width: 30, height: 30 }} />
23
+ <div className="flex flex-col gap-2 items-start">
24
+ <Skeleton style={{ width: 100, height: 14 }} />
25
+ <Skeleton style={{ width: 75, height: 14 }} />
26
+ </div>
27
+ </div>
28
+ <div className="flex flex-col gap-2 items-end">
29
+ <Skeleton style={{ width: 100, height: 14 }} />
30
+ <Skeleton style={{ width: 50, height: 12 }} />
31
+ </div>
32
+ </div>
33
+ )
34
+ }
35
+
36
+ export const CoinRow = ({ imageUrl, name, decimals, balance, symbol, fiatValue, priceChangePercentage }: CoinRowProps) => {
37
+ const formattedBalance = formatUnits(BigInt(balance), decimals)
38
+ const balanceDisplayed = formatDisplay(formattedBalance)
39
+
40
+ return (
41
+ <div className="flex h-14 items-center justify-between bg-background-secondary rounded-xl py-2 px-3">
42
+ <div className="flex justify-center items-center gap-2">
43
+ <TokenImage src={imageUrl} symbol={symbol} size="lg" />
44
+ <div className="flex flex-col items-start">
45
+ <Text variant="medium" color="primary">
46
+ {name}
47
+ </Text>
48
+ <Text color="muted" variant="normal">
49
+ {' '}
50
+ {`${balanceDisplayed} ${symbol}`}
51
+ </Text>
52
+ </div>
53
+ </div>
54
+ <div className="flex flex-col items-end">
55
+ <Text variant="normal" color="primary">{`$${fiatValue}`}</Text>
56
+ <Text variant="small" color={getPercentageColor(priceChangePercentage)}>
57
+ {priceChangePercentage.toFixed(2)}%
58
+ </Text>
59
+ </div>
60
+ </div>
61
+ )
62
+ }
@@ -0,0 +1,14 @@
1
+ import { Card, Image } from '@0xsequence/design-system'
2
+ import React from 'react'
3
+
4
+ interface CollectibleTileImageProps {
5
+ imageUrl?: string
6
+ }
7
+
8
+ export const CollectibleTileImage = ({ imageUrl }: CollectibleTileImageProps) => {
9
+ return (
10
+ <Card className="flex p-0 aspect-square justify-center items-center overflow-hidden rounded-lg bg-background-secondary">
11
+ <Image style={{ height: '100%' }} src={imageUrl} />
12
+ </Card>
13
+ )
14
+ }
@@ -0,0 +1,41 @@
1
+ import { Button, CopyIcon, CheckmarkIcon } from '@0xsequence/design-system'
2
+ import React, { useEffect, useState, ComponentProps } from 'react'
3
+ import { CopyToClipboard } from 'react-copy-to-clipboard'
4
+
5
+ type ButtonProps = ComponentProps<typeof Button>
6
+
7
+ interface CopyButtonProps extends ButtonProps {
8
+ text: string
9
+ buttonVariant: 'icon' | 'with-label'
10
+ }
11
+
12
+ export const CopyButton = (props: CopyButtonProps) => {
13
+ const { buttonVariant = 'icon', text, size = 'xs', ...rest } = props
14
+ const [isCopied, setCopy] = useState(false)
15
+
16
+ useEffect(() => {
17
+ if (isCopied) {
18
+ setTimeout(() => {
19
+ setCopy(false)
20
+ }, 4000)
21
+ }
22
+ }, [isCopied])
23
+
24
+ const handleCopy = () => {
25
+ setCopy(true)
26
+ }
27
+
28
+ const label = isCopied ? 'Copied!' : 'Copy'
29
+
30
+ return (
31
+ <CopyToClipboard text={text} onCopy={handleCopy}>
32
+ <Button
33
+ size={size!}
34
+ leftIcon={isCopied ? CheckmarkIcon : CopyIcon}
35
+ label={buttonVariant === 'with-label' ? label : undefined}
36
+ variant={buttonVariant === 'icon' ? 'ghost' : 'glass'}
37
+ {...rest}
38
+ />
39
+ </CopyToClipboard>
40
+ )
41
+ }
@@ -0,0 +1,22 @@
1
+ import { Text } from '@0xsequence/design-system'
2
+ import React from 'react'
3
+
4
+ interface DefaultIconProps {
5
+ size?: number
6
+ }
7
+
8
+ export const DefaultIcon = ({ size = 30 }: DefaultIconProps) => {
9
+ return (
10
+ <div
11
+ className="flex items-center justify-center rounded-full bg-background-inverse shrink-0"
12
+ style={{
13
+ width: `${size}px`,
14
+ height: `${size}px`
15
+ }}
16
+ >
17
+ <Text variant="large" color="inverse">
18
+ ?
19
+ </Text>
20
+ </div>
21
+ )
22
+ }
@@ -0,0 +1,133 @@
1
+ import { cn, Text, TokenImage } from '@0xsequence/design-system'
2
+ import React from 'react'
3
+ import { formatUnits, parseUnits, zeroAddress } from 'viem'
4
+
5
+ import { Alert, AlertProps } from './Alert'
6
+
7
+ export interface FeeOption {
8
+ token: FeeToken
9
+ to: string
10
+ value: string
11
+ gasLimit: number
12
+ }
13
+ export interface FeeToken {
14
+ chainId: number
15
+ name: string
16
+ symbol: string
17
+ decimals?: number
18
+ logoURL: string
19
+ contractAddress?: string
20
+ tokenID?: string
21
+ }
22
+
23
+ export interface FeeOptionBalance {
24
+ tokenName: string
25
+ decimals: number
26
+ balance: string
27
+ }
28
+
29
+ export interface FeeOptionSelectorProps {
30
+ txnFeeOptions: FeeOption[]
31
+ feeOptionBalances: FeeOptionBalance[]
32
+ selectedFeeOptionAddress: string | undefined
33
+ setSelectedFeeOptionAddress: (address: string) => void
34
+ }
35
+
36
+ const isBalanceSufficient = (balance: string, fee: string, decimals: number) => {
37
+ const balanceBN = parseUnits(balance, decimals)
38
+ const feeBN = parseUnits(fee, decimals)
39
+ return balanceBN >= feeBN
40
+ }
41
+
42
+ export const FeeOptionSelector: React.FC<FeeOptionSelectorProps> = ({
43
+ txnFeeOptions,
44
+ feeOptionBalances,
45
+ selectedFeeOptionAddress,
46
+ setSelectedFeeOptionAddress
47
+ }) => {
48
+ const [feeOptionAlert, setFeeOptionAlert] = React.useState<AlertProps | undefined>()
49
+
50
+ const sortedOptions = [...txnFeeOptions].sort((a, b) => {
51
+ const balanceA = feeOptionBalances.find(balance => balance.tokenName === a.token.name)
52
+ const balanceB = feeOptionBalances.find(balance => balance.tokenName === b.token.name)
53
+ const isSufficientA = balanceA ? isBalanceSufficient(balanceA.balance, a.value, a.token.decimals || 0) : false
54
+ const isSufficientB = balanceB ? isBalanceSufficient(balanceB.balance, b.value, b.token.decimals || 0) : false
55
+ return isSufficientA === isSufficientB ? 0 : isSufficientA ? -1 : 1
56
+ })
57
+
58
+ return (
59
+ <div className="mt-3 w-full">
60
+ <Text variant="normal" color="primary" fontWeight="bold">
61
+ Select a fee option
62
+ </Text>
63
+ <div className="flex flex-col mt-2 gap-2">
64
+ {sortedOptions.map((option, index) => {
65
+ const isSelected = selectedFeeOptionAddress === (option.token.contractAddress ?? zeroAddress)
66
+ const balance = feeOptionBalances.find(b => b.tokenName === option.token.name)
67
+ const isSufficient = isBalanceSufficient(balance?.balance || '0', option.value, option.token.decimals || 0)
68
+ return (
69
+ <div
70
+ className={cn(
71
+ 'px-3 py-2 rounded-xl border-2 border-solid bg-background-raised',
72
+ isSelected ? 'border-border-focus' : 'border-transparent'
73
+ )}
74
+ key={index}
75
+ onClick={() => {
76
+ if (isSufficient) {
77
+ setSelectedFeeOptionAddress(option.token.contractAddress ?? zeroAddress)
78
+ setFeeOptionAlert(undefined)
79
+ } else {
80
+ setFeeOptionAlert({
81
+ title: `Insufficient ${option.token.name} balance`,
82
+ description: `Please select another fee option or add funds to your wallet.`,
83
+ variant: 'warning'
84
+ })
85
+ }
86
+ }}
87
+ >
88
+ <div className="flex flex-row justify-between items-center">
89
+ <div className="flex flex-row items-center gap-2">
90
+ <TokenImage src={option.token.logoURL} symbol={option.token.name} />
91
+ <div className="flex flex-col">
92
+ <Text variant="small" color="primary" fontWeight="bold">
93
+ {option.token.name}
94
+ </Text>
95
+ <Text variant="xsmall" color="secondary">
96
+ Fee:{' '}
97
+ {parseFloat(formatUnits(BigInt(option.value), option.token.decimals || 0)).toLocaleString(undefined, {
98
+ maximumFractionDigits: 6
99
+ })}
100
+ </Text>
101
+ </div>
102
+ </div>
103
+ <div className="flex flex-col items-end">
104
+ <Text variant="xsmall" color="secondary">
105
+ Balance:
106
+ </Text>
107
+ <Text variant="xsmall" color="primary">
108
+ {parseFloat(formatUnits(BigInt(balance?.balance || '0'), option.token.decimals || 0)).toLocaleString(
109
+ undefined,
110
+ { maximumFractionDigits: 6 }
111
+ )}
112
+ </Text>
113
+ </div>
114
+ </div>
115
+ </div>
116
+ )
117
+ })}
118
+ </div>
119
+ <div className="flex mt-3 items-end justify-center flex-col">
120
+ {feeOptionAlert && (
121
+ <div className="mt-3">
122
+ <Alert
123
+ title={feeOptionAlert.title}
124
+ description={feeOptionAlert.description}
125
+ secondaryDescription={feeOptionAlert.secondaryDescription}
126
+ variant={feeOptionAlert.variant}
127
+ />
128
+ </div>
129
+ )}
130
+ </div>
131
+ </div>
132
+ )
133
+ }
@@ -0,0 +1,56 @@
1
+ import React, { RefObject, PropsWithChildren, useEffect, useRef, useState, useMemo } from 'react'
2
+
3
+ export const useIntersectionObserver = (ref: RefObject<Element | null>, options?: IntersectionObserverInit) => {
4
+ const [entry, setEntry] = useState<IntersectionObserverEntry | null>(null)
5
+ const observer = useMemo(() => new IntersectionObserver(([entry]) => setEntry(entry), options), [])
6
+
7
+ useEffect(() => {
8
+ if (ref.current) {
9
+ observer.observe(ref.current)
10
+ }
11
+
12
+ return () => {
13
+ if (ref.current) {
14
+ observer.disconnect()
15
+ }
16
+ }
17
+ }, [ref.current, observer])
18
+
19
+ return entry?.isIntersecting ?? false
20
+ }
21
+
22
+ interface InfiniteScrollProps {
23
+ onLoad: (pageNumber: number) => Promise<any>
24
+ hasMore?: boolean
25
+ }
26
+
27
+ export const InfiniteScroll = (props: PropsWithChildren<InfiniteScrollProps>) => {
28
+ const { onLoad, hasMore = true, children } = props
29
+
30
+ const [pageNumber, setPageNumber] = useState(0)
31
+ const [isLoading, setLoading] = useState(false)
32
+ const bottomRef = useRef<HTMLDivElement>(null)
33
+ const isBottom = useIntersectionObserver(bottomRef)
34
+
35
+ useEffect(() => {
36
+ if (isBottom && hasMore && !isLoading) {
37
+ handleLoad()
38
+ }
39
+ }, [isBottom])
40
+
41
+ const handleLoad = async () => {
42
+ setLoading(true)
43
+
44
+ await onLoad(pageNumber)
45
+
46
+ setPageNumber(pageNumber => pageNumber + 1)
47
+ setLoading(false)
48
+ }
49
+
50
+ return (
51
+ <>
52
+ {children}
53
+ <div ref={bottomRef} />
54
+ </>
55
+ )
56
+ }
@@ -0,0 +1,12 @@
1
+ import { Spinner } from '@0xsequence/design-system'
2
+ import React from 'react'
3
+
4
+ export const Loader = () => {
5
+ return (
6
+ <div className="flex flex-col justify-center items-center gap-6 mt-4">
7
+ <div>
8
+ <Spinner size="lg" />
9
+ </div>
10
+ </div>
11
+ )
12
+ }
@@ -0,0 +1,59 @@
1
+ import { IconButton, ChevronLeftIcon, Text, ModalPrimitive } from '@0xsequence/design-system'
2
+
3
+ import { HEADER_HEIGHT } from '../../constants'
4
+ import { useNavigationContext } from '../../contexts/Navigation'
5
+ import { useNavigation } from '../../hooks/useNavigation'
6
+
7
+ interface NavigationHeaderProps {
8
+ primaryText?: string
9
+ secondaryText?: string
10
+ }
11
+
12
+ export const NavigationHeader = ({ secondaryText, primaryText }: NavigationHeaderProps) => {
13
+ const { goBack, history } = useNavigation()
14
+ const { isBackButtonEnabled } = useNavigationContext()
15
+
16
+ const onClickBack = () => {
17
+ if (!isBackButtonEnabled) {
18
+ return
19
+ }
20
+ goBack()
21
+ }
22
+
23
+ return (
24
+ <div
25
+ className="flex bg-background-primary z-20 fixed w-full flex-row items-center justify-between px-4"
26
+ style={{
27
+ height: HEADER_HEIGHT,
28
+ paddingTop: '6px'
29
+ }}
30
+ >
31
+ {history.length > 0 ? (
32
+ <IconButton
33
+ onClick={onClickBack}
34
+ icon={ChevronLeftIcon}
35
+ size="xs"
36
+ disabled={!isBackButtonEnabled}
37
+ style={{ opacity: isBackButtonEnabled ? 1 : 0.5 }}
38
+ />
39
+ ) : (
40
+ <div />
41
+ )}
42
+ <div>
43
+ <Text fontWeight="medium" variant="small" color="muted">
44
+ {secondaryText}
45
+ </Text>
46
+ <ModalPrimitive.Title asChild>
47
+ <Text fontWeight="medium" variant="small" color="primary">
48
+ {primaryText}
49
+ </Text>
50
+ </ModalPrimitive.Title>
51
+ </div>
52
+ <div
53
+ style={{
54
+ width: '44px'
55
+ }}
56
+ />
57
+ </div>
58
+ )
59
+ }