thirdweb 5.64.0-nightly-cdb907f175f7472d1fb3dea6547d946514564085-20241023000322 → 5.64.0-nightly-e6e994479fb8386b1740de4170f33446f038f2b1-20241024000332
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/dist/cjs/analytics/track/connect.js +21 -0
- package/dist/cjs/analytics/track/connect.js.map +1 -0
- package/dist/cjs/analytics/track/index.js +21 -0
- package/dist/cjs/analytics/track/index.js.map +1 -0
- package/dist/cjs/analytics/track/pay.js +26 -0
- package/dist/cjs/analytics/track/pay.js.map +1 -0
- package/dist/cjs/analytics/track/siwe.js +32 -0
- package/dist/cjs/analytics/track/siwe.js.map +1 -0
- package/dist/cjs/analytics/track/transaction.js +36 -0
- package/dist/cjs/analytics/track/transaction.js.map +1 -0
- package/dist/cjs/auth/core/verify-login-payload.js +19 -1
- package/dist/cjs/auth/core/verify-login-payload.js.map +1 -1
- package/dist/cjs/exports/extensions/erc721.js +3 -1
- package/dist/cjs/exports/extensions/erc721.js.map +1 -1
- package/dist/cjs/exports/wallets/in-app.js +2 -1
- package/dist/cjs/exports/wallets/in-app.js.map +1 -1
- package/dist/cjs/extensions/erc1155/write/mintAdditionalSupplyToBatch.js +41 -1
- package/dist/cjs/extensions/erc1155/write/mintAdditionalSupplyToBatch.js.map +1 -1
- package/dist/cjs/extensions/erc721/drops/write/claimToBatch.js +115 -0
- package/dist/cjs/extensions/erc721/drops/write/claimToBatch.js.map +1 -0
- package/dist/cjs/react/core/utils/walletIcon.js +2 -2
- package/dist/cjs/react/core/utils/walletIcon.js.map +1 -1
- package/dist/cjs/react/web/hooks/transaction/useSendTransaction.js +3 -4
- package/dist/cjs/react/web/hooks/transaction/useSendTransaction.js.map +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/Details.js +2 -2
- package/dist/cjs/react/web/ui/ConnectWallet/Details.js.map +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/BuyScreen.js +3 -3
- package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/BuyScreen.js.map +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/DirectPaymentModeScreen.js +2 -2
- package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/DirectPaymentModeScreen.js.map +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/TransactionModeScreen.js +2 -2
- package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/TransactionModeScreen.js.map +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/fiat/FiatFlow.js +2 -2
- package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/fiat/FiatFlow.js.map +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/swap/ConfirmationScreen.js +5 -5
- package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/swap/ConfirmationScreen.js.map +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/screens/LinkedProfilesScreen.js +1 -1
- package/dist/cjs/react/web/ui/TransactionButton/TransactionModal.js +2 -2
- package/dist/cjs/react/web/ui/TransactionButton/TransactionModal.js.map +1 -1
- package/dist/cjs/react/web/ui/components/WalletImage.js +1 -1
- package/dist/cjs/react/web/wallets/shared/ConnectWalletSocialOptions.js +2 -2
- package/dist/cjs/version.js +1 -1
- package/dist/cjs/wallets/__generated__/getWalletInfo.js +45 -15
- package/dist/cjs/wallets/__generated__/getWalletInfo.js.map +1 -1
- package/dist/cjs/wallets/__generated__/wallet/app.nightly/image.js +7 -0
- package/dist/cjs/wallets/__generated__/wallet/app.nightly/image.js.map +1 -0
- package/dist/cjs/wallets/__generated__/wallet/app.nightly/index.js +34 -0
- package/dist/cjs/wallets/__generated__/wallet/app.nightly/index.js.map +1 -0
- package/dist/cjs/wallets/__generated__/wallet/app.status/image.js +1 -1
- package/dist/cjs/wallets/__generated__/wallet/app.status/image.js.map +1 -1
- package/dist/cjs/wallets/__generated__/wallet/app.status/index.js +1 -1
- package/dist/cjs/wallets/__generated__/wallet/app.walletnow/index.js +1 -1
- package/dist/cjs/wallets/__generated__/wallet/app.walletnow/index.js.map +1 -1
- package/dist/cjs/wallets/__generated__/wallet/com.beexo/image.js +7 -0
- package/dist/cjs/wallets/__generated__/wallet/com.beexo/image.js.map +1 -0
- package/dist/cjs/wallets/__generated__/wallet/{org.nitrogen → com.beexo}/index.js +9 -9
- package/dist/cjs/wallets/__generated__/wallet/com.beexo/index.js.map +1 -0
- package/dist/cjs/wallets/__generated__/wallet/com.brave.wallet/image.js +1 -1
- package/dist/cjs/wallets/__generated__/wallet/com.brave.wallet/image.js.map +1 -1
- package/dist/cjs/wallets/__generated__/wallet/com.brave.wallet/index.js +9 -9
- package/dist/cjs/wallets/__generated__/wallet/com.brave.wallet/index.js.map +1 -1
- package/dist/cjs/wallets/__generated__/wallet/com.coin98/image.js +1 -1
- package/dist/cjs/wallets/__generated__/wallet/com.coin98/image.js.map +1 -1
- package/dist/cjs/wallets/__generated__/wallet/com.coin98/index.js +1 -1
- package/dist/cjs/wallets/__generated__/wallet/com.crypto/image.js +1 -1
- package/dist/cjs/wallets/__generated__/wallet/com.crypto/image.js.map +1 -1
- package/dist/cjs/wallets/__generated__/wallet/com.crypto/index.js +1 -1
- package/dist/cjs/wallets/__generated__/wallet/com.daffione/image.js +7 -0
- package/dist/cjs/wallets/__generated__/wallet/{org.nitrogen → com.daffione}/image.js.map +1 -1
- package/dist/cjs/wallets/__generated__/wallet/com.daffione/index.js +34 -0
- package/dist/cjs/wallets/__generated__/wallet/com.daffione/index.js.map +1 -0
- package/dist/cjs/wallets/__generated__/wallet/com.ipmb/image.js +7 -0
- package/dist/cjs/wallets/__generated__/wallet/com.ipmb/image.js.map +1 -0
- package/dist/cjs/wallets/__generated__/wallet/com.ipmb/index.js +34 -0
- package/dist/cjs/wallets/__generated__/wallet/com.ipmb/index.js.map +1 -0
- package/dist/cjs/wallets/__generated__/wallet/com.webauth/image.js +7 -0
- package/dist/cjs/wallets/__generated__/wallet/com.webauth/image.js.map +1 -0
- package/dist/cjs/wallets/__generated__/wallet/com.webauth/index.js +34 -0
- package/dist/cjs/wallets/__generated__/wallet/com.webauth/index.js.map +1 -0
- package/dist/cjs/wallets/__generated__/wallet/finance.openwallet/index.js +2 -2
- package/dist/cjs/wallets/__generated__/wallet/finance.openwallet/index.js.map +1 -1
- package/dist/cjs/wallets/__generated__/wallet/finance.plena/index.js +1 -1
- package/dist/cjs/wallets/__generated__/wallet/finance.plena/index.js.map +1 -1
- package/dist/cjs/wallets/__generated__/wallet/id.plumaa/image.js +7 -0
- package/dist/cjs/wallets/__generated__/wallet/id.plumaa/image.js.map +1 -0
- package/dist/cjs/wallets/__generated__/wallet/id.plumaa/index.js +34 -0
- package/dist/cjs/wallets/__generated__/wallet/id.plumaa/index.js.map +1 -0
- package/dist/cjs/wallets/__generated__/wallet/io.miraiapp/image.js +1 -1
- package/dist/cjs/wallets/__generated__/wallet/io.miraiapp/image.js.map +1 -1
- package/dist/cjs/wallets/__generated__/wallet/io.miraiapp/index.js +1 -1
- package/dist/cjs/wallets/__generated__/wallet/io.owallet/image.js +7 -0
- package/dist/cjs/wallets/__generated__/wallet/io.owallet/image.js.map +1 -0
- package/dist/cjs/wallets/__generated__/wallet/io.owallet/index.js +34 -0
- package/dist/cjs/wallets/__generated__/wallet/io.owallet/index.js.map +1 -0
- package/dist/cjs/wallets/__generated__/wallet/io.tradestrike/image.js +1 -1
- package/dist/cjs/wallets/__generated__/wallet/io.tradestrike/image.js.map +1 -1
- package/dist/cjs/wallets/__generated__/wallet/io.tradestrike/index.js +2 -2
- package/dist/cjs/wallets/__generated__/wallet/io.tradestrike/index.js.map +1 -1
- package/dist/cjs/wallets/__generated__/wallet-infos.js +45 -15
- package/dist/cjs/wallets/__generated__/wallet-infos.js.map +1 -1
- package/dist/cjs/wallets/coinbase/coinbase-wallet.js +3 -3
- package/dist/cjs/wallets/coinbase/coinbase-wallet.js.map +1 -1
- package/dist/cjs/wallets/coinbase/coinbaseWebSDK.js +20 -8
- package/dist/cjs/wallets/coinbase/coinbaseWebSDK.js.map +1 -1
- package/dist/cjs/wallets/create-wallet.js +11 -6
- package/dist/cjs/wallets/create-wallet.js.map +1 -1
- package/dist/cjs/wallets/in-app/core/wallet/enclave-wallet.js +13 -3
- package/dist/cjs/wallets/in-app/core/wallet/enclave-wallet.js.map +1 -1
- package/dist/cjs/wallets/in-app/core/wallet/in-app-core.js +5 -3
- package/dist/cjs/wallets/in-app/core/wallet/in-app-core.js.map +1 -1
- package/dist/cjs/wallets/in-app/web/lib/iframe-wallet.js +9 -2
- package/dist/cjs/wallets/in-app/web/lib/iframe-wallet.js.map +1 -1
- package/dist/cjs/wallets/injected/index.js +36 -8
- package/dist/cjs/wallets/injected/index.js.map +1 -1
- package/dist/cjs/wallets/native/create-wallet.js +3 -3
- package/dist/cjs/wallets/native/create-wallet.js.map +1 -1
- package/dist/cjs/wallets/smart/smart-wallet.js +3 -3
- package/dist/cjs/wallets/smart/smart-wallet.js.map +1 -1
- package/dist/cjs/wallets/wallet-connect/controller.js +20 -8
- package/dist/cjs/wallets/wallet-connect/controller.js.map +1 -1
- package/dist/esm/analytics/track/connect.js +18 -0
- package/dist/esm/analytics/track/connect.js.map +1 -0
- package/dist/esm/analytics/track/index.js +18 -0
- package/dist/esm/analytics/track/index.js.map +1 -0
- package/dist/esm/analytics/track/pay.js +23 -0
- package/dist/esm/analytics/track/pay.js.map +1 -0
- package/dist/esm/analytics/track/siwe.js +29 -0
- package/dist/esm/analytics/track/siwe.js.map +1 -0
- package/dist/esm/analytics/track/transaction.js +33 -0
- package/dist/esm/analytics/track/transaction.js.map +1 -0
- package/dist/esm/auth/core/verify-login-payload.js +19 -1
- package/dist/esm/auth/core/verify-login-payload.js.map +1 -1
- package/dist/esm/exports/extensions/erc721.js +1 -0
- package/dist/esm/exports/extensions/erc721.js.map +1 -1
- package/dist/esm/exports/wallets/in-app.js +1 -1
- package/dist/esm/exports/wallets/in-app.js.map +1 -1
- package/dist/esm/extensions/erc1155/write/mintAdditionalSupplyToBatch.js +40 -1
- package/dist/esm/extensions/erc1155/write/mintAdditionalSupplyToBatch.js.map +1 -1
- package/dist/esm/extensions/erc721/drops/write/claimToBatch.js +111 -0
- package/dist/esm/extensions/erc721/drops/write/claimToBatch.js.map +1 -0
- package/dist/esm/react/core/utils/walletIcon.js +1 -1
- package/dist/esm/react/core/utils/walletIcon.js.map +1 -1
- package/dist/esm/react/web/hooks/transaction/useSendTransaction.js +3 -4
- package/dist/esm/react/web/hooks/transaction/useSendTransaction.js.map +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/Details.js +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/Details.js.map +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/BuyScreen.js +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/BuyScreen.js.map +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/DirectPaymentModeScreen.js +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/DirectPaymentModeScreen.js.map +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/TransactionModeScreen.js +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/TransactionModeScreen.js.map +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/fiat/FiatFlow.js +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/fiat/FiatFlow.js.map +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/swap/ConfirmationScreen.js +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/swap/ConfirmationScreen.js.map +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/screens/LinkedProfilesScreen.js +2 -2
- package/dist/esm/react/web/ui/TransactionButton/TransactionModal.js +1 -1
- package/dist/esm/react/web/ui/TransactionButton/TransactionModal.js.map +1 -1
- package/dist/esm/react/web/ui/components/WalletImage.js +2 -2
- package/dist/esm/react/web/wallets/shared/ConnectWalletSocialOptions.js +3 -3
- package/dist/esm/version.js +1 -1
- package/dist/esm/wallets/__generated__/getWalletInfo.js +45 -15
- package/dist/esm/wallets/__generated__/getWalletInfo.js.map +1 -1
- package/dist/esm/wallets/__generated__/wallet/app.nightly/image.js +5 -0
- package/dist/esm/wallets/__generated__/wallet/app.nightly/image.js.map +1 -0
- package/dist/esm/wallets/__generated__/wallet/app.nightly/index.js +31 -0
- package/dist/esm/wallets/__generated__/wallet/app.nightly/index.js.map +1 -0
- package/dist/esm/wallets/__generated__/wallet/app.status/image.js +1 -1
- package/dist/esm/wallets/__generated__/wallet/app.status/image.js.map +1 -1
- package/dist/esm/wallets/__generated__/wallet/app.status/index.js +1 -1
- package/dist/esm/wallets/__generated__/wallet/app.walletnow/index.js +1 -1
- package/dist/esm/wallets/__generated__/wallet/app.walletnow/index.js.map +1 -1
- package/dist/esm/wallets/__generated__/wallet/com.beexo/image.js +5 -0
- package/dist/esm/wallets/__generated__/wallet/com.beexo/image.js.map +1 -0
- package/dist/esm/wallets/__generated__/wallet/{org.nitrogen → com.beexo}/index.js +9 -9
- package/dist/esm/wallets/__generated__/wallet/com.beexo/index.js.map +1 -0
- package/dist/esm/wallets/__generated__/wallet/com.brave.wallet/image.js +1 -1
- package/dist/esm/wallets/__generated__/wallet/com.brave.wallet/image.js.map +1 -1
- package/dist/esm/wallets/__generated__/wallet/com.brave.wallet/index.js +9 -9
- package/dist/esm/wallets/__generated__/wallet/com.brave.wallet/index.js.map +1 -1
- package/dist/esm/wallets/__generated__/wallet/com.coin98/image.js +1 -1
- package/dist/esm/wallets/__generated__/wallet/com.coin98/image.js.map +1 -1
- package/dist/esm/wallets/__generated__/wallet/com.coin98/index.js +1 -1
- package/dist/esm/wallets/__generated__/wallet/com.crypto/image.js +1 -1
- package/dist/esm/wallets/__generated__/wallet/com.crypto/image.js.map +1 -1
- package/dist/esm/wallets/__generated__/wallet/com.crypto/index.js +1 -1
- package/dist/esm/wallets/__generated__/wallet/com.daffione/image.js +5 -0
- package/dist/esm/wallets/__generated__/wallet/{org.nitrogen → com.daffione}/image.js.map +1 -1
- package/dist/esm/wallets/__generated__/wallet/com.daffione/index.js +31 -0
- package/dist/esm/wallets/__generated__/wallet/com.daffione/index.js.map +1 -0
- package/dist/esm/wallets/__generated__/wallet/com.ipmb/image.js +5 -0
- package/dist/esm/wallets/__generated__/wallet/com.ipmb/image.js.map +1 -0
- package/dist/esm/wallets/__generated__/wallet/com.ipmb/index.js +31 -0
- package/dist/esm/wallets/__generated__/wallet/com.ipmb/index.js.map +1 -0
- package/dist/esm/wallets/__generated__/wallet/com.webauth/image.js +5 -0
- package/dist/esm/wallets/__generated__/wallet/com.webauth/image.js.map +1 -0
- package/dist/esm/wallets/__generated__/wallet/com.webauth/index.js +31 -0
- package/dist/esm/wallets/__generated__/wallet/com.webauth/index.js.map +1 -0
- package/dist/esm/wallets/__generated__/wallet/finance.openwallet/index.js +2 -2
- package/dist/esm/wallets/__generated__/wallet/finance.openwallet/index.js.map +1 -1
- package/dist/esm/wallets/__generated__/wallet/finance.plena/index.js +1 -1
- package/dist/esm/wallets/__generated__/wallet/finance.plena/index.js.map +1 -1
- package/dist/esm/wallets/__generated__/wallet/id.plumaa/image.js +5 -0
- package/dist/esm/wallets/__generated__/wallet/id.plumaa/image.js.map +1 -0
- package/dist/esm/wallets/__generated__/wallet/id.plumaa/index.js +31 -0
- package/dist/esm/wallets/__generated__/wallet/id.plumaa/index.js.map +1 -0
- package/dist/esm/wallets/__generated__/wallet/io.miraiapp/image.js +1 -1
- package/dist/esm/wallets/__generated__/wallet/io.miraiapp/image.js.map +1 -1
- package/dist/esm/wallets/__generated__/wallet/io.miraiapp/index.js +1 -1
- package/dist/esm/wallets/__generated__/wallet/io.owallet/image.js +5 -0
- package/dist/esm/wallets/__generated__/wallet/io.owallet/image.js.map +1 -0
- package/dist/esm/wallets/__generated__/wallet/io.owallet/index.js +31 -0
- package/dist/esm/wallets/__generated__/wallet/io.owallet/index.js.map +1 -0
- package/dist/esm/wallets/__generated__/wallet/io.tradestrike/image.js +1 -1
- package/dist/esm/wallets/__generated__/wallet/io.tradestrike/image.js.map +1 -1
- package/dist/esm/wallets/__generated__/wallet/io.tradestrike/index.js +2 -2
- package/dist/esm/wallets/__generated__/wallet/io.tradestrike/index.js.map +1 -1
- package/dist/esm/wallets/__generated__/wallet-infos.js +45 -15
- package/dist/esm/wallets/__generated__/wallet-infos.js.map +1 -1
- package/dist/esm/wallets/coinbase/coinbase-wallet.js +1 -1
- package/dist/esm/wallets/coinbase/coinbase-wallet.js.map +1 -1
- package/dist/esm/wallets/coinbase/coinbaseWebSDK.js +20 -8
- package/dist/esm/wallets/coinbase/coinbaseWebSDK.js.map +1 -1
- package/dist/esm/wallets/create-wallet.js +7 -2
- package/dist/esm/wallets/create-wallet.js.map +1 -1
- package/dist/esm/wallets/in-app/core/wallet/enclave-wallet.js +13 -3
- package/dist/esm/wallets/in-app/core/wallet/enclave-wallet.js.map +1 -1
- package/dist/esm/wallets/in-app/core/wallet/in-app-core.js +3 -1
- package/dist/esm/wallets/in-app/core/wallet/in-app-core.js.map +1 -1
- package/dist/esm/wallets/in-app/web/lib/iframe-wallet.js +9 -2
- package/dist/esm/wallets/in-app/web/lib/iframe-wallet.js.map +1 -1
- package/dist/esm/wallets/injected/index.js +36 -8
- package/dist/esm/wallets/injected/index.js.map +1 -1
- package/dist/esm/wallets/native/create-wallet.js +1 -1
- package/dist/esm/wallets/native/create-wallet.js.map +1 -1
- package/dist/esm/wallets/smart/smart-wallet.js +1 -1
- package/dist/esm/wallets/smart/smart-wallet.js.map +1 -1
- package/dist/esm/wallets/wallet-connect/controller.js +20 -8
- package/dist/esm/wallets/wallet-connect/controller.js.map +1 -1
- package/dist/types/analytics/track/connect.d.ts +12 -0
- package/dist/types/analytics/track/connect.d.ts.map +1 -0
- package/dist/types/analytics/track/index.d.ts +11 -0
- package/dist/types/analytics/track/index.d.ts.map +1 -0
- package/dist/types/analytics/{track.d.ts → track/pay.d.ts} +5 -11
- package/dist/types/analytics/track/pay.d.ts.map +1 -0
- package/dist/types/analytics/track/siwe.d.ts +19 -0
- package/dist/types/analytics/track/siwe.d.ts.map +1 -0
- package/dist/types/analytics/track/transaction.d.ts +24 -0
- package/dist/types/analytics/track/transaction.d.ts.map +1 -0
- package/dist/types/auth/core/verify-login-payload.d.ts.map +1 -1
- package/dist/types/exports/extensions/erc721.d.ts +1 -0
- package/dist/types/exports/extensions/erc721.d.ts.map +1 -1
- package/dist/types/exports/wallets/in-app.d.ts +1 -1
- package/dist/types/exports/wallets/in-app.d.ts.map +1 -1
- package/dist/types/extensions/erc1155/write/mintAdditionalSupplyToBatch.d.ts +23 -3
- package/dist/types/extensions/erc1155/write/mintAdditionalSupplyToBatch.d.ts.map +1 -1
- package/dist/types/extensions/erc721/drops/write/claimToBatch.d.ts +71 -0
- package/dist/types/extensions/erc721/drops/write/claimToBatch.d.ts.map +1 -0
- package/dist/types/react/core/utils/walletIcon.d.ts +2 -1
- package/dist/types/react/core/utils/walletIcon.d.ts.map +1 -1
- package/dist/types/react/web/hooks/transaction/useSendTransaction.d.ts +3 -4
- package/dist/types/react/web/hooks/transaction/useSendTransaction.d.ts.map +1 -1
- package/dist/types/react/web/ui/ConnectWallet/Details.d.ts.map +1 -1
- package/dist/types/react/web/ui/ConnectWallet/screens/Buy/swap/ConfirmationScreen.d.ts.map +1 -1
- package/dist/types/version.d.ts +1 -1
- package/dist/types/wallets/__generated__/getWalletInfo.d.ts.map +1 -1
- package/dist/types/wallets/__generated__/wallet/app.nightly/image.d.ts +3 -0
- package/dist/types/wallets/__generated__/wallet/app.nightly/image.d.ts.map +1 -0
- package/dist/types/wallets/__generated__/wallet/app.nightly/index.d.ts +29 -0
- package/dist/types/wallets/__generated__/wallet/app.nightly/index.d.ts.map +1 -0
- package/dist/types/wallets/__generated__/wallet/app.status/image.d.ts +1 -1
- package/dist/types/wallets/__generated__/wallet/app.status/image.d.ts.map +1 -1
- package/dist/types/wallets/__generated__/wallet/app.status/index.d.ts +1 -1
- package/dist/types/wallets/__generated__/wallet/app.walletnow/index.d.ts +1 -1
- package/dist/types/wallets/__generated__/wallet/com.beexo/image.d.ts +3 -0
- package/dist/types/wallets/__generated__/wallet/com.beexo/image.d.ts.map +1 -0
- package/dist/types/wallets/__generated__/wallet/{org.nitrogen → com.beexo}/index.d.ts +9 -9
- package/dist/types/wallets/__generated__/wallet/com.beexo/index.d.ts.map +1 -0
- package/dist/types/wallets/__generated__/wallet/com.brave.wallet/image.d.ts +1 -1
- package/dist/types/wallets/__generated__/wallet/com.brave.wallet/image.d.ts.map +1 -1
- package/dist/types/wallets/__generated__/wallet/com.brave.wallet/index.d.ts +9 -9
- package/dist/types/wallets/__generated__/wallet/com.brave.wallet/index.d.ts.map +1 -1
- package/dist/types/wallets/__generated__/wallet/com.coin98/image.d.ts +1 -1
- package/dist/types/wallets/__generated__/wallet/com.coin98/image.d.ts.map +1 -1
- package/dist/types/wallets/__generated__/wallet/com.coin98/index.d.ts +1 -1
- package/dist/types/wallets/__generated__/wallet/com.crypto/image.d.ts +1 -1
- package/dist/types/wallets/__generated__/wallet/com.crypto/image.d.ts.map +1 -1
- package/dist/types/wallets/__generated__/wallet/com.crypto/index.d.ts +1 -1
- package/dist/types/wallets/__generated__/wallet/com.daffione/image.d.ts +3 -0
- package/dist/types/wallets/__generated__/wallet/com.daffione/image.d.ts.map +1 -0
- package/dist/types/wallets/__generated__/wallet/com.daffione/index.d.ts +29 -0
- package/dist/types/wallets/__generated__/wallet/{org.nitrogen → com.daffione}/index.d.ts.map +1 -1
- package/dist/types/wallets/__generated__/wallet/com.ipmb/image.d.ts +3 -0
- package/dist/types/wallets/__generated__/wallet/com.ipmb/image.d.ts.map +1 -0
- package/dist/types/wallets/__generated__/wallet/com.ipmb/index.d.ts +29 -0
- package/dist/types/wallets/__generated__/wallet/com.ipmb/index.d.ts.map +1 -0
- package/dist/types/wallets/__generated__/wallet/com.webauth/image.d.ts +3 -0
- package/dist/types/wallets/__generated__/wallet/com.webauth/image.d.ts.map +1 -0
- package/dist/types/wallets/__generated__/wallet/com.webauth/index.d.ts +29 -0
- package/dist/types/wallets/__generated__/wallet/com.webauth/index.d.ts.map +1 -0
- package/dist/types/wallets/__generated__/wallet/finance.openwallet/index.d.ts +2 -2
- package/dist/types/wallets/__generated__/wallet/finance.plena/index.d.ts +1 -1
- package/dist/types/wallets/__generated__/wallet/id.plumaa/image.d.ts +3 -0
- package/dist/types/wallets/__generated__/wallet/id.plumaa/image.d.ts.map +1 -0
- package/dist/types/wallets/__generated__/wallet/id.plumaa/index.d.ts +29 -0
- package/dist/types/wallets/__generated__/wallet/id.plumaa/index.d.ts.map +1 -0
- package/dist/types/wallets/__generated__/wallet/io.miraiapp/image.d.ts +1 -1
- package/dist/types/wallets/__generated__/wallet/io.miraiapp/image.d.ts.map +1 -1
- package/dist/types/wallets/__generated__/wallet/io.miraiapp/index.d.ts +1 -1
- package/dist/types/wallets/__generated__/wallet/io.owallet/image.d.ts +3 -0
- package/dist/types/wallets/__generated__/wallet/io.owallet/image.d.ts.map +1 -0
- package/dist/types/wallets/__generated__/wallet/io.owallet/index.d.ts +29 -0
- package/dist/types/wallets/__generated__/wallet/io.owallet/index.d.ts.map +1 -0
- package/dist/types/wallets/__generated__/wallet/io.tradestrike/image.d.ts +1 -1
- package/dist/types/wallets/__generated__/wallet/io.tradestrike/image.d.ts.map +1 -1
- package/dist/types/wallets/__generated__/wallet/io.tradestrike/index.d.ts +2 -2
- package/dist/types/wallets/__generated__/wallet-ids.d.ts +2 -2
- package/dist/types/wallets/__generated__/wallet-ids.d.ts.map +1 -1
- package/dist/types/wallets/__generated__/wallet-infos.d.ts +36 -12
- package/dist/types/wallets/__generated__/wallet-infos.d.ts.map +1 -1
- package/dist/types/wallets/coinbase/coinbaseWebSDK.d.ts +1 -1
- package/dist/types/wallets/coinbase/coinbaseWebSDK.d.ts.map +1 -1
- package/dist/types/wallets/create-wallet.d.ts.map +1 -1
- package/dist/types/wallets/getAllWalletsList.d.ts +36 -12
- package/dist/types/wallets/getAllWalletsList.d.ts.map +1 -1
- package/dist/types/wallets/in-app/core/wallet/enclave-wallet.d.ts.map +1 -1
- package/dist/types/wallets/in-app/core/wallet/in-app-core.d.ts.map +1 -1
- package/dist/types/wallets/in-app/web/lib/iframe-wallet.d.ts.map +1 -1
- package/dist/types/wallets/injected/index.d.ts +15 -2
- package/dist/types/wallets/injected/index.d.ts.map +1 -1
- package/dist/types/wallets/wallet-connect/controller.d.ts +2 -1
- package/dist/types/wallets/wallet-connect/controller.d.ts.map +1 -1
- package/package.json +1 -1
- package/src/analytics/track/connect.test.ts +78 -0
- package/src/analytics/track/connect.ts +25 -0
- package/src/analytics/track/index.ts +30 -0
- package/src/analytics/track/pay.test.ts +98 -0
- package/src/analytics/track/pay.ts +37 -0
- package/src/analytics/track/siwe.test.ts +110 -0
- package/src/analytics/track/siwe.ts +48 -0
- package/src/analytics/track/track.test.ts +107 -0
- package/src/analytics/track/transaction.test.ts +130 -0
- package/src/analytics/track/transaction.ts +57 -0
- package/src/auth/core/verify-login-payload.ts +25 -1
- package/src/exports/extensions/erc721.ts +4 -0
- package/src/exports/wallets/in-app.ts +4 -1
- package/src/extensions/erc1155/drop1155.test.ts +11 -0
- package/src/extensions/erc1155/token1155.test.ts +170 -2
- package/src/extensions/erc1155/write/lazyMint.test.ts +2 -22
- package/src/extensions/erc1155/write/mintAdditionalSupplyToBatch.test.ts +16 -85
- package/src/extensions/erc1155/write/mintAdditionalSupplyToBatch.ts +51 -4
- package/src/extensions/erc721/drops/write/claimTo.test.ts +15 -0
- package/src/extensions/erc721/drops/write/claimToBatch.test.ts +154 -0
- package/src/extensions/erc721/drops/write/claimToBatch.ts +144 -0
- package/src/react/core/utils/walletIcon.ts +3 -1
- package/src/react/web/hooks/transaction/useSendTransaction.tsx +3 -4
- package/src/react/web/ui/ConnectWallet/Details.tsx +2 -4
- package/src/react/web/ui/ConnectWallet/screens/Buy/BuyScreen.tsx +1 -1
- package/src/react/web/ui/ConnectWallet/screens/Buy/DirectPaymentModeScreen.tsx +1 -1
- package/src/react/web/ui/ConnectWallet/screens/Buy/TransactionModeScreen.tsx +1 -1
- package/src/react/web/ui/ConnectWallet/screens/Buy/fiat/FiatFlow.tsx +1 -1
- package/src/react/web/ui/ConnectWallet/screens/Buy/swap/ConfirmationScreen.tsx +1 -1
- package/src/react/web/ui/ConnectWallet/screens/LinkedProfilesScreen.tsx +2 -2
- package/src/react/web/ui/TransactionButton/TransactionModal.tsx +1 -1
- package/src/react/web/ui/components/WalletImage.tsx +2 -2
- package/src/react/web/wallets/shared/ConnectWalletSocialOptions.tsx +3 -3
- package/src/version.ts +1 -1
- package/src/wallets/__generated__/getWalletInfo.ts +67 -25
- package/src/wallets/__generated__/wallet/app.nightly/image.ts +7 -0
- package/src/wallets/__generated__/wallet/app.nightly/index.ts +34 -0
- package/src/wallets/__generated__/wallet/app.status/image.ts +1 -1
- package/src/wallets/__generated__/wallet/app.status/index.ts +1 -1
- package/src/wallets/__generated__/wallet/app.walletnow/index.ts +1 -1
- package/src/wallets/__generated__/wallet/com.beexo/image.ts +7 -0
- package/src/wallets/__generated__/wallet/com.beexo/index.ts +31 -0
- package/src/wallets/__generated__/wallet/com.brave.wallet/image.ts +1 -1
- package/src/wallets/__generated__/wallet/com.brave.wallet/index.ts +9 -11
- package/src/wallets/__generated__/wallet/com.coin98/image.ts +1 -1
- package/src/wallets/__generated__/wallet/com.coin98/index.ts +1 -1
- package/src/wallets/__generated__/wallet/com.crypto/image.ts +1 -1
- package/src/wallets/__generated__/wallet/com.crypto/index.ts +1 -1
- package/src/wallets/__generated__/wallet/com.daffione/image.ts +7 -0
- package/src/wallets/__generated__/wallet/com.daffione/index.ts +31 -0
- package/src/wallets/__generated__/wallet/com.ipmb/image.ts +7 -0
- package/src/wallets/__generated__/wallet/com.ipmb/index.ts +32 -0
- package/src/wallets/__generated__/wallet/com.webauth/image.ts +7 -0
- package/src/wallets/__generated__/wallet/{org.nitrogen → com.webauth}/index.ts +8 -8
- package/src/wallets/__generated__/wallet/finance.openwallet/index.ts +2 -2
- package/src/wallets/__generated__/wallet/finance.plena/index.ts +1 -1
- package/src/wallets/__generated__/wallet/id.plumaa/image.ts +7 -0
- package/src/wallets/__generated__/wallet/id.plumaa/index.ts +31 -0
- package/src/wallets/__generated__/wallet/io.miraiapp/image.ts +1 -1
- package/src/wallets/__generated__/wallet/io.miraiapp/index.ts +1 -1
- package/src/wallets/__generated__/wallet/io.owallet/image.ts +7 -0
- package/src/wallets/__generated__/wallet/io.owallet/index.ts +32 -0
- package/src/wallets/__generated__/wallet/io.tradestrike/image.ts +1 -1
- package/src/wallets/__generated__/wallet/io.tradestrike/index.ts +2 -2
- package/src/wallets/__generated__/wallet-ids.ts +9 -6
- package/src/wallets/__generated__/wallet-infos.ts +45 -15
- package/src/wallets/coinbase/coinbase-wallet.ts +1 -1
- package/src/wallets/coinbase/coinbaseWebSDK.ts +30 -7
- package/src/wallets/create-wallet.ts +6 -5
- package/src/wallets/in-app/core/wallet/enclave-wallet.ts +16 -3
- package/src/wallets/in-app/core/wallet/in-app-core.ts +3 -1
- package/src/wallets/in-app/web/lib/iframe-wallet.ts +12 -2
- package/src/wallets/injected/index.ts +72 -17
- package/src/wallets/native/create-wallet.ts +1 -1
- package/src/wallets/smart/smart-wallet.ts +1 -1
- package/src/wallets/wallet-connect/controller.ts +29 -7
- package/dist/cjs/analytics/track.js +0 -51
- package/dist/cjs/analytics/track.js.map +0 -1
- package/dist/cjs/wallets/__generated__/wallet/org.nitrogen/image.js +0 -7
- package/dist/cjs/wallets/__generated__/wallet/org.nitrogen/index.js.map +0 -1
- package/dist/esm/analytics/track.js +0 -47
- package/dist/esm/analytics/track.js.map +0 -1
- package/dist/esm/wallets/__generated__/wallet/org.nitrogen/image.js +0 -5
- package/dist/esm/wallets/__generated__/wallet/org.nitrogen/index.js.map +0 -1
- package/dist/types/analytics/track.d.ts.map +0 -1
- package/dist/types/wallets/__generated__/wallet/org.nitrogen/image.d.ts +0 -3
- package/dist/types/wallets/__generated__/wallet/org.nitrogen/image.d.ts.map +0 -1
- package/src/analytics/track.ts +0 -67
- package/src/extensions/erc1155/read/getNFTs.test.ts +0 -44
- package/src/extensions/erc1155/read/getOwnedNFTs.test.ts +0 -62
- package/src/extensions/erc1155/read/getOwnedTokenIds.test.ts +0 -50
- package/src/extensions/erc1155/write/mintAdditionalSupplyTo.test.ts +0 -38
- package/src/extensions/erc1155/write/mintTo.test.ts +0 -42
- package/src/extensions/erc1155/write/mintToBatch.test.ts +0 -77
- package/src/extensions/erc1155/write/updateTokenURI.test.ts +0 -54
- package/src/wallets/__generated__/wallet/org.nitrogen/image.ts +0 -7
@@ -1,90 +1,21 @@
|
|
1
|
+
import {} from "viem";
|
1
2
|
import { describe, expect, it } from "vitest";
|
2
|
-
import { ANVIL_CHAIN } from "~test/chains.js";
|
3
|
-
import { TEST_CONTRACT_URI } from "~test/ipfs-uris.js";
|
4
|
-
import { TEST_CLIENT } from "~test/test-clients.js";
|
5
3
|
import { TEST_ACCOUNT_C } from "~test/test-wallets.js";
|
6
|
-
import {
|
7
|
-
import { deployERC1155Contract } from "../../../extensions/prebuilts/deploy-erc1155.js";
|
8
|
-
import { sendAndConfirmTransaction } from "../../../transaction/actions/send-and-confirm-transaction.js";
|
9
|
-
import { getNFTs } from "../read/getNFTs.js";
|
10
|
-
import { mintAdditionalSupplyToBatch } from "./mintAdditionalSupplyToBatch.js";
|
11
|
-
import { mintToBatch } from "./mintToBatch.js";
|
4
|
+
import { optimizeMintBatchContent } from "./mintAdditionalSupplyToBatch.js";
|
12
5
|
|
13
|
-
const chain = ANVIL_CHAIN;
|
14
|
-
const client = TEST_CLIENT;
|
15
6
|
const account = TEST_ACCOUNT_C;
|
16
7
|
|
17
|
-
describe
|
18
|
-
"
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
contractURI: TEST_CONTRACT_URI,
|
32
|
-
},
|
33
|
-
}),
|
34
|
-
});
|
35
|
-
|
36
|
-
await sendAndConfirmTransaction({
|
37
|
-
account,
|
38
|
-
transaction: mintToBatch({
|
39
|
-
contract,
|
40
|
-
to: account.address,
|
41
|
-
nfts: [
|
42
|
-
{ metadata: { name: "token 0" }, supply: 1n },
|
43
|
-
{ metadata: { name: "token 1" }, supply: 2n },
|
44
|
-
{ metadata: { name: "token 2" }, supply: 3n },
|
45
|
-
],
|
46
|
-
}),
|
47
|
-
});
|
48
|
-
|
49
|
-
await sendAndConfirmTransaction({
|
50
|
-
account,
|
51
|
-
transaction: mintAdditionalSupplyToBatch({
|
52
|
-
contract,
|
53
|
-
nfts: [
|
54
|
-
{ tokenId: 0n, supply: 99n, to: account.address },
|
55
|
-
{ tokenId: 1n, supply: 98n, to: account.address },
|
56
|
-
{ tokenId: 2n, supply: 97n, to: account.address },
|
57
|
-
],
|
58
|
-
}),
|
59
|
-
});
|
60
|
-
|
61
|
-
const nfts = await getNFTs({ contract });
|
62
|
-
expect(nfts).toStrictEqual([
|
63
|
-
{
|
64
|
-
metadata: { name: "token 0" },
|
65
|
-
owner: null,
|
66
|
-
id: 0n,
|
67
|
-
tokenURI: "ipfs://QmPZ6LpGqMuFbHKTXrNW1NRNLHf1nrxS4dtoFqdZZTKvPX/0",
|
68
|
-
type: "ERC1155",
|
69
|
-
supply: 100n,
|
70
|
-
},
|
71
|
-
{
|
72
|
-
metadata: { name: "token 1" },
|
73
|
-
owner: null,
|
74
|
-
id: 1n,
|
75
|
-
tokenURI: "ipfs://QmRFPyc3yEYxR4pQxwyTQWTine51TxWCoD6nzJWR3eX45b/0",
|
76
|
-
type: "ERC1155",
|
77
|
-
supply: 100n,
|
78
|
-
},
|
79
|
-
{
|
80
|
-
metadata: { name: "token 2" },
|
81
|
-
owner: null,
|
82
|
-
id: 2n,
|
83
|
-
tokenURI: "ipfs://QmesQiRLHCgqWZM2GFCs7Nb7rr2S72hU1BVQc7xiTyKZtT/0",
|
84
|
-
type: "ERC1155",
|
85
|
-
supply: 100n,
|
86
|
-
},
|
87
|
-
]);
|
88
|
-
});
|
89
|
-
},
|
90
|
-
);
|
8
|
+
describe("ERC1155 Edition: mintToBatch", () => {
|
9
|
+
it("should optimize the mint content", () => {
|
10
|
+
expect(
|
11
|
+
optimizeMintBatchContent([
|
12
|
+
{ tokenId: 0n, supply: 99n, to: account.address },
|
13
|
+
{ tokenId: 1n, supply: 49n, to: account.address },
|
14
|
+
{ tokenId: 1n, supply: 51n, to: account.address },
|
15
|
+
]),
|
16
|
+
).toStrictEqual([
|
17
|
+
{ tokenId: 0n, supply: 99n, to: account.address },
|
18
|
+
{ tokenId: 1n, supply: 100n, to: account.address },
|
19
|
+
]);
|
20
|
+
});
|
21
|
+
});
|
@@ -1,5 +1,8 @@
|
|
1
1
|
import { multicall } from "../../../extensions/common/__generated__/IMulticall/write/multicall.js";
|
2
|
-
import type {
|
2
|
+
import type {
|
3
|
+
BaseTransactionOptions,
|
4
|
+
WithOverrides,
|
5
|
+
} from "../../../transaction/types.js";
|
3
6
|
import { uri } from "../__generated__/IERC1155/read/uri.js";
|
4
7
|
import { encodeMintTo } from "../__generated__/IMintableERC1155/write/mintTo.js";
|
5
8
|
import type { MintAdditionalSupplyToParams } from "./mintAdditionalSupplyTo.js";
|
@@ -7,9 +10,9 @@ import type { MintAdditionalSupplyToParams } from "./mintAdditionalSupplyTo.js";
|
|
7
10
|
/**
|
8
11
|
* @extension ERC1155
|
9
12
|
*/
|
10
|
-
export type MintAdditionalSupplyToBatchParams = {
|
13
|
+
export type MintAdditionalSupplyToBatchParams = WithOverrides<{
|
11
14
|
nfts: MintAdditionalSupplyToParams[];
|
12
|
-
}
|
15
|
+
}>;
|
13
16
|
|
14
17
|
/**
|
15
18
|
* This extension batches multiple `mintAdditionalSupplyToBatch` extensions into one single multicall.
|
@@ -38,8 +41,9 @@ export function mintAdditionalSupplyToBatch(
|
|
38
41
|
return multicall({
|
39
42
|
contract: options.contract,
|
40
43
|
asyncParams: async () => {
|
44
|
+
const nfts = optimizeMintBatchContent(options.nfts);
|
41
45
|
const data = await Promise.all(
|
42
|
-
|
46
|
+
nfts.map(async (nft) => {
|
43
47
|
const tokenUri = await uri({
|
44
48
|
contract: options.contract,
|
45
49
|
tokenId: nft.tokenId,
|
@@ -54,5 +58,48 @@ export function mintAdditionalSupplyToBatch(
|
|
54
58
|
);
|
55
59
|
return { data };
|
56
60
|
},
|
61
|
+
overrides: options.overrides,
|
57
62
|
});
|
58
63
|
}
|
64
|
+
|
65
|
+
/**
|
66
|
+
* Optimization
|
67
|
+
*
|
68
|
+
* We can batch the records that share the same "to" & "tokenId" into 1 transaction
|
69
|
+
*
|
70
|
+
* For example, this struct:
|
71
|
+
* [
|
72
|
+
* { tokenId: 0n, supply: 99n, to: account.address },
|
73
|
+
* { tokenId: 1n, supply: 49n, to: account.address },
|
74
|
+
* { tokenId: 1n, supply: 51n, to: account.address },
|
75
|
+
* ]
|
76
|
+
*
|
77
|
+
* ...can be packed into:
|
78
|
+
* [
|
79
|
+
* { tokenId: 0n, supply: 99n, to: account.address },
|
80
|
+
* { tokenId: 1n, supply: 100n, to: account.address },
|
81
|
+
* ]
|
82
|
+
* @internal
|
83
|
+
*/
|
84
|
+
export function optimizeMintBatchContent(
|
85
|
+
nfts: MintAdditionalSupplyToParams[],
|
86
|
+
): MintAdditionalSupplyToParams[] {
|
87
|
+
const results: MintAdditionalSupplyToParams[] = [];
|
88
|
+
for (const item of nfts) {
|
89
|
+
const matchingIndex = results.findIndex(
|
90
|
+
(o) =>
|
91
|
+
o.tokenId === item.tokenId &&
|
92
|
+
o.to.toLowerCase() === item.to.toLowerCase(),
|
93
|
+
);
|
94
|
+
if (matchingIndex !== -1) {
|
95
|
+
results[matchingIndex] = {
|
96
|
+
to: item.to,
|
97
|
+
tokenId: item.tokenId,
|
98
|
+
supply: item.supply + (results[matchingIndex]?.supply || 0n),
|
99
|
+
};
|
100
|
+
} else {
|
101
|
+
results.push(item);
|
102
|
+
}
|
103
|
+
}
|
104
|
+
return results;
|
105
|
+
}
|
@@ -0,0 +1,15 @@
|
|
1
|
+
import { type Abi, toFunctionSelector } from "viem";
|
2
|
+
import { describe, expect, it } from "vitest";
|
3
|
+
import { NFT_DROP_CONTRACT } from "~test/test-contracts.js";
|
4
|
+
import { resolveContractAbi } from "../../../../contract/actions/resolve-abi.js";
|
5
|
+
import { isClaimToSupported } from "./claimTo.js";
|
6
|
+
|
7
|
+
describe.runIf(process.env.TW_SECRET_KEY)("ERC721: claimTo", () => {
|
8
|
+
it("isClaimToSupported should work", async () => {
|
9
|
+
const abi = await resolveContractAbi<Abi>(NFT_DROP_CONTRACT);
|
10
|
+
const selectors = abi
|
11
|
+
.filter((f) => f.type === "function")
|
12
|
+
.map((f) => toFunctionSelector(f));
|
13
|
+
expect(isClaimToSupported(selectors)).toBe(true);
|
14
|
+
});
|
15
|
+
});
|
@@ -0,0 +1,154 @@
|
|
1
|
+
import { describe, expect, it } from "vitest";
|
2
|
+
import { ANVIL_CHAIN } from "~test/chains.js";
|
3
|
+
import { TEST_CONTRACT_URI } from "~test/ipfs-uris.js";
|
4
|
+
import { TEST_CLIENT } from "~test/test-clients.js";
|
5
|
+
import {
|
6
|
+
TEST_ACCOUNT_A,
|
7
|
+
TEST_ACCOUNT_B,
|
8
|
+
TEST_ACCOUNT_C,
|
9
|
+
TEST_ACCOUNT_D,
|
10
|
+
} from "~test/test-wallets.js";
|
11
|
+
import { getContract } from "../../../../contract/contract.js";
|
12
|
+
import { deployERC721Contract } from "../../../../extensions/prebuilts/deploy-erc721.js";
|
13
|
+
import { sendAndConfirmTransaction } from "../../../../transaction/actions/send-and-confirm-transaction.js";
|
14
|
+
import { getNFTs } from "../../read/getNFTs.js";
|
15
|
+
import { lazyMint } from "../../write/lazyMint.js";
|
16
|
+
import { claimToBatch, optimizeClaimContent } from "./claimToBatch.js";
|
17
|
+
import { setClaimConditions } from "./setClaimConditions.js";
|
18
|
+
|
19
|
+
const chain = ANVIL_CHAIN;
|
20
|
+
const client = TEST_CLIENT;
|
21
|
+
const account = TEST_ACCOUNT_A;
|
22
|
+
|
23
|
+
describe.runIf(process.env.TW_SECRET_KEY)("erc721: claimToBatch", () => {
|
24
|
+
it("should optimize the claim content", () => {
|
25
|
+
expect(
|
26
|
+
optimizeClaimContent([
|
27
|
+
{
|
28
|
+
to: account.address,
|
29
|
+
quantity: 1n,
|
30
|
+
},
|
31
|
+
{
|
32
|
+
to: TEST_ACCOUNT_B.address,
|
33
|
+
quantity: 2n,
|
34
|
+
},
|
35
|
+
{
|
36
|
+
to: TEST_ACCOUNT_B.address,
|
37
|
+
quantity: 3n,
|
38
|
+
},
|
39
|
+
{ to: TEST_ACCOUNT_C.address, quantity: 2n },
|
40
|
+
{ to: TEST_ACCOUNT_D.address, quantity: 2n },
|
41
|
+
{ to: account.address, quantity: 1n },
|
42
|
+
]),
|
43
|
+
).toStrictEqual([
|
44
|
+
{ to: account.address, quantity: 1n },
|
45
|
+
{ to: TEST_ACCOUNT_B.address, quantity: 5n },
|
46
|
+
{ to: TEST_ACCOUNT_C.address, quantity: 2n },
|
47
|
+
{ to: TEST_ACCOUNT_D.address, quantity: 2n },
|
48
|
+
{ to: account.address, quantity: 1n },
|
49
|
+
]);
|
50
|
+
});
|
51
|
+
|
52
|
+
it("should claim in batch", async () => {
|
53
|
+
const address = await deployERC721Contract({
|
54
|
+
account,
|
55
|
+
chain,
|
56
|
+
client,
|
57
|
+
params: {
|
58
|
+
name: "Test DropERC721",
|
59
|
+
contractURI: TEST_CONTRACT_URI,
|
60
|
+
},
|
61
|
+
type: "DropERC721",
|
62
|
+
});
|
63
|
+
|
64
|
+
const contract = getContract({
|
65
|
+
address,
|
66
|
+
chain,
|
67
|
+
client,
|
68
|
+
});
|
69
|
+
|
70
|
+
await sendAndConfirmTransaction({
|
71
|
+
transaction: lazyMint({
|
72
|
+
contract,
|
73
|
+
nfts: [
|
74
|
+
{ name: "Test NFT 0" },
|
75
|
+
{ name: "Test NFT 1" },
|
76
|
+
{ name: "Test NFT 2" },
|
77
|
+
{ name: "Test NFT 3" },
|
78
|
+
{ name: "Test NFT 4" },
|
79
|
+
{ name: "Test NFT 5" },
|
80
|
+
{ name: "Test NFT 6" },
|
81
|
+
{ name: "Test NFT 7" },
|
82
|
+
{ name: "Test NFT 8" },
|
83
|
+
{ name: "Test NFT 9" },
|
84
|
+
{ name: "Test NFT 10" },
|
85
|
+
],
|
86
|
+
}),
|
87
|
+
account,
|
88
|
+
});
|
89
|
+
|
90
|
+
await sendAndConfirmTransaction({
|
91
|
+
transaction: setClaimConditions({
|
92
|
+
contract,
|
93
|
+
phases: [{}],
|
94
|
+
}),
|
95
|
+
account: TEST_ACCOUNT_A,
|
96
|
+
});
|
97
|
+
|
98
|
+
const transaction = claimToBatch({
|
99
|
+
contract,
|
100
|
+
from: account.address,
|
101
|
+
content: [
|
102
|
+
{
|
103
|
+
to: account.address,
|
104
|
+
quantity: 1n,
|
105
|
+
},
|
106
|
+
{
|
107
|
+
to: TEST_ACCOUNT_B.address,
|
108
|
+
quantity: 2n,
|
109
|
+
},
|
110
|
+
{
|
111
|
+
to: TEST_ACCOUNT_B.address,
|
112
|
+
quantity: 3n,
|
113
|
+
},
|
114
|
+
{ to: TEST_ACCOUNT_C.address, quantity: 2n },
|
115
|
+
{ to: TEST_ACCOUNT_D.address, quantity: 2n },
|
116
|
+
{ to: account.address, quantity: 1n },
|
117
|
+
],
|
118
|
+
});
|
119
|
+
|
120
|
+
await sendAndConfirmTransaction({ account, transaction });
|
121
|
+
|
122
|
+
const nfts = await getNFTs({ contract, includeOwners: true });
|
123
|
+
expect(nfts.length).toBe(11);
|
124
|
+
expect(nfts[0]?.owner?.toLowerCase()).toBe(account.address.toLowerCase());
|
125
|
+
expect(nfts[1]?.owner?.toLowerCase()).toBe(
|
126
|
+
TEST_ACCOUNT_B.address.toLowerCase(),
|
127
|
+
);
|
128
|
+
expect(nfts[2]?.owner?.toLowerCase()).toBe(
|
129
|
+
TEST_ACCOUNT_B.address.toLowerCase(),
|
130
|
+
);
|
131
|
+
expect(nfts[3]?.owner?.toLowerCase()).toBe(
|
132
|
+
TEST_ACCOUNT_B.address.toLowerCase(),
|
133
|
+
);
|
134
|
+
expect(nfts[4]?.owner?.toLowerCase()).toBe(
|
135
|
+
TEST_ACCOUNT_B.address.toLowerCase(),
|
136
|
+
);
|
137
|
+
expect(nfts[5]?.owner?.toLowerCase()).toBe(
|
138
|
+
TEST_ACCOUNT_B.address.toLowerCase(),
|
139
|
+
);
|
140
|
+
expect(nfts[6]?.owner?.toLowerCase()).toBe(
|
141
|
+
TEST_ACCOUNT_C.address.toLowerCase(),
|
142
|
+
);
|
143
|
+
expect(nfts[7]?.owner?.toLowerCase()).toBe(
|
144
|
+
TEST_ACCOUNT_C.address.toLowerCase(),
|
145
|
+
);
|
146
|
+
expect(nfts[8]?.owner?.toLowerCase()).toBe(
|
147
|
+
TEST_ACCOUNT_D.address.toLowerCase(),
|
148
|
+
);
|
149
|
+
expect(nfts[9]?.owner?.toLowerCase()).toBe(
|
150
|
+
TEST_ACCOUNT_D.address.toLowerCase(),
|
151
|
+
);
|
152
|
+
expect(nfts[10]?.owner?.toLowerCase()).toBe(account.address.toLowerCase());
|
153
|
+
});
|
154
|
+
});
|
@@ -0,0 +1,144 @@
|
|
1
|
+
import type { Address } from "abitype";
|
2
|
+
import { multicall } from "../../../../extensions/common/__generated__/IMulticall/write/multicall.js";
|
3
|
+
import type {
|
4
|
+
BaseTransactionOptions,
|
5
|
+
WithOverrides,
|
6
|
+
} from "../../../../transaction/types.js";
|
7
|
+
import { getClaimParams } from "../../../../utils/extensions/drops/get-claim-params.js";
|
8
|
+
import { encodeClaim } from "../../__generated__/IDrop/write/claim.js";
|
9
|
+
|
10
|
+
/**
|
11
|
+
* @extension ERC721
|
12
|
+
*/
|
13
|
+
export type ClaimToBatchParams = WithOverrides<{
|
14
|
+
content: Array<{
|
15
|
+
to: Address;
|
16
|
+
quantity: bigint;
|
17
|
+
}>;
|
18
|
+
from?: Address;
|
19
|
+
}>;
|
20
|
+
|
21
|
+
/**
|
22
|
+
* This extension batches multiple `claimTo` extensions into one single multicall.
|
23
|
+
* Keep in mind that there is a limit of how many NFTs you can claim per transaction.
|
24
|
+
* This limit varies depends on the network that you are transacting on.
|
25
|
+
*
|
26
|
+
* You are recommended to experiment with the number to figure out the best number for your chain of choice.
|
27
|
+
* @extension ERC721
|
28
|
+
* @param options the transaction options
|
29
|
+
* @returns A promise that resolves to the transaction result.
|
30
|
+
*
|
31
|
+
* @example
|
32
|
+
* ```ts
|
33
|
+
* import { claimToBatch } from "thirdweb/extensions/erc721";
|
34
|
+
*
|
35
|
+
* const transaction = claimToBatch({
|
36
|
+
* contract: nftDropContract,
|
37
|
+
* from: claimer.address, // address of the one calling this transaction
|
38
|
+
* content: [
|
39
|
+
* { to: "0x...1", quantity: 1n },
|
40
|
+
* { to: "0x...2", quantity: 12n },
|
41
|
+
* { to: "0x...3", quantity: 2n },
|
42
|
+
* ],
|
43
|
+
* });
|
44
|
+
* ```
|
45
|
+
*/
|
46
|
+
export function claimToBatch(
|
47
|
+
options: BaseTransactionOptions<ClaimToBatchParams>,
|
48
|
+
) {
|
49
|
+
return multicall({
|
50
|
+
contract: options.contract,
|
51
|
+
asyncParams: () => getClaimToBatchParams(options),
|
52
|
+
overrides: options.overrides,
|
53
|
+
});
|
54
|
+
}
|
55
|
+
|
56
|
+
/**
|
57
|
+
* @internal
|
58
|
+
*/
|
59
|
+
async function getClaimToBatchParams(
|
60
|
+
options: BaseTransactionOptions<ClaimToBatchParams>,
|
61
|
+
) {
|
62
|
+
const errorIndexTo = options.content.findIndex((o) => !o.to);
|
63
|
+
if (errorIndexTo !== -1) {
|
64
|
+
throw new Error(
|
65
|
+
`Error: Item at index ${errorIndexTo} is missing recipient address ("to")`,
|
66
|
+
);
|
67
|
+
}
|
68
|
+
const errorIndexQuantity = options.content.findIndex((o) => !o.quantity);
|
69
|
+
if (errorIndexQuantity !== -1) {
|
70
|
+
throw new Error(
|
71
|
+
`Error: Item at index ${errorIndexQuantity} is missing claim quantity`,
|
72
|
+
);
|
73
|
+
}
|
74
|
+
const content = optimizeClaimContent(options.content);
|
75
|
+
const data = await Promise.all(
|
76
|
+
content.map(async (item) => {
|
77
|
+
const claimParams = await getClaimParams({
|
78
|
+
type: "erc721",
|
79
|
+
contract: options.contract,
|
80
|
+
to: item.to,
|
81
|
+
from: options.from,
|
82
|
+
quantity: item.quantity,
|
83
|
+
});
|
84
|
+
|
85
|
+
return encodeClaim({
|
86
|
+
receiver: claimParams.receiver,
|
87
|
+
quantity: claimParams.quantity,
|
88
|
+
currency: claimParams.currency,
|
89
|
+
pricePerToken: claimParams.pricePerToken,
|
90
|
+
allowlistProof: claimParams.allowlistProof,
|
91
|
+
data: claimParams.data,
|
92
|
+
});
|
93
|
+
}),
|
94
|
+
);
|
95
|
+
|
96
|
+
return { data };
|
97
|
+
}
|
98
|
+
|
99
|
+
/**
|
100
|
+
* Optimization
|
101
|
+
* For identical addresses that stays next to each other in the array,
|
102
|
+
* we can combine them into one transaction _without altering the claiming order_
|
103
|
+
*
|
104
|
+
* For exampple, this structure:
|
105
|
+
* [
|
106
|
+
* {
|
107
|
+
* to: "0xabc",
|
108
|
+
* quantity: 1n,
|
109
|
+
* },
|
110
|
+
* {
|
111
|
+
* to: "0xabc",
|
112
|
+
* quantity: 13n,
|
113
|
+
* },
|
114
|
+
* ];
|
115
|
+
*
|
116
|
+
* ...can be combined in one tx (without altering the claiming order)
|
117
|
+
* {
|
118
|
+
* to: "0xabc",
|
119
|
+
* quantity: 14n,
|
120
|
+
* }
|
121
|
+
*
|
122
|
+
* @internal
|
123
|
+
*/
|
124
|
+
export function optimizeClaimContent(
|
125
|
+
content: Array<{ to: Address; quantity: bigint }>,
|
126
|
+
): Array<{ to: Address; quantity: bigint }> {
|
127
|
+
const results: Array<{ to: Address; quantity: bigint }> = [];
|
128
|
+
content.forEach((item, index) => {
|
129
|
+
const previousItem = results.at(-1);
|
130
|
+
if (
|
131
|
+
index > 0 &&
|
132
|
+
previousItem &&
|
133
|
+
item.to.toLowerCase() === previousItem.to.toLowerCase()
|
134
|
+
) {
|
135
|
+
results[results.length - 1] = {
|
136
|
+
to: item.to,
|
137
|
+
quantity: item.quantity + previousItem.quantity,
|
138
|
+
};
|
139
|
+
} else {
|
140
|
+
results.push(item);
|
141
|
+
}
|
142
|
+
});
|
143
|
+
return results;
|
144
|
+
}
|
@@ -1,3 +1,5 @@
|
|
1
|
+
import type { AuthOption } from "../../../wallets/types.js";
|
2
|
+
|
1
3
|
// TODO make the social icons usable in RN too
|
2
4
|
const googleIconUri =
|
3
5
|
"";
|
@@ -49,7 +51,7 @@ export const socialIcons = {
|
|
49
51
|
};
|
50
52
|
|
51
53
|
// TODO: this should return actual <svg> elements so they can be themed
|
52
|
-
export function
|
54
|
+
export function getSocialIcon(provider: AuthOption | ({} & string)) {
|
53
55
|
switch (provider) {
|
54
56
|
case "google":
|
55
57
|
return googleIconUri;
|
@@ -36,10 +36,9 @@ import { TransactionModal } from "../../ui/TransactionButton/TransactionModal.js
|
|
36
36
|
*
|
37
37
|
* const onClick = () => {
|
38
38
|
* const transaction = prepareContractCall({
|
39
|
-
*
|
40
|
-
*
|
41
|
-
*
|
42
|
-
* }),
|
39
|
+
* contract,
|
40
|
+
* method: "function transfer(address to, uint256 value)",
|
41
|
+
* params: [to, value],
|
43
42
|
* });
|
44
43
|
* sendTx(transaction);
|
45
44
|
* };
|
@@ -10,7 +10,7 @@ import {
|
|
10
10
|
} from "@radix-ui/react-icons";
|
11
11
|
import { useQuery } from "@tanstack/react-query";
|
12
12
|
import { useContext, useEffect, useState } from "react";
|
13
|
-
import { trackPayEvent } from "../../../../analytics/track.js";
|
13
|
+
import { trackPayEvent } from "../../../../analytics/track/pay.js";
|
14
14
|
import type { Chain } from "../../../../chains/types.js";
|
15
15
|
import type { ThirdwebClient } from "../../../../client/client.js";
|
16
16
|
import { getContract } from "../../../../contract/contract.js";
|
@@ -200,9 +200,7 @@ export const ConnectedWalletDetails: React.FC<{
|
|
200
200
|
|
201
201
|
const avatarSrc = props.detailsButton?.connectedAccountAvatarUrl || pfp;
|
202
202
|
|
203
|
-
const combinedClassName = `${TW_CONNECTED_WALLET} ${
|
204
|
-
props.detailsButton?.className || ""
|
205
|
-
}`;
|
203
|
+
const combinedClassName = `${TW_CONNECTED_WALLET} ${props.detailsButton?.className || ""}`;
|
206
204
|
|
207
205
|
return (
|
208
206
|
<WalletInfoButton
|
@@ -1,7 +1,7 @@
|
|
1
1
|
import { IdCardIcon } from "@radix-ui/react-icons";
|
2
2
|
import { useQueryClient } from "@tanstack/react-query";
|
3
3
|
import { useCallback, useMemo, useState } from "react";
|
4
|
-
import { trackPayEvent } from "../../../../../../analytics/track.js";
|
4
|
+
import { trackPayEvent } from "../../../../../../analytics/track/pay.js";
|
5
5
|
import type { Chain } from "../../../../../../chains/types.js";
|
6
6
|
import type { ThirdwebClient } from "../../../../../../client/client.js";
|
7
7
|
import { NATIVE_TOKEN_ADDRESS } from "../../../../../../constants/addresses.js";
|
@@ -1,5 +1,5 @@
|
|
1
1
|
import { useQuery } from "@tanstack/react-query";
|
2
|
-
import { trackPayEvent } from "../../../../../../analytics/track.js";
|
2
|
+
import { trackPayEvent } from "../../../../../../analytics/track/pay.js";
|
3
3
|
import type { Chain } from "../../../../../../chains/types.js";
|
4
4
|
import type { ThirdwebClient } from "../../../../../../client/client.js";
|
5
5
|
import { NATIVE_TOKEN_ADDRESS } from "../../../../../../constants/addresses.js";
|
@@ -1,4 +1,4 @@
|
|
1
|
-
import { trackPayEvent } from "../../../../../../analytics/track.js";
|
1
|
+
import { trackPayEvent } from "../../../../../../analytics/track/pay.js";
|
2
2
|
import type { Chain } from "../../../../../../chains/types.js";
|
3
3
|
import type { ThirdwebClient } from "../../../../../../client/client.js";
|
4
4
|
import { NATIVE_TOKEN_ADDRESS } from "../../../../../../constants/addresses.js";
|
@@ -1,5 +1,5 @@
|
|
1
1
|
import { useCallback, useState } from "react";
|
2
|
-
import { trackPayEvent } from "../../../../../../../analytics/track.js";
|
2
|
+
import { trackPayEvent } from "../../../../../../../analytics/track/pay.js";
|
3
3
|
import type { ThirdwebClient } from "../../../../../../../client/client.js";
|
4
4
|
import type { BuyWithFiatQuote } from "../../../../../../../pay/buyWithFiat/getQuote.js";
|
5
5
|
import {
|
@@ -1,6 +1,6 @@
|
|
1
1
|
import { CrossCircledIcon } from "@radix-ui/react-icons";
|
2
2
|
import { useState } from "react";
|
3
|
-
import { trackPayEvent } from "../../../../../../../analytics/track.js";
|
3
|
+
import { trackPayEvent } from "../../../../../../../analytics/track/pay.js";
|
4
4
|
import type { Chain } from "../../../../../../../chains/types.js";
|
5
5
|
import type { ThirdwebClient } from "../../../../../../../client/client.js";
|
6
6
|
import type { BuyWithCryptoQuote } from "../../../../../../../pay/buyWithCrypto/getQuote.js";
|
@@ -4,7 +4,7 @@ import { shortenAddress } from "../../../../../utils/address.js";
|
|
4
4
|
import type { Profile } from "../../../../../wallets/in-app/core/authentication/types.js";
|
5
5
|
import { fontSize, iconSize } from "../../../../core/design-system/index.js";
|
6
6
|
import { useSocialProfiles } from "../../../../core/social/useSocialProfiles.js";
|
7
|
-
import {
|
7
|
+
import { getSocialIcon } from "../../../../core/utils/walletIcon.js";
|
8
8
|
import { useProfiles } from "../../../hooks/wallets/useProfiles.js";
|
9
9
|
import { LoadingScreen } from "../../../wallets/shared/LoadingScreen.js";
|
10
10
|
import { Img } from "../../components/Img.js";
|
@@ -149,7 +149,7 @@ function LinkedProfile({
|
|
149
149
|
</Container>
|
150
150
|
) : (
|
151
151
|
<Img
|
152
|
-
src={
|
152
|
+
src={getSocialIcon(profile.type)}
|
153
153
|
width={iconSize.lg}
|
154
154
|
height={iconSize.lg}
|
155
155
|
loading="eager"
|
@@ -1,6 +1,6 @@
|
|
1
1
|
import { useQuery } from "@tanstack/react-query";
|
2
2
|
import { useState } from "react";
|
3
|
-
import { trackPayEvent } from "../../../../analytics/track.js";
|
3
|
+
import { trackPayEvent } from "../../../../analytics/track/pay.js";
|
4
4
|
import type { ThirdwebClient } from "../../../../client/client.js";
|
5
5
|
import type { WaitForReceiptOptions } from "../../../../transaction/actions/wait-for-tx-receipt.js";
|
6
6
|
import type { PreparedTransaction } from "../../../../transaction/prepare-transaction.js";
|
@@ -11,7 +11,7 @@ import { getLastAuthProvider } from "../../../core/utils/storage.js";
|
|
11
11
|
import { useWalletImage } from "../../../core/utils/wallet.js";
|
12
12
|
import {
|
13
13
|
genericWalletIcon,
|
14
|
-
|
14
|
+
getSocialIcon,
|
15
15
|
} from "../../../core/utils/walletIcon.js";
|
16
16
|
import { Img } from "./Img.js";
|
17
17
|
|
@@ -43,7 +43,7 @@ export function WalletImage(props: {
|
|
43
43
|
// when showing an active wallet icon - check last auth provider and override the IAW icon
|
44
44
|
const lastAuthProvider = await getLastAuthProvider(storage);
|
45
45
|
image = lastAuthProvider
|
46
|
-
?
|
46
|
+
? getSocialIcon(lastAuthProvider)
|
47
47
|
: genericWalletIcon;
|
48
48
|
} else {
|
49
49
|
const mipdImage = getInstalledWalletProviders().find(
|
@@ -26,7 +26,7 @@ import {
|
|
26
26
|
import { setLastAuthProvider } from "../../../core/utils/storage.js";
|
27
27
|
import {
|
28
28
|
emailIcon,
|
29
|
-
|
29
|
+
getSocialIcon,
|
30
30
|
passkeyIcon,
|
31
31
|
phoneIcon,
|
32
32
|
socialIcons,
|
@@ -471,7 +471,7 @@ export const ConnectWalletSocialOptions = (
|
|
471
471
|
{guestEnabled && (
|
472
472
|
<WalletTypeRowButton
|
473
473
|
client={props.client}
|
474
|
-
icon={
|
474
|
+
icon={getSocialIcon("guest")}
|
475
475
|
onClick={() => {
|
476
476
|
handleGuestLogin();
|
477
477
|
}}
|
@@ -483,7 +483,7 @@ export const ConnectWalletSocialOptions = (
|
|
483
483
|
{props.isLinking && (
|
484
484
|
<WalletTypeRowButton
|
485
485
|
client={props.client}
|
486
|
-
icon={
|
486
|
+
icon={getSocialIcon("")}
|
487
487
|
onClick={() => {
|
488
488
|
handleWalletLogin();
|
489
489
|
}}
|