@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,30 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./Home"), exports);
18
+ __exportStar(require("./Receive"), exports);
19
+ __exportStar(require("./SendCoin"), exports);
20
+ __exportStar(require("./SendCollectible"), exports);
21
+ __exportStar(require("./History"), exports);
22
+ __exportStar(require("./Search"), exports);
23
+ __exportStar(require("./Settings"), exports);
24
+ __exportStar(require("./CoinDetails"), exports);
25
+ __exportStar(require("./CollectionDetails"), exports);
26
+ __exportStar(require("./CollectibleDetails"), exports);
27
+ __exportStar(require("./TransactionDetails"), exports);
28
+ __exportStar(require("./SwapCoin"), exports);
29
+ __exportStar(require("./SwapCoin/SwapList"), exports);
30
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/views/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,yCAAsB;AACtB,4CAAyB;AACzB,6CAA0B;AAC1B,oDAAiC;AACjC,4CAAyB;AACzB,2CAAwB;AACxB,6CAA0B;AAC1B,gDAA6B;AAC7B,sDAAmC;AACnC,uDAAoC;AACpC,uDAAoC;AACpC,6CAA0B;AAC1B,sDAAmC"}
@@ -0,0 +1,11 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Button, cn, Text } from '@0xsequence/design-system';
3
+ const variants = {
4
+ negative: 'bg-negative',
5
+ warning: 'bg-warning',
6
+ positive: 'bg-positive'
7
+ };
8
+ export const Alert = ({ title, description, secondaryDescription, variant, buttonProps, children }) => {
9
+ return (_jsx("div", { className: cn('rounded-xl', variants[variant]), children: _jsxs("div", { className: "flex bg-background-overlay rounded-xl py-4 w-full flex-col gap-3", children: [_jsxs("div", { className: "flex w-full gap-2 justify-between", children: [_jsxs("div", { className: "flex flex-col gap-1", children: [_jsx(Text, { variant: "normal", color: "primary", fontWeight: "medium", children: title }), _jsx(Text, { variant: "normal", color: "muted", fontWeight: "medium", children: description }), secondaryDescription && (_jsx(Text, { variant: "normal", color: "secondary", fontWeight: "medium", children: secondaryDescription }))] }), buttonProps ? (_jsx("div", { className: "rounded-lg w-min h-min", children: _jsx(Button, { className: "shrink-0", variant: "emphasis", shape: "square", ...buttonProps }) })) : null] }), children] }) }));
10
+ };
11
+ //# sourceMappingURL=Alert.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Alert.js","sourceRoot":"","sources":["../../../src/components/Alert.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,MAAM,EAAE,EAAE,EAAE,IAAI,EAAE,MAAM,2BAA2B,CAAA;AAY5D,MAAM,QAAQ,GAAG;IACf,QAAQ,EAAE,aAAa;IACvB,OAAO,EAAE,YAAY;IACrB,QAAQ,EAAE,aAAa;CACxB,CAAA;AAED,MAAM,CAAC,MAAM,KAAK,GAAG,CAAC,EAAE,KAAK,EAAE,WAAW,EAAE,oBAAoB,EAAE,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAc,EAAE,EAAE;IAChH,OAAO,CACL,cAAK,SAAS,EAAE,EAAE,CAAC,YAAY,EAAE,QAAQ,CAAC,OAAO,CAAC,CAAC,YACjD,eAAK,SAAS,EAAC,kEAAkE,aAC/E,eAAK,SAAS,EAAC,mCAAmC,aAChD,eAAK,SAAS,EAAC,qBAAqB,aAClC,KAAC,IAAI,IAAC,OAAO,EAAC,QAAQ,EAAC,KAAK,EAAC,SAAS,EAAC,UAAU,EAAC,QAAQ,YACvD,KAAK,GACD,EAEP,KAAC,IAAI,IAAC,OAAO,EAAC,QAAQ,EAAC,KAAK,EAAC,OAAO,EAAC,UAAU,EAAC,QAAQ,YACrD,WAAW,GACP,EAEN,oBAAoB,IAAI,CACvB,KAAC,IAAI,IAAC,OAAO,EAAC,QAAQ,EAAC,KAAK,EAAC,WAAW,EAAC,UAAU,EAAC,QAAQ,YACzD,oBAAoB,GAChB,CACR,IACG,EAEL,WAAW,CAAC,CAAC,CAAC,CACb,cAAK,SAAS,EAAC,wBAAwB,YACrC,KAAC,MAAM,IAAC,SAAS,EAAC,UAAU,EAAC,OAAO,EAAC,UAAU,EAAC,KAAK,EAAC,QAAQ,KAAK,WAAW,GAAI,GAC9E,CACP,CAAC,CAAC,CAAC,IAAI,IACJ,EAEL,QAAQ,IACL,GACF,CACP,CAAA;AACH,CAAC,CAAA"}
@@ -0,0 +1,14 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { formatDisplay } from '@0xsequence/connect';
3
+ import { Skeleton, Text, TokenImage } from '@0xsequence/design-system';
4
+ import { formatUnits } from 'viem';
5
+ import { getPercentageColor } from '../utils';
6
+ export const CoinRowSkeleton = () => {
7
+ return (_jsxs("div", { className: "flex h-14 items-center justify-between bg-background-secondary rounded-xl py-2 px-3", children: [_jsxs("div", { className: "flex justify-center items-center gap-2", children: [_jsx(Skeleton, { className: "rounded-full", style: { width: 30, height: 30 } }), _jsxs("div", { className: "flex flex-col gap-2 items-start", children: [_jsx(Skeleton, { style: { width: 100, height: 14 } }), _jsx(Skeleton, { style: { width: 75, height: 14 } })] })] }), _jsxs("div", { className: "flex flex-col gap-2 items-end", children: [_jsx(Skeleton, { style: { width: 100, height: 14 } }), _jsx(Skeleton, { style: { width: 50, height: 12 } })] })] }));
8
+ };
9
+ export const CoinRow = ({ imageUrl, name, decimals, balance, symbol, fiatValue, priceChangePercentage }) => {
10
+ const formattedBalance = formatUnits(BigInt(balance), decimals);
11
+ const balanceDisplayed = formatDisplay(formattedBalance);
12
+ return (_jsxs("div", { className: "flex h-14 items-center justify-between bg-background-secondary rounded-xl py-2 px-3", children: [_jsxs("div", { className: "flex justify-center items-center gap-2", children: [_jsx(TokenImage, { src: imageUrl, symbol: symbol, size: "lg" }), _jsxs("div", { className: "flex flex-col items-start", children: [_jsx(Text, { variant: "medium", color: "primary", children: name }), _jsxs(Text, { color: "muted", variant: "normal", children: [' ', `${balanceDisplayed} ${symbol}`] })] })] }), _jsxs("div", { className: "flex flex-col items-end", children: [_jsx(Text, { variant: "normal", color: "primary", children: `$${fiatValue}` }), _jsxs(Text, { variant: "small", color: getPercentageColor(priceChangePercentage), children: [priceChangePercentage.toFixed(2), "%"] })] })] }));
13
+ };
14
+ //# sourceMappingURL=CoinRow.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CoinRow.js","sourceRoot":"","sources":["../../../src/components/CoinRow.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAA;AACnD,OAAO,EAAE,QAAQ,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAA;AAEtE,OAAO,EAAE,WAAW,EAAE,MAAM,MAAM,CAAA;AAElC,OAAO,EAAE,kBAAkB,EAAE,MAAM,UAAU,CAAA;AAY7C,MAAM,CAAC,MAAM,eAAe,GAAG,GAAG,EAAE;IAClC,OAAO,CACL,eAAK,SAAS,EAAC,qFAAqF,aAClG,eAAK,SAAS,EAAC,wCAAwC,aACrD,KAAC,QAAQ,IAAC,SAAS,EAAC,cAAc,EAAC,KAAK,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,GAAI,EACvE,eAAK,SAAS,EAAC,iCAAiC,aAC9C,KAAC,QAAQ,IAAC,KAAK,EAAE,EAAE,KAAK,EAAE,GAAG,EAAE,MAAM,EAAE,EAAE,EAAE,GAAI,EAC/C,KAAC,QAAQ,IAAC,KAAK,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,GAAI,IAC1C,IACF,EACN,eAAK,SAAS,EAAC,+BAA+B,aAC5C,KAAC,QAAQ,IAAC,KAAK,EAAE,EAAE,KAAK,EAAE,GAAG,EAAE,MAAM,EAAE,EAAE,EAAE,GAAI,EAC/C,KAAC,QAAQ,IAAC,KAAK,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,GAAI,IAC1C,IACF,CACP,CAAA;AACH,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,OAAO,GAAG,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,qBAAqB,EAAgB,EAAE,EAAE;IACvH,MAAM,gBAAgB,GAAG,WAAW,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,QAAQ,CAAC,CAAA;IAC/D,MAAM,gBAAgB,GAAG,aAAa,CAAC,gBAAgB,CAAC,CAAA;IAExD,OAAO,CACL,eAAK,SAAS,EAAC,qFAAqF,aAClG,eAAK,SAAS,EAAC,wCAAwC,aACrD,KAAC,UAAU,IAAC,GAAG,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAC,IAAI,GAAG,EACvD,eAAK,SAAS,EAAC,2BAA2B,aACxC,KAAC,IAAI,IAAC,OAAO,EAAC,QAAQ,EAAC,KAAK,EAAC,SAAS,YACnC,IAAI,GACA,EACP,MAAC,IAAI,IAAC,KAAK,EAAC,OAAO,EAAC,OAAO,EAAC,QAAQ,aACjC,GAAG,EACH,GAAG,gBAAgB,IAAI,MAAM,EAAE,IAC3B,IACH,IACF,EACN,eAAK,SAAS,EAAC,yBAAyB,aACtC,KAAC,IAAI,IAAC,OAAO,EAAC,QAAQ,EAAC,KAAK,EAAC,SAAS,YAAE,IAAI,SAAS,EAAE,GAAQ,EAC/D,MAAC,IAAI,IAAC,OAAO,EAAC,OAAO,EAAC,KAAK,EAAE,kBAAkB,CAAC,qBAAqB,CAAC,aACnE,qBAAqB,CAAC,OAAO,CAAC,CAAC,CAAC,SAC5B,IACH,IACF,CACP,CAAA;AACH,CAAC,CAAA"}
@@ -0,0 +1,6 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { Card, Image } from '@0xsequence/design-system';
3
+ export const CollectibleTileImage = ({ imageUrl }) => {
4
+ return (_jsx(Card, { className: "flex p-0 aspect-square justify-center items-center overflow-hidden rounded-lg bg-background-secondary", children: _jsx(Image, { style: { height: '100%' }, src: imageUrl }) }));
5
+ };
6
+ //# sourceMappingURL=CollectibleTileImage.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CollectibleTileImage.js","sourceRoot":"","sources":["../../../src/components/CollectibleTileImage.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,2BAA2B,CAAA;AAOvD,MAAM,CAAC,MAAM,oBAAoB,GAAG,CAAC,EAAE,QAAQ,EAA6B,EAAE,EAAE;IAC9E,OAAO,CACL,KAAC,IAAI,IAAC,SAAS,EAAC,uGAAuG,YACrH,KAAC,KAAK,IAAC,KAAK,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE,EAAE,GAAG,EAAE,QAAQ,GAAI,GAC9C,CACR,CAAA;AACH,CAAC,CAAA"}
@@ -0,0 +1,21 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { Button, CopyIcon, CheckmarkIcon } from '@0xsequence/design-system';
3
+ import { useEffect, useState } from 'react';
4
+ import { CopyToClipboard } from 'react-copy-to-clipboard';
5
+ export const CopyButton = (props) => {
6
+ const { buttonVariant = 'icon', text, size = 'xs', ...rest } = props;
7
+ const [isCopied, setCopy] = useState(false);
8
+ useEffect(() => {
9
+ if (isCopied) {
10
+ setTimeout(() => {
11
+ setCopy(false);
12
+ }, 4000);
13
+ }
14
+ }, [isCopied]);
15
+ const handleCopy = () => {
16
+ setCopy(true);
17
+ };
18
+ const label = isCopied ? 'Copied!' : 'Copy';
19
+ return (_jsx(CopyToClipboard, { text: text, onCopy: handleCopy, children: _jsx(Button, { size: size, leftIcon: isCopied ? CheckmarkIcon : CopyIcon, label: buttonVariant === 'with-label' ? label : undefined, variant: buttonVariant === 'icon' ? 'ghost' : 'glass', ...rest }) }));
20
+ };
21
+ //# sourceMappingURL=CopyButton.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CopyButton.js","sourceRoot":"","sources":["../../../src/components/CopyButton.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAA;AAC3E,OAAc,EAAE,SAAS,EAAE,QAAQ,EAAkB,MAAM,OAAO,CAAA;AAClE,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAA;AASzD,MAAM,CAAC,MAAM,UAAU,GAAG,CAAC,KAAsB,EAAE,EAAE;IACnD,MAAM,EAAE,aAAa,GAAG,MAAM,EAAE,IAAI,EAAE,IAAI,GAAG,IAAI,EAAE,GAAG,IAAI,EAAE,GAAG,KAAK,CAAA;IACpE,MAAM,CAAC,QAAQ,EAAE,OAAO,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAA;IAE3C,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,QAAQ,EAAE,CAAC;YACb,UAAU,CAAC,GAAG,EAAE;gBACd,OAAO,CAAC,KAAK,CAAC,CAAA;YAChB,CAAC,EAAE,IAAI,CAAC,CAAA;QACV,CAAC;IACH,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAA;IAEd,MAAM,UAAU,GAAG,GAAG,EAAE;QACtB,OAAO,CAAC,IAAI,CAAC,CAAA;IACf,CAAC,CAAA;IAED,MAAM,KAAK,GAAG,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,CAAA;IAE3C,OAAO,CACL,KAAC,eAAe,IAAC,IAAI,EAAE,IAAI,EAAE,MAAM,EAAE,UAAU,YAC7C,KAAC,MAAM,IACL,IAAI,EAAE,IAAK,EACX,QAAQ,EAAE,QAAQ,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,QAAQ,EAC7C,KAAK,EAAE,aAAa,KAAK,YAAY,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS,EACzD,OAAO,EAAE,aAAa,KAAK,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,KACjD,IAAI,GACR,GACc,CACnB,CAAA;AACH,CAAC,CAAA"}
@@ -0,0 +1,9 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { Text } from '@0xsequence/design-system';
3
+ export const DefaultIcon = ({ size = 30 }) => {
4
+ return (_jsx("div", { className: "flex items-center justify-center rounded-full bg-background-inverse shrink-0", style: {
5
+ width: `${size}px`,
6
+ height: `${size}px`
7
+ }, children: _jsx(Text, { variant: "large", color: "inverse", children: "?" }) }));
8
+ };
9
+ //# sourceMappingURL=DefaultIcon.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DefaultIcon.js","sourceRoot":"","sources":["../../../src/components/DefaultIcon.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,2BAA2B,CAAA;AAOhD,MAAM,CAAC,MAAM,WAAW,GAAG,CAAC,EAAE,IAAI,GAAG,EAAE,EAAoB,EAAE,EAAE;IAC7D,OAAO,CACL,cACE,SAAS,EAAC,8EAA8E,EACxF,KAAK,EAAE;YACL,KAAK,EAAE,GAAG,IAAI,IAAI;YAClB,MAAM,EAAE,GAAG,IAAI,IAAI;SACpB,YAED,KAAC,IAAI,IAAC,OAAO,EAAC,OAAO,EAAC,KAAK,EAAC,SAAS,kBAE9B,GACH,CACP,CAAA;AACH,CAAC,CAAA"}
@@ -0,0 +1,41 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { cn, Text, TokenImage } from '@0xsequence/design-system';
3
+ import React from 'react';
4
+ import { formatUnits, parseUnits, zeroAddress } from 'viem';
5
+ import { Alert } from './Alert';
6
+ const isBalanceSufficient = (balance, fee, decimals) => {
7
+ const balanceBN = parseUnits(balance, decimals);
8
+ const feeBN = parseUnits(fee, decimals);
9
+ return balanceBN >= feeBN;
10
+ };
11
+ export const FeeOptionSelector = ({ txnFeeOptions, feeOptionBalances, selectedFeeOptionAddress, setSelectedFeeOptionAddress }) => {
12
+ const [feeOptionAlert, setFeeOptionAlert] = React.useState();
13
+ const sortedOptions = [...txnFeeOptions].sort((a, b) => {
14
+ const balanceA = feeOptionBalances.find(balance => balance.tokenName === a.token.name);
15
+ const balanceB = feeOptionBalances.find(balance => balance.tokenName === b.token.name);
16
+ const isSufficientA = balanceA ? isBalanceSufficient(balanceA.balance, a.value, a.token.decimals || 0) : false;
17
+ const isSufficientB = balanceB ? isBalanceSufficient(balanceB.balance, b.value, b.token.decimals || 0) : false;
18
+ return isSufficientA === isSufficientB ? 0 : isSufficientA ? -1 : 1;
19
+ });
20
+ return (_jsxs("div", { className: "mt-3 w-full", children: [_jsx(Text, { variant: "normal", color: "primary", fontWeight: "bold", children: "Select a fee option" }), _jsx("div", { className: "flex flex-col mt-2 gap-2", children: sortedOptions.map((option, index) => {
21
+ const isSelected = selectedFeeOptionAddress === (option.token.contractAddress ?? zeroAddress);
22
+ const balance = feeOptionBalances.find(b => b.tokenName === option.token.name);
23
+ const isSufficient = isBalanceSufficient(balance?.balance || '0', option.value, option.token.decimals || 0);
24
+ return (_jsx("div", { className: cn('px-3 py-2 rounded-xl border-2 border-solid bg-background-raised', isSelected ? 'border-border-focus' : 'border-transparent'), onClick: () => {
25
+ if (isSufficient) {
26
+ setSelectedFeeOptionAddress(option.token.contractAddress ?? zeroAddress);
27
+ setFeeOptionAlert(undefined);
28
+ }
29
+ else {
30
+ setFeeOptionAlert({
31
+ title: `Insufficient ${option.token.name} balance`,
32
+ description: `Please select another fee option or add funds to your wallet.`,
33
+ variant: 'warning'
34
+ });
35
+ }
36
+ }, children: _jsxs("div", { className: "flex flex-row justify-between items-center", children: [_jsxs("div", { className: "flex flex-row items-center gap-2", children: [_jsx(TokenImage, { src: option.token.logoURL, symbol: option.token.name }), _jsxs("div", { className: "flex flex-col", children: [_jsx(Text, { variant: "small", color: "primary", fontWeight: "bold", children: option.token.name }), _jsxs(Text, { variant: "xsmall", color: "secondary", children: ["Fee:", ' ', parseFloat(formatUnits(BigInt(option.value), option.token.decimals || 0)).toLocaleString(undefined, {
37
+ maximumFractionDigits: 6
38
+ })] })] })] }), _jsxs("div", { className: "flex flex-col items-end", children: [_jsx(Text, { variant: "xsmall", color: "secondary", children: "Balance:" }), _jsx(Text, { variant: "xsmall", color: "primary", children: parseFloat(formatUnits(BigInt(balance?.balance || '0'), option.token.decimals || 0)).toLocaleString(undefined, { maximumFractionDigits: 6 }) })] })] }) }, index));
39
+ }) }), _jsx("div", { className: "flex mt-3 items-end justify-center flex-col", children: feeOptionAlert && (_jsx("div", { className: "mt-3", children: _jsx(Alert, { title: feeOptionAlert.title, description: feeOptionAlert.description, secondaryDescription: feeOptionAlert.secondaryDescription, variant: feeOptionAlert.variant }) })) })] }));
40
+ };
41
+ //# sourceMappingURL=FeeOptionSelector.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FeeOptionSelector.js","sourceRoot":"","sources":["../../../src/components/FeeOptionSelector.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,37 @@
1
+ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useEffect, useRef, useState, useMemo } from 'react';
3
+ export const useIntersectionObserver = (ref, options) => {
4
+ const [entry, setEntry] = useState(null);
5
+ const observer = useMemo(() => new IntersectionObserver(([entry]) => setEntry(entry), options), []);
6
+ useEffect(() => {
7
+ if (ref.current) {
8
+ observer.observe(ref.current);
9
+ }
10
+ return () => {
11
+ if (ref.current) {
12
+ observer.disconnect();
13
+ }
14
+ };
15
+ }, [ref.current, observer]);
16
+ return entry?.isIntersecting ?? false;
17
+ };
18
+ export const InfiniteScroll = (props) => {
19
+ const { onLoad, hasMore = true, children } = props;
20
+ const [pageNumber, setPageNumber] = useState(0);
21
+ const [isLoading, setLoading] = useState(false);
22
+ const bottomRef = useRef(null);
23
+ const isBottom = useIntersectionObserver(bottomRef);
24
+ useEffect(() => {
25
+ if (isBottom && hasMore && !isLoading) {
26
+ handleLoad();
27
+ }
28
+ }, [isBottom]);
29
+ const handleLoad = async () => {
30
+ setLoading(true);
31
+ await onLoad(pageNumber);
32
+ setPageNumber(pageNumber => pageNumber + 1);
33
+ setLoading(false);
34
+ };
35
+ return (_jsxs(_Fragment, { children: [children, _jsx("div", { ref: bottomRef })] }));
36
+ };
37
+ //# sourceMappingURL=InfiniteScroll.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"InfiniteScroll.js","sourceRoot":"","sources":["../../../src/components/InfiniteScroll.tsx"],"names":[],"mappings":";AAAA,OAAc,EAAgC,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,OAAO,CAAA;AAEjG,MAAM,CAAC,MAAM,uBAAuB,GAAG,CAAC,GAA8B,EAAE,OAAkC,EAAE,EAAE;IAC5G,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAmC,IAAI,CAAC,CAAA;IAC1E,MAAM,QAAQ,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC,IAAI,oBAAoB,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,OAAO,CAAC,EAAE,EAAE,CAAC,CAAA;IAEnG,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,GAAG,CAAC,OAAO,EAAE,CAAC;YAChB,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAA;QAC/B,CAAC;QAED,OAAO,GAAG,EAAE;YACV,IAAI,GAAG,CAAC,OAAO,EAAE,CAAC;gBAChB,QAAQ,CAAC,UAAU,EAAE,CAAA;YACvB,CAAC;QACH,CAAC,CAAA;IACH,CAAC,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC,CAAA;IAE3B,OAAO,KAAK,EAAE,cAAc,IAAI,KAAK,CAAA;AACvC,CAAC,CAAA;AAOD,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,KAA6C,EAAE,EAAE;IAC9E,MAAM,EAAE,MAAM,EAAE,OAAO,GAAG,IAAI,EAAE,QAAQ,EAAE,GAAG,KAAK,CAAA;IAElD,MAAM,CAAC,UAAU,EAAE,aAAa,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAA;IAC/C,MAAM,CAAC,SAAS,EAAE,UAAU,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAA;IAC/C,MAAM,SAAS,GAAG,MAAM,CAAiB,IAAI,CAAC,CAAA;IAC9C,MAAM,QAAQ,GAAG,uBAAuB,CAAC,SAAS,CAAC,CAAA;IAEnD,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,QAAQ,IAAI,OAAO,IAAI,CAAC,SAAS,EAAE,CAAC;YACtC,UAAU,EAAE,CAAA;QACd,CAAC;IACH,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAA;IAEd,MAAM,UAAU,GAAG,KAAK,IAAI,EAAE;QAC5B,UAAU,CAAC,IAAI,CAAC,CAAA;QAEhB,MAAM,MAAM,CAAC,UAAU,CAAC,CAAA;QAExB,aAAa,CAAC,UAAU,CAAC,EAAE,CAAC,UAAU,GAAG,CAAC,CAAC,CAAA;QAC3C,UAAU,CAAC,KAAK,CAAC,CAAA;IACnB,CAAC,CAAA;IAED,OAAO,CACL,8BACG,QAAQ,EACT,cAAK,GAAG,EAAE,SAAS,GAAI,IACtB,CACJ,CAAA;AACH,CAAC,CAAA"}
@@ -0,0 +1,6 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { Spinner } from '@0xsequence/design-system';
3
+ export const Loader = () => {
4
+ return (_jsx("div", { className: "flex flex-col justify-center items-center gap-6 mt-4", children: _jsx("div", { children: _jsx(Spinner, { size: "lg" }) }) }));
5
+ };
6
+ //# sourceMappingURL=Loader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Loader.js","sourceRoot":"","sources":["../../../src/components/Loader.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAA;AAGnD,MAAM,CAAC,MAAM,MAAM,GAAG,GAAG,EAAE;IACzB,OAAO,CACL,cAAK,SAAS,EAAC,sDAAsD,YACnE,wBACE,KAAC,OAAO,IAAC,IAAI,EAAC,IAAI,GAAG,GACjB,GACF,CACP,CAAA;AACH,CAAC,CAAA"}
@@ -0,0 +1,22 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { IconButton, ChevronLeftIcon, Text, ModalPrimitive } from '@0xsequence/design-system';
3
+ import { HEADER_HEIGHT } from '../../constants';
4
+ import { useNavigationContext } from '../../contexts/Navigation';
5
+ import { useNavigation } from '../../hooks/useNavigation';
6
+ export const NavigationHeader = ({ secondaryText, primaryText }) => {
7
+ const { goBack, history } = useNavigation();
8
+ const { isBackButtonEnabled } = useNavigationContext();
9
+ const onClickBack = () => {
10
+ if (!isBackButtonEnabled) {
11
+ return;
12
+ }
13
+ goBack();
14
+ };
15
+ return (_jsxs("div", { className: "flex bg-background-primary z-20 fixed w-full flex-row items-center justify-between px-4", style: {
16
+ height: HEADER_HEIGHT,
17
+ paddingTop: '6px'
18
+ }, children: [history.length > 0 ? (_jsx(IconButton, { onClick: onClickBack, icon: ChevronLeftIcon, size: "xs", disabled: !isBackButtonEnabled, style: { opacity: isBackButtonEnabled ? 1 : 0.5 } })) : (_jsx("div", {})), _jsxs("div", { children: [_jsx(Text, { fontWeight: "medium", variant: "small", color: "muted", children: secondaryText }), _jsx(ModalPrimitive.Title, { asChild: true, children: _jsx(Text, { fontWeight: "medium", variant: "small", color: "primary", children: primaryText }) })] }), _jsx("div", { style: {
19
+ width: '44px'
20
+ } })] }));
21
+ };
22
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/NavigationHeader/index.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,UAAU,EAAE,eAAe,EAAE,IAAI,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAA;AAE7F,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAA;AAC/C,OAAO,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAA;AAChE,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAA;AAOzD,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC,EAAE,aAAa,EAAE,WAAW,EAAyB,EAAE,EAAE;IACxF,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,aAAa,EAAE,CAAA;IAC3C,MAAM,EAAE,mBAAmB,EAAE,GAAG,oBAAoB,EAAE,CAAA;IAEtD,MAAM,WAAW,GAAG,GAAG,EAAE;QACvB,IAAI,CAAC,mBAAmB,EAAE,CAAC;YACzB,OAAM;QACR,CAAC;QACD,MAAM,EAAE,CAAA;IACV,CAAC,CAAA;IAED,OAAO,CACL,eACE,SAAS,EAAC,yFAAyF,EACnG,KAAK,EAAE;YACL,MAAM,EAAE,aAAa;YACrB,UAAU,EAAE,KAAK;SAClB,aAEA,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CACpB,KAAC,UAAU,IACT,OAAO,EAAE,WAAW,EACpB,IAAI,EAAE,eAAe,EACrB,IAAI,EAAC,IAAI,EACT,QAAQ,EAAE,CAAC,mBAAmB,EAC9B,KAAK,EAAE,EAAE,OAAO,EAAE,mBAAmB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,GACjD,CACH,CAAC,CAAC,CAAC,CACF,eAAO,CACR,EACD,0BACE,KAAC,IAAI,IAAC,UAAU,EAAC,QAAQ,EAAC,OAAO,EAAC,OAAO,EAAC,KAAK,EAAC,OAAO,YACpD,aAAa,GACT,EACP,KAAC,cAAc,CAAC,KAAK,IAAC,OAAO,kBAC3B,KAAC,IAAI,IAAC,UAAU,EAAC,QAAQ,EAAC,OAAO,EAAC,OAAO,EAAC,KAAK,EAAC,SAAS,YACtD,WAAW,GACP,GACc,IACnB,EACN,cACE,KAAK,EAAE;oBACL,KAAK,EAAE,MAAM;iBACd,GACD,IACE,CACP,CAAA;AACH,CAAC,CAAA"}
@@ -0,0 +1,14 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { getNetwork, getNetworkColor, getNetworkBackgroundColor } from '@0xsequence/connect';
3
+ import { NetworkImage, Text } from '@0xsequence/design-system';
4
+ export const NetworkBadge = ({ chainId }) => {
5
+ const network = getNetwork(chainId);
6
+ const chainColor = getNetworkColor(chainId);
7
+ const chainBGColor = getNetworkBackgroundColor(chainId);
8
+ return (_jsxs("div", { className: "flex h-6 px-2 gap-1 rounded-sm flex-row justify-center items-center w-fit", style: {
9
+ background: chainBGColor
10
+ }, children: [_jsx(NetworkImage, { chainId: chainId, size: "xs" }), _jsx(Text, { variant: "xsmall", fontWeight: "bold", capitalize: true, ellipsis: true, style: {
11
+ color: chainColor
12
+ }, children: network.title ?? network.name })] }));
13
+ };
14
+ //# sourceMappingURL=NetworkBadge.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NetworkBadge.js","sourceRoot":"","sources":["../../../src/components/NetworkBadge.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,UAAU,EAAE,eAAe,EAAE,yBAAyB,EAAE,MAAM,qBAAqB,CAAA;AAC5F,OAAO,EAAE,YAAY,EAAE,IAAI,EAAE,MAAM,2BAA2B,CAAA;AAO9D,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,EAAE,OAAO,EAAqB,EAAE,EAAE;IAC7D,MAAM,OAAO,GAAG,UAAU,CAAC,OAAO,CAAC,CAAA;IACnC,MAAM,UAAU,GAAG,eAAe,CAAC,OAAO,CAAC,CAAA;IAC3C,MAAM,YAAY,GAAG,yBAAyB,CAAC,OAAO,CAAC,CAAA;IAEvD,OAAO,CACL,eACE,SAAS,EAAC,2EAA2E,EACrF,KAAK,EAAE;YACL,UAAU,EAAE,YAAY;SACzB,aAED,KAAC,YAAY,IAAC,OAAO,EAAE,OAAO,EAAE,IAAI,EAAC,IAAI,GAAG,EAC5C,KAAC,IAAI,IACH,OAAO,EAAC,QAAQ,EAChB,UAAU,EAAC,MAAM,EACjB,UAAU,QACV,QAAQ,QACR,KAAK,EAAE;oBACL,KAAK,EAAE,UAAU;iBAClB,YAEA,OAAO,CAAC,KAAK,IAAI,OAAO,CAAC,IAAI,GACzB,IACH,CACP,CAAA;AACH,CAAC,CAAA"}
@@ -0,0 +1,8 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Card, cn } from '@0xsequence/design-system';
3
+ import { SelectedIndicator } from './SelectedIndicator';
4
+ export const SelectButton = (props) => {
5
+ const { value, selected, children, disabled, onClick, className, hideIndicator, squareIndicator = false, ...rest } = props;
6
+ return (_jsx(Card, { className: cn('flex select-none items-center justify-between text-left w-full border-none appearance-none', className), clickable: true, disabled: disabled, asChild: true, children: _jsxs("button", { onClick: () => onClick(value), ...rest, children: [children, !hideIndicator && _jsx(SelectedIndicator, { selected: selected, squareIndicator: squareIndicator })] }) }));
7
+ };
8
+ //# sourceMappingURL=SelectButton.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SelectButton.js","sourceRoot":"","sources":["../../../../src/components/SelectButton/SelectButton.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,IAAI,EAAE,EAAE,EAAE,MAAM,2BAA2B,CAAA;AAGpD,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAA;AAavD,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,KAAwB,EAAE,EAAE;IACvD,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,OAAO,EAAE,SAAS,EAAE,aAAa,EAAE,eAAe,GAAG,KAAK,EAAE,GAAG,IAAI,EAAE,GAAG,KAAK,CAAA;IAE1H,OAAO,CACL,KAAC,IAAI,IACH,SAAS,EAAE,EAAE,CAAC,4FAA4F,EAAE,SAAS,CAAC,EACtH,SAAS,QACT,QAAQ,EAAE,QAAQ,EAClB,OAAO,kBAEP,kBAAQ,OAAO,EAAE,GAAG,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,KAAM,IAAI,aAC5C,QAAQ,EACR,CAAC,aAAa,IAAI,KAAC,iBAAiB,IAAC,QAAQ,EAAE,QAAQ,EAAE,eAAe,EAAE,eAAe,GAAI,IACvF,GACJ,CACR,CAAA;AACH,CAAC,CAAA"}
@@ -0,0 +1,8 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { CheckmarkIcon, cn } from '@0xsequence/design-system';
3
+ import { motion } from 'motion/react';
4
+ export const SelectedIndicator = (props) => {
5
+ const { selected, className, squareIndicator = false } = props;
6
+ return (_jsx("div", { className: cn(`w-5 h-5 flex border-solid border-1 relative items-center justify-center shrink-0 border-border-normal`, squareIndicator ? 'rounded-sm' : 'rounded-full', className), children: _jsx(motion.div, { className: cn('flex absolute text-text-inverse100 justify-center items-center bg-border-normal', squareIndicator ? 'rounded-sm w-5 h-5' : 'rounded-full w-[14px] h-[14px]'), initial: { opacity: selected ? 1 : 0, scale: selected ? 1 : 0.5 }, animate: { opacity: selected ? 1 : 0, scale: selected ? 1 : 0.5 }, transition: { ease: 'backOut' }, children: squareIndicator && _jsx(CheckmarkIcon, { className: "text-white w-[14px] h-[14px]" }) }) }));
7
+ };
8
+ //# sourceMappingURL=SelectedIndicator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SelectedIndicator.js","sourceRoot":"","sources":["../../../../src/components/SelectButton/SelectedIndicator.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,aAAa,EAAE,EAAE,EAAE,MAAM,2BAA2B,CAAA;AAC7D,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAA;AASrC,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,KAA6B,EAAE,EAAE;IACjE,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,eAAe,GAAG,KAAK,EAAE,GAAG,KAAK,CAAA;IAC9D,OAAO,CACL,cACE,SAAS,EAAE,EAAE,CACX,uGAAuG,EACvG,eAAe,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,cAAc,EAC/C,SAAS,CACV,YAED,KAAC,MAAM,CAAC,GAAG,IACT,SAAS,EAAE,EAAE,CACX,iFAAiF,EACjF,eAAe,CAAC,CAAC,CAAC,oBAAoB,CAAC,CAAC,CAAC,gCAAgC,CAC1E,EACD,OAAO,EAAE,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,EACjE,OAAO,EAAE,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,EACjE,UAAU,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,YAE9B,eAAe,IAAI,KAAC,aAAa,IAAC,SAAS,EAAC,8BAA8B,GAAG,GACnE,GACT,CACP,CAAA;AACH,CAAC,CAAA"}
@@ -0,0 +1,2 @@
1
+ export { SelectButton } from './SelectButton';
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/SelectButton/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAA"}
@@ -0,0 +1,16 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { formatDisplay } from '@0xsequence/connect';
3
+ import { NetworkImage, Skeleton, Text, TokenImage } from '@0xsequence/design-system';
4
+ import { formatUnits } from 'viem';
5
+ import { useSettings } from '../hooks';
6
+ import { CollectibleTileImage } from './CollectibleTileImage';
7
+ export const SendItemInfoSkeleton = () => {
8
+ return (_jsxs("div", { className: "flex items-center justify-between", children: [_jsxs("div", { className: "flex justify-center items-center gap-2", children: [_jsx(Skeleton, { className: "rounded-full", style: { width: 30, height: 30 } }), _jsxs("div", { className: "flex flex-col gap-2 items-start", children: [_jsx(Skeleton, { style: { width: 100, height: 14 } }), _jsx(Skeleton, { style: { width: 75, height: 14 } })] })] }), _jsxs("div", { className: "flex flex-col gap-2 items-end", children: [_jsx(Skeleton, { style: { width: 100, height: 14 } }), _jsx(Skeleton, { style: { width: 50, height: 12 } })] })] }));
9
+ };
10
+ export const SendItemInfo = ({ imageUrl, name, decimals, balance, symbol, fiatValue, chainId, showSquareImage, balanceSuffix = 'available' }) => {
11
+ const { fiatCurrency } = useSettings();
12
+ const formattedBalance = formatUnits(BigInt(balance), decimals);
13
+ const balanceDisplayed = formatDisplay(formattedBalance);
14
+ return (_jsxs("div", { className: "flex items-end justify-between", children: [_jsxs("div", { className: "flex justify-between items-center gap-2", children: [showSquareImage ? (_jsx("div", { style: { width: '40px' }, children: _jsx(CollectibleTileImage, { imageUrl: imageUrl }) })) : (_jsx(TokenImage, { src: imageUrl, size: "lg" })), _jsxs("div", { className: "flex flex-col items-start", children: [_jsxs("div", { className: "flex flex-row items-center gap-1", children: [_jsx(Text, { variant: "medium", color: "primary", children: name }), _jsx(NetworkImage, { chainId: chainId, size: "xs" })] }), _jsxs(Text, { color: "muted", variant: "normal", children: [' ', `${balanceDisplayed} ${symbol} ${balanceSuffix}`] })] })] }), _jsx("div", { className: "flex flex-col items-end justify-end", children: fiatValue && _jsx(Text, { variant: "normal", color: "primary", children: `${fiatCurrency.sign}${fiatValue}` }) })] }));
15
+ };
16
+ //# sourceMappingURL=SendItemInfo.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SendItemInfo.js","sourceRoot":"","sources":["../../../src/components/SendItemInfo.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAA;AACnD,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAA;AAEpF,OAAO,EAAE,WAAW,EAAE,MAAM,MAAM,CAAA;AAElC,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAA;AAEtC,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAA;AAc7D,MAAM,CAAC,MAAM,oBAAoB,GAAG,GAAG,EAAE;IACvC,OAAO,CACL,eAAK,SAAS,EAAC,mCAAmC,aAChD,eAAK,SAAS,EAAC,wCAAwC,aACrD,KAAC,QAAQ,IAAC,SAAS,EAAC,cAAc,EAAC,KAAK,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,GAAI,EACvE,eAAK,SAAS,EAAC,iCAAiC,aAC9C,KAAC,QAAQ,IAAC,KAAK,EAAE,EAAE,KAAK,EAAE,GAAG,EAAE,MAAM,EAAE,EAAE,EAAE,GAAI,EAC/C,KAAC,QAAQ,IAAC,KAAK,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,GAAI,IAC1C,IACF,EACN,eAAK,SAAS,EAAC,+BAA+B,aAC5C,KAAC,QAAQ,IAAC,KAAK,EAAE,EAAE,KAAK,EAAE,GAAG,EAAE,MAAM,EAAE,EAAE,EAAE,GAAI,EAC/C,KAAC,QAAQ,IAAC,KAAK,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,GAAI,IAC1C,IACF,CACP,CAAA;AACH,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,EAC3B,QAAQ,EACR,IAAI,EACJ,QAAQ,EACR,OAAO,EACP,MAAM,EACN,SAAS,EACT,OAAO,EACP,eAAe,EACf,aAAa,GAAG,WAAW,EACT,EAAE,EAAE;IACtB,MAAM,EAAE,YAAY,EAAE,GAAG,WAAW,EAAE,CAAA;IACtC,MAAM,gBAAgB,GAAG,WAAW,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,QAAQ,CAAC,CAAA;IAC/D,MAAM,gBAAgB,GAAG,aAAa,CAAC,gBAAgB,CAAC,CAAA;IAExD,OAAO,CACL,eAAK,SAAS,EAAC,gCAAgC,aAC7C,eAAK,SAAS,EAAC,yCAAyC,aACrD,eAAe,CAAC,CAAC,CAAC,CACjB,cAAK,KAAK,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,YAC3B,KAAC,oBAAoB,IAAC,QAAQ,EAAE,QAAQ,GAAI,GACxC,CACP,CAAC,CAAC,CAAC,CACF,KAAC,UAAU,IAAC,GAAG,EAAE,QAAQ,EAAE,IAAI,EAAC,IAAI,GAAG,CACxC,EACD,eAAK,SAAS,EAAC,2BAA2B,aACxC,eAAK,SAAS,EAAC,kCAAkC,aAC/C,KAAC,IAAI,IAAC,OAAO,EAAC,QAAQ,EAAC,KAAK,EAAC,SAAS,YACnC,IAAI,GACA,EACP,KAAC,YAAY,IAAC,OAAO,EAAE,OAAO,EAAE,IAAI,EAAC,IAAI,GAAG,IACxC,EACN,MAAC,IAAI,IAAC,KAAK,EAAC,OAAO,EAAC,OAAO,EAAC,QAAQ,aACjC,GAAG,EACH,GAAG,gBAAgB,IAAI,MAAM,IAAI,aAAa,EAAE,IAC5C,IACH,IACF,EACN,cAAK,SAAS,EAAC,qCAAqC,YACjD,SAAS,IAAI,KAAC,IAAI,IAAC,OAAO,EAAC,QAAQ,EAAC,KAAK,EAAC,SAAS,YAAE,GAAG,YAAY,CAAC,IAAI,GAAG,SAAS,EAAE,GAAQ,GAC5F,IACF,CACP,CAAA;AACH,CAAC,CAAA"}
@@ -0,0 +1,50 @@
1
+ 'use client';
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
+ import { getModalPositionCss, useTheme, ShadowRoot } from '@0xsequence/connect';
4
+ import { Modal, Scroll } from '@0xsequence/design-system';
5
+ import { QueryClient, QueryClientProvider } from '@tanstack/react-query';
6
+ import { AnimatePresence } from 'motion/react';
7
+ import { useState } from 'react';
8
+ import { HEADER_HEIGHT } from '../../constants';
9
+ import { NavigationContextProvider, WalletModalContextProvider } from '../../contexts';
10
+ import { getHeader, getContent } from './utils';
11
+ const DEFAULT_LOCATION = {
12
+ location: 'home'
13
+ };
14
+ export const SequenceWalletProvider = (props) => {
15
+ const queryClient = new QueryClient();
16
+ return (_jsx(QueryClientProvider, { client: queryClient, children: _jsx(WalletContent, { ...props }) }));
17
+ };
18
+ export const WalletContent = ({ children }) => {
19
+ const { theme, position } = useTheme();
20
+ // Wallet Modal Context
21
+ const [openWalletModal, setOpenWalletModalState] = useState(false);
22
+ const setOpenWalletModal = (open, options) => {
23
+ setOpenWalletModalState(open);
24
+ setTimeout(() => {
25
+ setHistory(options?.defaultNavigation ? [options.defaultNavigation] : []);
26
+ }, 0);
27
+ };
28
+ // Navigation Context
29
+ const [history, setHistory] = useState([]);
30
+ const [isBackButtonEnabled, setIsBackButtonEnabled] = useState(true);
31
+ const navigation = history.length > 0 ? history[history.length - 1] : DEFAULT_LOCATION;
32
+ const displayScrollbar = navigation.location === 'home' ||
33
+ navigation.location === 'collection-details' ||
34
+ navigation.location === 'collectible-details' ||
35
+ navigation.location === 'coin-details' ||
36
+ navigation.location === 'history' ||
37
+ navigation.location === 'search' ||
38
+ navigation.location === 'search-view-all' ||
39
+ navigation.location === 'settings-currency';
40
+ return (_jsx(WalletModalContextProvider, { value: { setOpenWalletModal, openWalletModalState: openWalletModal }, children: _jsxs(NavigationContextProvider, { value: { setHistory, history, isBackButtonEnabled, setIsBackButtonEnabled }, children: [_jsx(ShadowRoot, { theme: theme, children: _jsx(AnimatePresence, { children: openWalletModal && (_jsx(Modal, { contentProps: {
41
+ style: {
42
+ maxWidth: '400px',
43
+ height: 'fit-content',
44
+ ...getModalPositionCss(position),
45
+ scrollbarColor: 'gray black',
46
+ scrollbarWidth: 'thin'
47
+ }
48
+ }, scroll: false, onClose: () => setOpenWalletModal(false), children: _jsxs("div", { id: "sequence-kit-wallet-content", children: [getHeader(navigation), displayScrollbar ? (_jsx(Scroll, { style: { paddingTop: HEADER_HEIGHT, height: 'min(800px, 80vh)' }, children: getContent(navigation) })) : (getContent(navigation))] }) })) }) }), children] }) }));
49
+ };
50
+ //# sourceMappingURL=SequenceWalletProvider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SequenceWalletProvider.js","sourceRoot":"","sources":["../../../../src/components/SequenceWalletProvider/SequenceWalletProvider.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export * from './SequenceWalletProvider';
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/SequenceWalletProvider/index.ts"],"names":[],"mappings":"AAAA,cAAc,0BAA0B,CAAA"}
@@ -0,0 +1,79 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { CoinDetails, CollectibleDetails, CollectionDetails, Home, Receive, SendCoin, SendCollectible, History, SearchWallet, SearchWalletViewAll, SettingsMenu, SettingsCurrency, SettingsNetwork, SettingsGeneral, TransactionDetails, SwapCoin, SwapList } from '../../../views';
3
+ import { NavigationHeader } from '../../NavigationHeader';
4
+ import { WalletHeader } from '../../WalletHeader';
5
+ export const getContent = (navigation) => {
6
+ const { location } = navigation;
7
+ switch (location) {
8
+ case 'send-coin':
9
+ return _jsx(SendCoin, { chainId: navigation.params.chainId, contractAddress: navigation.params.contractAddress });
10
+ case 'send-collectible':
11
+ return (_jsx(SendCollectible, { chainId: navigation.params.chainId, contractAddress: navigation.params.contractAddress, tokenId: navigation.params.tokenId }));
12
+ case 'receive':
13
+ return _jsx(Receive, {});
14
+ case 'history':
15
+ return _jsx(History, {});
16
+ case 'search':
17
+ return _jsx(SearchWallet, {});
18
+ case 'search-view-all':
19
+ return _jsx(SearchWalletViewAll, { defaultTab: navigation.params.defaultTab });
20
+ case 'settings':
21
+ return _jsx(SettingsMenu, {});
22
+ case 'settings-general':
23
+ return _jsx(SettingsGeneral, {});
24
+ case 'settings-currency':
25
+ return _jsx(SettingsCurrency, {});
26
+ case 'settings-networks':
27
+ return _jsx(SettingsNetwork, {});
28
+ case 'coin-details':
29
+ return _jsx(CoinDetails, { contractAddress: navigation.params.contractAddress, chainId: navigation.params.chainId });
30
+ case 'collectible-details':
31
+ return (_jsx(CollectibleDetails, { contractAddress: navigation.params.contractAddress, chainId: navigation.params.chainId, tokenId: navigation.params.tokenId }));
32
+ case 'collection-details':
33
+ return _jsx(CollectionDetails, { contractAddress: navigation.params.contractAddress, chainId: navigation.params.chainId });
34
+ case 'transaction-details':
35
+ return _jsx(TransactionDetails, { transaction: navigation.params.transaction });
36
+ case 'swap-coin':
37
+ return _jsx(SwapCoin, { contractAddress: navigation.params.contractAddress, chainId: navigation.params.chainId });
38
+ case 'swap-coin-list':
39
+ return (_jsx(SwapList, { contractAddress: navigation.params.contractAddress, chainId: navigation.params.chainId, amount: navigation.params.amount }));
40
+ default:
41
+ return _jsx(Home, {});
42
+ }
43
+ };
44
+ export const getHeader = (navigation) => {
45
+ const { location } = navigation;
46
+ switch (location) {
47
+ case 'search':
48
+ return _jsx(NavigationHeader, { primaryText: "Search wallet" });
49
+ case 'search-view-all':
50
+ return _jsx(NavigationHeader, { secondaryText: "Search wallet / ", primaryText: "View all" });
51
+ case 'settings':
52
+ return _jsx(NavigationHeader, { secondaryText: "Wallet / ", primaryText: "Settings" });
53
+ case 'settings-general':
54
+ return _jsx(NavigationHeader, { secondaryText: "Wallet / Settings / ", primaryText: "General" });
55
+ case 'settings-currency':
56
+ return _jsx(NavigationHeader, { secondaryText: "Wallet / Settings / ", primaryText: "Currency" });
57
+ case 'settings-networks':
58
+ return _jsx(NavigationHeader, { secondaryText: "Wallet / Settings / ", primaryText: "Networks" });
59
+ case 'receive':
60
+ return _jsx(NavigationHeader, { secondaryText: "Wallet / ", primaryText: "Receive" });
61
+ case 'history':
62
+ return _jsx(NavigationHeader, { secondaryText: "Wallet / ", primaryText: "History" });
63
+ case 'coin-details':
64
+ return _jsx(WalletHeader, {});
65
+ case 'collectible-details':
66
+ return _jsx(WalletHeader, {});
67
+ case 'transaction-details':
68
+ return _jsx(NavigationHeader, { secondaryText: "", primaryText: "" });
69
+ case 'send-collectible':
70
+ case 'send-coin':
71
+ return _jsx(NavigationHeader, { secondaryText: "Wallet / ", primaryText: "Send" });
72
+ case 'swap-coin':
73
+ case 'swap-coin-list':
74
+ return _jsx(NavigationHeader, { secondaryText: "Wallet / ", primaryText: "Buy" });
75
+ default:
76
+ return _jsx(WalletHeader, {});
77
+ }
78
+ };
79
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/components/SequenceWalletProvider/utils/index.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,61 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import { truncateAtMiddle } from '@0xsequence/connect';
3
+ import { Button, ChevronRightIcon, Text, Card, GradientAvatar, Spinner } from '@0xsequence/design-system';
4
+ import { useIndexerClient } from '@0xsequence/react-hooks';
5
+ import { useQuery } from '@tanstack/react-query';
6
+ import { useState } from 'react';
7
+ import { useAccount } from 'wagmi';
8
+ import { FeeOptionSelector } from './FeeOptionSelector';
9
+ import { SendItemInfo } from './SendItemInfo';
10
+ const useFeeOptionBalances = (feeOptions, chainId) => {
11
+ const { address: accountAddress } = useAccount();
12
+ const indexerClient = useIndexerClient(chainId);
13
+ return useQuery({
14
+ queryKey: ['feeOptionBalances', chainId, accountAddress, feeOptions?.options?.length],
15
+ queryFn: async () => {
16
+ if (!feeOptions?.options || !accountAddress || !indexerClient) {
17
+ return [];
18
+ }
19
+ const nativeTokenBalance = await indexerClient.getEtherBalance({
20
+ accountAddress
21
+ });
22
+ const tokenBalances = await indexerClient.getTokenBalances({
23
+ accountAddress
24
+ });
25
+ return feeOptions.options.map(option => {
26
+ if (option.token.contractAddress === null) {
27
+ return {
28
+ tokenName: option.token.name,
29
+ decimals: option.token.decimals || 0,
30
+ balance: nativeTokenBalance.balance.balanceWei
31
+ };
32
+ }
33
+ else {
34
+ return {
35
+ tokenName: option.token.name,
36
+ decimals: option.token.decimals || 0,
37
+ balance: tokenBalances.balances.find(b => b.contractAddress.toLowerCase() === option.token.contractAddress?.toLowerCase())
38
+ ?.balance || '0'
39
+ };
40
+ }
41
+ });
42
+ },
43
+ enabled: Boolean(feeOptions?.options && accountAddress && indexerClient),
44
+ refetchInterval: 10000,
45
+ staleTime: 10000
46
+ });
47
+ };
48
+ export const TransactionConfirmation = ({ name, symbol, imageUrl, amount, toAddress, showSquareImage, fiatValue, chainId, balance, decimals, feeOptions, onSelectFeeOption, isLoading, onConfirm, onCancel }) => {
49
+ const [selectedFeeOptionAddress, setSelectedFeeOptionAddress] = useState();
50
+ const { data: feeOptionBalances = [] } = useFeeOptionBalances(feeOptions, chainId);
51
+ const handleFeeOptionSelect = (address) => {
52
+ setSelectedFeeOptionAddress(address);
53
+ onSelectFeeOption?.(address);
54
+ };
55
+ // If feeOptions exist and have options, a selection is required
56
+ // If feeOptions don't exist or have no options, no selection is required
57
+ const isFeeSelectionRequired = Boolean(feeOptions?.options?.length);
58
+ const isConfirmDisabled = isFeeSelectionRequired && !selectedFeeOptionAddress;
59
+ return (_jsx("div", { className: "flex w-full h-full items-center justify-center bg-background-primary", children: _jsxs("div", { className: "flex gap-2 flex-col bg-background-primary w-full", children: [_jsxs("div", { className: "flex bg-background-secondary rounded-xl p-4 pb-3 gap-2 flex-col", children: [_jsx(SendItemInfo, { imageUrl: imageUrl, showSquareImage: showSquareImage, name: name, symbol: symbol, chainId: chainId, balance: balance, decimals: decimals }), _jsxs("div", { className: "flex mt-2 gap-1 flex-col", children: [_jsx(Text, { variant: "small", color: "muted", children: "Amount" }), _jsxs("div", { className: "flex flex-row items-center gap-2", children: [_jsxs(Text, { variant: "normal", color: "primary", children: [amount, " ", symbol] }), fiatValue && (_jsxs(Text, { variant: "small", color: "muted", children: ["~$", fiatValue] }))] })] }), _jsxs("div", { className: "flex mt-2 gap-1 flex-col", children: [_jsx(Text, { variant: "small", color: "muted", children: "To" }), _jsx(Card, { className: "flex w-full flex-row items-center", style: { height: '52px' }, children: _jsxs("div", { className: "flex flex-row justify-center items-center gap-2", children: [_jsx(GradientAvatar, { size: "sm", address: toAddress }), _jsx(Text, { color: "primary", variant: "normal", children: `0x${truncateAtMiddle(toAddress.substring(2), 10)}` })] }) })] }), isFeeSelectionRequired && feeOptions?.options && (_jsx(FeeOptionSelector, { txnFeeOptions: feeOptions.options, feeOptionBalances: feeOptionBalances, selectedFeeOptionAddress: selectedFeeOptionAddress, setSelectedFeeOptionAddress: handleFeeOptionSelect }))] }), _jsx("div", { className: "flex mt-3 gap-2", children: isLoading ? (_jsx("div", { className: "flex w-full items-center justify-center", style: { height: '52px' }, children: _jsx(Spinner, {}) })) : (_jsxs(_Fragment, { children: [_jsx(Button, { className: "w-full", variant: "primary", size: "lg", onClick: onConfirm, label: "Confirm", rightIcon: ChevronRightIcon, disabled: isConfirmDisabled }), _jsx(Button, { className: "w-full", variant: "glass", size: "lg", onClick: onCancel, label: "Cancel" })] })) })] }) }));
60
+ };
61
+ //# sourceMappingURL=TransactionConfirmation.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TransactionConfirmation.js","sourceRoot":"","sources":["../../../src/components/TransactionConfirmation.tsx"],"names":[],"mappings":"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"}