@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.
- package/LICENSE +219 -0
- package/README.md +53 -0
- package/dist/cjs/components/Alert.js +15 -0
- package/dist/cjs/components/Alert.js.map +1 -0
- package/dist/cjs/components/CoinRow.js +19 -0
- package/dist/cjs/components/CoinRow.js.map +1 -0
- package/dist/cjs/components/CollectibleTileImage.js +10 -0
- package/dist/cjs/components/CollectibleTileImage.js.map +1 -0
- package/dist/cjs/components/CopyButton.js +25 -0
- package/dist/cjs/components/CopyButton.js.map +1 -0
- package/dist/cjs/components/DefaultIcon.js +13 -0
- package/dist/cjs/components/DefaultIcon.js.map +1 -0
- package/dist/cjs/components/FeeOptionSelector.js +48 -0
- package/dist/cjs/components/FeeOptionSelector.js.map +1 -0
- package/dist/cjs/components/InfiniteScroll.js +42 -0
- package/dist/cjs/components/InfiniteScroll.js.map +1 -0
- package/dist/cjs/components/Loader.js +10 -0
- package/dist/cjs/components/Loader.js.map +1 -0
- package/dist/cjs/components/NavigationHeader/index.js +26 -0
- package/dist/cjs/components/NavigationHeader/index.js.map +1 -0
- package/dist/cjs/components/NetworkBadge.js +18 -0
- package/dist/cjs/components/NetworkBadge.js.map +1 -0
- package/dist/cjs/components/SelectButton/SelectButton.js +12 -0
- package/dist/cjs/components/SelectButton/SelectButton.js.map +1 -0
- package/dist/cjs/components/SelectButton/SelectedIndicator.js +12 -0
- package/dist/cjs/components/SelectButton/SelectedIndicator.js.map +1 -0
- package/dist/cjs/components/SelectButton/index.js +6 -0
- package/dist/cjs/components/SelectButton/index.js.map +1 -0
- package/dist/cjs/components/SendItemInfo.js +21 -0
- package/dist/cjs/components/SendItemInfo.js.map +1 -0
- package/dist/cjs/components/SequenceWalletProvider/SequenceWalletProvider.js +55 -0
- package/dist/cjs/components/SequenceWalletProvider/SequenceWalletProvider.js.map +1 -0
- package/dist/cjs/components/SequenceWalletProvider/index.js +18 -0
- package/dist/cjs/components/SequenceWalletProvider/index.js.map +1 -0
- package/dist/cjs/components/SequenceWalletProvider/utils/index.js +84 -0
- package/dist/cjs/components/SequenceWalletProvider/utils/index.js.map +1 -0
- package/dist/cjs/components/TransactionConfirmation.js +65 -0
- package/dist/cjs/components/TransactionConfirmation.js.map +1 -0
- package/dist/cjs/components/TransactionHistoryList/TransactionHistoryItem.js +117 -0
- package/dist/cjs/components/TransactionHistoryList/TransactionHistoryItem.js.map +1 -0
- package/dist/cjs/components/TransactionHistoryList/TransactionHistorySkeleton.js +17 -0
- package/dist/cjs/components/TransactionHistoryList/TransactionHistorySkeleton.js.map +1 -0
- package/dist/cjs/components/TransactionHistoryList/index.js +97 -0
- package/dist/cjs/components/TransactionHistoryList/index.js.map +1 -0
- package/dist/cjs/components/WalletHeader/components/AccountInformation.js +15 -0
- package/dist/cjs/components/WalletHeader/components/AccountInformation.js.map +1 -0
- package/dist/cjs/components/WalletHeader/components/WalletDropdownContent.js +57 -0
- package/dist/cjs/components/WalletHeader/components/WalletDropdownContent.js.map +1 -0
- package/dist/cjs/components/WalletHeader/index.js +87 -0
- package/dist/cjs/components/WalletHeader/index.js.map +1 -0
- package/dist/cjs/constants/abi.js +92 -0
- package/dist/cjs/constants/abi.js.map +1 -0
- package/dist/cjs/constants/currency.js +29 -0
- package/dist/cjs/constants/currency.js.map +1 -0
- package/dist/cjs/constants/index.js +20 -0
- package/dist/cjs/constants/index.js.map +1 -0
- package/dist/cjs/constants/sizing.js +5 -0
- package/dist/cjs/constants/sizing.js.map +1 -0
- package/dist/cjs/contexts/Navigation.js +8 -0
- package/dist/cjs/contexts/Navigation.js.map +1 -0
- package/dist/cjs/contexts/WalletModal.js +8 -0
- package/dist/cjs/contexts/WalletModal.js.map +1 -0
- package/dist/cjs/contexts/genericContext.js +20 -0
- package/dist/cjs/contexts/genericContext.js.map +1 -0
- package/dist/cjs/contexts/index.js +19 -0
- package/dist/cjs/contexts/index.js.map +1 -0
- package/dist/cjs/hooks/index.js +20 -0
- package/dist/cjs/hooks/index.js.map +1 -0
- package/dist/cjs/hooks/useNavigation.js +23 -0
- package/dist/cjs/hooks/useNavigation.js.map +1 -0
- package/dist/cjs/hooks/useOpenWalletModal.js +10 -0
- package/dist/cjs/hooks/useOpenWalletModal.js.map +1 -0
- package/dist/cjs/hooks/useScrollbarWidth.js +13 -0
- package/dist/cjs/hooks/useScrollbarWidth.js.map +1 -0
- package/dist/cjs/hooks/useSettings.js +100 -0
- package/dist/cjs/hooks/useSettings.js.map +1 -0
- package/dist/cjs/index.js +12 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/cjs/utils/helpers.js +49 -0
- package/dist/cjs/utils/helpers.js.map +1 -0
- package/dist/cjs/utils/index.js +19 -0
- package/dist/cjs/utils/index.js.map +1 -0
- package/dist/cjs/utils/tokens.js +78 -0
- package/dist/cjs/utils/tokens.js.map +1 -0
- package/dist/cjs/views/CoinDetails/Skeleton.js +13 -0
- package/dist/cjs/views/CoinDetails/Skeleton.js.map +1 -0
- package/dist/cjs/views/CoinDetails/index.js +90 -0
- package/dist/cjs/views/CoinDetails/index.js.map +1 -0
- package/dist/cjs/views/CollectibleDetails/Skeleton.js +14 -0
- package/dist/cjs/views/CollectibleDetails/Skeleton.js.map +1 -0
- package/dist/cjs/views/CollectibleDetails/index.js +83 -0
- package/dist/cjs/views/CollectibleDetails/index.js.map +1 -0
- package/dist/cjs/views/CollectionDetails/Skeleton.js +15 -0
- package/dist/cjs/views/CollectionDetails/Skeleton.js.map +1 -0
- package/dist/cjs/views/CollectionDetails/index.js +50 -0
- package/dist/cjs/views/CollectionDetails/index.js.map +1 -0
- package/dist/cjs/views/History.js +19 -0
- package/dist/cjs/views/History.js.map +1 -0
- package/dist/cjs/views/Home/components/AssetSummary/CoinTile/CoinTileContent.js +14 -0
- package/dist/cjs/views/Home/components/AssetSummary/CoinTile/CoinTileContent.js.map +1 -0
- package/dist/cjs/views/Home/components/AssetSummary/CoinTile/index.js +60 -0
- package/dist/cjs/views/Home/components/AssetSummary/CoinTile/index.js.map +1 -0
- package/dist/cjs/views/Home/components/AssetSummary/CollectibleTile/index.js +17 -0
- package/dist/cjs/views/Home/components/AssetSummary/CollectibleTile/index.js.map +1 -0
- package/dist/cjs/views/Home/components/AssetSummary/SkeletonTiles.js +14 -0
- package/dist/cjs/views/Home/components/AssetSummary/SkeletonTiles.js.map +1 -0
- package/dist/cjs/views/Home/components/AssetSummary/index.js +98 -0
- package/dist/cjs/views/Home/components/AssetSummary/index.js.map +1 -0
- package/dist/cjs/views/Home/index.js +10 -0
- package/dist/cjs/views/Home/index.js.map +1 -0
- package/dist/cjs/views/Receive.js +42 -0
- package/dist/cjs/views/Receive.js.map +1 -0
- package/dist/cjs/views/Search/SearchWallet.js +112 -0
- package/dist/cjs/views/Search/SearchWallet.js.map +1 -0
- package/dist/cjs/views/Search/SearchWalletViewAll.js +169 -0
- package/dist/cjs/views/Search/SearchWalletViewAll.js.map +1 -0
- package/dist/cjs/views/Search/components/BalanceItem.js +52 -0
- package/dist/cjs/views/Search/components/BalanceItem.js.map +1 -0
- package/dist/cjs/views/Search/components/CoinsTab.js +49 -0
- package/dist/cjs/views/Search/components/CoinsTab.js.map +1 -0
- package/dist/cjs/views/Search/components/CollectionsTab.js +49 -0
- package/dist/cjs/views/Search/components/CollectionsTab.js.map +1 -0
- package/dist/cjs/views/Search/components/WalletLink.js +15 -0
- package/dist/cjs/views/Search/components/WalletLink.js.map +1 -0
- package/dist/cjs/views/Search/index.js +19 -0
- package/dist/cjs/views/Search/index.js.map +1 -0
- package/dist/cjs/views/SendCoin.js +198 -0
- package/dist/cjs/views/SendCoin.js.map +1 -0
- package/dist/cjs/views/SendCollectible.js +237 -0
- package/dist/cjs/views/SendCollectible.js.map +1 -0
- package/dist/cjs/views/Settings/Currency.js +16 -0
- package/dist/cjs/views/Settings/Currency.js.map +1 -0
- package/dist/cjs/views/Settings/General.js +23 -0
- package/dist/cjs/views/Settings/General.js.map +1 -0
- package/dist/cjs/views/Settings/Menu.js +28 -0
- package/dist/cjs/views/Settings/Menu.js.map +1 -0
- package/dist/cjs/views/Settings/Network.js +35 -0
- package/dist/cjs/views/Settings/Network.js.map +1 -0
- package/dist/cjs/views/Settings/index.js +21 -0
- package/dist/cjs/views/Settings/index.js.map +1 -0
- package/dist/cjs/views/SwapCoin/SwapList.js +190 -0
- package/dist/cjs/views/SwapCoin/SwapList.js.map +1 -0
- package/dist/cjs/views/SwapCoin/index.js +89 -0
- package/dist/cjs/views/SwapCoin/index.js.map +1 -0
- package/dist/cjs/views/TransactionDetails/index.js +88 -0
- package/dist/cjs/views/TransactionDetails/index.js.map +1 -0
- package/dist/cjs/views/index.js +30 -0
- package/dist/cjs/views/index.js.map +1 -0
- package/dist/esm/components/Alert.js +11 -0
- package/dist/esm/components/Alert.js.map +1 -0
- package/dist/esm/components/CoinRow.js +14 -0
- package/dist/esm/components/CoinRow.js.map +1 -0
- package/dist/esm/components/CollectibleTileImage.js +6 -0
- package/dist/esm/components/CollectibleTileImage.js.map +1 -0
- package/dist/esm/components/CopyButton.js +21 -0
- package/dist/esm/components/CopyButton.js.map +1 -0
- package/dist/esm/components/DefaultIcon.js +9 -0
- package/dist/esm/components/DefaultIcon.js.map +1 -0
- package/dist/esm/components/FeeOptionSelector.js +41 -0
- package/dist/esm/components/FeeOptionSelector.js.map +1 -0
- package/dist/esm/components/InfiniteScroll.js +37 -0
- package/dist/esm/components/InfiniteScroll.js.map +1 -0
- package/dist/esm/components/Loader.js +6 -0
- package/dist/esm/components/Loader.js.map +1 -0
- package/dist/esm/components/NavigationHeader/index.js +22 -0
- package/dist/esm/components/NavigationHeader/index.js.map +1 -0
- package/dist/esm/components/NetworkBadge.js +14 -0
- package/dist/esm/components/NetworkBadge.js.map +1 -0
- package/dist/esm/components/SelectButton/SelectButton.js +8 -0
- package/dist/esm/components/SelectButton/SelectButton.js.map +1 -0
- package/dist/esm/components/SelectButton/SelectedIndicator.js +8 -0
- package/dist/esm/components/SelectButton/SelectedIndicator.js.map +1 -0
- package/dist/esm/components/SelectButton/index.js +2 -0
- package/dist/esm/components/SelectButton/index.js.map +1 -0
- package/dist/esm/components/SendItemInfo.js +16 -0
- package/dist/esm/components/SendItemInfo.js.map +1 -0
- package/dist/esm/components/SequenceWalletProvider/SequenceWalletProvider.js +50 -0
- package/dist/esm/components/SequenceWalletProvider/SequenceWalletProvider.js.map +1 -0
- package/dist/esm/components/SequenceWalletProvider/index.js +2 -0
- package/dist/esm/components/SequenceWalletProvider/index.js.map +1 -0
- package/dist/esm/components/SequenceWalletProvider/utils/index.js +79 -0
- package/dist/esm/components/SequenceWalletProvider/utils/index.js.map +1 -0
- package/dist/esm/components/TransactionConfirmation.js +61 -0
- package/dist/esm/components/TransactionConfirmation.js.map +1 -0
- package/dist/esm/components/TransactionHistoryList/TransactionHistoryItem.js +110 -0
- package/dist/esm/components/TransactionHistoryList/TransactionHistoryItem.js.map +1 -0
- package/dist/esm/components/TransactionHistoryList/TransactionHistorySkeleton.js +13 -0
- package/dist/esm/components/TransactionHistoryList/TransactionHistorySkeleton.js.map +1 -0
- package/dist/esm/components/TransactionHistoryList/index.js +93 -0
- package/dist/esm/components/TransactionHistoryList/index.js.map +1 -0
- package/dist/esm/components/WalletHeader/components/AccountInformation.js +12 -0
- package/dist/esm/components/WalletHeader/components/AccountInformation.js.map +1 -0
- package/dist/esm/components/WalletHeader/components/WalletDropdownContent.js +54 -0
- package/dist/esm/components/WalletHeader/components/WalletDropdownContent.js.map +1 -0
- package/dist/esm/components/WalletHeader/index.js +50 -0
- package/dist/esm/components/WalletHeader/index.js.map +1 -0
- package/dist/esm/constants/abi.js +89 -0
- package/dist/esm/constants/abi.js.map +1 -0
- package/dist/esm/constants/currency.js +26 -0
- package/dist/esm/constants/currency.js.map +1 -0
- package/dist/esm/constants/index.js +4 -0
- package/dist/esm/constants/index.js.map +1 -0
- package/dist/esm/constants/sizing.js +2 -0
- package/dist/esm/constants/sizing.js.map +1 -0
- package/dist/esm/contexts/Navigation.js +4 -0
- package/dist/esm/contexts/Navigation.js.map +1 -0
- package/dist/esm/contexts/WalletModal.js +4 -0
- package/dist/esm/contexts/WalletModal.js.map +1 -0
- package/dist/esm/contexts/genericContext.js +16 -0
- package/dist/esm/contexts/genericContext.js.map +1 -0
- package/dist/esm/contexts/index.js +3 -0
- package/dist/esm/contexts/index.js.map +1 -0
- package/dist/esm/hooks/index.js +4 -0
- package/dist/esm/hooks/index.js.map +1 -0
- package/dist/esm/hooks/useNavigation.js +19 -0
- package/dist/esm/hooks/useNavigation.js.map +1 -0
- package/dist/esm/hooks/useOpenWalletModal.js +6 -0
- package/dist/esm/hooks/useOpenWalletModal.js.map +1 -0
- package/dist/esm/hooks/useScrollbarWidth.js +9 -0
- package/dist/esm/hooks/useScrollbarWidth.js.map +1 -0
- package/dist/esm/hooks/useSettings.js +96 -0
- package/dist/esm/hooks/useSettings.js.map +1 -0
- package/dist/esm/index.js +6 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/utils/helpers.js +41 -0
- package/dist/esm/utils/helpers.js.map +1 -0
- package/dist/esm/utils/index.js +3 -0
- package/dist/esm/utils/index.js.map +1 -0
- package/dist/esm/utils/tokens.js +70 -0
- package/dist/esm/utils/tokens.js.map +1 -0
- package/dist/esm/views/CoinDetails/Skeleton.js +9 -0
- package/dist/esm/views/CoinDetails/Skeleton.js.map +1 -0
- package/dist/esm/views/CoinDetails/index.js +86 -0
- package/dist/esm/views/CoinDetails/index.js.map +1 -0
- package/dist/esm/views/CollectibleDetails/Skeleton.js +10 -0
- package/dist/esm/views/CollectibleDetails/Skeleton.js.map +1 -0
- package/dist/esm/views/CollectibleDetails/index.js +79 -0
- package/dist/esm/views/CollectibleDetails/index.js.map +1 -0
- package/dist/esm/views/CollectionDetails/Skeleton.js +11 -0
- package/dist/esm/views/CollectionDetails/Skeleton.js.map +1 -0
- package/dist/esm/views/CollectionDetails/index.js +46 -0
- package/dist/esm/views/CollectionDetails/index.js.map +1 -0
- package/dist/esm/views/History.js +15 -0
- package/dist/esm/views/History.js.map +1 -0
- package/dist/esm/views/Home/components/AssetSummary/CoinTile/CoinTileContent.js +10 -0
- package/dist/esm/views/Home/components/AssetSummary/CoinTile/CoinTileContent.js.map +1 -0
- package/dist/esm/views/Home/components/AssetSummary/CoinTile/index.js +56 -0
- package/dist/esm/views/Home/components/AssetSummary/CoinTile/index.js.map +1 -0
- package/dist/esm/views/Home/components/AssetSummary/CollectibleTile/index.js +13 -0
- package/dist/esm/views/Home/components/AssetSummary/CollectibleTile/index.js.map +1 -0
- package/dist/esm/views/Home/components/AssetSummary/SkeletonTiles.js +10 -0
- package/dist/esm/views/Home/components/AssetSummary/SkeletonTiles.js.map +1 -0
- package/dist/esm/views/Home/components/AssetSummary/index.js +94 -0
- package/dist/esm/views/Home/components/AssetSummary/index.js.map +1 -0
- package/dist/esm/views/Home/index.js +6 -0
- package/dist/esm/views/Home/index.js.map +1 -0
- package/dist/esm/views/Receive.js +38 -0
- package/dist/esm/views/Receive.js.map +1 -0
- package/dist/esm/views/Search/SearchWallet.js +105 -0
- package/dist/esm/views/Search/SearchWallet.js.map +1 -0
- package/dist/esm/views/Search/SearchWalletViewAll.js +162 -0
- package/dist/esm/views/Search/SearchWalletViewAll.js.map +1 -0
- package/dist/esm/views/Search/components/BalanceItem.js +48 -0
- package/dist/esm/views/Search/components/BalanceItem.js.map +1 -0
- package/dist/esm/views/Search/components/CoinsTab.js +45 -0
- package/dist/esm/views/Search/components/CoinsTab.js.map +1 -0
- package/dist/esm/views/Search/components/CollectionsTab.js +45 -0
- package/dist/esm/views/Search/components/CollectionsTab.js.map +1 -0
- package/dist/esm/views/Search/components/WalletLink.js +11 -0
- package/dist/esm/views/Search/components/WalletLink.js.map +1 -0
- package/dist/esm/views/Search/index.js +3 -0
- package/dist/esm/views/Search/index.js.map +1 -0
- package/dist/esm/views/SendCoin.js +194 -0
- package/dist/esm/views/SendCoin.js.map +1 -0
- package/dist/esm/views/SendCollectible.js +233 -0
- package/dist/esm/views/SendCollectible.js.map +1 -0
- package/dist/esm/views/Settings/Currency.js +12 -0
- package/dist/esm/views/Settings/Currency.js.map +1 -0
- package/dist/esm/views/Settings/General.js +19 -0
- package/dist/esm/views/Settings/General.js.map +1 -0
- package/dist/esm/views/Settings/Menu.js +24 -0
- package/dist/esm/views/Settings/Menu.js.map +1 -0
- package/dist/esm/views/Settings/Network.js +31 -0
- package/dist/esm/views/Settings/Network.js.map +1 -0
- package/dist/esm/views/Settings/index.js +5 -0
- package/dist/esm/views/Settings/index.js.map +1 -0
- package/dist/esm/views/SwapCoin/SwapList.js +186 -0
- package/dist/esm/views/SwapCoin/SwapList.js.map +1 -0
- package/dist/esm/views/SwapCoin/index.js +85 -0
- package/dist/esm/views/SwapCoin/index.js.map +1 -0
- package/dist/esm/views/TransactionDetails/index.js +81 -0
- package/dist/esm/views/TransactionDetails/index.js.map +1 -0
- package/dist/esm/views/index.js +14 -0
- package/dist/esm/views/index.js.map +1 -0
- package/dist/types/components/Alert.d.ts +12 -0
- package/dist/types/components/Alert.d.ts.map +1 -0
- package/dist/types/components/CoinRow.d.ts +13 -0
- package/dist/types/components/CoinRow.d.ts.map +1 -0
- package/dist/types/components/CollectibleTileImage.d.ts +6 -0
- package/dist/types/components/CollectibleTileImage.d.ts.map +1 -0
- package/dist/types/components/CopyButton.d.ts +10 -0
- package/dist/types/components/CopyButton.d.ts.map +1 -0
- package/dist/types/components/DefaultIcon.d.ts +6 -0
- package/dist/types/components/DefaultIcon.d.ts.map +1 -0
- package/dist/types/components/FeeOptionSelector.d.ts +29 -0
- package/dist/types/components/FeeOptionSelector.d.ts.map +1 -0
- package/dist/types/components/InfiniteScroll.d.ts +9 -0
- package/dist/types/components/InfiniteScroll.d.ts.map +1 -0
- package/dist/types/components/Loader.d.ts +2 -0
- package/dist/types/components/Loader.d.ts.map +1 -0
- package/dist/types/components/NavigationHeader/index.d.ts +7 -0
- package/dist/types/components/NavigationHeader/index.d.ts.map +1 -0
- package/dist/types/components/NetworkBadge.d.ts +6 -0
- package/dist/types/components/NetworkBadge.d.ts.map +1 -0
- package/dist/types/components/SelectButton/SelectButton.d.ts +13 -0
- package/dist/types/components/SelectButton/SelectButton.d.ts.map +1 -0
- package/dist/types/components/SelectButton/SelectedIndicator.d.ts +8 -0
- package/dist/types/components/SelectButton/SelectedIndicator.d.ts.map +1 -0
- package/dist/types/components/SelectButton/index.d.ts +2 -0
- package/dist/types/components/SelectButton/index.d.ts.map +1 -0
- package/dist/types/components/SendItemInfo.d.ts +15 -0
- package/dist/types/components/SendItemInfo.d.ts.map +1 -0
- package/dist/types/components/SequenceWalletProvider/SequenceWalletProvider.d.ts +7 -0
- package/dist/types/components/SequenceWalletProvider/SequenceWalletProvider.d.ts.map +1 -0
- package/dist/types/components/SequenceWalletProvider/index.d.ts +2 -0
- package/dist/types/components/SequenceWalletProvider/index.d.ts.map +1 -0
- package/dist/types/components/SequenceWalletProvider/utils/index.d.ts +4 -0
- package/dist/types/components/SequenceWalletProvider/utils/index.d.ts.map +1 -0
- package/dist/types/components/TransactionConfirmation.d.ts +24 -0
- package/dist/types/components/TransactionConfirmation.d.ts.map +1 -0
- package/dist/types/components/TransactionHistoryList/TransactionHistoryItem.d.ts +7 -0
- package/dist/types/components/TransactionHistoryList/TransactionHistoryItem.d.ts.map +1 -0
- package/dist/types/components/TransactionHistoryList/TransactionHistorySkeleton.d.ts +2 -0
- package/dist/types/components/TransactionHistoryList/TransactionHistorySkeleton.d.ts.map +1 -0
- package/dist/types/components/TransactionHistoryList/index.d.ts +9 -0
- package/dist/types/components/TransactionHistoryList/index.d.ts.map +1 -0
- package/dist/types/components/WalletHeader/components/AccountInformation.d.ts +7 -0
- package/dist/types/components/WalletHeader/components/AccountInformation.d.ts.map +1 -0
- package/dist/types/components/WalletHeader/components/WalletDropdownContent.d.ts +7 -0
- package/dist/types/components/WalletHeader/components/WalletDropdownContent.d.ts.map +1 -0
- package/dist/types/components/WalletHeader/index.d.ts +2 -0
- package/dist/types/components/WalletHeader/index.d.ts.map +1 -0
- package/dist/types/constants/abi.d.ts +40 -0
- package/dist/types/constants/abi.d.ts.map +1 -0
- package/dist/types/constants/currency.d.ts +11 -0
- package/dist/types/constants/currency.d.ts.map +1 -0
- package/dist/types/constants/index.d.ts +4 -0
- package/dist/types/constants/index.d.ts.map +1 -0
- package/dist/types/constants/sizing.d.ts +2 -0
- package/dist/types/constants/sizing.d.ts.map +1 -0
- package/dist/types/contexts/Navigation.d.ts +88 -0
- package/dist/types/contexts/Navigation.d.ts.map +1 -0
- package/dist/types/contexts/WalletModal.d.ts +11 -0
- package/dist/types/contexts/WalletModal.d.ts.map +1 -0
- package/dist/types/contexts/genericContext.d.ts +2 -0
- package/dist/types/contexts/genericContext.d.ts.map +1 -0
- package/dist/types/contexts/index.d.ts +3 -0
- package/dist/types/contexts/index.d.ts.map +1 -0
- package/dist/types/hooks/index.d.ts +4 -0
- package/dist/types/hooks/index.d.ts.map +1 -0
- package/dist/types/hooks/useNavigation.d.ts +10 -0
- package/dist/types/hooks/useNavigation.d.ts.map +1 -0
- package/dist/types/hooks/useOpenWalletModal.d.ts +5 -0
- package/dist/types/hooks/useOpenWalletModal.d.ts.map +1 -0
- package/dist/types/hooks/useScrollbarWidth.d.ts +2 -0
- package/dist/types/hooks/useScrollbarWidth.d.ts.map +1 -0
- package/dist/types/hooks/useSettings.d.ts +14 -0
- package/dist/types/hooks/useSettings.d.ts.map +1 -0
- package/dist/types/index.d.ts +4 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/utils/helpers.d.ts +6 -0
- package/dist/types/utils/helpers.d.ts.map +1 -0
- package/dist/types/utils/index.d.ts +3 -0
- package/dist/types/utils/index.d.ts.map +1 -0
- package/dist/types/utils/tokens.d.ts +21 -0
- package/dist/types/utils/tokens.d.ts.map +1 -0
- package/dist/types/views/CoinDetails/Skeleton.d.ts +7 -0
- package/dist/types/views/CoinDetails/Skeleton.d.ts.map +1 -0
- package/dist/types/views/CoinDetails/index.d.ts +6 -0
- package/dist/types/views/CoinDetails/index.d.ts.map +1 -0
- package/dist/types/views/CollectibleDetails/Skeleton.d.ts +6 -0
- package/dist/types/views/CollectibleDetails/Skeleton.d.ts.map +1 -0
- package/dist/types/views/CollectibleDetails/index.d.ts +7 -0
- package/dist/types/views/CollectibleDetails/index.d.ts.map +1 -0
- package/dist/types/views/CollectionDetails/Skeleton.d.ts +6 -0
- package/dist/types/views/CollectionDetails/Skeleton.d.ts.map +1 -0
- package/dist/types/views/CollectionDetails/index.d.ts +7 -0
- package/dist/types/views/CollectionDetails/index.d.ts.map +1 -0
- package/dist/types/views/History.d.ts +2 -0
- package/dist/types/views/History.d.ts.map +1 -0
- package/dist/types/views/Home/components/AssetSummary/CoinTile/CoinTileContent.d.ts +12 -0
- package/dist/types/views/Home/components/AssetSummary/CoinTile/CoinTileContent.d.ts.map +1 -0
- package/dist/types/views/Home/components/AssetSummary/CoinTile/index.d.ts +7 -0
- package/dist/types/views/Home/components/AssetSummary/CoinTile/index.d.ts.map +1 -0
- package/dist/types/views/Home/components/AssetSummary/CollectibleTile/index.d.ts +7 -0
- package/dist/types/views/Home/components/AssetSummary/CollectibleTile/index.d.ts.map +1 -0
- package/dist/types/views/Home/components/AssetSummary/SkeletonTiles.d.ts +2 -0
- package/dist/types/views/Home/components/AssetSummary/SkeletonTiles.d.ts.map +1 -0
- package/dist/types/views/Home/components/AssetSummary/index.d.ts +2 -0
- package/dist/types/views/Home/components/AssetSummary/index.d.ts.map +1 -0
- package/dist/types/views/Home/index.d.ts +2 -0
- package/dist/types/views/Home/index.d.ts.map +1 -0
- package/dist/types/views/Receive.d.ts +2 -0
- package/dist/types/views/Receive.d.ts.map +1 -0
- package/dist/types/views/Search/SearchWallet.d.ts +2 -0
- package/dist/types/views/Search/SearchWallet.d.ts.map +1 -0
- package/dist/types/views/Search/SearchWalletViewAll.d.ts +10 -0
- package/dist/types/views/Search/SearchWalletViewAll.d.ts.map +1 -0
- package/dist/types/views/Search/components/BalanceItem.d.ts +7 -0
- package/dist/types/views/Search/components/BalanceItem.d.ts.map +1 -0
- package/dist/types/views/Search/components/CoinsTab.d.ts +16 -0
- package/dist/types/views/Search/components/CoinsTab.d.ts.map +1 -0
- package/dist/types/views/Search/components/CollectionsTab.d.ts +16 -0
- package/dist/types/views/Search/components/CollectionsTab.d.ts.map +1 -0
- package/dist/types/views/Search/components/WalletLink.d.ts +8 -0
- package/dist/types/views/Search/components/WalletLink.d.ts.map +1 -0
- package/dist/types/views/Search/index.d.ts +3 -0
- package/dist/types/views/Search/index.d.ts.map +1 -0
- package/dist/types/views/SendCoin.d.ts +7 -0
- package/dist/types/views/SendCoin.d.ts.map +1 -0
- package/dist/types/views/SendCollectible.d.ts +8 -0
- package/dist/types/views/SendCollectible.d.ts.map +1 -0
- package/dist/types/views/Settings/Currency.d.ts +2 -0
- package/dist/types/views/Settings/Currency.d.ts.map +1 -0
- package/dist/types/views/Settings/General.d.ts +2 -0
- package/dist/types/views/Settings/General.d.ts.map +1 -0
- package/dist/types/views/Settings/Menu.d.ts +2 -0
- package/dist/types/views/Settings/Menu.d.ts.map +1 -0
- package/dist/types/views/Settings/Network.d.ts +2 -0
- package/dist/types/views/Settings/Network.d.ts.map +1 -0
- package/dist/types/views/Settings/index.d.ts +5 -0
- package/dist/types/views/Settings/index.d.ts.map +1 -0
- package/dist/types/views/SwapCoin/SwapList.d.ts +8 -0
- package/dist/types/views/SwapCoin/SwapList.d.ts.map +1 -0
- package/dist/types/views/SwapCoin/index.d.ts +6 -0
- package/dist/types/views/SwapCoin/index.d.ts.map +1 -0
- package/dist/types/views/TransactionDetails/index.d.ts +7 -0
- package/dist/types/views/TransactionDetails/index.d.ts.map +1 -0
- package/dist/types/views/index.d.ts +14 -0
- package/dist/types/views/index.d.ts.map +1 -0
- package/package.json +69 -0
- package/src/components/Alert.tsx +51 -0
- package/src/components/CoinRow.tsx +62 -0
- package/src/components/CollectibleTileImage.tsx +14 -0
- package/src/components/CopyButton.tsx +41 -0
- package/src/components/DefaultIcon.tsx +22 -0
- package/src/components/FeeOptionSelector.tsx +133 -0
- package/src/components/InfiniteScroll.tsx +56 -0
- package/src/components/Loader.tsx +12 -0
- package/src/components/NavigationHeader/index.tsx +59 -0
- package/src/components/NetworkBadge.tsx +35 -0
- package/src/components/SelectButton/SelectButton.tsx +33 -0
- package/src/components/SelectButton/SelectedIndicator.tsx +34 -0
- package/src/components/SelectButton/index.ts +1 -0
- package/src/components/SendItemInfo.tsx +83 -0
- package/src/components/SequenceWalletProvider/SequenceWalletProvider.tsx +96 -0
- package/src/components/SequenceWalletProvider/index.ts +1 -0
- package/src/components/SequenceWalletProvider/utils/index.tsx +119 -0
- package/src/components/TransactionConfirmation.tsx +183 -0
- package/src/components/TransactionHistoryList/TransactionHistoryItem.tsx +190 -0
- package/src/components/TransactionHistoryList/TransactionHistorySkeleton.tsx +36 -0
- package/src/components/TransactionHistoryList/index.tsx +160 -0
- package/src/components/WalletHeader/components/AccountInformation.tsx +31 -0
- package/src/components/WalletHeader/components/WalletDropdownContent.tsx +96 -0
- package/src/components/WalletHeader/index.tsx +84 -0
- package/src/constants/abi.ts +90 -0
- package/src/constants/currency.ts +35 -0
- package/src/constants/index.ts +3 -0
- package/src/constants/sizing.ts +1 -0
- package/src/contexts/Navigation.ts +132 -0
- package/src/contexts/WalletModal.ts +15 -0
- package/src/contexts/genericContext.ts +19 -0
- package/src/contexts/index.ts +2 -0
- package/src/hooks/index.ts +3 -0
- package/src/hooks/useNavigation.ts +30 -0
- package/src/hooks/useOpenWalletModal.ts +7 -0
- package/src/hooks/useScrollbarWidth.ts +11 -0
- package/src/hooks/useSettings.ts +121 -0
- package/src/index.ts +6 -0
- package/src/utils/helpers.ts +51 -0
- package/src/utils/index.ts +2 -0
- package/src/utils/tokens.ts +98 -0
- package/src/views/CoinDetails/Skeleton.tsx +46 -0
- package/src/views/CoinDetails/index.tsx +153 -0
- package/src/views/CollectibleDetails/Skeleton.tsx +50 -0
- package/src/views/CollectibleDetails/index.tsx +184 -0
- package/src/views/CollectionDetails/Skeleton.tsx +36 -0
- package/src/views/CollectionDetails/index.tsx +98 -0
- package/src/views/History.tsx +28 -0
- package/src/views/Home/components/AssetSummary/CoinTile/CoinTileContent.tsx +60 -0
- package/src/views/Home/components/AssetSummary/CoinTile/index.tsx +93 -0
- package/src/views/Home/components/AssetSummary/CollectibleTile/index.tsx +20 -0
- package/src/views/Home/components/AssetSummary/SkeletonTiles.tsx +21 -0
- package/src/views/Home/components/AssetSummary/index.tsx +128 -0
- package/src/views/Home/index.tsx +11 -0
- package/src/views/Receive.tsx +83 -0
- package/src/views/Search/SearchWallet.tsx +177 -0
- package/src/views/Search/SearchWalletViewAll.tsx +265 -0
- package/src/views/Search/components/BalanceItem.tsx +76 -0
- package/src/views/Search/components/CoinsTab.tsx +89 -0
- package/src/views/Search/components/CollectionsTab.tsx +88 -0
- package/src/views/Search/components/WalletLink.tsx +32 -0
- package/src/views/Search/index.ts +2 -0
- package/src/views/SendCoin.tsx +397 -0
- package/src/views/SendCollectible.tsx +447 -0
- package/src/views/Settings/Currency.tsx +34 -0
- package/src/views/Settings/General.tsx +55 -0
- package/src/views/Settings/Menu.tsx +60 -0
- package/src/views/Settings/Network.tsx +60 -0
- package/src/views/Settings/index.ts +4 -0
- package/src/views/SwapCoin/SwapList.tsx +320 -0
- package/src/views/SwapCoin/index.tsx +150 -0
- package/src/views/TransactionDetails/index.tsx +213 -0
- 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 @@
|
|
|
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 @@
|
|
|
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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"}
|