thirdweb 5.61.5-nightly-ccd4cd6f59423d417757e86bf04a5a07b061e2f9-20241010000335 → 5.61.6
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/contract/deployment/deploy-with-abi.js +13 -0
- package/dist/cjs/contract/deployment/deploy-with-abi.js.map +1 -1
- package/dist/cjs/exports/extensions/unstoppable-domains.js +6 -1
- package/dist/cjs/exports/extensions/unstoppable-domains.js.map +1 -1
- package/dist/cjs/extensions/modules/__generated__/BatchMetadataERC1155/events/BatchMetadataUpdate.js +1 -1
- package/dist/cjs/extensions/modules/__generated__/BatchMetadataERC1155/events/BatchMetadataUpdate.js.map +1 -1
- package/dist/cjs/extensions/modules/__generated__/BatchMetadataERC1155/read/getBatchIndex.js +114 -0
- package/dist/cjs/extensions/modules/__generated__/BatchMetadataERC1155/read/getBatchIndex.js.map +1 -0
- package/dist/cjs/extensions/modules/__generated__/BatchMetadataERC1155/read/getMetadataBatch.js +128 -0
- package/dist/cjs/extensions/modules/__generated__/BatchMetadataERC1155/read/getMetadataBatch.js.map +1 -0
- package/dist/cjs/extensions/modules/__generated__/BatchMetadataERC1155/read/getModuleConfig.js +109 -0
- package/dist/cjs/extensions/modules/__generated__/BatchMetadataERC1155/read/getModuleConfig.js.map +1 -0
- package/dist/cjs/extensions/modules/__generated__/BatchMetadataERC1155/write/setBaseURI.js +124 -0
- package/dist/cjs/extensions/modules/__generated__/BatchMetadataERC1155/write/setBaseURI.js.map +1 -0
- package/dist/cjs/extensions/modules/__generated__/BatchMetadataERC721/events/BatchMetadataUpdate.js +1 -1
- package/dist/cjs/extensions/modules/__generated__/BatchMetadataERC721/events/BatchMetadataUpdate.js.map +1 -1
- package/dist/cjs/extensions/modules/__generated__/BatchMetadataERC721/read/getBatchIndex.js +114 -0
- package/dist/cjs/extensions/modules/__generated__/BatchMetadataERC721/read/getBatchIndex.js.map +1 -0
- package/dist/cjs/extensions/modules/__generated__/BatchMetadataERC721/read/getMetadataBatch.js +128 -0
- package/dist/cjs/extensions/modules/__generated__/BatchMetadataERC721/read/getMetadataBatch.js.map +1 -0
- package/dist/cjs/extensions/modules/__generated__/BatchMetadataERC721/read/getModuleConfig.js +109 -0
- package/dist/cjs/extensions/modules/__generated__/BatchMetadataERC721/read/getModuleConfig.js.map +1 -0
- package/dist/cjs/extensions/modules/__generated__/BatchMetadataERC721/write/setBaseURI.js +124 -0
- package/dist/cjs/extensions/modules/__generated__/BatchMetadataERC721/write/setBaseURI.js.map +1 -0
- package/dist/cjs/extensions/modules/__generated__/SequentialTokenIdERC1155/encode/encodeBytesOnInstall.js +29 -0
- package/dist/cjs/extensions/modules/__generated__/SequentialTokenIdERC1155/encode/encodeBytesOnInstall.js.map +1 -0
- package/dist/cjs/extensions/modules/__generated__/SequentialTokenIdERC1155/module/install.js +11 -6
- package/dist/cjs/extensions/modules/__generated__/SequentialTokenIdERC1155/module/install.js.map +1 -1
- package/dist/cjs/extensions/modules/__generated__/SequentialTokenIdERC1155/read/getModuleConfig.js +109 -0
- package/dist/cjs/extensions/modules/__generated__/SequentialTokenIdERC1155/read/getModuleConfig.js.map +1 -0
- package/dist/cjs/extensions/modules/__generated__/SequentialTokenIdERC1155/write/updateTokenIdERC1155.js +121 -0
- package/dist/cjs/extensions/modules/__generated__/SequentialTokenIdERC1155/write/updateTokenIdERC1155.js.map +1 -0
- package/dist/cjs/extensions/prebuilts/deploy-published.js +0 -17
- package/dist/cjs/extensions/prebuilts/deploy-published.js.map +1 -1
- package/dist/cjs/extensions/unstoppable-domains/__generated__/UnstoppableDomains/read/exists.js +114 -0
- package/dist/cjs/extensions/unstoppable-domains/__generated__/UnstoppableDomains/read/exists.js.map +1 -0
- package/dist/cjs/extensions/unstoppable-domains/read/resolveAddress.js +6 -0
- package/dist/cjs/extensions/unstoppable-domains/read/resolveAddress.js.map +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/swap/useSwapSupportedChains.js +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/swap/useSwapSupportedChains.js.map +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/useConnectModal.js.map +1 -1
- package/dist/cjs/transaction/read-contract.js +11 -19
- package/dist/cjs/transaction/read-contract.js.map +1 -1
- package/dist/cjs/version.js +1 -1
- package/dist/cjs/version.js.map +1 -1
- package/dist/cjs/wallets/in-app/native/helpers/constants.js +2 -1
- package/dist/cjs/wallets/in-app/native/helpers/constants.js.map +1 -1
- package/dist/cjs/wallets/in-app/native/helpers/storage/local.js +10 -0
- package/dist/cjs/wallets/in-app/native/helpers/storage/local.js.map +1 -1
- package/dist/cjs/wallets/in-app/native/helpers/wallet/retrieval.js +17 -2
- package/dist/cjs/wallets/in-app/native/helpers/wallet/retrieval.js.map +1 -1
- package/dist/cjs/wallets/in-app/web/lib/actions/get-enclave-user-status.js +0 -2
- package/dist/cjs/wallets/in-app/web/lib/actions/get-enclave-user-status.js.map +1 -1
- package/dist/cjs/wallets/in-app/web/lib/actions/sign-message.enclave.js +3 -0
- package/dist/cjs/wallets/in-app/web/lib/actions/sign-message.enclave.js.map +1 -1
- package/dist/cjs/wallets/in-app/web/lib/actions/sign-transaction.enclave.js +3 -1
- package/dist/cjs/wallets/in-app/web/lib/actions/sign-transaction.enclave.js.map +1 -1
- package/dist/cjs/wallets/in-app/web/lib/actions/sign-typed-data.enclave.js +3 -0
- package/dist/cjs/wallets/in-app/web/lib/actions/sign-typed-data.enclave.js.map +1 -1
- package/dist/cjs/wallets/wallet-connect/receiver/index.js +1 -1
- package/dist/cjs/wallets/wallet-connect/receiver/session-request.js +13 -14
- package/dist/cjs/wallets/wallet-connect/receiver/session-request.js.map +1 -1
- package/dist/esm/contract/deployment/deploy-with-abi.js +13 -0
- package/dist/esm/contract/deployment/deploy-with-abi.js.map +1 -1
- package/dist/esm/exports/extensions/unstoppable-domains.js +4 -0
- package/dist/esm/exports/extensions/unstoppable-domains.js.map +1 -1
- package/dist/esm/extensions/modules/__generated__/BatchMetadataERC1155/events/BatchMetadataUpdate.js +1 -1
- package/dist/esm/extensions/modules/__generated__/BatchMetadataERC1155/events/BatchMetadataUpdate.js.map +1 -1
- package/dist/esm/extensions/modules/__generated__/BatchMetadataERC1155/read/getBatchIndex.js +106 -0
- package/dist/esm/extensions/modules/__generated__/BatchMetadataERC1155/read/getBatchIndex.js.map +1 -0
- package/dist/esm/extensions/modules/__generated__/BatchMetadataERC1155/read/getMetadataBatch.js +120 -0
- package/dist/esm/extensions/modules/__generated__/BatchMetadataERC1155/read/getMetadataBatch.js.map +1 -0
- package/dist/esm/extensions/modules/__generated__/BatchMetadataERC1155/read/getModuleConfig.js +103 -0
- package/dist/esm/extensions/modules/__generated__/BatchMetadataERC1155/read/getModuleConfig.js.map +1 -0
- package/dist/esm/extensions/modules/__generated__/BatchMetadataERC1155/write/setBaseURI.js +117 -0
- package/dist/esm/extensions/modules/__generated__/BatchMetadataERC1155/write/setBaseURI.js.map +1 -0
- package/dist/esm/extensions/modules/__generated__/BatchMetadataERC721/events/BatchMetadataUpdate.js +1 -1
- package/dist/esm/extensions/modules/__generated__/BatchMetadataERC721/events/BatchMetadataUpdate.js.map +1 -1
- package/dist/esm/extensions/modules/__generated__/BatchMetadataERC721/read/getBatchIndex.js +106 -0
- package/dist/esm/extensions/modules/__generated__/BatchMetadataERC721/read/getBatchIndex.js.map +1 -0
- package/dist/esm/extensions/modules/__generated__/BatchMetadataERC721/read/getMetadataBatch.js +120 -0
- package/dist/esm/extensions/modules/__generated__/BatchMetadataERC721/read/getMetadataBatch.js.map +1 -0
- package/dist/esm/extensions/modules/__generated__/BatchMetadataERC721/read/getModuleConfig.js +103 -0
- package/dist/esm/extensions/modules/__generated__/BatchMetadataERC721/read/getModuleConfig.js.map +1 -0
- package/dist/esm/extensions/modules/__generated__/BatchMetadataERC721/write/setBaseURI.js +117 -0
- package/dist/esm/extensions/modules/__generated__/BatchMetadataERC721/write/setBaseURI.js.map +1 -0
- package/dist/esm/extensions/modules/__generated__/SequentialTokenIdERC1155/encode/encodeBytesOnInstall.js +25 -0
- package/dist/esm/extensions/modules/__generated__/SequentialTokenIdERC1155/encode/encodeBytesOnInstall.js.map +1 -0
- package/dist/esm/extensions/modules/__generated__/SequentialTokenIdERC1155/module/install.js +11 -6
- package/dist/esm/extensions/modules/__generated__/SequentialTokenIdERC1155/module/install.js.map +1 -1
- package/dist/esm/extensions/modules/__generated__/SequentialTokenIdERC1155/read/getModuleConfig.js +103 -0
- package/dist/esm/extensions/modules/__generated__/SequentialTokenIdERC1155/read/getModuleConfig.js.map +1 -0
- package/dist/esm/extensions/modules/__generated__/SequentialTokenIdERC1155/write/updateTokenIdERC1155.js +114 -0
- package/dist/esm/extensions/modules/__generated__/SequentialTokenIdERC1155/write/updateTokenIdERC1155.js.map +1 -0
- package/dist/esm/extensions/prebuilts/deploy-published.js +0 -18
- package/dist/esm/extensions/prebuilts/deploy-published.js.map +1 -1
- package/dist/esm/extensions/unstoppable-domains/__generated__/UnstoppableDomains/read/exists.js +106 -0
- package/dist/esm/extensions/unstoppable-domains/__generated__/UnstoppableDomains/read/exists.js.map +1 -0
- package/dist/esm/extensions/unstoppable-domains/read/resolveAddress.js +6 -0
- package/dist/esm/extensions/unstoppable-domains/read/resolveAddress.js.map +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/swap/useSwapSupportedChains.js +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/swap/useSwapSupportedChains.js.map +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/useConnectModal.js.map +1 -1
- package/dist/esm/transaction/read-contract.js +11 -19
- package/dist/esm/transaction/read-contract.js.map +1 -1
- package/dist/esm/version.js +1 -1
- package/dist/esm/version.js.map +1 -1
- package/dist/esm/wallets/in-app/native/helpers/constants.js +1 -0
- package/dist/esm/wallets/in-app/native/helpers/constants.js.map +1 -1
- package/dist/esm/wallets/in-app/native/helpers/storage/local.js +9 -0
- package/dist/esm/wallets/in-app/native/helpers/storage/local.js.map +1 -1
- package/dist/esm/wallets/in-app/native/helpers/wallet/retrieval.js +19 -4
- package/dist/esm/wallets/in-app/native/helpers/wallet/retrieval.js.map +1 -1
- package/dist/esm/wallets/in-app/web/lib/actions/get-enclave-user-status.js +0 -2
- package/dist/esm/wallets/in-app/web/lib/actions/get-enclave-user-status.js.map +1 -1
- package/dist/esm/wallets/in-app/web/lib/actions/sign-message.enclave.js +3 -0
- package/dist/esm/wallets/in-app/web/lib/actions/sign-message.enclave.js.map +1 -1
- package/dist/esm/wallets/in-app/web/lib/actions/sign-transaction.enclave.js +3 -1
- package/dist/esm/wallets/in-app/web/lib/actions/sign-transaction.enclave.js.map +1 -1
- package/dist/esm/wallets/in-app/web/lib/actions/sign-typed-data.enclave.js +3 -0
- package/dist/esm/wallets/in-app/web/lib/actions/sign-typed-data.enclave.js.map +1 -1
- package/dist/esm/wallets/wallet-connect/receiver/index.js +1 -1
- package/dist/esm/wallets/wallet-connect/receiver/session-request.js +6 -7
- package/dist/esm/wallets/wallet-connect/receiver/session-request.js.map +1 -1
- package/dist/types/contract/deployment/deploy-with-abi.d.ts.map +1 -1
- package/dist/types/exports/extensions/unstoppable-domains.d.ts +2 -0
- package/dist/types/exports/extensions/unstoppable-domains.d.ts.map +1 -1
- package/dist/types/extensions/modules/__generated__/BatchMetadataERC1155/events/BatchMetadataUpdate.d.ts +5 -2
- package/dist/types/extensions/modules/__generated__/BatchMetadataERC1155/events/BatchMetadataUpdate.d.ts.map +1 -1
- package/dist/types/extensions/modules/__generated__/BatchMetadataERC1155/read/getBatchIndex.d.ts +83 -0
- package/dist/types/extensions/modules/__generated__/BatchMetadataERC1155/read/getBatchIndex.d.ts.map +1 -0
- package/dist/types/extensions/modules/__generated__/BatchMetadataERC1155/read/getMetadataBatch.d.ts +91 -0
- package/dist/types/extensions/modules/__generated__/BatchMetadataERC1155/read/getMetadataBatch.d.ts.map +1 -0
- package/dist/types/extensions/modules/__generated__/BatchMetadataERC1155/read/getModuleConfig.d.ts +66 -0
- package/dist/types/extensions/modules/__generated__/BatchMetadataERC1155/read/getModuleConfig.d.ts.map +1 -0
- package/dist/types/extensions/modules/__generated__/BatchMetadataERC1155/write/setBaseURI.d.ts +86 -0
- package/dist/types/extensions/modules/__generated__/BatchMetadataERC1155/write/setBaseURI.d.ts.map +1 -0
- package/dist/types/extensions/modules/__generated__/BatchMetadataERC721/events/BatchMetadataUpdate.d.ts +5 -2
- package/dist/types/extensions/modules/__generated__/BatchMetadataERC721/events/BatchMetadataUpdate.d.ts.map +1 -1
- package/dist/types/extensions/modules/__generated__/BatchMetadataERC721/read/getBatchIndex.d.ts +83 -0
- package/dist/types/extensions/modules/__generated__/BatchMetadataERC721/read/getBatchIndex.d.ts.map +1 -0
- package/dist/types/extensions/modules/__generated__/BatchMetadataERC721/read/getMetadataBatch.d.ts +91 -0
- package/dist/types/extensions/modules/__generated__/BatchMetadataERC721/read/getMetadataBatch.d.ts.map +1 -0
- package/dist/types/extensions/modules/__generated__/BatchMetadataERC721/read/getModuleConfig.d.ts +66 -0
- package/dist/types/extensions/modules/__generated__/BatchMetadataERC721/read/getModuleConfig.d.ts.map +1 -0
- package/dist/types/extensions/modules/__generated__/BatchMetadataERC721/write/setBaseURI.d.ts +86 -0
- package/dist/types/extensions/modules/__generated__/BatchMetadataERC721/write/setBaseURI.d.ts.map +1 -0
- package/dist/types/extensions/modules/__generated__/SequentialTokenIdERC1155/encode/encodeBytesOnInstall.d.ts +26 -0
- package/dist/types/extensions/modules/__generated__/SequentialTokenIdERC1155/encode/encodeBytesOnInstall.d.ts.map +1 -0
- package/dist/types/extensions/modules/__generated__/SequentialTokenIdERC1155/module/install.d.ts +11 -6
- package/dist/types/extensions/modules/__generated__/SequentialTokenIdERC1155/module/install.d.ts.map +1 -1
- package/dist/types/extensions/modules/__generated__/SequentialTokenIdERC1155/read/getModuleConfig.d.ts +66 -0
- package/dist/types/extensions/modules/__generated__/SequentialTokenIdERC1155/read/getModuleConfig.d.ts.map +1 -0
- package/dist/types/extensions/modules/__generated__/SequentialTokenIdERC1155/write/updateTokenIdERC1155.d.ts +79 -0
- package/dist/types/extensions/modules/__generated__/SequentialTokenIdERC1155/write/updateTokenIdERC1155.d.ts.map +1 -0
- package/dist/types/extensions/prebuilts/deploy-published.d.ts.map +1 -1
- package/dist/types/extensions/unstoppable-domains/__generated__/UnstoppableDomains/read/exists.d.ts +83 -0
- package/dist/types/extensions/unstoppable-domains/__generated__/UnstoppableDomains/read/exists.d.ts.map +1 -0
- package/dist/types/extensions/unstoppable-domains/read/resolveAddress.d.ts.map +1 -1
- package/dist/types/react/web/ui/ConnectWallet/useConnectModal.d.ts +8 -0
- package/dist/types/react/web/ui/ConnectWallet/useConnectModal.d.ts.map +1 -1
- package/dist/types/transaction/read-contract.d.ts +11 -19
- package/dist/types/transaction/read-contract.d.ts.map +1 -1
- package/dist/types/version.d.ts +1 -1
- package/dist/types/version.d.ts.map +1 -1
- package/dist/types/wallets/in-app/core/authentication/types.d.ts +6 -0
- package/dist/types/wallets/in-app/core/authentication/types.d.ts.map +1 -1
- package/dist/types/wallets/in-app/native/helpers/constants.d.ts +1 -0
- package/dist/types/wallets/in-app/native/helpers/constants.d.ts.map +1 -1
- package/dist/types/wallets/in-app/native/helpers/storage/local.d.ts +3 -0
- package/dist/types/wallets/in-app/native/helpers/storage/local.d.ts.map +1 -1
- package/dist/types/wallets/in-app/native/helpers/wallet/retrieval.d.ts.map +1 -1
- package/dist/types/wallets/in-app/web/lib/actions/get-enclave-user-status.d.ts.map +1 -1
- package/dist/types/wallets/in-app/web/lib/actions/sign-message.enclave.d.ts.map +1 -1
- package/dist/types/wallets/in-app/web/lib/actions/sign-transaction.enclave.d.ts.map +1 -1
- package/dist/types/wallets/in-app/web/lib/actions/sign-typed-data.enclave.d.ts.map +1 -1
- package/dist/types/wallets/wallet-connect/receiver/index.d.ts +1 -1
- package/dist/types/wallets/wallet-connect/receiver/session-request.d.ts.map +1 -1
- package/package.json +1 -1
- package/src/contract/deployment/deploy-with-abi.ts +14 -0
- package/src/exports/extensions/unstoppable-domains.ts +9 -0
- package/src/extensions/ens/resolve-avatar.test.ts +1 -4
- package/src/extensions/erc20/read/getCurrencyMetadata.test.ts +20 -0
- package/src/extensions/erc20/read/isERC20.test.ts +35 -0
- package/src/extensions/erc20/write/transferBatch.test.ts +81 -0
- package/src/extensions/modules/MintableERC1155/mintableERC1155.test.ts +3 -1
- package/src/extensions/modules/__generated__/BatchMetadataERC1155/events/BatchMetadataUpdate.ts +1 -1
- package/src/extensions/modules/__generated__/BatchMetadataERC1155/read/getBatchIndex.ts +125 -0
- package/src/extensions/modules/__generated__/BatchMetadataERC1155/read/getMetadataBatch.ts +142 -0
- package/src/extensions/modules/__generated__/BatchMetadataERC1155/read/getModuleConfig.ts +109 -0
- package/src/extensions/modules/__generated__/BatchMetadataERC1155/write/setBaseURI.ts +148 -0
- package/src/extensions/modules/__generated__/BatchMetadataERC721/events/BatchMetadataUpdate.ts +1 -1
- package/src/extensions/modules/__generated__/BatchMetadataERC721/read/getBatchIndex.ts +125 -0
- package/src/extensions/modules/__generated__/BatchMetadataERC721/read/getMetadataBatch.ts +142 -0
- package/src/extensions/modules/__generated__/BatchMetadataERC721/read/getModuleConfig.ts +109 -0
- package/src/extensions/modules/__generated__/BatchMetadataERC721/write/setBaseURI.ts +148 -0
- package/src/extensions/modules/__generated__/SequentialTokenIdERC1155/encode/encodeBytesOnInstall.ts +40 -0
- package/src/extensions/modules/__generated__/SequentialTokenIdERC1155/module/install.ts +18 -9
- package/src/extensions/modules/__generated__/SequentialTokenIdERC1155/read/getModuleConfig.ts +109 -0
- package/src/extensions/modules/__generated__/SequentialTokenIdERC1155/write/updateTokenIdERC1155.ts +145 -0
- package/src/extensions/prebuilts/deploy-published.ts +0 -19
- package/src/extensions/unstoppable-domains/__generated__/UnstoppableDomains/read/exists.ts +121 -0
- package/src/extensions/unstoppable-domains/read/resolveAddress.test.ts +11 -0
- package/src/extensions/unstoppable-domains/read/resolveAddress.ts +9 -0
- package/src/react/web/ui/ConnectWallet/screens/Buy/swap/useSwapSupportedChains.ts +1 -1
- package/src/react/web/ui/ConnectWallet/useConnectModal.tsx +11 -0
- package/src/transaction/read-contract.ts +11 -19
- package/src/version.ts +1 -1
- package/src/wallets/in-app/core/authentication/types.ts +13 -2
- package/src/wallets/in-app/native/helpers/constants.ts +2 -0
- package/src/wallets/in-app/native/helpers/storage/local.ts +16 -0
- package/src/wallets/in-app/native/helpers/wallet/retrieval.ts +19 -3
- package/src/wallets/in-app/web/lib/actions/get-enclave-user-status.ts +0 -2
- package/src/wallets/in-app/web/lib/actions/sign-message.enclave.ts +4 -0
- package/src/wallets/in-app/web/lib/actions/sign-transaction.enclave.ts +4 -1
- package/src/wallets/in-app/web/lib/actions/sign-typed-data.enclave.ts +4 -0
- package/src/wallets/wallet-connect/receiver/index.ts +1 -1
- package/src/wallets/wallet-connect/receiver/session-request.ts +6 -23
- package/dist/cjs/extensions/modules/__generated__/SequentialTokenIdERC1155/read/encodeBytesOnInstall.js +0 -70
- package/dist/cjs/extensions/modules/__generated__/SequentialTokenIdERC1155/read/encodeBytesOnInstall.js.map +0 -1
- package/dist/esm/extensions/modules/__generated__/SequentialTokenIdERC1155/read/encodeBytesOnInstall.js +0 -64
- package/dist/esm/extensions/modules/__generated__/SequentialTokenIdERC1155/read/encodeBytesOnInstall.js.map +0 -1
- package/dist/types/extensions/modules/__generated__/SequentialTokenIdERC1155/read/encodeBytesOnInstall.d.ts +0 -44
- package/dist/types/extensions/modules/__generated__/SequentialTokenIdERC1155/read/encodeBytesOnInstall.d.ts.map +0 -1
- package/src/extensions/modules/__generated__/SequentialTokenIdERC1155/read/encodeBytesOnInstall.ts +0 -70
@@ -1,5 +1,4 @@
|
|
1
1
|
import { describe, expect, it } from "vitest";
|
2
|
-
|
3
2
|
import { TEST_CLIENT } from "../../../test/src/test-clients.js";
|
4
3
|
import { resolveAvatar } from "./resolve-avatar.js";
|
5
4
|
|
@@ -22,9 +21,7 @@ describe.runIf(process.env.TW_SECRET_KEY)("ENS:resolve-avatar", () => {
|
|
22
21
|
client: TEST_CLIENT,
|
23
22
|
name: "vitalik.eth",
|
24
23
|
});
|
25
|
-
expect(avatarUri
|
26
|
-
`"QmSP4nq9fnN9dAiCj42ug9Wa79rqmQerZXZch82VqpiH7U/image.gif"`,
|
27
|
-
);
|
24
|
+
expect(avatarUri).toMatchInlineSnapshot(`"https://euc.li/vitalik.eth"`);
|
28
25
|
});
|
29
26
|
|
30
27
|
it("resolves name without avatar record to null", async () => {
|
@@ -0,0 +1,20 @@
|
|
1
|
+
import { describe, expect, it } from "vitest";
|
2
|
+
import { DOODLES_CONTRACT, USDT_CONTRACT } from "~test/test-contracts.js";
|
3
|
+
import { getCurrencyMetadata } from "./getCurrencyMetadata.js";
|
4
|
+
|
5
|
+
describe("getCurrencyMetadata", () => {
|
6
|
+
it("should throw if not a valid ERC20 contract", async () => {
|
7
|
+
await expect(() =>
|
8
|
+
getCurrencyMetadata({ contract: DOODLES_CONTRACT }),
|
9
|
+
).rejects.toThrowError("Invalid currency token");
|
10
|
+
});
|
11
|
+
|
12
|
+
it("should return valid result if the contract is ERC20", async () => {
|
13
|
+
const result = await getCurrencyMetadata({ contract: USDT_CONTRACT });
|
14
|
+
expect(result).toStrictEqual({
|
15
|
+
name: "Tether USD",
|
16
|
+
symbol: "USDT",
|
17
|
+
decimals: 6,
|
18
|
+
});
|
19
|
+
});
|
20
|
+
});
|
@@ -0,0 +1,35 @@
|
|
1
|
+
import { type Abi, toFunctionSelector } from "viem";
|
2
|
+
import { describe, expect, it } from "vitest";
|
3
|
+
import {
|
4
|
+
BASE_USDC_PROXY_CONTRACT,
|
5
|
+
DOODLES_CONTRACT,
|
6
|
+
USDT_CONTRACT,
|
7
|
+
} from "~test/test-contracts.js";
|
8
|
+
import { resolveContractAbi } from "../../../contract/actions/resolve-abi.js";
|
9
|
+
import { isERC20 } from "./isERC20.js";
|
10
|
+
|
11
|
+
describe("isERC20", () => {
|
12
|
+
it("should detect USDT as a valid erc20 contract", async () => {
|
13
|
+
const abi = await resolveContractAbi<Abi>(USDT_CONTRACT);
|
14
|
+
const selectors = abi
|
15
|
+
.filter((f) => f.type === "function")
|
16
|
+
.map((f) => toFunctionSelector(f));
|
17
|
+
expect(isERC20(selectors)).toBe(true);
|
18
|
+
});
|
19
|
+
|
20
|
+
it("should detect USDC as a valid erc20 contract", async () => {
|
21
|
+
const abi = await resolveContractAbi<Abi>(BASE_USDC_PROXY_CONTRACT);
|
22
|
+
const selectors = abi
|
23
|
+
.filter((f) => f.type === "function")
|
24
|
+
.map((f) => toFunctionSelector(f));
|
25
|
+
expect(isERC20(selectors)).toBe(true);
|
26
|
+
});
|
27
|
+
|
28
|
+
it("should NOT detect any NFT contract as a valid erc20 contract", async () => {
|
29
|
+
const abi = await resolveContractAbi<Abi>(DOODLES_CONTRACT);
|
30
|
+
const selectors = abi
|
31
|
+
.filter((f) => f.type === "function")
|
32
|
+
.map((f) => toFunctionSelector(f));
|
33
|
+
expect(isERC20(selectors)).toBe(false);
|
34
|
+
});
|
35
|
+
});
|
@@ -0,0 +1,81 @@
|
|
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 { deployERC20Contract } from "../../../extensions/prebuilts/deploy-erc20.js";
|
13
|
+
import { sendAndConfirmTransaction } from "../../../transaction/actions/send-and-confirm-transaction.js";
|
14
|
+
import { balanceOf } from "../__generated__/IERC20/read/balanceOf.js";
|
15
|
+
import { mintTo } from "./mintTo.js";
|
16
|
+
import { transferBatch } from "./transferBatch.js";
|
17
|
+
|
18
|
+
const chain = ANVIL_CHAIN;
|
19
|
+
const client = TEST_CLIENT;
|
20
|
+
const account = TEST_ACCOUNT_A;
|
21
|
+
|
22
|
+
describe("erc20: transferBatch", () => {
|
23
|
+
it("should transfer tokens to multiple recipients", async () => {
|
24
|
+
const address = await deployERC20Contract({
|
25
|
+
type: "TokenERC20",
|
26
|
+
account,
|
27
|
+
chain,
|
28
|
+
client,
|
29
|
+
params: {
|
30
|
+
name: "",
|
31
|
+
contractURI: TEST_CONTRACT_URI,
|
32
|
+
},
|
33
|
+
});
|
34
|
+
const contract = getContract({
|
35
|
+
address,
|
36
|
+
chain,
|
37
|
+
client,
|
38
|
+
});
|
39
|
+
|
40
|
+
// Mint 100 tokens
|
41
|
+
await sendAndConfirmTransaction({
|
42
|
+
transaction: mintTo({ contract, to: account.address, amount: 100 }),
|
43
|
+
account,
|
44
|
+
});
|
45
|
+
|
46
|
+
// Send 25 tokens to each account B, C and D
|
47
|
+
await sendAndConfirmTransaction({
|
48
|
+
account,
|
49
|
+
transaction: transferBatch({
|
50
|
+
contract,
|
51
|
+
batch: [
|
52
|
+
{
|
53
|
+
to: TEST_ACCOUNT_B.address,
|
54
|
+
amount: 25,
|
55
|
+
},
|
56
|
+
{
|
57
|
+
to: TEST_ACCOUNT_C.address,
|
58
|
+
amount: 25,
|
59
|
+
},
|
60
|
+
{
|
61
|
+
to: TEST_ACCOUNT_D.address,
|
62
|
+
amount: 25,
|
63
|
+
},
|
64
|
+
],
|
65
|
+
}),
|
66
|
+
});
|
67
|
+
|
68
|
+
// After that, each address A, B, C and D should have 25 tokens
|
69
|
+
const [balanceA, balanceB, balanceC, balanceD] = await Promise.all([
|
70
|
+
balanceOf({ contract, address: TEST_ACCOUNT_A.address }),
|
71
|
+
balanceOf({ contract, address: TEST_ACCOUNT_B.address }),
|
72
|
+
balanceOf({ contract, address: TEST_ACCOUNT_C.address }),
|
73
|
+
balanceOf({ contract, address: TEST_ACCOUNT_D.address }),
|
74
|
+
]);
|
75
|
+
|
76
|
+
expect(balanceA).toBe(25n * 10n ** 18n);
|
77
|
+
expect(balanceB).toBe(25n * 10n ** 18n);
|
78
|
+
expect(balanceC).toBe(25n * 10n ** 18n);
|
79
|
+
expect(balanceD).toBe(25n * 10n ** 18n);
|
80
|
+
});
|
81
|
+
});
|
@@ -40,7 +40,9 @@ describe.runIf(process.env.TW_SECRET_KEY)("ModularTokenERC1155", () => {
|
|
40
40
|
primarySaleRecipient: TEST_ACCOUNT_A.address,
|
41
41
|
}),
|
42
42
|
BatchMetadataERC1155.module(),
|
43
|
-
SequentialTokenIdERC1155.module(
|
43
|
+
SequentialTokenIdERC1155.module({
|
44
|
+
startTokenId: 0n,
|
45
|
+
}),
|
44
46
|
],
|
45
47
|
});
|
46
48
|
contract = getContract({
|
package/src/extensions/modules/__generated__/BatchMetadataERC1155/events/BatchMetadataUpdate.ts
CHANGED
@@ -20,6 +20,6 @@ import { prepareEvent } from "../../../../../event/prepare-event.js";
|
|
20
20
|
export function batchMetadataUpdateEvent() {
|
21
21
|
return prepareEvent({
|
22
22
|
signature:
|
23
|
-
"event BatchMetadataUpdate(uint256
|
23
|
+
"event BatchMetadataUpdate(uint256 startTokenIdIncluside, uint256 endTokenIdInclusive, string baseURI)",
|
24
24
|
});
|
25
25
|
}
|
@@ -0,0 +1,125 @@
|
|
1
|
+
import type { AbiParameterToPrimitiveType } from "abitype";
|
2
|
+
import { readContract } from "../../../../../transaction/read-contract.js";
|
3
|
+
import type { BaseTransactionOptions } from "../../../../../transaction/types.js";
|
4
|
+
import { encodeAbiParameters } from "../../../../../utils/abi/encodeAbiParameters.js";
|
5
|
+
import { decodeAbiParameters } from "viem";
|
6
|
+
import type { Hex } from "../../../../../utils/encoding/hex.js";
|
7
|
+
import { detectMethod } from "../../../../../utils/bytecode/detectExtension.js";
|
8
|
+
|
9
|
+
/**
|
10
|
+
* Represents the parameters for the "getBatchIndex" function.
|
11
|
+
*/
|
12
|
+
export type GetBatchIndexParams = {
|
13
|
+
tokenId: AbiParameterToPrimitiveType<{ type: "uint256"; name: "_tokenId" }>;
|
14
|
+
};
|
15
|
+
|
16
|
+
export const FN_SELECTOR = "0x44ec3c07" as const;
|
17
|
+
const FN_INPUTS = [
|
18
|
+
{
|
19
|
+
type: "uint256",
|
20
|
+
name: "_tokenId",
|
21
|
+
},
|
22
|
+
] as const;
|
23
|
+
const FN_OUTPUTS = [
|
24
|
+
{
|
25
|
+
type: "uint256",
|
26
|
+
},
|
27
|
+
] as const;
|
28
|
+
|
29
|
+
/**
|
30
|
+
* Checks if the `getBatchIndex` method is supported by the given contract.
|
31
|
+
* @param availableSelectors An array of 4byte function selectors of the contract. You can get this in various ways, such as using "whatsabi" or if you have the ABI of the contract available you can use it to generate the selectors.
|
32
|
+
* @returns A boolean indicating if the `getBatchIndex` method is supported.
|
33
|
+
* @modules BatchMetadataERC1155
|
34
|
+
* @example
|
35
|
+
* ```ts
|
36
|
+
* import { BatchMetadataERC1155 } from "thirdweb/modules";
|
37
|
+
* const supported = BatchMetadataERC1155.isGetBatchIndexSupported(["0x..."]);
|
38
|
+
* ```
|
39
|
+
*/
|
40
|
+
export function isGetBatchIndexSupported(availableSelectors: string[]) {
|
41
|
+
return detectMethod({
|
42
|
+
availableSelectors,
|
43
|
+
method: [FN_SELECTOR, FN_INPUTS, FN_OUTPUTS] as const,
|
44
|
+
});
|
45
|
+
}
|
46
|
+
|
47
|
+
/**
|
48
|
+
* Encodes the parameters for the "getBatchIndex" function.
|
49
|
+
* @param options - The options for the getBatchIndex function.
|
50
|
+
* @returns The encoded ABI parameters.
|
51
|
+
* @modules BatchMetadataERC1155
|
52
|
+
* @example
|
53
|
+
* ```ts
|
54
|
+
* import { BatchMetadataERC1155 } from "thirdweb/modules";
|
55
|
+
* const result = BatchMetadataERC1155.encodeGetBatchIndexParams({
|
56
|
+
* tokenId: ...,
|
57
|
+
* });
|
58
|
+
* ```
|
59
|
+
*/
|
60
|
+
export function encodeGetBatchIndexParams(options: GetBatchIndexParams) {
|
61
|
+
return encodeAbiParameters(FN_INPUTS, [options.tokenId]);
|
62
|
+
}
|
63
|
+
|
64
|
+
/**
|
65
|
+
* Encodes the "getBatchIndex" function into a Hex string with its parameters.
|
66
|
+
* @param options - The options for the getBatchIndex function.
|
67
|
+
* @returns The encoded hexadecimal string.
|
68
|
+
* @modules BatchMetadataERC1155
|
69
|
+
* @example
|
70
|
+
* ```ts
|
71
|
+
* import { BatchMetadataERC1155 } from "thirdweb/modules";
|
72
|
+
* const result = BatchMetadataERC1155.encodeGetBatchIndex({
|
73
|
+
* tokenId: ...,
|
74
|
+
* });
|
75
|
+
* ```
|
76
|
+
*/
|
77
|
+
export function encodeGetBatchIndex(options: GetBatchIndexParams) {
|
78
|
+
// we do a "manual" concat here to avoid the overhead of the "concatHex" function
|
79
|
+
// we can do this because we know the specific formats of the values
|
80
|
+
return (FN_SELECTOR +
|
81
|
+
encodeGetBatchIndexParams(options).slice(
|
82
|
+
2,
|
83
|
+
)) as `${typeof FN_SELECTOR}${string}`;
|
84
|
+
}
|
85
|
+
|
86
|
+
/**
|
87
|
+
* Decodes the result of the getBatchIndex function call.
|
88
|
+
* @param result - The hexadecimal result to decode.
|
89
|
+
* @returns The decoded result as per the FN_OUTPUTS definition.
|
90
|
+
* @modules BatchMetadataERC1155
|
91
|
+
* @example
|
92
|
+
* ```ts
|
93
|
+
* import { BatchMetadataERC1155 } from "thirdweb/modules";
|
94
|
+
* const result = BatchMetadataERC1155.decodeGetBatchIndexResultResult("...");
|
95
|
+
* ```
|
96
|
+
*/
|
97
|
+
export function decodeGetBatchIndexResult(result: Hex) {
|
98
|
+
return decodeAbiParameters(FN_OUTPUTS, result)[0];
|
99
|
+
}
|
100
|
+
|
101
|
+
/**
|
102
|
+
* Calls the "getBatchIndex" function on the contract.
|
103
|
+
* @param options - The options for the getBatchIndex function.
|
104
|
+
* @returns The parsed result of the function call.
|
105
|
+
* @modules BatchMetadataERC1155
|
106
|
+
* @example
|
107
|
+
* ```ts
|
108
|
+
* import { BatchMetadataERC1155 } from "thirdweb/modules";
|
109
|
+
*
|
110
|
+
* const result = await BatchMetadataERC1155.getBatchIndex({
|
111
|
+
* contract,
|
112
|
+
* tokenId: ...,
|
113
|
+
* });
|
114
|
+
*
|
115
|
+
* ```
|
116
|
+
*/
|
117
|
+
export async function getBatchIndex(
|
118
|
+
options: BaseTransactionOptions<GetBatchIndexParams>,
|
119
|
+
) {
|
120
|
+
return readContract({
|
121
|
+
contract: options.contract,
|
122
|
+
method: [FN_SELECTOR, FN_INPUTS, FN_OUTPUTS] as const,
|
123
|
+
params: [options.tokenId],
|
124
|
+
});
|
125
|
+
}
|
@@ -0,0 +1,142 @@
|
|
1
|
+
import type { AbiParameterToPrimitiveType } from "abitype";
|
2
|
+
import { readContract } from "../../../../../transaction/read-contract.js";
|
3
|
+
import type { BaseTransactionOptions } from "../../../../../transaction/types.js";
|
4
|
+
import { encodeAbiParameters } from "../../../../../utils/abi/encodeAbiParameters.js";
|
5
|
+
import { decodeAbiParameters } from "viem";
|
6
|
+
import type { Hex } from "../../../../../utils/encoding/hex.js";
|
7
|
+
import { detectMethod } from "../../../../../utils/bytecode/detectExtension.js";
|
8
|
+
|
9
|
+
/**
|
10
|
+
* Represents the parameters for the "getMetadataBatch" function.
|
11
|
+
*/
|
12
|
+
export type GetMetadataBatchParams = {
|
13
|
+
batchIndex: AbiParameterToPrimitiveType<{
|
14
|
+
type: "uint256";
|
15
|
+
name: "_batchIndex";
|
16
|
+
}>;
|
17
|
+
};
|
18
|
+
|
19
|
+
export const FN_SELECTOR = "0xe034558b" as const;
|
20
|
+
const FN_INPUTS = [
|
21
|
+
{
|
22
|
+
type: "uint256",
|
23
|
+
name: "_batchIndex",
|
24
|
+
},
|
25
|
+
] as const;
|
26
|
+
const FN_OUTPUTS = [
|
27
|
+
{
|
28
|
+
type: "tuple",
|
29
|
+
components: [
|
30
|
+
{
|
31
|
+
type: "uint256",
|
32
|
+
name: "startTokenIdInclusive",
|
33
|
+
},
|
34
|
+
{
|
35
|
+
type: "uint256",
|
36
|
+
name: "endTokenIdInclusive",
|
37
|
+
},
|
38
|
+
{
|
39
|
+
type: "string",
|
40
|
+
name: "baseURI",
|
41
|
+
},
|
42
|
+
],
|
43
|
+
},
|
44
|
+
] as const;
|
45
|
+
|
46
|
+
/**
|
47
|
+
* Checks if the `getMetadataBatch` method is supported by the given contract.
|
48
|
+
* @param availableSelectors An array of 4byte function selectors of the contract. You can get this in various ways, such as using "whatsabi" or if you have the ABI of the contract available you can use it to generate the selectors.
|
49
|
+
* @returns A boolean indicating if the `getMetadataBatch` method is supported.
|
50
|
+
* @modules BatchMetadataERC1155
|
51
|
+
* @example
|
52
|
+
* ```ts
|
53
|
+
* import { BatchMetadataERC1155 } from "thirdweb/modules";
|
54
|
+
* const supported = BatchMetadataERC1155.isGetMetadataBatchSupported(["0x..."]);
|
55
|
+
* ```
|
56
|
+
*/
|
57
|
+
export function isGetMetadataBatchSupported(availableSelectors: string[]) {
|
58
|
+
return detectMethod({
|
59
|
+
availableSelectors,
|
60
|
+
method: [FN_SELECTOR, FN_INPUTS, FN_OUTPUTS] as const,
|
61
|
+
});
|
62
|
+
}
|
63
|
+
|
64
|
+
/**
|
65
|
+
* Encodes the parameters for the "getMetadataBatch" function.
|
66
|
+
* @param options - The options for the getMetadataBatch function.
|
67
|
+
* @returns The encoded ABI parameters.
|
68
|
+
* @modules BatchMetadataERC1155
|
69
|
+
* @example
|
70
|
+
* ```ts
|
71
|
+
* import { BatchMetadataERC1155 } from "thirdweb/modules";
|
72
|
+
* const result = BatchMetadataERC1155.encodeGetMetadataBatchParams({
|
73
|
+
* batchIndex: ...,
|
74
|
+
* });
|
75
|
+
* ```
|
76
|
+
*/
|
77
|
+
export function encodeGetMetadataBatchParams(options: GetMetadataBatchParams) {
|
78
|
+
return encodeAbiParameters(FN_INPUTS, [options.batchIndex]);
|
79
|
+
}
|
80
|
+
|
81
|
+
/**
|
82
|
+
* Encodes the "getMetadataBatch" function into a Hex string with its parameters.
|
83
|
+
* @param options - The options for the getMetadataBatch function.
|
84
|
+
* @returns The encoded hexadecimal string.
|
85
|
+
* @modules BatchMetadataERC1155
|
86
|
+
* @example
|
87
|
+
* ```ts
|
88
|
+
* import { BatchMetadataERC1155 } from "thirdweb/modules";
|
89
|
+
* const result = BatchMetadataERC1155.encodeGetMetadataBatch({
|
90
|
+
* batchIndex: ...,
|
91
|
+
* });
|
92
|
+
* ```
|
93
|
+
*/
|
94
|
+
export function encodeGetMetadataBatch(options: GetMetadataBatchParams) {
|
95
|
+
// we do a "manual" concat here to avoid the overhead of the "concatHex" function
|
96
|
+
// we can do this because we know the specific formats of the values
|
97
|
+
return (FN_SELECTOR +
|
98
|
+
encodeGetMetadataBatchParams(options).slice(
|
99
|
+
2,
|
100
|
+
)) as `${typeof FN_SELECTOR}${string}`;
|
101
|
+
}
|
102
|
+
|
103
|
+
/**
|
104
|
+
* Decodes the result of the getMetadataBatch function call.
|
105
|
+
* @param result - The hexadecimal result to decode.
|
106
|
+
* @returns The decoded result as per the FN_OUTPUTS definition.
|
107
|
+
* @modules BatchMetadataERC1155
|
108
|
+
* @example
|
109
|
+
* ```ts
|
110
|
+
* import { BatchMetadataERC1155 } from "thirdweb/modules";
|
111
|
+
* const result = BatchMetadataERC1155.decodeGetMetadataBatchResultResult("...");
|
112
|
+
* ```
|
113
|
+
*/
|
114
|
+
export function decodeGetMetadataBatchResult(result: Hex) {
|
115
|
+
return decodeAbiParameters(FN_OUTPUTS, result)[0];
|
116
|
+
}
|
117
|
+
|
118
|
+
/**
|
119
|
+
* Calls the "getMetadataBatch" function on the contract.
|
120
|
+
* @param options - The options for the getMetadataBatch function.
|
121
|
+
* @returns The parsed result of the function call.
|
122
|
+
* @modules BatchMetadataERC1155
|
123
|
+
* @example
|
124
|
+
* ```ts
|
125
|
+
* import { BatchMetadataERC1155 } from "thirdweb/modules";
|
126
|
+
*
|
127
|
+
* const result = await BatchMetadataERC1155.getMetadataBatch({
|
128
|
+
* contract,
|
129
|
+
* batchIndex: ...,
|
130
|
+
* });
|
131
|
+
*
|
132
|
+
* ```
|
133
|
+
*/
|
134
|
+
export async function getMetadataBatch(
|
135
|
+
options: BaseTransactionOptions<GetMetadataBatchParams>,
|
136
|
+
) {
|
137
|
+
return readContract({
|
138
|
+
contract: options.contract,
|
139
|
+
method: [FN_SELECTOR, FN_INPUTS, FN_OUTPUTS] as const,
|
140
|
+
params: [options.batchIndex],
|
141
|
+
});
|
142
|
+
}
|
@@ -0,0 +1,109 @@
|
|
1
|
+
import { readContract } from "../../../../../transaction/read-contract.js";
|
2
|
+
import type { BaseTransactionOptions } from "../../../../../transaction/types.js";
|
3
|
+
|
4
|
+
import { decodeAbiParameters } from "viem";
|
5
|
+
import type { Hex } from "../../../../../utils/encoding/hex.js";
|
6
|
+
import { detectMethod } from "../../../../../utils/bytecode/detectExtension.js";
|
7
|
+
|
8
|
+
export const FN_SELECTOR = "0x89e04e0e" as const;
|
9
|
+
const FN_INPUTS = [] as const;
|
10
|
+
const FN_OUTPUTS = [
|
11
|
+
{
|
12
|
+
type: "tuple",
|
13
|
+
name: "config",
|
14
|
+
components: [
|
15
|
+
{
|
16
|
+
type: "bool",
|
17
|
+
name: "registerInstallationCallback",
|
18
|
+
},
|
19
|
+
{
|
20
|
+
type: "bytes4[]",
|
21
|
+
name: "requiredInterfaces",
|
22
|
+
},
|
23
|
+
{
|
24
|
+
type: "bytes4[]",
|
25
|
+
name: "supportedInterfaces",
|
26
|
+
},
|
27
|
+
{
|
28
|
+
type: "tuple[]",
|
29
|
+
name: "callbackFunctions",
|
30
|
+
components: [
|
31
|
+
{
|
32
|
+
type: "bytes4",
|
33
|
+
name: "selector",
|
34
|
+
},
|
35
|
+
],
|
36
|
+
},
|
37
|
+
{
|
38
|
+
type: "tuple[]",
|
39
|
+
name: "fallbackFunctions",
|
40
|
+
components: [
|
41
|
+
{
|
42
|
+
type: "bytes4",
|
43
|
+
name: "selector",
|
44
|
+
},
|
45
|
+
{
|
46
|
+
type: "uint256",
|
47
|
+
name: "permissionBits",
|
48
|
+
},
|
49
|
+
],
|
50
|
+
},
|
51
|
+
],
|
52
|
+
},
|
53
|
+
] as const;
|
54
|
+
|
55
|
+
/**
|
56
|
+
* Checks if the `getModuleConfig` method is supported by the given contract.
|
57
|
+
* @param availableSelectors An array of 4byte function selectors of the contract. You can get this in various ways, such as using "whatsabi" or if you have the ABI of the contract available you can use it to generate the selectors.
|
58
|
+
* @returns A boolean indicating if the `getModuleConfig` method is supported.
|
59
|
+
* @modules BatchMetadataERC1155
|
60
|
+
* @example
|
61
|
+
* ```ts
|
62
|
+
* import { BatchMetadataERC1155 } from "thirdweb/modules";
|
63
|
+
* const supported = BatchMetadataERC1155.isGetModuleConfigSupported(["0x..."]);
|
64
|
+
* ```
|
65
|
+
*/
|
66
|
+
export function isGetModuleConfigSupported(availableSelectors: string[]) {
|
67
|
+
return detectMethod({
|
68
|
+
availableSelectors,
|
69
|
+
method: [FN_SELECTOR, FN_INPUTS, FN_OUTPUTS] as const,
|
70
|
+
});
|
71
|
+
}
|
72
|
+
|
73
|
+
/**
|
74
|
+
* Decodes the result of the getModuleConfig function call.
|
75
|
+
* @param result - The hexadecimal result to decode.
|
76
|
+
* @returns The decoded result as per the FN_OUTPUTS definition.
|
77
|
+
* @modules BatchMetadataERC1155
|
78
|
+
* @example
|
79
|
+
* ```ts
|
80
|
+
* import { BatchMetadataERC1155 } from "thirdweb/modules";
|
81
|
+
* const result = BatchMetadataERC1155.decodeGetModuleConfigResultResult("...");
|
82
|
+
* ```
|
83
|
+
*/
|
84
|
+
export function decodeGetModuleConfigResult(result: Hex) {
|
85
|
+
return decodeAbiParameters(FN_OUTPUTS, result)[0];
|
86
|
+
}
|
87
|
+
|
88
|
+
/**
|
89
|
+
* Calls the "getModuleConfig" function on the contract.
|
90
|
+
* @param options - The options for the getModuleConfig function.
|
91
|
+
* @returns The parsed result of the function call.
|
92
|
+
* @modules BatchMetadataERC1155
|
93
|
+
* @example
|
94
|
+
* ```ts
|
95
|
+
* import { BatchMetadataERC1155 } from "thirdweb/modules";
|
96
|
+
*
|
97
|
+
* const result = await BatchMetadataERC1155.getModuleConfig({
|
98
|
+
* contract,
|
99
|
+
* });
|
100
|
+
*
|
101
|
+
* ```
|
102
|
+
*/
|
103
|
+
export async function getModuleConfig(options: BaseTransactionOptions) {
|
104
|
+
return readContract({
|
105
|
+
contract: options.contract,
|
106
|
+
method: [FN_SELECTOR, FN_INPUTS, FN_OUTPUTS] as const,
|
107
|
+
params: [],
|
108
|
+
});
|
109
|
+
}
|