thirdweb 5.63.3-nightly-50f98d7486809c541252a9cfc6979d102960366b-20241022000337 → 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.
Files changed (511) hide show
  1. package/dist/cjs/analytics/track/connect.js +21 -0
  2. package/dist/cjs/analytics/track/connect.js.map +1 -0
  3. package/dist/cjs/analytics/track/index.js +21 -0
  4. package/dist/cjs/analytics/track/index.js.map +1 -0
  5. package/dist/cjs/analytics/track/pay.js +26 -0
  6. package/dist/cjs/analytics/track/pay.js.map +1 -0
  7. package/dist/cjs/analytics/track/siwe.js +32 -0
  8. package/dist/cjs/analytics/track/siwe.js.map +1 -0
  9. package/dist/cjs/analytics/track/transaction.js +36 -0
  10. package/dist/cjs/analytics/track/transaction.js.map +1 -0
  11. package/dist/cjs/auth/core/verify-login-payload.js +19 -1
  12. package/dist/cjs/auth/core/verify-login-payload.js.map +1 -1
  13. package/dist/cjs/exports/extensions/erc1155.js +3 -1
  14. package/dist/cjs/exports/extensions/erc1155.js.map +1 -1
  15. package/dist/cjs/exports/extensions/erc721.js +3 -1
  16. package/dist/cjs/exports/extensions/erc721.js.map +1 -1
  17. package/dist/cjs/exports/wallets/in-app.js +2 -1
  18. package/dist/cjs/exports/wallets/in-app.js.map +1 -1
  19. package/dist/cjs/extensions/erc1155/write/mintAdditionalSupplyToBatch.js +88 -0
  20. package/dist/cjs/extensions/erc1155/write/mintAdditionalSupplyToBatch.js.map +1 -0
  21. package/dist/cjs/extensions/erc1155/write/mintToBatch.js +9 -17
  22. package/dist/cjs/extensions/erc1155/write/mintToBatch.js.map +1 -1
  23. package/dist/cjs/extensions/erc721/drops/write/claimToBatch.js +115 -0
  24. package/dist/cjs/extensions/erc721/drops/write/claimToBatch.js.map +1 -0
  25. package/dist/cjs/react/core/utils/walletIcon.js +6 -2
  26. package/dist/cjs/react/core/utils/walletIcon.js.map +1 -1
  27. package/dist/cjs/react/native/ui/components/WalletImage.js +2 -0
  28. package/dist/cjs/react/native/ui/components/WalletImage.js.map +1 -1
  29. package/dist/cjs/react/native/ui/connect/InAppWalletUI.js +1 -0
  30. package/dist/cjs/react/native/ui/connect/InAppWalletUI.js.map +1 -1
  31. package/dist/cjs/react/native/ui/icons/svgs.js +5 -1
  32. package/dist/cjs/react/native/ui/icons/svgs.js.map +1 -1
  33. package/dist/cjs/react/web/hooks/transaction/useSendTransaction.js +3 -4
  34. package/dist/cjs/react/web/hooks/transaction/useSendTransaction.js.map +1 -1
  35. package/dist/cjs/react/web/ui/ConnectWallet/Details.js +2 -2
  36. package/dist/cjs/react/web/ui/ConnectWallet/Details.js.map +1 -1
  37. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/BuyScreen.js +3 -3
  38. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/BuyScreen.js.map +1 -1
  39. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/DirectPaymentModeScreen.js +2 -2
  40. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/DirectPaymentModeScreen.js.map +1 -1
  41. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/TransactionModeScreen.js +2 -2
  42. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/TransactionModeScreen.js.map +1 -1
  43. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/fiat/FiatFlow.js +2 -2
  44. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/fiat/FiatFlow.js.map +1 -1
  45. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/swap/ConfirmationScreen.js +5 -5
  46. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/swap/ConfirmationScreen.js.map +1 -1
  47. package/dist/cjs/react/web/ui/ConnectWallet/screens/LinkedProfilesScreen.js +1 -1
  48. package/dist/cjs/react/web/ui/TransactionButton/TransactionModal.js +2 -2
  49. package/dist/cjs/react/web/ui/TransactionButton/TransactionModal.js.map +1 -1
  50. package/dist/cjs/react/web/ui/components/WalletImage.js +1 -1
  51. package/dist/cjs/react/web/wallets/shared/ConnectWalletSocialOptions.js +5 -3
  52. package/dist/cjs/react/web/wallets/shared/ConnectWalletSocialOptions.js.map +1 -1
  53. package/dist/cjs/react/web/wallets/shared/oauthSignIn.js +1 -0
  54. package/dist/cjs/react/web/wallets/shared/oauthSignIn.js.map +1 -1
  55. package/dist/cjs/version.js +1 -1
  56. package/dist/cjs/wallets/__generated__/getWalletInfo.js +45 -15
  57. package/dist/cjs/wallets/__generated__/getWalletInfo.js.map +1 -1
  58. package/dist/cjs/wallets/__generated__/wallet/app.nightly/image.js +7 -0
  59. package/dist/cjs/wallets/__generated__/wallet/app.nightly/image.js.map +1 -0
  60. package/dist/cjs/wallets/__generated__/wallet/app.nightly/index.js +34 -0
  61. package/dist/cjs/wallets/__generated__/wallet/app.nightly/index.js.map +1 -0
  62. package/dist/cjs/wallets/__generated__/wallet/app.status/image.js +1 -1
  63. package/dist/cjs/wallets/__generated__/wallet/app.status/image.js.map +1 -1
  64. package/dist/cjs/wallets/__generated__/wallet/app.status/index.js +1 -1
  65. package/dist/cjs/wallets/__generated__/wallet/app.walletnow/index.js +1 -1
  66. package/dist/cjs/wallets/__generated__/wallet/app.walletnow/index.js.map +1 -1
  67. package/dist/cjs/wallets/__generated__/wallet/com.beexo/image.js +7 -0
  68. package/dist/cjs/wallets/__generated__/wallet/com.beexo/image.js.map +1 -0
  69. package/dist/cjs/wallets/__generated__/wallet/{org.nitrogen → com.beexo}/index.js +9 -9
  70. package/dist/cjs/wallets/__generated__/wallet/com.beexo/index.js.map +1 -0
  71. package/dist/cjs/wallets/__generated__/wallet/com.brave.wallet/image.js +1 -1
  72. package/dist/cjs/wallets/__generated__/wallet/com.brave.wallet/image.js.map +1 -1
  73. package/dist/cjs/wallets/__generated__/wallet/com.brave.wallet/index.js +9 -9
  74. package/dist/cjs/wallets/__generated__/wallet/com.brave.wallet/index.js.map +1 -1
  75. package/dist/cjs/wallets/__generated__/wallet/com.coin98/image.js +1 -1
  76. package/dist/cjs/wallets/__generated__/wallet/com.coin98/image.js.map +1 -1
  77. package/dist/cjs/wallets/__generated__/wallet/com.coin98/index.js +1 -1
  78. package/dist/cjs/wallets/__generated__/wallet/com.crypto/image.js +1 -1
  79. package/dist/cjs/wallets/__generated__/wallet/com.crypto/image.js.map +1 -1
  80. package/dist/cjs/wallets/__generated__/wallet/com.crypto/index.js +1 -1
  81. package/dist/cjs/wallets/__generated__/wallet/com.daffione/image.js +7 -0
  82. package/dist/cjs/wallets/__generated__/wallet/{org.nitrogen → com.daffione}/image.js.map +1 -1
  83. package/dist/cjs/wallets/__generated__/wallet/com.daffione/index.js +34 -0
  84. package/dist/cjs/wallets/__generated__/wallet/com.daffione/index.js.map +1 -0
  85. package/dist/cjs/wallets/__generated__/wallet/com.ipmb/image.js +7 -0
  86. package/dist/cjs/wallets/__generated__/wallet/com.ipmb/image.js.map +1 -0
  87. package/dist/cjs/wallets/__generated__/wallet/com.ipmb/index.js +34 -0
  88. package/dist/cjs/wallets/__generated__/wallet/com.ipmb/index.js.map +1 -0
  89. package/dist/cjs/wallets/__generated__/wallet/com.webauth/image.js +7 -0
  90. package/dist/cjs/wallets/__generated__/wallet/com.webauth/image.js.map +1 -0
  91. package/dist/cjs/wallets/__generated__/wallet/com.webauth/index.js +34 -0
  92. package/dist/cjs/wallets/__generated__/wallet/com.webauth/index.js.map +1 -0
  93. package/dist/cjs/wallets/__generated__/wallet/finance.openwallet/index.js +2 -2
  94. package/dist/cjs/wallets/__generated__/wallet/finance.openwallet/index.js.map +1 -1
  95. package/dist/cjs/wallets/__generated__/wallet/finance.plena/index.js +1 -1
  96. package/dist/cjs/wallets/__generated__/wallet/finance.plena/index.js.map +1 -1
  97. package/dist/cjs/wallets/__generated__/wallet/id.plumaa/image.js +7 -0
  98. package/dist/cjs/wallets/__generated__/wallet/id.plumaa/image.js.map +1 -0
  99. package/dist/cjs/wallets/__generated__/wallet/id.plumaa/index.js +34 -0
  100. package/dist/cjs/wallets/__generated__/wallet/id.plumaa/index.js.map +1 -0
  101. package/dist/cjs/wallets/__generated__/wallet/io.miraiapp/image.js +1 -1
  102. package/dist/cjs/wallets/__generated__/wallet/io.miraiapp/image.js.map +1 -1
  103. package/dist/cjs/wallets/__generated__/wallet/io.miraiapp/index.js +1 -1
  104. package/dist/cjs/wallets/__generated__/wallet/io.owallet/image.js +7 -0
  105. package/dist/cjs/wallets/__generated__/wallet/io.owallet/image.js.map +1 -0
  106. package/dist/cjs/wallets/__generated__/wallet/io.owallet/index.js +34 -0
  107. package/dist/cjs/wallets/__generated__/wallet/io.owallet/index.js.map +1 -0
  108. package/dist/cjs/wallets/__generated__/wallet/io.tradestrike/image.js +1 -1
  109. package/dist/cjs/wallets/__generated__/wallet/io.tradestrike/image.js.map +1 -1
  110. package/dist/cjs/wallets/__generated__/wallet/io.tradestrike/index.js +2 -2
  111. package/dist/cjs/wallets/__generated__/wallet/io.tradestrike/index.js.map +1 -1
  112. package/dist/cjs/wallets/__generated__/wallet-infos.js +45 -15
  113. package/dist/cjs/wallets/__generated__/wallet-infos.js.map +1 -1
  114. package/dist/cjs/wallets/coinbase/coinbase-wallet.js +3 -3
  115. package/dist/cjs/wallets/coinbase/coinbase-wallet.js.map +1 -1
  116. package/dist/cjs/wallets/coinbase/coinbaseWebSDK.js +20 -8
  117. package/dist/cjs/wallets/coinbase/coinbaseWebSDK.js.map +1 -1
  118. package/dist/cjs/wallets/create-wallet.js +11 -6
  119. package/dist/cjs/wallets/create-wallet.js.map +1 -1
  120. package/dist/cjs/wallets/ecosystem/get-ecosystem-wallet-auth-options.js +3 -3
  121. package/dist/cjs/wallets/ecosystem/get-ecosystem-wallet-auth-options.js.map +1 -1
  122. package/dist/cjs/wallets/in-app/core/wallet/enclave-wallet.js +13 -3
  123. package/dist/cjs/wallets/in-app/core/wallet/enclave-wallet.js.map +1 -1
  124. package/dist/cjs/wallets/in-app/core/wallet/in-app-core.js +8 -6
  125. package/dist/cjs/wallets/in-app/core/wallet/in-app-core.js.map +1 -1
  126. package/dist/cjs/wallets/in-app/core/wallet/index.js +50 -2
  127. package/dist/cjs/wallets/in-app/core/wallet/index.js.map +1 -1
  128. package/dist/cjs/wallets/in-app/web/lib/iframe-wallet.js +9 -2
  129. package/dist/cjs/wallets/in-app/web/lib/iframe-wallet.js.map +1 -1
  130. package/dist/cjs/wallets/in-app/web/lib/web-connector.js +2 -0
  131. package/dist/cjs/wallets/in-app/web/lib/web-connector.js.map +1 -1
  132. package/dist/cjs/wallets/injected/index.js +36 -8
  133. package/dist/cjs/wallets/injected/index.js.map +1 -1
  134. package/dist/cjs/wallets/native/create-wallet.js +3 -3
  135. package/dist/cjs/wallets/native/create-wallet.js.map +1 -1
  136. package/dist/cjs/wallets/smart/index.js +30 -2
  137. package/dist/cjs/wallets/smart/index.js.map +1 -1
  138. package/dist/cjs/wallets/smart/smart-wallet.js +6 -9
  139. package/dist/cjs/wallets/smart/smart-wallet.js.map +1 -1
  140. package/dist/cjs/wallets/types.js +1 -0
  141. package/dist/cjs/wallets/types.js.map +1 -1
  142. package/dist/cjs/wallets/wallet-connect/controller.js +20 -8
  143. package/dist/cjs/wallets/wallet-connect/controller.js.map +1 -1
  144. package/dist/esm/analytics/track/connect.js +18 -0
  145. package/dist/esm/analytics/track/connect.js.map +1 -0
  146. package/dist/esm/analytics/track/index.js +18 -0
  147. package/dist/esm/analytics/track/index.js.map +1 -0
  148. package/dist/esm/analytics/track/pay.js +23 -0
  149. package/dist/esm/analytics/track/pay.js.map +1 -0
  150. package/dist/esm/analytics/track/siwe.js +29 -0
  151. package/dist/esm/analytics/track/siwe.js.map +1 -0
  152. package/dist/esm/analytics/track/transaction.js +33 -0
  153. package/dist/esm/analytics/track/transaction.js.map +1 -0
  154. package/dist/esm/auth/core/verify-login-payload.js +19 -1
  155. package/dist/esm/auth/core/verify-login-payload.js.map +1 -1
  156. package/dist/esm/exports/extensions/erc1155.js +1 -0
  157. package/dist/esm/exports/extensions/erc1155.js.map +1 -1
  158. package/dist/esm/exports/extensions/erc721.js +1 -0
  159. package/dist/esm/exports/extensions/erc721.js.map +1 -1
  160. package/dist/esm/exports/wallets/in-app.js +1 -1
  161. package/dist/esm/exports/wallets/in-app.js.map +1 -1
  162. package/dist/esm/extensions/erc1155/write/mintAdditionalSupplyToBatch.js +84 -0
  163. package/dist/esm/extensions/erc1155/write/mintAdditionalSupplyToBatch.js.map +1 -0
  164. package/dist/esm/extensions/erc1155/write/mintToBatch.js +9 -17
  165. package/dist/esm/extensions/erc1155/write/mintToBatch.js.map +1 -1
  166. package/dist/esm/extensions/erc721/drops/write/claimToBatch.js +111 -0
  167. package/dist/esm/extensions/erc721/drops/write/claimToBatch.js.map +1 -0
  168. package/dist/esm/react/core/utils/walletIcon.js +5 -1
  169. package/dist/esm/react/core/utils/walletIcon.js.map +1 -1
  170. package/dist/esm/react/native/ui/components/WalletImage.js +3 -1
  171. package/dist/esm/react/native/ui/components/WalletImage.js.map +1 -1
  172. package/dist/esm/react/native/ui/connect/InAppWalletUI.js +2 -1
  173. package/dist/esm/react/native/ui/connect/InAppWalletUI.js.map +1 -1
  174. package/dist/esm/react/native/ui/icons/svgs.js +4 -0
  175. package/dist/esm/react/native/ui/icons/svgs.js.map +1 -1
  176. package/dist/esm/react/web/hooks/transaction/useSendTransaction.js +3 -4
  177. package/dist/esm/react/web/hooks/transaction/useSendTransaction.js.map +1 -1
  178. package/dist/esm/react/web/ui/ConnectWallet/Details.js +1 -1
  179. package/dist/esm/react/web/ui/ConnectWallet/Details.js.map +1 -1
  180. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/BuyScreen.js +1 -1
  181. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/BuyScreen.js.map +1 -1
  182. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/DirectPaymentModeScreen.js +1 -1
  183. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/DirectPaymentModeScreen.js.map +1 -1
  184. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/TransactionModeScreen.js +1 -1
  185. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/TransactionModeScreen.js.map +1 -1
  186. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/fiat/FiatFlow.js +1 -1
  187. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/fiat/FiatFlow.js.map +1 -1
  188. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/swap/ConfirmationScreen.js +1 -1
  189. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/swap/ConfirmationScreen.js.map +1 -1
  190. package/dist/esm/react/web/ui/ConnectWallet/screens/LinkedProfilesScreen.js +2 -2
  191. package/dist/esm/react/web/ui/TransactionButton/TransactionModal.js +1 -1
  192. package/dist/esm/react/web/ui/TransactionButton/TransactionModal.js.map +1 -1
  193. package/dist/esm/react/web/ui/components/WalletImage.js +2 -2
  194. package/dist/esm/react/web/wallets/shared/ConnectWalletSocialOptions.js +7 -5
  195. package/dist/esm/react/web/wallets/shared/ConnectWalletSocialOptions.js.map +1 -1
  196. package/dist/esm/react/web/wallets/shared/oauthSignIn.js +1 -0
  197. package/dist/esm/react/web/wallets/shared/oauthSignIn.js.map +1 -1
  198. package/dist/esm/version.js +1 -1
  199. package/dist/esm/wallets/__generated__/getWalletInfo.js +45 -15
  200. package/dist/esm/wallets/__generated__/getWalletInfo.js.map +1 -1
  201. package/dist/esm/wallets/__generated__/wallet/app.nightly/image.js +5 -0
  202. package/dist/esm/wallets/__generated__/wallet/app.nightly/image.js.map +1 -0
  203. package/dist/esm/wallets/__generated__/wallet/app.nightly/index.js +31 -0
  204. package/dist/esm/wallets/__generated__/wallet/app.nightly/index.js.map +1 -0
  205. package/dist/esm/wallets/__generated__/wallet/app.status/image.js +1 -1
  206. package/dist/esm/wallets/__generated__/wallet/app.status/image.js.map +1 -1
  207. package/dist/esm/wallets/__generated__/wallet/app.status/index.js +1 -1
  208. package/dist/esm/wallets/__generated__/wallet/app.walletnow/index.js +1 -1
  209. package/dist/esm/wallets/__generated__/wallet/app.walletnow/index.js.map +1 -1
  210. package/dist/esm/wallets/__generated__/wallet/com.beexo/image.js +5 -0
  211. package/dist/esm/wallets/__generated__/wallet/com.beexo/image.js.map +1 -0
  212. package/dist/esm/wallets/__generated__/wallet/{org.nitrogen → com.beexo}/index.js +9 -9
  213. package/dist/esm/wallets/__generated__/wallet/com.beexo/index.js.map +1 -0
  214. package/dist/esm/wallets/__generated__/wallet/com.brave.wallet/image.js +1 -1
  215. package/dist/esm/wallets/__generated__/wallet/com.brave.wallet/image.js.map +1 -1
  216. package/dist/esm/wallets/__generated__/wallet/com.brave.wallet/index.js +9 -9
  217. package/dist/esm/wallets/__generated__/wallet/com.brave.wallet/index.js.map +1 -1
  218. package/dist/esm/wallets/__generated__/wallet/com.coin98/image.js +1 -1
  219. package/dist/esm/wallets/__generated__/wallet/com.coin98/image.js.map +1 -1
  220. package/dist/esm/wallets/__generated__/wallet/com.coin98/index.js +1 -1
  221. package/dist/esm/wallets/__generated__/wallet/com.crypto/image.js +1 -1
  222. package/dist/esm/wallets/__generated__/wallet/com.crypto/image.js.map +1 -1
  223. package/dist/esm/wallets/__generated__/wallet/com.crypto/index.js +1 -1
  224. package/dist/esm/wallets/__generated__/wallet/com.daffione/image.js +5 -0
  225. package/dist/esm/wallets/__generated__/wallet/{org.nitrogen → com.daffione}/image.js.map +1 -1
  226. package/dist/esm/wallets/__generated__/wallet/com.daffione/index.js +31 -0
  227. package/dist/esm/wallets/__generated__/wallet/com.daffione/index.js.map +1 -0
  228. package/dist/esm/wallets/__generated__/wallet/com.ipmb/image.js +5 -0
  229. package/dist/esm/wallets/__generated__/wallet/com.ipmb/image.js.map +1 -0
  230. package/dist/esm/wallets/__generated__/wallet/com.ipmb/index.js +31 -0
  231. package/dist/esm/wallets/__generated__/wallet/com.ipmb/index.js.map +1 -0
  232. package/dist/esm/wallets/__generated__/wallet/com.webauth/image.js +5 -0
  233. package/dist/esm/wallets/__generated__/wallet/com.webauth/image.js.map +1 -0
  234. package/dist/esm/wallets/__generated__/wallet/com.webauth/index.js +31 -0
  235. package/dist/esm/wallets/__generated__/wallet/com.webauth/index.js.map +1 -0
  236. package/dist/esm/wallets/__generated__/wallet/finance.openwallet/index.js +2 -2
  237. package/dist/esm/wallets/__generated__/wallet/finance.openwallet/index.js.map +1 -1
  238. package/dist/esm/wallets/__generated__/wallet/finance.plena/index.js +1 -1
  239. package/dist/esm/wallets/__generated__/wallet/finance.plena/index.js.map +1 -1
  240. package/dist/esm/wallets/__generated__/wallet/id.plumaa/image.js +5 -0
  241. package/dist/esm/wallets/__generated__/wallet/id.plumaa/image.js.map +1 -0
  242. package/dist/esm/wallets/__generated__/wallet/id.plumaa/index.js +31 -0
  243. package/dist/esm/wallets/__generated__/wallet/id.plumaa/index.js.map +1 -0
  244. package/dist/esm/wallets/__generated__/wallet/io.miraiapp/image.js +1 -1
  245. package/dist/esm/wallets/__generated__/wallet/io.miraiapp/image.js.map +1 -1
  246. package/dist/esm/wallets/__generated__/wallet/io.miraiapp/index.js +1 -1
  247. package/dist/esm/wallets/__generated__/wallet/io.owallet/image.js +5 -0
  248. package/dist/esm/wallets/__generated__/wallet/io.owallet/image.js.map +1 -0
  249. package/dist/esm/wallets/__generated__/wallet/io.owallet/index.js +31 -0
  250. package/dist/esm/wallets/__generated__/wallet/io.owallet/index.js.map +1 -0
  251. package/dist/esm/wallets/__generated__/wallet/io.tradestrike/image.js +1 -1
  252. package/dist/esm/wallets/__generated__/wallet/io.tradestrike/image.js.map +1 -1
  253. package/dist/esm/wallets/__generated__/wallet/io.tradestrike/index.js +2 -2
  254. package/dist/esm/wallets/__generated__/wallet/io.tradestrike/index.js.map +1 -1
  255. package/dist/esm/wallets/__generated__/wallet-infos.js +45 -15
  256. package/dist/esm/wallets/__generated__/wallet-infos.js.map +1 -1
  257. package/dist/esm/wallets/coinbase/coinbase-wallet.js +1 -1
  258. package/dist/esm/wallets/coinbase/coinbase-wallet.js.map +1 -1
  259. package/dist/esm/wallets/coinbase/coinbaseWebSDK.js +20 -8
  260. package/dist/esm/wallets/coinbase/coinbaseWebSDK.js.map +1 -1
  261. package/dist/esm/wallets/create-wallet.js +7 -2
  262. package/dist/esm/wallets/create-wallet.js.map +1 -1
  263. package/dist/esm/wallets/ecosystem/get-ecosystem-wallet-auth-options.js +2 -2
  264. package/dist/esm/wallets/ecosystem/get-ecosystem-wallet-auth-options.js.map +1 -1
  265. package/dist/esm/wallets/in-app/core/wallet/enclave-wallet.js +13 -3
  266. package/dist/esm/wallets/in-app/core/wallet/enclave-wallet.js.map +1 -1
  267. package/dist/esm/wallets/in-app/core/wallet/in-app-core.js +6 -4
  268. package/dist/esm/wallets/in-app/core/wallet/in-app-core.js.map +1 -1
  269. package/dist/esm/wallets/in-app/core/wallet/index.js +50 -2
  270. package/dist/esm/wallets/in-app/core/wallet/index.js.map +1 -1
  271. package/dist/esm/wallets/in-app/web/lib/iframe-wallet.js +9 -2
  272. package/dist/esm/wallets/in-app/web/lib/iframe-wallet.js.map +1 -1
  273. package/dist/esm/wallets/in-app/web/lib/web-connector.js +2 -0
  274. package/dist/esm/wallets/in-app/web/lib/web-connector.js.map +1 -1
  275. package/dist/esm/wallets/injected/index.js +36 -8
  276. package/dist/esm/wallets/injected/index.js.map +1 -1
  277. package/dist/esm/wallets/native/create-wallet.js +1 -1
  278. package/dist/esm/wallets/native/create-wallet.js.map +1 -1
  279. package/dist/esm/wallets/smart/index.js +30 -2
  280. package/dist/esm/wallets/smart/index.js.map +1 -1
  281. package/dist/esm/wallets/smart/smart-wallet.js +4 -7
  282. package/dist/esm/wallets/smart/smart-wallet.js.map +1 -1
  283. package/dist/esm/wallets/types.js +1 -0
  284. package/dist/esm/wallets/types.js.map +1 -1
  285. package/dist/esm/wallets/wallet-connect/controller.js +20 -8
  286. package/dist/esm/wallets/wallet-connect/controller.js.map +1 -1
  287. package/dist/types/analytics/track/connect.d.ts +12 -0
  288. package/dist/types/analytics/track/connect.d.ts.map +1 -0
  289. package/dist/types/analytics/track/index.d.ts +11 -0
  290. package/dist/types/analytics/track/index.d.ts.map +1 -0
  291. package/dist/types/analytics/{track.d.ts → track/pay.d.ts} +5 -11
  292. package/dist/types/analytics/track/pay.d.ts.map +1 -0
  293. package/dist/types/analytics/track/siwe.d.ts +19 -0
  294. package/dist/types/analytics/track/siwe.d.ts.map +1 -0
  295. package/dist/types/analytics/track/transaction.d.ts +24 -0
  296. package/dist/types/analytics/track/transaction.d.ts.map +1 -0
  297. package/dist/types/auth/core/verify-login-payload.d.ts.map +1 -1
  298. package/dist/types/exports/extensions/erc1155.d.ts +1 -0
  299. package/dist/types/exports/extensions/erc1155.d.ts.map +1 -1
  300. package/dist/types/exports/extensions/erc721.d.ts +1 -0
  301. package/dist/types/exports/extensions/erc721.d.ts.map +1 -1
  302. package/dist/types/exports/wallets/in-app.d.ts +1 -1
  303. package/dist/types/exports/wallets/in-app.d.ts.map +1 -1
  304. package/dist/types/extensions/erc1155/write/mintAdditionalSupplyToBatch.d.ts +51 -0
  305. package/dist/types/extensions/erc1155/write/mintAdditionalSupplyToBatch.d.ts.map +1 -0
  306. package/dist/types/extensions/erc1155/write/mintToBatch.d.ts.map +1 -1
  307. package/dist/types/extensions/erc721/drops/write/claimToBatch.d.ts +71 -0
  308. package/dist/types/extensions/erc721/drops/write/claimToBatch.d.ts.map +1 -0
  309. package/dist/types/react/core/utils/walletIcon.d.ts +3 -1
  310. package/dist/types/react/core/utils/walletIcon.d.ts.map +1 -1
  311. package/dist/types/react/native/ui/components/WalletImage.d.ts.map +1 -1
  312. package/dist/types/react/native/ui/connect/InAppWalletUI.d.ts.map +1 -1
  313. package/dist/types/react/native/ui/icons/svgs.d.ts +1 -0
  314. package/dist/types/react/native/ui/icons/svgs.d.ts.map +1 -1
  315. package/dist/types/react/web/hooks/transaction/useSendTransaction.d.ts +3 -4
  316. package/dist/types/react/web/hooks/transaction/useSendTransaction.d.ts.map +1 -1
  317. package/dist/types/react/web/ui/ConnectWallet/Details.d.ts.map +1 -1
  318. package/dist/types/react/web/ui/ConnectWallet/screens/Buy/swap/ConfirmationScreen.d.ts.map +1 -1
  319. package/dist/types/react/web/wallets/shared/ConnectWalletSocialOptions.d.ts.map +1 -1
  320. package/dist/types/react/web/wallets/shared/oauthSignIn.d.ts.map +1 -1
  321. package/dist/types/version.d.ts +1 -1
  322. package/dist/types/wallets/__generated__/getWalletInfo.d.ts.map +1 -1
  323. package/dist/types/wallets/__generated__/wallet/app.nightly/image.d.ts +3 -0
  324. package/dist/types/wallets/__generated__/wallet/app.nightly/image.d.ts.map +1 -0
  325. package/dist/types/wallets/__generated__/wallet/app.nightly/index.d.ts +29 -0
  326. package/dist/types/wallets/__generated__/wallet/app.nightly/index.d.ts.map +1 -0
  327. package/dist/types/wallets/__generated__/wallet/app.status/image.d.ts +1 -1
  328. package/dist/types/wallets/__generated__/wallet/app.status/image.d.ts.map +1 -1
  329. package/dist/types/wallets/__generated__/wallet/app.status/index.d.ts +1 -1
  330. package/dist/types/wallets/__generated__/wallet/app.walletnow/index.d.ts +1 -1
  331. package/dist/types/wallets/__generated__/wallet/com.beexo/image.d.ts +3 -0
  332. package/dist/types/wallets/__generated__/wallet/com.beexo/image.d.ts.map +1 -0
  333. package/dist/types/wallets/__generated__/wallet/{org.nitrogen → com.beexo}/index.d.ts +9 -9
  334. package/dist/types/wallets/__generated__/wallet/com.beexo/index.d.ts.map +1 -0
  335. package/dist/types/wallets/__generated__/wallet/com.brave.wallet/image.d.ts +1 -1
  336. package/dist/types/wallets/__generated__/wallet/com.brave.wallet/image.d.ts.map +1 -1
  337. package/dist/types/wallets/__generated__/wallet/com.brave.wallet/index.d.ts +9 -9
  338. package/dist/types/wallets/__generated__/wallet/com.brave.wallet/index.d.ts.map +1 -1
  339. package/dist/types/wallets/__generated__/wallet/com.coin98/image.d.ts +1 -1
  340. package/dist/types/wallets/__generated__/wallet/com.coin98/image.d.ts.map +1 -1
  341. package/dist/types/wallets/__generated__/wallet/com.coin98/index.d.ts +1 -1
  342. package/dist/types/wallets/__generated__/wallet/com.crypto/image.d.ts +1 -1
  343. package/dist/types/wallets/__generated__/wallet/com.crypto/image.d.ts.map +1 -1
  344. package/dist/types/wallets/__generated__/wallet/com.crypto/index.d.ts +1 -1
  345. package/dist/types/wallets/__generated__/wallet/com.daffione/image.d.ts +3 -0
  346. package/dist/types/wallets/__generated__/wallet/com.daffione/image.d.ts.map +1 -0
  347. package/dist/types/wallets/__generated__/wallet/com.daffione/index.d.ts +29 -0
  348. package/dist/types/wallets/__generated__/wallet/{org.nitrogen → com.daffione}/index.d.ts.map +1 -1
  349. package/dist/types/wallets/__generated__/wallet/com.ipmb/image.d.ts +3 -0
  350. package/dist/types/wallets/__generated__/wallet/com.ipmb/image.d.ts.map +1 -0
  351. package/dist/types/wallets/__generated__/wallet/com.ipmb/index.d.ts +29 -0
  352. package/dist/types/wallets/__generated__/wallet/com.ipmb/index.d.ts.map +1 -0
  353. package/dist/types/wallets/__generated__/wallet/com.webauth/image.d.ts +3 -0
  354. package/dist/types/wallets/__generated__/wallet/com.webauth/image.d.ts.map +1 -0
  355. package/dist/types/wallets/__generated__/wallet/com.webauth/index.d.ts +29 -0
  356. package/dist/types/wallets/__generated__/wallet/com.webauth/index.d.ts.map +1 -0
  357. package/dist/types/wallets/__generated__/wallet/finance.openwallet/index.d.ts +2 -2
  358. package/dist/types/wallets/__generated__/wallet/finance.plena/index.d.ts +1 -1
  359. package/dist/types/wallets/__generated__/wallet/id.plumaa/image.d.ts +3 -0
  360. package/dist/types/wallets/__generated__/wallet/id.plumaa/image.d.ts.map +1 -0
  361. package/dist/types/wallets/__generated__/wallet/id.plumaa/index.d.ts +29 -0
  362. package/dist/types/wallets/__generated__/wallet/id.plumaa/index.d.ts.map +1 -0
  363. package/dist/types/wallets/__generated__/wallet/io.miraiapp/image.d.ts +1 -1
  364. package/dist/types/wallets/__generated__/wallet/io.miraiapp/image.d.ts.map +1 -1
  365. package/dist/types/wallets/__generated__/wallet/io.miraiapp/index.d.ts +1 -1
  366. package/dist/types/wallets/__generated__/wallet/io.owallet/image.d.ts +3 -0
  367. package/dist/types/wallets/__generated__/wallet/io.owallet/image.d.ts.map +1 -0
  368. package/dist/types/wallets/__generated__/wallet/io.owallet/index.d.ts +29 -0
  369. package/dist/types/wallets/__generated__/wallet/io.owallet/index.d.ts.map +1 -0
  370. package/dist/types/wallets/__generated__/wallet/io.tradestrike/image.d.ts +1 -1
  371. package/dist/types/wallets/__generated__/wallet/io.tradestrike/image.d.ts.map +1 -1
  372. package/dist/types/wallets/__generated__/wallet/io.tradestrike/index.d.ts +2 -2
  373. package/dist/types/wallets/__generated__/wallet-ids.d.ts +2 -2
  374. package/dist/types/wallets/__generated__/wallet-ids.d.ts.map +1 -1
  375. package/dist/types/wallets/__generated__/wallet-infos.d.ts +36 -12
  376. package/dist/types/wallets/__generated__/wallet-infos.d.ts.map +1 -1
  377. package/dist/types/wallets/coinbase/coinbaseWebSDK.d.ts +1 -1
  378. package/dist/types/wallets/coinbase/coinbaseWebSDK.d.ts.map +1 -1
  379. package/dist/types/wallets/create-wallet.d.ts.map +1 -1
  380. package/dist/types/wallets/ecosystem/get-ecosystem-wallet-auth-options.d.ts +11 -1
  381. package/dist/types/wallets/ecosystem/get-ecosystem-wallet-auth-options.d.ts.map +1 -1
  382. package/dist/types/wallets/getAllWalletsList.d.ts +36 -12
  383. package/dist/types/wallets/getAllWalletsList.d.ts.map +1 -1
  384. package/dist/types/wallets/in-app/core/authentication/types.d.ts +1 -1
  385. package/dist/types/wallets/in-app/core/authentication/types.d.ts.map +1 -1
  386. package/dist/types/wallets/in-app/core/wallet/enclave-wallet.d.ts.map +1 -1
  387. package/dist/types/wallets/in-app/core/wallet/in-app-core.d.ts.map +1 -1
  388. package/dist/types/wallets/in-app/core/wallet/index.d.ts +3 -2
  389. package/dist/types/wallets/in-app/core/wallet/index.d.ts.map +1 -1
  390. package/dist/types/wallets/in-app/web/lib/iframe-wallet.d.ts.map +1 -1
  391. package/dist/types/wallets/in-app/web/lib/web-connector.d.ts.map +1 -1
  392. package/dist/types/wallets/injected/index.d.ts +15 -2
  393. package/dist/types/wallets/injected/index.d.ts.map +1 -1
  394. package/dist/types/wallets/smart/index.d.ts.map +1 -1
  395. package/dist/types/wallets/smart/smart-wallet.d.ts +3 -6
  396. package/dist/types/wallets/smart/smart-wallet.d.ts.map +1 -1
  397. package/dist/types/wallets/types.d.ts +2 -2
  398. package/dist/types/wallets/types.d.ts.map +1 -1
  399. package/dist/types/wallets/wallet-connect/controller.d.ts +2 -1
  400. package/dist/types/wallets/wallet-connect/controller.d.ts.map +1 -1
  401. package/package.json +1 -1
  402. package/src/analytics/track/connect.test.ts +78 -0
  403. package/src/analytics/track/connect.ts +25 -0
  404. package/src/analytics/track/index.ts +30 -0
  405. package/src/analytics/track/pay.test.ts +98 -0
  406. package/src/analytics/track/pay.ts +37 -0
  407. package/src/analytics/track/siwe.test.ts +110 -0
  408. package/src/analytics/track/siwe.ts +48 -0
  409. package/src/analytics/track/track.test.ts +107 -0
  410. package/src/analytics/track/transaction.test.ts +130 -0
  411. package/src/analytics/track/transaction.ts +57 -0
  412. package/src/auth/core/verify-login-payload.ts +25 -1
  413. package/src/exports/extensions/erc1155.ts +5 -0
  414. package/src/exports/extensions/erc721.ts +4 -0
  415. package/src/exports/wallets/in-app.ts +4 -1
  416. package/src/extensions/erc1155/drop1155.test.ts +11 -0
  417. package/src/extensions/erc1155/token1155.test.ts +170 -2
  418. package/src/extensions/erc1155/write/lazyMint.test.ts +2 -22
  419. package/src/extensions/erc1155/write/mintAdditionalSupplyToBatch.test.ts +21 -0
  420. package/src/extensions/erc1155/write/mintAdditionalSupplyToBatch.ts +105 -0
  421. package/src/extensions/erc1155/write/mintToBatch.ts +15 -24
  422. package/src/extensions/erc721/drops/write/claimTo.test.ts +15 -0
  423. package/src/extensions/erc721/drops/write/claimToBatch.test.ts +154 -0
  424. package/src/extensions/erc721/drops/write/claimToBatch.ts +144 -0
  425. package/src/extensions/unstoppable-domains/read/resolveName.test.ts +9 -0
  426. package/src/react/core/utils/walletIcon.ts +8 -1
  427. package/src/react/native/ui/components/WalletImage.tsx +3 -0
  428. package/src/react/native/ui/connect/InAppWalletUI.tsx +2 -0
  429. package/src/react/native/ui/icons/svgs.ts +5 -0
  430. package/src/react/web/hooks/transaction/useSendTransaction.tsx +3 -4
  431. package/src/react/web/ui/ConnectWallet/Details.tsx +2 -4
  432. package/src/react/web/ui/ConnectWallet/screens/Buy/BuyScreen.tsx +1 -1
  433. package/src/react/web/ui/ConnectWallet/screens/Buy/DirectPaymentModeScreen.tsx +1 -1
  434. package/src/react/web/ui/ConnectWallet/screens/Buy/TransactionModeScreen.tsx +1 -1
  435. package/src/react/web/ui/ConnectWallet/screens/Buy/fiat/FiatFlow.tsx +1 -1
  436. package/src/react/web/ui/ConnectWallet/screens/Buy/swap/ConfirmationScreen.tsx +1 -1
  437. package/src/react/web/ui/ConnectWallet/screens/LinkedProfilesScreen.tsx +2 -2
  438. package/src/react/web/ui/TransactionButton/TransactionModal.tsx +1 -1
  439. package/src/react/web/ui/components/WalletImage.tsx +2 -2
  440. package/src/react/web/wallets/shared/ConnectWalletSocialOptions.tsx +7 -5
  441. package/src/react/web/wallets/shared/oauthSignIn.ts +1 -0
  442. package/src/version.ts +1 -1
  443. package/src/wallets/__generated__/getWalletInfo.ts +67 -25
  444. package/src/wallets/__generated__/wallet/app.nightly/image.ts +7 -0
  445. package/src/wallets/__generated__/wallet/app.nightly/index.ts +34 -0
  446. package/src/wallets/__generated__/wallet/app.status/image.ts +1 -1
  447. package/src/wallets/__generated__/wallet/app.status/index.ts +1 -1
  448. package/src/wallets/__generated__/wallet/app.walletnow/index.ts +1 -1
  449. package/src/wallets/__generated__/wallet/com.beexo/image.ts +7 -0
  450. package/src/wallets/__generated__/wallet/com.beexo/index.ts +31 -0
  451. package/src/wallets/__generated__/wallet/com.brave.wallet/image.ts +1 -1
  452. package/src/wallets/__generated__/wallet/com.brave.wallet/index.ts +9 -11
  453. package/src/wallets/__generated__/wallet/com.coin98/image.ts +1 -1
  454. package/src/wallets/__generated__/wallet/com.coin98/index.ts +1 -1
  455. package/src/wallets/__generated__/wallet/com.crypto/image.ts +1 -1
  456. package/src/wallets/__generated__/wallet/com.crypto/index.ts +1 -1
  457. package/src/wallets/__generated__/wallet/com.daffione/image.ts +7 -0
  458. package/src/wallets/__generated__/wallet/com.daffione/index.ts +31 -0
  459. package/src/wallets/__generated__/wallet/com.ipmb/image.ts +7 -0
  460. package/src/wallets/__generated__/wallet/com.ipmb/index.ts +32 -0
  461. package/src/wallets/__generated__/wallet/com.webauth/image.ts +7 -0
  462. package/src/wallets/__generated__/wallet/{org.nitrogen → com.webauth}/index.ts +8 -8
  463. package/src/wallets/__generated__/wallet/finance.openwallet/index.ts +2 -2
  464. package/src/wallets/__generated__/wallet/finance.plena/index.ts +1 -1
  465. package/src/wallets/__generated__/wallet/id.plumaa/image.ts +7 -0
  466. package/src/wallets/__generated__/wallet/id.plumaa/index.ts +31 -0
  467. package/src/wallets/__generated__/wallet/io.miraiapp/image.ts +1 -1
  468. package/src/wallets/__generated__/wallet/io.miraiapp/index.ts +1 -1
  469. package/src/wallets/__generated__/wallet/io.owallet/image.ts +7 -0
  470. package/src/wallets/__generated__/wallet/io.owallet/index.ts +32 -0
  471. package/src/wallets/__generated__/wallet/io.tradestrike/image.ts +1 -1
  472. package/src/wallets/__generated__/wallet/io.tradestrike/index.ts +2 -2
  473. package/src/wallets/__generated__/wallet-ids.ts +9 -6
  474. package/src/wallets/__generated__/wallet-infos.ts +45 -15
  475. package/src/wallets/coinbase/coinbase-wallet.ts +1 -1
  476. package/src/wallets/coinbase/coinbaseWebSDK.ts +30 -7
  477. package/src/wallets/create-wallet.ts +6 -5
  478. package/src/wallets/ecosystem/get-ecosystem-wallet-auth-options.ts +14 -3
  479. package/src/wallets/in-app/core/authentication/types.ts +1 -0
  480. package/src/wallets/in-app/core/wallet/enclave-wallet.ts +16 -3
  481. package/src/wallets/in-app/core/wallet/in-app-core.ts +6 -1
  482. package/src/wallets/in-app/core/wallet/index.ts +59 -0
  483. package/src/wallets/in-app/web/lib/iframe-wallet.ts +12 -2
  484. package/src/wallets/in-app/web/lib/web-connector.ts +2 -0
  485. package/src/wallets/injected/index.ts +72 -17
  486. package/src/wallets/native/create-wallet.ts +1 -1
  487. package/src/wallets/smart/index.ts +40 -2
  488. package/src/wallets/smart/smart-wallet-integration-v07.test.ts +2 -4
  489. package/src/wallets/smart/smart-wallet.ts +4 -7
  490. package/src/wallets/types.ts +1 -0
  491. package/src/wallets/wallet-connect/controller.ts +29 -7
  492. package/dist/cjs/analytics/track.js +0 -51
  493. package/dist/cjs/analytics/track.js.map +0 -1
  494. package/dist/cjs/wallets/__generated__/wallet/org.nitrogen/image.js +0 -7
  495. package/dist/cjs/wallets/__generated__/wallet/org.nitrogen/index.js.map +0 -1
  496. package/dist/esm/analytics/track.js +0 -47
  497. package/dist/esm/analytics/track.js.map +0 -1
  498. package/dist/esm/wallets/__generated__/wallet/org.nitrogen/image.js +0 -5
  499. package/dist/esm/wallets/__generated__/wallet/org.nitrogen/index.js.map +0 -1
  500. package/dist/types/analytics/track.d.ts.map +0 -1
  501. package/dist/types/wallets/__generated__/wallet/org.nitrogen/image.d.ts +0 -3
  502. package/dist/types/wallets/__generated__/wallet/org.nitrogen/image.d.ts.map +0 -1
  503. package/src/analytics/track.ts +0 -67
  504. package/src/extensions/erc1155/read/getNFTs.test.ts +0 -44
  505. package/src/extensions/erc1155/read/getOwnedNFTs.test.ts +0 -62
  506. package/src/extensions/erc1155/read/getOwnedTokenIds.test.ts +0 -50
  507. package/src/extensions/erc1155/write/mintAdditionalSupplyTo.test.ts +0 -38
  508. package/src/extensions/erc1155/write/mintTo.test.ts +0 -42
  509. package/src/extensions/erc1155/write/mintToBatch.test.ts +0 -77
  510. package/src/extensions/erc1155/write/updateTokenURI.test.ts +0 -54
  511. package/src/wallets/__generated__/wallet/org.nitrogen/image.ts +0 -7
@@ -1,3 +1,4 @@
1
+ import { type Abi, toFunctionSelector } from "viem";
1
2
  import { beforeAll, describe, expect, it } from "vitest";
2
3
  import { TEST_CONTRACT_URI } from "~test/ipfs-uris.js";
3
4
  import { ANVIL_CHAIN } from "../../../test/src/chains.js";
@@ -5,17 +6,27 @@ import { TEST_CLIENT } from "../../../test/src/test-clients.js";
5
6
  import {
6
7
  TEST_ACCOUNT_A,
7
8
  TEST_ACCOUNT_B,
9
+ TEST_ACCOUNT_C,
8
10
  } from "../../../test/src/test-wallets.js";
11
+ import { resolveContractAbi } from "../../contract/actions/resolve-abi.js";
9
12
  import { type ThirdwebContract, getContract } from "../../contract/contract.js";
10
13
  import { sendAndConfirmTransaction } from "../../transaction/actions/send-and-confirm-transaction.js";
11
14
  import { deployERC1155Contract } from "../prebuilts/deploy-erc1155.js";
12
15
  import { balanceOf } from "./__generated__/IERC1155/read/balanceOf.js";
13
16
  import { totalSupply } from "./__generated__/IERC1155/read/totalSupply.js";
17
+ import { uri } from "./__generated__/IERC1155/read/uri.js";
14
18
  import { nextTokenIdToMint } from "./__generated__/IERC1155Enumerable/read/nextTokenIdToMint.js";
15
19
  import { getNFT } from "./read/getNFT.js";
16
- import { getNFTs } from "./read/getNFTs.js";
17
- import { mintAdditionalSupplyTo } from "./write/mintAdditionalSupplyTo.js";
20
+ import { getNFTs, isGetNFTsSupported } from "./read/getNFTs.js";
21
+ import { getOwnedTokenIds } from "./read/getOwnedTokenIds.js";
22
+ import {
23
+ isMintAdditionalSupplyToSupported,
24
+ mintAdditionalSupplyTo,
25
+ } from "./write/mintAdditionalSupplyTo.js";
26
+ import { mintAdditionalSupplyToBatch } from "./write/mintAdditionalSupplyToBatch.js";
18
27
  import { mintTo } from "./write/mintTo.js";
28
+ import { mintToBatch } from "./write/mintToBatch.js";
29
+ import { updateTokenURI } from "./write/updateTokenURI.js";
19
30
 
20
31
  describe.runIf(process.env.TW_SECRET_KEY)("TokenERC1155", () => {
21
32
  let contract: ThirdwebContract;
@@ -158,4 +169,161 @@ describe.runIf(process.env.TW_SECRET_KEY)("TokenERC1155", () => {
158
169
  ]
159
170
  `);
160
171
  });
172
+
173
+ it("isGetNFTsSupported should work with our Edition contracts", async () => {
174
+ const abi = await resolveContractAbi<Abi>(contract);
175
+ const selectors = abi
176
+ .filter((f) => f.type === "function")
177
+ .map((f) => toFunctionSelector(f));
178
+ expect(isGetNFTsSupported(selectors)).toBe(true);
179
+ });
180
+
181
+ // tokenId #0 is updated in this test
182
+ it("should update tokenURI", async () => {
183
+ await sendAndConfirmTransaction({
184
+ transaction: updateTokenURI({
185
+ contract,
186
+ newMetadata: { name: "Test1 Updated" },
187
+ tokenId: 0n,
188
+ }),
189
+ account: TEST_ACCOUNT_A,
190
+ });
191
+ const nft = await getNFT({ contract, tokenId: 0n });
192
+ expect(nft.metadata.name).toBe("Test1 Updated");
193
+ });
194
+
195
+ it("should mint with `nft` being declared as a string", async () => {
196
+ await sendAndConfirmTransaction({
197
+ transaction: mintTo({
198
+ contract,
199
+ nft: TEST_CONTRACT_URI,
200
+ to: TEST_ACCOUNT_A.address,
201
+ supply: 1n,
202
+ }),
203
+ account: TEST_ACCOUNT_A,
204
+ });
205
+
206
+ const tokenUri = await uri({ contract, tokenId: 2n });
207
+ expect(tokenUri).toBe(TEST_CONTRACT_URI);
208
+ });
209
+
210
+ it("`isMintAdditionalSupplyToSupported` should work with our Edition contracts", async () => {
211
+ const abi = await resolveContractAbi<Abi>(contract);
212
+ const selectors = abi
213
+ .filter((f) => f.type === "function")
214
+ .map((f) => toFunctionSelector(f));
215
+ expect(isMintAdditionalSupplyToSupported(selectors)).toBe(true);
216
+ });
217
+
218
+ it("should mint multiple tokens in one tx", async () => {
219
+ await sendAndConfirmTransaction({
220
+ account: TEST_ACCOUNT_A,
221
+ transaction: mintToBatch({
222
+ contract,
223
+ to: TEST_ACCOUNT_C.address,
224
+ nfts: [
225
+ { metadata: { name: "batch token 0" }, supply: 1n },
226
+ { metadata: { name: "batch token 1" }, supply: 2n },
227
+ { metadata: { name: "batch token 2" }, supply: 3n },
228
+ ],
229
+ }),
230
+ });
231
+
232
+ const nfts = await getNFTs({ contract });
233
+ expect(nfts).toStrictEqual([
234
+ {
235
+ // Updated tokenURI from the test above
236
+ metadata: { name: "Test1 Updated" },
237
+ owner: null,
238
+ id: 0n,
239
+ tokenURI: "ipfs://QmTSyt6YgoFtH8yhWgevC22BxjyrkCKuzdk86nqQJCwrV9/0",
240
+ type: "ERC1155",
241
+ supply: 15n,
242
+ },
243
+ {
244
+ metadata: { name: "Test NFT 2" },
245
+ owner: null,
246
+ id: 1n,
247
+ tokenURI: "ipfs://QmV6gsfzdiMRtpnh8ay3CgutStVbes7qoF4DKpYE64h8hT/0",
248
+ type: "ERC1155",
249
+ supply: 5n,
250
+ },
251
+ {
252
+ metadata: {
253
+ name: "tw-contract-name",
254
+ symbol: "tw-contract-symbol",
255
+ description: "tw-contract-description",
256
+ },
257
+ owner: null,
258
+ id: 2n,
259
+ // Minted using URI from the test above
260
+ tokenURI:
261
+ "ipfs://bafybeiewg2e3vehsb5pb34xwk25eyyfwlvajzmgz3rtdrvn3upsxnsbhzi/contractUri.json",
262
+ type: "ERC1155",
263
+ supply: 1n,
264
+ },
265
+ {
266
+ metadata: { name: "batch token 0" },
267
+ owner: null,
268
+ id: 3n,
269
+ tokenURI: "ipfs://QmPSQhC2J6Wig4pH1Lt5th19FM58J5oukhfLfpc9L1i39Q/0",
270
+ type: "ERC1155",
271
+ supply: 1n,
272
+ },
273
+ {
274
+ metadata: { name: "batch token 1" },
275
+ owner: null,
276
+ id: 4n,
277
+ tokenURI: "ipfs://QmWRQwLBAeq6Wr65Yj7A4aeYqMD1C7Hs1moz15ncS6EhGu/0",
278
+ type: "ERC1155",
279
+ supply: 2n,
280
+ },
281
+ {
282
+ metadata: { name: "batch token 2" },
283
+ owner: null,
284
+ id: 5n,
285
+ tokenURI: "ipfs://QmTg1wxKGvdZR4NrdkYZGcfB5YYaBz75DH83td5RwprMRP/0",
286
+ type: "ERC1155",
287
+ supply: 3n,
288
+ },
289
+ ]);
290
+ });
291
+
292
+ it("getOwnedTokenIds should work", async () => {
293
+ const ownedTokenIds = await getOwnedTokenIds({
294
+ contract,
295
+ address: TEST_ACCOUNT_C.address,
296
+ });
297
+ expect(ownedTokenIds).toStrictEqual([
298
+ { tokenId: 3n, balance: 1n },
299
+ { tokenId: 4n, balance: 2n },
300
+ { tokenId: 5n, balance: 3n },
301
+ ]);
302
+ });
303
+
304
+ it("should mint multiple ADDITIONAL tokens in one tx", async () => {
305
+ await sendAndConfirmTransaction({
306
+ account: TEST_ACCOUNT_A,
307
+ transaction: mintAdditionalSupplyToBatch({
308
+ contract,
309
+ nfts: [
310
+ { tokenId: 3n, supply: 99n, to: TEST_ACCOUNT_C.address },
311
+ { tokenId: 4n, supply: 94n, to: TEST_ACCOUNT_C.address },
312
+ { tokenId: 5n, supply: 97n, to: TEST_ACCOUNT_C.address },
313
+ { tokenId: 3n, supply: 4n, to: TEST_ACCOUNT_C.address },
314
+ ],
315
+ }),
316
+ });
317
+
318
+ const ownedTokenIds = await getOwnedTokenIds({
319
+ contract,
320
+ address: TEST_ACCOUNT_C.address,
321
+ });
322
+
323
+ expect(ownedTokenIds).toStrictEqual([
324
+ { tokenId: 3n, balance: 104n },
325
+ { tokenId: 4n, balance: 96n },
326
+ { tokenId: 5n, balance: 100n },
327
+ ]);
328
+ });
161
329
  });
@@ -1,32 +1,12 @@
1
1
  import { type Abi, toFunctionSelector } from "viem";
2
2
  import { describe, expect, it } from "vitest";
3
- import { ANVIL_CHAIN } from "~test/chains.js";
4
- import { TEST_CONTRACT_URI } from "~test/ipfs-uris.js";
5
- import { TEST_CLIENT } from "~test/test-clients.js";
6
- import { TEST_ACCOUNT_C } from "~test/test-wallets.js";
3
+ import { DROP1155_CONTRACT } from "~test/test-contracts.js";
7
4
  import { resolveContractAbi } from "../../../contract/actions/resolve-abi.js";
8
- import { getContract } from "../../../contract/contract.js";
9
- import { deployERC1155Contract } from "../../../extensions/prebuilts/deploy-erc1155.js";
10
5
  import { isLazyMintSupported } from "./lazyMint.js";
11
6
 
12
7
  describe.runIf(process.env.TW_SECRET_KEY)("erc1155: lazyMint", () => {
13
8
  it("`isLazyMintSupported` should work with our Edition Drop contracts", async () => {
14
- const contract = getContract({
15
- address: await deployERC1155Contract({
16
- chain: ANVIL_CHAIN,
17
- client: TEST_CLIENT,
18
- params: {
19
- name: "",
20
- contractURI: TEST_CONTRACT_URI,
21
- },
22
- type: "DropERC1155",
23
- account: TEST_ACCOUNT_C,
24
- }),
25
- chain: ANVIL_CHAIN,
26
- client: TEST_CLIENT,
27
- });
28
-
29
- const abi = await resolveContractAbi<Abi>(contract);
9
+ const abi = await resolveContractAbi<Abi>(DROP1155_CONTRACT);
30
10
  const selectors = abi
31
11
  .filter((f) => f.type === "function")
32
12
  .map((f) => toFunctionSelector(f));
@@ -0,0 +1,21 @@
1
+ import {} from "viem";
2
+ import { describe, expect, it } from "vitest";
3
+ import { TEST_ACCOUNT_C } from "~test/test-wallets.js";
4
+ import { optimizeMintBatchContent } from "./mintAdditionalSupplyToBatch.js";
5
+
6
+ const account = TEST_ACCOUNT_C;
7
+
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
+ });
@@ -0,0 +1,105 @@
1
+ import { multicall } from "../../../extensions/common/__generated__/IMulticall/write/multicall.js";
2
+ import type {
3
+ BaseTransactionOptions,
4
+ WithOverrides,
5
+ } from "../../../transaction/types.js";
6
+ import { uri } from "../__generated__/IERC1155/read/uri.js";
7
+ import { encodeMintTo } from "../__generated__/IMintableERC1155/write/mintTo.js";
8
+ import type { MintAdditionalSupplyToParams } from "./mintAdditionalSupplyTo.js";
9
+
10
+ /**
11
+ * @extension ERC1155
12
+ */
13
+ export type MintAdditionalSupplyToBatchParams = WithOverrides<{
14
+ nfts: MintAdditionalSupplyToParams[];
15
+ }>;
16
+
17
+ /**
18
+ * This extension batches multiple `mintAdditionalSupplyToBatch` extensions into one single multicall.
19
+ * Keep in mind that there is a limit of how many NFTs you can mint per transaction.
20
+ * This limit varies depends on the network that you are transacting on.
21
+ *
22
+ * You are recommended to experiment with the number to figure out the best number for your chain of choice.
23
+ * @extension ERC1155
24
+ * @example
25
+ * ```ts
26
+ * import { mintAdditionalSupplyToBatch } from "thirdweb/extensions/erc1155";
27
+ *
28
+ * const transaction = mintAdditionalSupplyToBatch({
29
+ * contract,
30
+ * nfts: [
31
+ * { tokenId: 0n, supply: 99n, to: account.address },
32
+ * { tokenId: 1n, supply: 98n, to: account.address },
33
+ * { tokenId: 2n, supply: 97n, to: account.address },
34
+ * ],
35
+ * });
36
+ * ```
37
+ */
38
+ export function mintAdditionalSupplyToBatch(
39
+ options: BaseTransactionOptions<MintAdditionalSupplyToBatchParams>,
40
+ ) {
41
+ return multicall({
42
+ contract: options.contract,
43
+ asyncParams: async () => {
44
+ const nfts = optimizeMintBatchContent(options.nfts);
45
+ const data = await Promise.all(
46
+ nfts.map(async (nft) => {
47
+ const tokenUri = await uri({
48
+ contract: options.contract,
49
+ tokenId: nft.tokenId,
50
+ });
51
+ return encodeMintTo({
52
+ to: nft.to,
53
+ tokenId: nft.tokenId,
54
+ amount: nft.supply,
55
+ uri: tokenUri,
56
+ });
57
+ }),
58
+ );
59
+ return { data };
60
+ },
61
+ overrides: options.overrides,
62
+ });
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
+ }
@@ -83,33 +83,24 @@ export function mintToBatch(
83
83
  return multicall({
84
84
  contract: options.contract,
85
85
  asyncParams: async () => {
86
- const uris = await Promise.all(
87
- options.nfts.map((item) => {
88
- if (typeof item.metadata === "string") {
89
- return item.metadata;
90
- }
91
- return upload({
92
- client: options.contract.client,
93
- files: [item.metadata],
86
+ const data = await Promise.all(
87
+ options.nfts.map(async (nft) => {
88
+ const uri =
89
+ typeof nft.metadata === "string"
90
+ ? nft.metadata
91
+ : await upload({
92
+ client: options.contract.client,
93
+ files: [nft.metadata],
94
+ });
95
+ return encodeMintTo({
96
+ to: options.to,
97
+ // maxUint256 is used to indicate that this is a NEW token!
98
+ tokenId: maxUint256,
99
+ uri,
100
+ amount: nft.supply,
94
101
  });
95
102
  }),
96
103
  );
97
-
98
- const data = uris.map((uri, index) => {
99
- const item = options.nfts[index];
100
- if (!item) {
101
- // Should not happen
102
- throw new Error("Index mismatch");
103
- }
104
- return encodeMintTo({
105
- to: options.to,
106
- // maxUint256 is used to indicate that this is a NEW token!
107
- tokenId: maxUint256,
108
- uri,
109
- amount: item.supply,
110
- });
111
- });
112
-
113
104
  return { data };
114
105
  },
115
106
  overrides: options.overrides,
@@ -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
+ });