thirdweb 5.64.0-nightly-cdb907f175f7472d1fb3dea6547d946514564085-20241023000322 → 5.64.0

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 (595) 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/erc721.js +3 -1
  14. package/dist/cjs/exports/extensions/erc721.js.map +1 -1
  15. package/dist/cjs/exports/wallets/in-app.js +2 -1
  16. package/dist/cjs/exports/wallets/in-app.js.map +1 -1
  17. package/dist/cjs/extensions/erc1155/write/mintAdditionalSupplyTo.js +1 -6
  18. package/dist/cjs/extensions/erc1155/write/mintAdditionalSupplyTo.js.map +1 -1
  19. package/dist/cjs/extensions/erc1155/write/mintAdditionalSupplyToBatch.js +41 -1
  20. package/dist/cjs/extensions/erc1155/write/mintAdditionalSupplyToBatch.js.map +1 -1
  21. package/dist/cjs/extensions/erc721/drops/write/claimToBatch.js +115 -0
  22. package/dist/cjs/extensions/erc721/drops/write/claimToBatch.js.map +1 -0
  23. package/dist/cjs/react/core/utils/walletIcon.js +2 -2
  24. package/dist/cjs/react/core/utils/walletIcon.js.map +1 -1
  25. package/dist/cjs/react/native/ui/components/WalletImage.js +3 -1
  26. package/dist/cjs/react/native/ui/components/WalletImage.js.map +1 -1
  27. package/dist/cjs/react/web/hooks/transaction/useSendTransaction.js +3 -4
  28. package/dist/cjs/react/web/hooks/transaction/useSendTransaction.js.map +1 -1
  29. package/dist/cjs/react/web/ui/ConnectWallet/Details.js +2 -2
  30. package/dist/cjs/react/web/ui/ConnectWallet/Details.js.map +1 -1
  31. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/BuyScreen.js +3 -3
  32. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/BuyScreen.js.map +1 -1
  33. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/DirectPaymentModeScreen.js +2 -2
  34. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/DirectPaymentModeScreen.js.map +1 -1
  35. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/TransactionModeScreen.js +2 -2
  36. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/TransactionModeScreen.js.map +1 -1
  37. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/fiat/FiatFlow.js +2 -2
  38. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/fiat/FiatFlow.js.map +1 -1
  39. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/swap/ConfirmationScreen.js +5 -5
  40. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/swap/ConfirmationScreen.js.map +1 -1
  41. package/dist/cjs/react/web/ui/ConnectWallet/screens/LinkedProfilesScreen.js +1 -1
  42. package/dist/cjs/react/web/ui/TransactionButton/TransactionModal.js +2 -2
  43. package/dist/cjs/react/web/ui/TransactionButton/TransactionModal.js.map +1 -1
  44. package/dist/cjs/react/web/ui/components/WalletImage.js +1 -1
  45. package/dist/cjs/react/web/wallets/ecosystem/EcosystemWalletConnectUI.js +1 -1
  46. package/dist/cjs/react/web/wallets/ecosystem/EcosystemWalletConnectUI.js.map +1 -1
  47. package/dist/cjs/react/web/wallets/in-app/InAppWalletConnectUI.js +1 -1
  48. package/dist/cjs/react/web/wallets/in-app/InAppWalletConnectUI.js.map +1 -1
  49. package/dist/cjs/react/web/wallets/in-app/WalletAuth.js +20 -10
  50. package/dist/cjs/react/web/wallets/in-app/WalletAuth.js.map +1 -1
  51. package/dist/cjs/react/web/wallets/shared/ConnectWalletSocialOptions.js +8 -3
  52. package/dist/cjs/react/web/wallets/shared/ConnectWalletSocialOptions.js.map +1 -1
  53. package/dist/cjs/react/web/wallets/shared/locale/de.js +1 -0
  54. package/dist/cjs/react/web/wallets/shared/locale/de.js.map +1 -1
  55. package/dist/cjs/react/web/wallets/shared/locale/en.js +1 -0
  56. package/dist/cjs/react/web/wallets/shared/locale/en.js.map +1 -1
  57. package/dist/cjs/react/web/wallets/shared/locale/es.js +1 -0
  58. package/dist/cjs/react/web/wallets/shared/locale/es.js.map +1 -1
  59. package/dist/cjs/react/web/wallets/shared/locale/fr.js +1 -0
  60. package/dist/cjs/react/web/wallets/shared/locale/fr.js.map +1 -1
  61. package/dist/cjs/react/web/wallets/shared/locale/ja.js +1 -0
  62. package/dist/cjs/react/web/wallets/shared/locale/ja.js.map +1 -1
  63. package/dist/cjs/react/web/wallets/shared/locale/kr.js +1 -0
  64. package/dist/cjs/react/web/wallets/shared/locale/kr.js.map +1 -1
  65. package/dist/cjs/react/web/wallets/shared/locale/tl.js +1 -0
  66. package/dist/cjs/react/web/wallets/shared/locale/tl.js.map +1 -1
  67. package/dist/cjs/react/web/wallets/shared/locale/vi.js +1 -0
  68. package/dist/cjs/react/web/wallets/shared/locale/vi.js.map +1 -1
  69. package/dist/cjs/version.js +1 -1
  70. package/dist/cjs/version.js.map +1 -1
  71. package/dist/cjs/wallets/__generated__/getWalletInfo.js +45 -15
  72. package/dist/cjs/wallets/__generated__/getWalletInfo.js.map +1 -1
  73. package/dist/cjs/wallets/__generated__/wallet/app.nightly/image.js +7 -0
  74. package/dist/cjs/wallets/__generated__/wallet/app.nightly/image.js.map +1 -0
  75. package/dist/cjs/wallets/__generated__/wallet/app.nightly/index.js +34 -0
  76. package/dist/cjs/wallets/__generated__/wallet/app.nightly/index.js.map +1 -0
  77. package/dist/cjs/wallets/__generated__/wallet/app.status/image.js +1 -1
  78. package/dist/cjs/wallets/__generated__/wallet/app.status/image.js.map +1 -1
  79. package/dist/cjs/wallets/__generated__/wallet/app.status/index.js +1 -1
  80. package/dist/cjs/wallets/__generated__/wallet/app.walletnow/index.js +1 -1
  81. package/dist/cjs/wallets/__generated__/wallet/app.walletnow/index.js.map +1 -1
  82. package/dist/cjs/wallets/__generated__/wallet/com.beexo/image.js +7 -0
  83. package/dist/cjs/wallets/__generated__/wallet/com.beexo/image.js.map +1 -0
  84. package/dist/cjs/wallets/__generated__/wallet/{org.nitrogen → com.beexo}/index.js +9 -9
  85. package/dist/cjs/wallets/__generated__/wallet/com.beexo/index.js.map +1 -0
  86. package/dist/cjs/wallets/__generated__/wallet/com.brave.wallet/image.js +1 -1
  87. package/dist/cjs/wallets/__generated__/wallet/com.brave.wallet/image.js.map +1 -1
  88. package/dist/cjs/wallets/__generated__/wallet/com.brave.wallet/index.js +9 -9
  89. package/dist/cjs/wallets/__generated__/wallet/com.brave.wallet/index.js.map +1 -1
  90. package/dist/cjs/wallets/__generated__/wallet/com.coin98/image.js +1 -1
  91. package/dist/cjs/wallets/__generated__/wallet/com.coin98/image.js.map +1 -1
  92. package/dist/cjs/wallets/__generated__/wallet/com.coin98/index.js +1 -1
  93. package/dist/cjs/wallets/__generated__/wallet/com.crypto/image.js +1 -1
  94. package/dist/cjs/wallets/__generated__/wallet/com.crypto/image.js.map +1 -1
  95. package/dist/cjs/wallets/__generated__/wallet/com.crypto/index.js +1 -1
  96. package/dist/cjs/wallets/__generated__/wallet/com.daffione/image.js +7 -0
  97. package/dist/cjs/wallets/__generated__/wallet/{org.nitrogen → com.daffione}/image.js.map +1 -1
  98. package/dist/cjs/wallets/__generated__/wallet/com.daffione/index.js +34 -0
  99. package/dist/cjs/wallets/__generated__/wallet/com.daffione/index.js.map +1 -0
  100. package/dist/cjs/wallets/__generated__/wallet/com.ipmb/image.js +7 -0
  101. package/dist/cjs/wallets/__generated__/wallet/com.ipmb/image.js.map +1 -0
  102. package/dist/cjs/wallets/__generated__/wallet/com.ipmb/index.js +34 -0
  103. package/dist/cjs/wallets/__generated__/wallet/com.ipmb/index.js.map +1 -0
  104. package/dist/cjs/wallets/__generated__/wallet/com.webauth/image.js +7 -0
  105. package/dist/cjs/wallets/__generated__/wallet/com.webauth/image.js.map +1 -0
  106. package/dist/cjs/wallets/__generated__/wallet/com.webauth/index.js +34 -0
  107. package/dist/cjs/wallets/__generated__/wallet/com.webauth/index.js.map +1 -0
  108. package/dist/cjs/wallets/__generated__/wallet/finance.openwallet/index.js +2 -2
  109. package/dist/cjs/wallets/__generated__/wallet/finance.openwallet/index.js.map +1 -1
  110. package/dist/cjs/wallets/__generated__/wallet/finance.plena/index.js +1 -1
  111. package/dist/cjs/wallets/__generated__/wallet/finance.plena/index.js.map +1 -1
  112. package/dist/cjs/wallets/__generated__/wallet/id.plumaa/image.js +7 -0
  113. package/dist/cjs/wallets/__generated__/wallet/id.plumaa/image.js.map +1 -0
  114. package/dist/cjs/wallets/__generated__/wallet/id.plumaa/index.js +34 -0
  115. package/dist/cjs/wallets/__generated__/wallet/id.plumaa/index.js.map +1 -0
  116. package/dist/cjs/wallets/__generated__/wallet/io.miraiapp/image.js +1 -1
  117. package/dist/cjs/wallets/__generated__/wallet/io.miraiapp/image.js.map +1 -1
  118. package/dist/cjs/wallets/__generated__/wallet/io.miraiapp/index.js +1 -1
  119. package/dist/cjs/wallets/__generated__/wallet/io.owallet/image.js +7 -0
  120. package/dist/cjs/wallets/__generated__/wallet/io.owallet/image.js.map +1 -0
  121. package/dist/cjs/wallets/__generated__/wallet/io.owallet/index.js +34 -0
  122. package/dist/cjs/wallets/__generated__/wallet/io.owallet/index.js.map +1 -0
  123. package/dist/cjs/wallets/__generated__/wallet/io.tradestrike/image.js +1 -1
  124. package/dist/cjs/wallets/__generated__/wallet/io.tradestrike/image.js.map +1 -1
  125. package/dist/cjs/wallets/__generated__/wallet/io.tradestrike/index.js +2 -2
  126. package/dist/cjs/wallets/__generated__/wallet/io.tradestrike/index.js.map +1 -1
  127. package/dist/cjs/wallets/__generated__/wallet-infos.js +45 -15
  128. package/dist/cjs/wallets/__generated__/wallet-infos.js.map +1 -1
  129. package/dist/cjs/wallets/coinbase/coinbase-wallet.js +3 -3
  130. package/dist/cjs/wallets/coinbase/coinbase-wallet.js.map +1 -1
  131. package/dist/cjs/wallets/coinbase/coinbaseWebSDK.js +20 -8
  132. package/dist/cjs/wallets/coinbase/coinbaseWebSDK.js.map +1 -1
  133. package/dist/cjs/wallets/create-wallet.js +11 -6
  134. package/dist/cjs/wallets/create-wallet.js.map +1 -1
  135. package/dist/cjs/wallets/ecosystem/get-ecosystem-wallet-auth-options.js +5 -0
  136. package/dist/cjs/wallets/ecosystem/get-ecosystem-wallet-auth-options.js.map +1 -1
  137. package/dist/cjs/wallets/in-app/core/authentication/getLoginPath.js +1 -1
  138. package/dist/cjs/wallets/in-app/core/authentication/getLoginPath.js.map +1 -1
  139. package/dist/cjs/wallets/in-app/core/wallet/enclave-wallet.js +13 -3
  140. package/dist/cjs/wallets/in-app/core/wallet/enclave-wallet.js.map +1 -1
  141. package/dist/cjs/wallets/in-app/core/wallet/in-app-core.js +5 -3
  142. package/dist/cjs/wallets/in-app/core/wallet/in-app-core.js.map +1 -1
  143. package/dist/cjs/wallets/in-app/web/lib/iframe-wallet.js +9 -2
  144. package/dist/cjs/wallets/in-app/web/lib/iframe-wallet.js.map +1 -1
  145. package/dist/cjs/wallets/injected/index.js +36 -8
  146. package/dist/cjs/wallets/injected/index.js.map +1 -1
  147. package/dist/cjs/wallets/native/create-wallet.js +3 -3
  148. package/dist/cjs/wallets/native/create-wallet.js.map +1 -1
  149. package/dist/cjs/wallets/smart/smart-wallet.js +3 -3
  150. package/dist/cjs/wallets/smart/smart-wallet.js.map +1 -1
  151. package/dist/cjs/wallets/types.js +1 -0
  152. package/dist/cjs/wallets/types.js.map +1 -1
  153. package/dist/cjs/wallets/wallet-connect/controller.js +20 -8
  154. package/dist/cjs/wallets/wallet-connect/controller.js.map +1 -1
  155. package/dist/esm/analytics/track/connect.js +18 -0
  156. package/dist/esm/analytics/track/connect.js.map +1 -0
  157. package/dist/esm/analytics/track/index.js +18 -0
  158. package/dist/esm/analytics/track/index.js.map +1 -0
  159. package/dist/esm/analytics/track/pay.js +23 -0
  160. package/dist/esm/analytics/track/pay.js.map +1 -0
  161. package/dist/esm/analytics/track/siwe.js +29 -0
  162. package/dist/esm/analytics/track/siwe.js.map +1 -0
  163. package/dist/esm/analytics/track/transaction.js +33 -0
  164. package/dist/esm/analytics/track/transaction.js.map +1 -0
  165. package/dist/esm/auth/core/verify-login-payload.js +19 -1
  166. package/dist/esm/auth/core/verify-login-payload.js.map +1 -1
  167. package/dist/esm/exports/extensions/erc721.js +1 -0
  168. package/dist/esm/exports/extensions/erc721.js.map +1 -1
  169. package/dist/esm/exports/pay.js +0 -1
  170. package/dist/esm/exports/pay.js.map +1 -1
  171. package/dist/esm/exports/react.js +0 -5
  172. package/dist/esm/exports/react.js.map +1 -1
  173. package/dist/esm/exports/react.native.js +0 -2
  174. package/dist/esm/exports/react.native.js.map +1 -1
  175. package/dist/esm/exports/thirdweb.js +0 -1
  176. package/dist/esm/exports/thirdweb.js.map +1 -1
  177. package/dist/esm/exports/wallets/embedded.js +0 -1
  178. package/dist/esm/exports/wallets/embedded.js.map +1 -1
  179. package/dist/esm/exports/wallets/in-app.js +1 -2
  180. package/dist/esm/exports/wallets/in-app.js.map +1 -1
  181. package/dist/esm/exports/wallets/in-app.native.js +0 -1
  182. package/dist/esm/exports/wallets/in-app.native.js.map +1 -1
  183. package/dist/esm/exports/wallets.js +0 -1
  184. package/dist/esm/exports/wallets.js.map +1 -1
  185. package/dist/esm/exports/wallets.native.js +0 -1
  186. package/dist/esm/exports/wallets.native.js.map +1 -1
  187. package/dist/esm/extensions/erc1155/write/mintAdditionalSupplyTo.js +1 -6
  188. package/dist/esm/extensions/erc1155/write/mintAdditionalSupplyTo.js.map +1 -1
  189. package/dist/esm/extensions/erc1155/write/mintAdditionalSupplyToBatch.js +40 -1
  190. package/dist/esm/extensions/erc1155/write/mintAdditionalSupplyToBatch.js.map +1 -1
  191. package/dist/esm/extensions/erc721/drops/write/claimToBatch.js +111 -0
  192. package/dist/esm/extensions/erc721/drops/write/claimToBatch.js.map +1 -0
  193. package/dist/esm/react/core/utils/walletIcon.js +1 -1
  194. package/dist/esm/react/core/utils/walletIcon.js.map +1 -1
  195. package/dist/esm/react/native/ui/components/WalletImage.js +3 -1
  196. package/dist/esm/react/native/ui/components/WalletImage.js.map +1 -1
  197. package/dist/esm/react/web/hooks/transaction/useSendTransaction.js +3 -4
  198. package/dist/esm/react/web/hooks/transaction/useSendTransaction.js.map +1 -1
  199. package/dist/esm/react/web/ui/ConnectWallet/Details.js +1 -1
  200. package/dist/esm/react/web/ui/ConnectWallet/Details.js.map +1 -1
  201. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/BuyScreen.js +1 -1
  202. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/BuyScreen.js.map +1 -1
  203. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/DirectPaymentModeScreen.js +1 -1
  204. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/DirectPaymentModeScreen.js.map +1 -1
  205. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/TransactionModeScreen.js +1 -1
  206. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/TransactionModeScreen.js.map +1 -1
  207. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/fiat/FiatFlow.js +1 -1
  208. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/fiat/FiatFlow.js.map +1 -1
  209. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/swap/ConfirmationScreen.js +1 -1
  210. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/swap/ConfirmationScreen.js.map +1 -1
  211. package/dist/esm/react/web/ui/ConnectWallet/screens/LinkedProfilesScreen.js +2 -2
  212. package/dist/esm/react/web/ui/TransactionButton/TransactionModal.js +1 -1
  213. package/dist/esm/react/web/ui/TransactionButton/TransactionModal.js.map +1 -1
  214. package/dist/esm/react/web/ui/components/WalletImage.js +2 -2
  215. package/dist/esm/react/web/wallets/ecosystem/EcosystemWalletConnectUI.js +1 -1
  216. package/dist/esm/react/web/wallets/ecosystem/EcosystemWalletConnectUI.js.map +1 -1
  217. package/dist/esm/react/web/wallets/in-app/InAppWalletConnectUI.js +1 -1
  218. package/dist/esm/react/web/wallets/in-app/InAppWalletConnectUI.js.map +1 -1
  219. package/dist/esm/react/web/wallets/in-app/WalletAuth.js +20 -10
  220. package/dist/esm/react/web/wallets/in-app/WalletAuth.js.map +1 -1
  221. package/dist/esm/react/web/wallets/shared/ConnectWalletSocialOptions.js +9 -4
  222. package/dist/esm/react/web/wallets/shared/ConnectWalletSocialOptions.js.map +1 -1
  223. package/dist/esm/react/web/wallets/shared/locale/de.js +1 -0
  224. package/dist/esm/react/web/wallets/shared/locale/de.js.map +1 -1
  225. package/dist/esm/react/web/wallets/shared/locale/en.js +1 -0
  226. package/dist/esm/react/web/wallets/shared/locale/en.js.map +1 -1
  227. package/dist/esm/react/web/wallets/shared/locale/es.js +1 -0
  228. package/dist/esm/react/web/wallets/shared/locale/es.js.map +1 -1
  229. package/dist/esm/react/web/wallets/shared/locale/fr.js +1 -0
  230. package/dist/esm/react/web/wallets/shared/locale/fr.js.map +1 -1
  231. package/dist/esm/react/web/wallets/shared/locale/ja.js +1 -0
  232. package/dist/esm/react/web/wallets/shared/locale/ja.js.map +1 -1
  233. package/dist/esm/react/web/wallets/shared/locale/kr.js +1 -0
  234. package/dist/esm/react/web/wallets/shared/locale/kr.js.map +1 -1
  235. package/dist/esm/react/web/wallets/shared/locale/tl.js +1 -0
  236. package/dist/esm/react/web/wallets/shared/locale/tl.js.map +1 -1
  237. package/dist/esm/react/web/wallets/shared/locale/vi.js +1 -0
  238. package/dist/esm/react/web/wallets/shared/locale/vi.js.map +1 -1
  239. package/dist/esm/version.js +1 -1
  240. package/dist/esm/version.js.map +1 -1
  241. package/dist/esm/wallets/__generated__/getWalletInfo.js +45 -15
  242. package/dist/esm/wallets/__generated__/getWalletInfo.js.map +1 -1
  243. package/dist/esm/wallets/__generated__/wallet/app.nightly/image.js +5 -0
  244. package/dist/esm/wallets/__generated__/wallet/app.nightly/image.js.map +1 -0
  245. package/dist/esm/wallets/__generated__/wallet/app.nightly/index.js +31 -0
  246. package/dist/esm/wallets/__generated__/wallet/app.nightly/index.js.map +1 -0
  247. package/dist/esm/wallets/__generated__/wallet/app.status/image.js +1 -1
  248. package/dist/esm/wallets/__generated__/wallet/app.status/image.js.map +1 -1
  249. package/dist/esm/wallets/__generated__/wallet/app.status/index.js +1 -1
  250. package/dist/esm/wallets/__generated__/wallet/app.walletnow/index.js +1 -1
  251. package/dist/esm/wallets/__generated__/wallet/app.walletnow/index.js.map +1 -1
  252. package/dist/esm/wallets/__generated__/wallet/com.beexo/image.js +5 -0
  253. package/dist/esm/wallets/__generated__/wallet/com.beexo/image.js.map +1 -0
  254. package/dist/esm/wallets/__generated__/wallet/{org.nitrogen → com.beexo}/index.js +9 -9
  255. package/dist/esm/wallets/__generated__/wallet/com.beexo/index.js.map +1 -0
  256. package/dist/esm/wallets/__generated__/wallet/com.brave.wallet/image.js +1 -1
  257. package/dist/esm/wallets/__generated__/wallet/com.brave.wallet/image.js.map +1 -1
  258. package/dist/esm/wallets/__generated__/wallet/com.brave.wallet/index.js +9 -9
  259. package/dist/esm/wallets/__generated__/wallet/com.brave.wallet/index.js.map +1 -1
  260. package/dist/esm/wallets/__generated__/wallet/com.coin98/image.js +1 -1
  261. package/dist/esm/wallets/__generated__/wallet/com.coin98/image.js.map +1 -1
  262. package/dist/esm/wallets/__generated__/wallet/com.coin98/index.js +1 -1
  263. package/dist/esm/wallets/__generated__/wallet/com.crypto/image.js +1 -1
  264. package/dist/esm/wallets/__generated__/wallet/com.crypto/image.js.map +1 -1
  265. package/dist/esm/wallets/__generated__/wallet/com.crypto/index.js +1 -1
  266. package/dist/esm/wallets/__generated__/wallet/com.daffione/image.js +5 -0
  267. package/dist/esm/wallets/__generated__/wallet/{org.nitrogen → com.daffione}/image.js.map +1 -1
  268. package/dist/esm/wallets/__generated__/wallet/com.daffione/index.js +31 -0
  269. package/dist/esm/wallets/__generated__/wallet/com.daffione/index.js.map +1 -0
  270. package/dist/esm/wallets/__generated__/wallet/com.ipmb/image.js +5 -0
  271. package/dist/esm/wallets/__generated__/wallet/com.ipmb/image.js.map +1 -0
  272. package/dist/esm/wallets/__generated__/wallet/com.ipmb/index.js +31 -0
  273. package/dist/esm/wallets/__generated__/wallet/com.ipmb/index.js.map +1 -0
  274. package/dist/esm/wallets/__generated__/wallet/com.webauth/image.js +5 -0
  275. package/dist/esm/wallets/__generated__/wallet/com.webauth/image.js.map +1 -0
  276. package/dist/esm/wallets/__generated__/wallet/com.webauth/index.js +31 -0
  277. package/dist/esm/wallets/__generated__/wallet/com.webauth/index.js.map +1 -0
  278. package/dist/esm/wallets/__generated__/wallet/finance.openwallet/index.js +2 -2
  279. package/dist/esm/wallets/__generated__/wallet/finance.openwallet/index.js.map +1 -1
  280. package/dist/esm/wallets/__generated__/wallet/finance.plena/index.js +1 -1
  281. package/dist/esm/wallets/__generated__/wallet/finance.plena/index.js.map +1 -1
  282. package/dist/esm/wallets/__generated__/wallet/id.plumaa/image.js +5 -0
  283. package/dist/esm/wallets/__generated__/wallet/id.plumaa/image.js.map +1 -0
  284. package/dist/esm/wallets/__generated__/wallet/id.plumaa/index.js +31 -0
  285. package/dist/esm/wallets/__generated__/wallet/id.plumaa/index.js.map +1 -0
  286. package/dist/esm/wallets/__generated__/wallet/io.miraiapp/image.js +1 -1
  287. package/dist/esm/wallets/__generated__/wallet/io.miraiapp/image.js.map +1 -1
  288. package/dist/esm/wallets/__generated__/wallet/io.miraiapp/index.js +1 -1
  289. package/dist/esm/wallets/__generated__/wallet/io.owallet/image.js +5 -0
  290. package/dist/esm/wallets/__generated__/wallet/io.owallet/image.js.map +1 -0
  291. package/dist/esm/wallets/__generated__/wallet/io.owallet/index.js +31 -0
  292. package/dist/esm/wallets/__generated__/wallet/io.owallet/index.js.map +1 -0
  293. package/dist/esm/wallets/__generated__/wallet/io.tradestrike/image.js +1 -1
  294. package/dist/esm/wallets/__generated__/wallet/io.tradestrike/image.js.map +1 -1
  295. package/dist/esm/wallets/__generated__/wallet/io.tradestrike/index.js +2 -2
  296. package/dist/esm/wallets/__generated__/wallet/io.tradestrike/index.js.map +1 -1
  297. package/dist/esm/wallets/__generated__/wallet-infos.js +45 -15
  298. package/dist/esm/wallets/__generated__/wallet-infos.js.map +1 -1
  299. package/dist/esm/wallets/coinbase/coinbase-wallet.js +1 -1
  300. package/dist/esm/wallets/coinbase/coinbase-wallet.js.map +1 -1
  301. package/dist/esm/wallets/coinbase/coinbaseWebSDK.js +20 -8
  302. package/dist/esm/wallets/coinbase/coinbaseWebSDK.js.map +1 -1
  303. package/dist/esm/wallets/create-wallet.js +7 -2
  304. package/dist/esm/wallets/create-wallet.js.map +1 -1
  305. package/dist/esm/wallets/ecosystem/get-ecosystem-wallet-auth-options.js +5 -0
  306. package/dist/esm/wallets/ecosystem/get-ecosystem-wallet-auth-options.js.map +1 -1
  307. package/dist/esm/wallets/in-app/core/authentication/getLoginPath.js +1 -1
  308. package/dist/esm/wallets/in-app/core/authentication/getLoginPath.js.map +1 -1
  309. package/dist/esm/wallets/in-app/core/wallet/enclave-wallet.js +13 -3
  310. package/dist/esm/wallets/in-app/core/wallet/enclave-wallet.js.map +1 -1
  311. package/dist/esm/wallets/in-app/core/wallet/in-app-core.js +3 -1
  312. package/dist/esm/wallets/in-app/core/wallet/in-app-core.js.map +1 -1
  313. package/dist/esm/wallets/in-app/web/lib/iframe-wallet.js +9 -2
  314. package/dist/esm/wallets/in-app/web/lib/iframe-wallet.js.map +1 -1
  315. package/dist/esm/wallets/injected/index.js +36 -8
  316. package/dist/esm/wallets/injected/index.js.map +1 -1
  317. package/dist/esm/wallets/native/create-wallet.js +1 -1
  318. package/dist/esm/wallets/native/create-wallet.js.map +1 -1
  319. package/dist/esm/wallets/smart/smart-wallet.js +1 -1
  320. package/dist/esm/wallets/smart/smart-wallet.js.map +1 -1
  321. package/dist/esm/wallets/types.js +1 -0
  322. package/dist/esm/wallets/types.js.map +1 -1
  323. package/dist/esm/wallets/wallet-connect/controller.js +20 -8
  324. package/dist/esm/wallets/wallet-connect/controller.js.map +1 -1
  325. package/dist/types/analytics/track/connect.d.ts +12 -0
  326. package/dist/types/analytics/track/connect.d.ts.map +1 -0
  327. package/dist/types/analytics/track/index.d.ts +11 -0
  328. package/dist/types/analytics/track/index.d.ts.map +1 -0
  329. package/dist/types/analytics/{track.d.ts → track/pay.d.ts} +5 -11
  330. package/dist/types/analytics/track/pay.d.ts.map +1 -0
  331. package/dist/types/analytics/track/siwe.d.ts +19 -0
  332. package/dist/types/analytics/track/siwe.d.ts.map +1 -0
  333. package/dist/types/analytics/track/transaction.d.ts +24 -0
  334. package/dist/types/analytics/track/transaction.d.ts.map +1 -0
  335. package/dist/types/auth/core/verify-login-payload.d.ts.map +1 -1
  336. package/dist/types/exports/extensions/erc721.d.ts +1 -0
  337. package/dist/types/exports/extensions/erc721.d.ts.map +1 -1
  338. package/dist/types/exports/pay.d.ts +1 -1
  339. package/dist/types/exports/pay.d.ts.map +1 -1
  340. package/dist/types/exports/react.d.ts +3 -3
  341. package/dist/types/exports/react.d.ts.map +1 -1
  342. package/dist/types/exports/react.native.d.ts +1 -1
  343. package/dist/types/exports/react.native.d.ts.map +1 -1
  344. package/dist/types/exports/thirdweb.d.ts +1 -1
  345. package/dist/types/exports/thirdweb.d.ts.map +1 -1
  346. package/dist/types/exports/wallets/embedded.d.ts +1 -1
  347. package/dist/types/exports/wallets/embedded.d.ts.map +1 -1
  348. package/dist/types/exports/wallets/in-app.d.ts +2 -2
  349. package/dist/types/exports/wallets/in-app.d.ts.map +1 -1
  350. package/dist/types/exports/wallets/in-app.native.d.ts +1 -1
  351. package/dist/types/exports/wallets/in-app.native.d.ts.map +1 -1
  352. package/dist/types/exports/wallets.d.ts +1 -1
  353. package/dist/types/exports/wallets.d.ts.map +1 -1
  354. package/dist/types/exports/wallets.native.d.ts +1 -1
  355. package/dist/types/exports/wallets.native.d.ts.map +1 -1
  356. package/dist/types/extensions/erc1155/write/mintAdditionalSupplyTo.d.ts.map +1 -1
  357. package/dist/types/extensions/erc1155/write/mintAdditionalSupplyToBatch.d.ts +23 -3
  358. package/dist/types/extensions/erc1155/write/mintAdditionalSupplyToBatch.d.ts.map +1 -1
  359. package/dist/types/extensions/erc721/drops/write/claimToBatch.d.ts +71 -0
  360. package/dist/types/extensions/erc721/drops/write/claimToBatch.d.ts.map +1 -0
  361. package/dist/types/react/core/utils/walletIcon.d.ts +2 -1
  362. package/dist/types/react/core/utils/walletIcon.d.ts.map +1 -1
  363. package/dist/types/react/native/ui/components/WalletImage.d.ts.map +1 -1
  364. package/dist/types/react/web/hooks/transaction/useSendTransaction.d.ts +3 -4
  365. package/dist/types/react/web/hooks/transaction/useSendTransaction.d.ts.map +1 -1
  366. package/dist/types/react/web/ui/ConnectWallet/Details.d.ts.map +1 -1
  367. package/dist/types/react/web/ui/ConnectWallet/screens/Buy/swap/ConfirmationScreen.d.ts.map +1 -1
  368. package/dist/types/react/web/wallets/ecosystem/EcosystemWalletConnectUI.d.ts.map +1 -1
  369. package/dist/types/react/web/wallets/in-app/InAppWalletConnectUI.d.ts.map +1 -1
  370. package/dist/types/react/web/wallets/in-app/WalletAuth.d.ts +1 -0
  371. package/dist/types/react/web/wallets/in-app/WalletAuth.d.ts.map +1 -1
  372. package/dist/types/react/web/wallets/shared/ConnectWalletSocialOptions.d.ts +3 -1
  373. package/dist/types/react/web/wallets/shared/ConnectWalletSocialOptions.d.ts.map +1 -1
  374. package/dist/types/react/web/wallets/shared/locale/de.d.ts +1 -0
  375. package/dist/types/react/web/wallets/shared/locale/de.d.ts.map +1 -1
  376. package/dist/types/react/web/wallets/shared/locale/en.d.ts +1 -0
  377. package/dist/types/react/web/wallets/shared/locale/en.d.ts.map +1 -1
  378. package/dist/types/react/web/wallets/shared/locale/es.d.ts +1 -0
  379. package/dist/types/react/web/wallets/shared/locale/es.d.ts.map +1 -1
  380. package/dist/types/react/web/wallets/shared/locale/fr.d.ts +1 -0
  381. package/dist/types/react/web/wallets/shared/locale/fr.d.ts.map +1 -1
  382. package/dist/types/react/web/wallets/shared/locale/ja.d.ts +1 -0
  383. package/dist/types/react/web/wallets/shared/locale/ja.d.ts.map +1 -1
  384. package/dist/types/react/web/wallets/shared/locale/kr.d.ts +1 -0
  385. package/dist/types/react/web/wallets/shared/locale/kr.d.ts.map +1 -1
  386. package/dist/types/react/web/wallets/shared/locale/tl.d.ts +1 -0
  387. package/dist/types/react/web/wallets/shared/locale/tl.d.ts.map +1 -1
  388. package/dist/types/react/web/wallets/shared/locale/types.d.ts +1 -0
  389. package/dist/types/react/web/wallets/shared/locale/types.d.ts.map +1 -1
  390. package/dist/types/react/web/wallets/shared/locale/vi.d.ts +1 -0
  391. package/dist/types/react/web/wallets/shared/locale/vi.d.ts.map +1 -1
  392. package/dist/types/version.d.ts +1 -1
  393. package/dist/types/version.d.ts.map +1 -1
  394. package/dist/types/wallets/__generated__/getWalletInfo.d.ts.map +1 -1
  395. package/dist/types/wallets/__generated__/wallet/app.nightly/image.d.ts +3 -0
  396. package/dist/types/wallets/__generated__/wallet/app.nightly/image.d.ts.map +1 -0
  397. package/dist/types/wallets/__generated__/wallet/app.nightly/index.d.ts +29 -0
  398. package/dist/types/wallets/__generated__/wallet/app.nightly/index.d.ts.map +1 -0
  399. package/dist/types/wallets/__generated__/wallet/app.status/image.d.ts +1 -1
  400. package/dist/types/wallets/__generated__/wallet/app.status/image.d.ts.map +1 -1
  401. package/dist/types/wallets/__generated__/wallet/app.status/index.d.ts +1 -1
  402. package/dist/types/wallets/__generated__/wallet/app.walletnow/index.d.ts +1 -1
  403. package/dist/types/wallets/__generated__/wallet/com.beexo/image.d.ts +3 -0
  404. package/dist/types/wallets/__generated__/wallet/com.beexo/image.d.ts.map +1 -0
  405. package/dist/types/wallets/__generated__/wallet/{org.nitrogen → com.beexo}/index.d.ts +9 -9
  406. package/dist/types/wallets/__generated__/wallet/com.beexo/index.d.ts.map +1 -0
  407. package/dist/types/wallets/__generated__/wallet/com.brave.wallet/image.d.ts +1 -1
  408. package/dist/types/wallets/__generated__/wallet/com.brave.wallet/image.d.ts.map +1 -1
  409. package/dist/types/wallets/__generated__/wallet/com.brave.wallet/index.d.ts +9 -9
  410. package/dist/types/wallets/__generated__/wallet/com.brave.wallet/index.d.ts.map +1 -1
  411. package/dist/types/wallets/__generated__/wallet/com.coin98/image.d.ts +1 -1
  412. package/dist/types/wallets/__generated__/wallet/com.coin98/image.d.ts.map +1 -1
  413. package/dist/types/wallets/__generated__/wallet/com.coin98/index.d.ts +1 -1
  414. package/dist/types/wallets/__generated__/wallet/com.crypto/image.d.ts +1 -1
  415. package/dist/types/wallets/__generated__/wallet/com.crypto/image.d.ts.map +1 -1
  416. package/dist/types/wallets/__generated__/wallet/com.crypto/index.d.ts +1 -1
  417. package/dist/types/wallets/__generated__/wallet/com.daffione/image.d.ts +3 -0
  418. package/dist/types/wallets/__generated__/wallet/com.daffione/image.d.ts.map +1 -0
  419. package/dist/types/wallets/__generated__/wallet/com.daffione/index.d.ts +29 -0
  420. package/dist/types/wallets/__generated__/wallet/{org.nitrogen → com.daffione}/index.d.ts.map +1 -1
  421. package/dist/types/wallets/__generated__/wallet/com.ipmb/image.d.ts +3 -0
  422. package/dist/types/wallets/__generated__/wallet/com.ipmb/image.d.ts.map +1 -0
  423. package/dist/types/wallets/__generated__/wallet/com.ipmb/index.d.ts +29 -0
  424. package/dist/types/wallets/__generated__/wallet/com.ipmb/index.d.ts.map +1 -0
  425. package/dist/types/wallets/__generated__/wallet/com.webauth/image.d.ts +3 -0
  426. package/dist/types/wallets/__generated__/wallet/com.webauth/image.d.ts.map +1 -0
  427. package/dist/types/wallets/__generated__/wallet/com.webauth/index.d.ts +29 -0
  428. package/dist/types/wallets/__generated__/wallet/com.webauth/index.d.ts.map +1 -0
  429. package/dist/types/wallets/__generated__/wallet/finance.openwallet/index.d.ts +2 -2
  430. package/dist/types/wallets/__generated__/wallet/finance.plena/index.d.ts +1 -1
  431. package/dist/types/wallets/__generated__/wallet/id.plumaa/image.d.ts +3 -0
  432. package/dist/types/wallets/__generated__/wallet/id.plumaa/image.d.ts.map +1 -0
  433. package/dist/types/wallets/__generated__/wallet/id.plumaa/index.d.ts +29 -0
  434. package/dist/types/wallets/__generated__/wallet/id.plumaa/index.d.ts.map +1 -0
  435. package/dist/types/wallets/__generated__/wallet/io.miraiapp/image.d.ts +1 -1
  436. package/dist/types/wallets/__generated__/wallet/io.miraiapp/image.d.ts.map +1 -1
  437. package/dist/types/wallets/__generated__/wallet/io.miraiapp/index.d.ts +1 -1
  438. package/dist/types/wallets/__generated__/wallet/io.owallet/image.d.ts +3 -0
  439. package/dist/types/wallets/__generated__/wallet/io.owallet/image.d.ts.map +1 -0
  440. package/dist/types/wallets/__generated__/wallet/io.owallet/index.d.ts +29 -0
  441. package/dist/types/wallets/__generated__/wallet/io.owallet/index.d.ts.map +1 -0
  442. package/dist/types/wallets/__generated__/wallet/io.tradestrike/image.d.ts +1 -1
  443. package/dist/types/wallets/__generated__/wallet/io.tradestrike/image.d.ts.map +1 -1
  444. package/dist/types/wallets/__generated__/wallet/io.tradestrike/index.d.ts +2 -2
  445. package/dist/types/wallets/__generated__/wallet-ids.d.ts +2 -2
  446. package/dist/types/wallets/__generated__/wallet-ids.d.ts.map +1 -1
  447. package/dist/types/wallets/__generated__/wallet-infos.d.ts +36 -12
  448. package/dist/types/wallets/__generated__/wallet-infos.d.ts.map +1 -1
  449. package/dist/types/wallets/coinbase/coinbaseWebSDK.d.ts +1 -1
  450. package/dist/types/wallets/coinbase/coinbaseWebSDK.d.ts.map +1 -1
  451. package/dist/types/wallets/create-wallet.d.ts.map +1 -1
  452. package/dist/types/wallets/ecosystem/get-ecosystem-wallet-auth-options.d.ts.map +1 -1
  453. package/dist/types/wallets/getAllWalletsList.d.ts +36 -12
  454. package/dist/types/wallets/getAllWalletsList.d.ts.map +1 -1
  455. package/dist/types/wallets/in-app/core/authentication/getLoginPath.d.ts +2 -2
  456. package/dist/types/wallets/in-app/core/authentication/getLoginPath.d.ts.map +1 -1
  457. package/dist/types/wallets/in-app/core/authentication/types.d.ts +1 -1
  458. package/dist/types/wallets/in-app/core/authentication/types.d.ts.map +1 -1
  459. package/dist/types/wallets/in-app/core/wallet/enclave-wallet.d.ts.map +1 -1
  460. package/dist/types/wallets/in-app/core/wallet/in-app-core.d.ts.map +1 -1
  461. package/dist/types/wallets/in-app/web/lib/iframe-wallet.d.ts.map +1 -1
  462. package/dist/types/wallets/injected/index.d.ts +15 -2
  463. package/dist/types/wallets/injected/index.d.ts.map +1 -1
  464. package/dist/types/wallets/types.d.ts +1 -1
  465. package/dist/types/wallets/types.d.ts.map +1 -1
  466. package/dist/types/wallets/wallet-connect/controller.d.ts +2 -1
  467. package/dist/types/wallets/wallet-connect/controller.d.ts.map +1 -1
  468. package/package.json +19 -19
  469. package/src/analytics/track/connect.test.ts +78 -0
  470. package/src/analytics/track/connect.ts +25 -0
  471. package/src/analytics/track/index.ts +30 -0
  472. package/src/analytics/track/pay.test.ts +98 -0
  473. package/src/analytics/track/pay.ts +37 -0
  474. package/src/analytics/track/siwe.test.ts +110 -0
  475. package/src/analytics/track/siwe.ts +48 -0
  476. package/src/analytics/track/track.test.ts +107 -0
  477. package/src/analytics/track/transaction.test.ts +130 -0
  478. package/src/analytics/track/transaction.ts +57 -0
  479. package/src/auth/core/verify-login-payload.ts +25 -1
  480. package/src/exports/extensions/erc721.ts +4 -0
  481. package/src/exports/pay.ts +3 -3
  482. package/src/exports/react.native.ts +3 -3
  483. package/src/exports/react.ts +5 -5
  484. package/src/exports/thirdweb.ts +3 -3
  485. package/src/exports/wallets/embedded.ts +1 -1
  486. package/src/exports/wallets/in-app.native.ts +1 -1
  487. package/src/exports/wallets/in-app.ts +5 -2
  488. package/src/exports/wallets.native.ts +1 -1
  489. package/src/exports/wallets.ts +1 -1
  490. package/src/extensions/erc1155/drop1155.test.ts +175 -34
  491. package/src/extensions/erc1155/drops/read/getActiveClaimCondition.test.ts +0 -90
  492. package/src/extensions/erc1155/token1155.test.ts +170 -2
  493. package/src/extensions/erc1155/write/lazyMint.test.ts +2 -22
  494. package/src/extensions/erc1155/write/mintAdditionalSupplyTo.ts +1 -7
  495. package/src/extensions/erc1155/write/mintAdditionalSupplyToBatch.test.ts +16 -85
  496. package/src/extensions/erc1155/write/mintAdditionalSupplyToBatch.ts +51 -4
  497. package/src/extensions/erc721/drops/write/claimTo.test.ts +15 -0
  498. package/src/extensions/erc721/drops/write/claimToBatch.test.ts +154 -0
  499. package/src/extensions/erc721/drops/write/claimToBatch.ts +144 -0
  500. package/src/extensions/prebuilts/deploy-erc1155.test.ts +5 -5
  501. package/src/extensions/prebuilts/deploy-pack.test.ts +4 -2
  502. package/src/react/core/utils/walletIcon.ts +3 -1
  503. package/src/react/native/ui/components/WalletImage.tsx +3 -1
  504. package/src/react/web/hooks/transaction/useSendTransaction.tsx +3 -4
  505. package/src/react/web/ui/ConnectWallet/Details.tsx +2 -4
  506. package/src/react/web/ui/ConnectWallet/screens/Buy/BuyScreen.tsx +1 -1
  507. package/src/react/web/ui/ConnectWallet/screens/Buy/DirectPaymentModeScreen.tsx +1 -1
  508. package/src/react/web/ui/ConnectWallet/screens/Buy/TransactionModeScreen.tsx +1 -1
  509. package/src/react/web/ui/ConnectWallet/screens/Buy/fiat/FiatFlow.tsx +1 -1
  510. package/src/react/web/ui/ConnectWallet/screens/Buy/swap/ConfirmationScreen.tsx +1 -1
  511. package/src/react/web/ui/ConnectWallet/screens/LinkedProfilesScreen.tsx +2 -2
  512. package/src/react/web/ui/TransactionButton/TransactionModal.tsx +1 -1
  513. package/src/react/web/ui/components/WalletImage.tsx +2 -2
  514. package/src/react/web/wallets/ecosystem/EcosystemWalletConnectUI.tsx +1 -0
  515. package/src/react/web/wallets/in-app/InAppWalletConnectUI.tsx +1 -0
  516. package/src/react/web/wallets/in-app/WalletAuth.tsx +20 -10
  517. package/src/react/web/wallets/shared/ConnectWalletSocialOptions.tsx +22 -5
  518. package/src/react/web/wallets/shared/locale/de.ts +1 -0
  519. package/src/react/web/wallets/shared/locale/en.ts +1 -0
  520. package/src/react/web/wallets/shared/locale/es.ts +1 -0
  521. package/src/react/web/wallets/shared/locale/fr.ts +1 -0
  522. package/src/react/web/wallets/shared/locale/ja.ts +1 -0
  523. package/src/react/web/wallets/shared/locale/kr.ts +1 -0
  524. package/src/react/web/wallets/shared/locale/tl.ts +1 -0
  525. package/src/react/web/wallets/shared/locale/types.ts +1 -0
  526. package/src/react/web/wallets/shared/locale/vi.ts +1 -0
  527. package/src/version.ts +1 -1
  528. package/src/wallets/__generated__/getWalletInfo.ts +67 -25
  529. package/src/wallets/__generated__/wallet/app.nightly/image.ts +7 -0
  530. package/src/wallets/__generated__/wallet/app.nightly/index.ts +34 -0
  531. package/src/wallets/__generated__/wallet/app.status/image.ts +1 -1
  532. package/src/wallets/__generated__/wallet/app.status/index.ts +1 -1
  533. package/src/wallets/__generated__/wallet/app.walletnow/index.ts +1 -1
  534. package/src/wallets/__generated__/wallet/com.beexo/image.ts +7 -0
  535. package/src/wallets/__generated__/wallet/com.beexo/index.ts +31 -0
  536. package/src/wallets/__generated__/wallet/com.brave.wallet/image.ts +1 -1
  537. package/src/wallets/__generated__/wallet/com.brave.wallet/index.ts +9 -11
  538. package/src/wallets/__generated__/wallet/com.coin98/image.ts +1 -1
  539. package/src/wallets/__generated__/wallet/com.coin98/index.ts +1 -1
  540. package/src/wallets/__generated__/wallet/com.crypto/image.ts +1 -1
  541. package/src/wallets/__generated__/wallet/com.crypto/index.ts +1 -1
  542. package/src/wallets/__generated__/wallet/com.daffione/image.ts +7 -0
  543. package/src/wallets/__generated__/wallet/com.daffione/index.ts +31 -0
  544. package/src/wallets/__generated__/wallet/com.ipmb/image.ts +7 -0
  545. package/src/wallets/__generated__/wallet/com.ipmb/index.ts +32 -0
  546. package/src/wallets/__generated__/wallet/com.webauth/image.ts +7 -0
  547. package/src/wallets/__generated__/wallet/{org.nitrogen → com.webauth}/index.ts +8 -8
  548. package/src/wallets/__generated__/wallet/finance.openwallet/index.ts +2 -2
  549. package/src/wallets/__generated__/wallet/finance.plena/index.ts +1 -1
  550. package/src/wallets/__generated__/wallet/id.plumaa/image.ts +7 -0
  551. package/src/wallets/__generated__/wallet/id.plumaa/index.ts +31 -0
  552. package/src/wallets/__generated__/wallet/io.miraiapp/image.ts +1 -1
  553. package/src/wallets/__generated__/wallet/io.miraiapp/index.ts +1 -1
  554. package/src/wallets/__generated__/wallet/io.owallet/image.ts +7 -0
  555. package/src/wallets/__generated__/wallet/io.owallet/index.ts +32 -0
  556. package/src/wallets/__generated__/wallet/io.tradestrike/image.ts +1 -1
  557. package/src/wallets/__generated__/wallet/io.tradestrike/index.ts +2 -2
  558. package/src/wallets/__generated__/wallet-ids.ts +9 -6
  559. package/src/wallets/__generated__/wallet-infos.ts +45 -15
  560. package/src/wallets/coinbase/coinbase-wallet.ts +1 -1
  561. package/src/wallets/coinbase/coinbaseWebSDK.ts +30 -7
  562. package/src/wallets/create-wallet.ts +6 -5
  563. package/src/wallets/ecosystem/get-ecosystem-wallet-auth-options.ts +6 -0
  564. package/src/wallets/in-app/core/authentication/getLoginPath.ts +4 -4
  565. package/src/wallets/in-app/core/authentication/types.ts +1 -1
  566. package/src/wallets/in-app/core/wallet/enclave-wallet.ts +16 -3
  567. package/src/wallets/in-app/core/wallet/in-app-core.ts +3 -1
  568. package/src/wallets/in-app/web/lib/iframe-wallet.ts +12 -2
  569. package/src/wallets/injected/index.ts +72 -17
  570. package/src/wallets/native/create-wallet.ts +1 -1
  571. package/src/wallets/smart/smart-wallet.ts +1 -1
  572. package/src/wallets/types.ts +1 -0
  573. package/src/wallets/wallet-connect/controller.ts +29 -7
  574. package/dist/cjs/analytics/track.js +0 -51
  575. package/dist/cjs/analytics/track.js.map +0 -1
  576. package/dist/cjs/wallets/__generated__/wallet/org.nitrogen/image.js +0 -7
  577. package/dist/cjs/wallets/__generated__/wallet/org.nitrogen/index.js.map +0 -1
  578. package/dist/esm/analytics/track.js +0 -47
  579. package/dist/esm/analytics/track.js.map +0 -1
  580. package/dist/esm/wallets/__generated__/wallet/org.nitrogen/image.js +0 -5
  581. package/dist/esm/wallets/__generated__/wallet/org.nitrogen/index.js.map +0 -1
  582. package/dist/types/analytics/track.d.ts.map +0 -1
  583. package/dist/types/wallets/__generated__/wallet/org.nitrogen/image.d.ts +0 -3
  584. package/dist/types/wallets/__generated__/wallet/org.nitrogen/image.d.ts.map +0 -1
  585. package/src/analytics/track.ts +0 -67
  586. package/src/extensions/erc1155/drops/write/claimTo.test.ts +0 -185
  587. package/src/extensions/erc1155/drops/write/updateMetadata.test.ts +0 -54
  588. package/src/extensions/erc1155/read/getNFTs.test.ts +0 -44
  589. package/src/extensions/erc1155/read/getOwnedNFTs.test.ts +0 -62
  590. package/src/extensions/erc1155/read/getOwnedTokenIds.test.ts +0 -50
  591. package/src/extensions/erc1155/write/mintAdditionalSupplyTo.test.ts +0 -38
  592. package/src/extensions/erc1155/write/mintTo.test.ts +0 -42
  593. package/src/extensions/erc1155/write/mintToBatch.test.ts +0 -77
  594. package/src/extensions/erc1155/write/updateTokenURI.test.ts +0 -54
  595. 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));
@@ -38,16 +38,10 @@ export function mintAdditionalSupplyTo(
38
38
  return MintTo.mintTo({
39
39
  contract: options.contract,
40
40
  asyncParams: async () => {
41
- // we'll be re-using the exising token URI
42
- const tokenUri = await URI.uri({
43
- contract: options.contract,
44
- tokenId: options.tokenId,
45
- });
46
-
47
41
  return {
48
42
  to: options.to,
49
43
  tokenId: options.tokenId,
50
- uri: tokenUri,
44
+ uri: "", // contract will maintain the existing token URI
51
45
  amount: options.supply,
52
46
  };
53
47
  },
@@ -1,90 +1,21 @@
1
+ import {} from "viem";
1
2
  import { describe, expect, it } from "vitest";
2
- import { ANVIL_CHAIN } from "~test/chains.js";
3
- import { TEST_CONTRACT_URI } from "~test/ipfs-uris.js";
4
- import { TEST_CLIENT } from "~test/test-clients.js";
5
3
  import { TEST_ACCOUNT_C } from "~test/test-wallets.js";
6
- import { getContract } from "../../../contract/contract.js";
7
- import { deployERC1155Contract } from "../../../extensions/prebuilts/deploy-erc1155.js";
8
- import { sendAndConfirmTransaction } from "../../../transaction/actions/send-and-confirm-transaction.js";
9
- import { getNFTs } from "../read/getNFTs.js";
10
- import { mintAdditionalSupplyToBatch } from "./mintAdditionalSupplyToBatch.js";
11
- import { mintToBatch } from "./mintToBatch.js";
4
+ import { optimizeMintBatchContent } from "./mintAdditionalSupplyToBatch.js";
12
5
 
13
- const chain = ANVIL_CHAIN;
14
- const client = TEST_CLIENT;
15
6
  const account = TEST_ACCOUNT_C;
16
7
 
17
- describe.runIf(process.env.TW_SECRET_KEY)(
18
- "ERC1155 Edition: mintToBatch",
19
- () => {
20
- it("should mint multiple tokens in one tx", async () => {
21
- const contract = getContract({
22
- chain,
23
- client,
24
- address: await deployERC1155Contract({
25
- chain,
26
- client,
27
- account,
28
- type: "TokenERC1155",
29
- params: {
30
- name: "edition",
31
- contractURI: TEST_CONTRACT_URI,
32
- },
33
- }),
34
- });
35
-
36
- await sendAndConfirmTransaction({
37
- account,
38
- transaction: mintToBatch({
39
- contract,
40
- to: account.address,
41
- nfts: [
42
- { metadata: { name: "token 0" }, supply: 1n },
43
- { metadata: { name: "token 1" }, supply: 2n },
44
- { metadata: { name: "token 2" }, supply: 3n },
45
- ],
46
- }),
47
- });
48
-
49
- await sendAndConfirmTransaction({
50
- account,
51
- transaction: mintAdditionalSupplyToBatch({
52
- contract,
53
- nfts: [
54
- { tokenId: 0n, supply: 99n, to: account.address },
55
- { tokenId: 1n, supply: 98n, to: account.address },
56
- { tokenId: 2n, supply: 97n, to: account.address },
57
- ],
58
- }),
59
- });
60
-
61
- const nfts = await getNFTs({ contract });
62
- expect(nfts).toStrictEqual([
63
- {
64
- metadata: { name: "token 0" },
65
- owner: null,
66
- id: 0n,
67
- tokenURI: "ipfs://QmPZ6LpGqMuFbHKTXrNW1NRNLHf1nrxS4dtoFqdZZTKvPX/0",
68
- type: "ERC1155",
69
- supply: 100n,
70
- },
71
- {
72
- metadata: { name: "token 1" },
73
- owner: null,
74
- id: 1n,
75
- tokenURI: "ipfs://QmRFPyc3yEYxR4pQxwyTQWTine51TxWCoD6nzJWR3eX45b/0",
76
- type: "ERC1155",
77
- supply: 100n,
78
- },
79
- {
80
- metadata: { name: "token 2" },
81
- owner: null,
82
- id: 2n,
83
- tokenURI: "ipfs://QmesQiRLHCgqWZM2GFCs7Nb7rr2S72hU1BVQc7xiTyKZtT/0",
84
- type: "ERC1155",
85
- supply: 100n,
86
- },
87
- ]);
88
- });
89
- },
90
- );
8
+ describe("ERC1155 Edition: mintToBatch", () => {
9
+ it("should optimize the mint content", () => {
10
+ expect(
11
+ optimizeMintBatchContent([
12
+ { tokenId: 0n, supply: 99n, to: account.address },
13
+ { tokenId: 1n, supply: 49n, to: account.address },
14
+ { tokenId: 1n, supply: 51n, to: account.address },
15
+ ]),
16
+ ).toStrictEqual([
17
+ { tokenId: 0n, supply: 99n, to: account.address },
18
+ { tokenId: 1n, supply: 100n, to: account.address },
19
+ ]);
20
+ });
21
+ });
@@ -1,5 +1,8 @@
1
1
  import { multicall } from "../../../extensions/common/__generated__/IMulticall/write/multicall.js";
2
- import type { BaseTransactionOptions } from "../../../transaction/types.js";
2
+ import type {
3
+ BaseTransactionOptions,
4
+ WithOverrides,
5
+ } from "../../../transaction/types.js";
3
6
  import { uri } from "../__generated__/IERC1155/read/uri.js";
4
7
  import { encodeMintTo } from "../__generated__/IMintableERC1155/write/mintTo.js";
5
8
  import type { MintAdditionalSupplyToParams } from "./mintAdditionalSupplyTo.js";
@@ -7,9 +10,9 @@ import type { MintAdditionalSupplyToParams } from "./mintAdditionalSupplyTo.js";
7
10
  /**
8
11
  * @extension ERC1155
9
12
  */
10
- export type MintAdditionalSupplyToBatchParams = {
13
+ export type MintAdditionalSupplyToBatchParams = WithOverrides<{
11
14
  nfts: MintAdditionalSupplyToParams[];
12
- };
15
+ }>;
13
16
 
14
17
  /**
15
18
  * This extension batches multiple `mintAdditionalSupplyToBatch` extensions into one single multicall.
@@ -38,8 +41,9 @@ export function mintAdditionalSupplyToBatch(
38
41
  return multicall({
39
42
  contract: options.contract,
40
43
  asyncParams: async () => {
44
+ const nfts = optimizeMintBatchContent(options.nfts);
41
45
  const data = await Promise.all(
42
- options.nfts.map(async (nft) => {
46
+ nfts.map(async (nft) => {
43
47
  const tokenUri = await uri({
44
48
  contract: options.contract,
45
49
  tokenId: nft.tokenId,
@@ -54,5 +58,48 @@ export function mintAdditionalSupplyToBatch(
54
58
  );
55
59
  return { data };
56
60
  },
61
+ overrides: options.overrides,
57
62
  });
58
63
  }
64
+
65
+ /**
66
+ * Optimization
67
+ *
68
+ * We can batch the records that share the same "to" & "tokenId" into 1 transaction
69
+ *
70
+ * For example, this struct:
71
+ * [
72
+ * { tokenId: 0n, supply: 99n, to: account.address },
73
+ * { tokenId: 1n, supply: 49n, to: account.address },
74
+ * { tokenId: 1n, supply: 51n, to: account.address },
75
+ * ]
76
+ *
77
+ * ...can be packed into:
78
+ * [
79
+ * { tokenId: 0n, supply: 99n, to: account.address },
80
+ * { tokenId: 1n, supply: 100n, to: account.address },
81
+ * ]
82
+ * @internal
83
+ */
84
+ export function optimizeMintBatchContent(
85
+ nfts: MintAdditionalSupplyToParams[],
86
+ ): MintAdditionalSupplyToParams[] {
87
+ const results: MintAdditionalSupplyToParams[] = [];
88
+ for (const item of nfts) {
89
+ const matchingIndex = results.findIndex(
90
+ (o) =>
91
+ o.tokenId === item.tokenId &&
92
+ o.to.toLowerCase() === item.to.toLowerCase(),
93
+ );
94
+ if (matchingIndex !== -1) {
95
+ results[matchingIndex] = {
96
+ to: item.to,
97
+ tokenId: item.tokenId,
98
+ supply: item.supply + (results[matchingIndex]?.supply || 0n),
99
+ };
100
+ } else {
101
+ results.push(item);
102
+ }
103
+ }
104
+ return results;
105
+ }
@@ -0,0 +1,15 @@
1
+ import { type Abi, toFunctionSelector } from "viem";
2
+ import { describe, expect, it } from "vitest";
3
+ import { NFT_DROP_CONTRACT } from "~test/test-contracts.js";
4
+ import { resolveContractAbi } from "../../../../contract/actions/resolve-abi.js";
5
+ import { isClaimToSupported } from "./claimTo.js";
6
+
7
+ describe.runIf(process.env.TW_SECRET_KEY)("ERC721: claimTo", () => {
8
+ it("isClaimToSupported should work", async () => {
9
+ const abi = await resolveContractAbi<Abi>(NFT_DROP_CONTRACT);
10
+ const selectors = abi
11
+ .filter((f) => f.type === "function")
12
+ .map((f) => toFunctionSelector(f));
13
+ expect(isClaimToSupported(selectors)).toBe(true);
14
+ });
15
+ });
@@ -0,0 +1,154 @@
1
+ import { describe, expect, it } from "vitest";
2
+ import { ANVIL_CHAIN } from "~test/chains.js";
3
+ import { TEST_CONTRACT_URI } from "~test/ipfs-uris.js";
4
+ import { TEST_CLIENT } from "~test/test-clients.js";
5
+ import {
6
+ TEST_ACCOUNT_A,
7
+ TEST_ACCOUNT_B,
8
+ TEST_ACCOUNT_C,
9
+ TEST_ACCOUNT_D,
10
+ } from "~test/test-wallets.js";
11
+ import { getContract } from "../../../../contract/contract.js";
12
+ import { deployERC721Contract } from "../../../../extensions/prebuilts/deploy-erc721.js";
13
+ import { sendAndConfirmTransaction } from "../../../../transaction/actions/send-and-confirm-transaction.js";
14
+ import { getNFTs } from "../../read/getNFTs.js";
15
+ import { lazyMint } from "../../write/lazyMint.js";
16
+ import { claimToBatch, optimizeClaimContent } from "./claimToBatch.js";
17
+ import { setClaimConditions } from "./setClaimConditions.js";
18
+
19
+ const chain = ANVIL_CHAIN;
20
+ const client = TEST_CLIENT;
21
+ const account = TEST_ACCOUNT_A;
22
+
23
+ describe.runIf(process.env.TW_SECRET_KEY)("erc721: claimToBatch", () => {
24
+ it("should optimize the claim content", () => {
25
+ expect(
26
+ optimizeClaimContent([
27
+ {
28
+ to: account.address,
29
+ quantity: 1n,
30
+ },
31
+ {
32
+ to: TEST_ACCOUNT_B.address,
33
+ quantity: 2n,
34
+ },
35
+ {
36
+ to: TEST_ACCOUNT_B.address,
37
+ quantity: 3n,
38
+ },
39
+ { to: TEST_ACCOUNT_C.address, quantity: 2n },
40
+ { to: TEST_ACCOUNT_D.address, quantity: 2n },
41
+ { to: account.address, quantity: 1n },
42
+ ]),
43
+ ).toStrictEqual([
44
+ { to: account.address, quantity: 1n },
45
+ { to: TEST_ACCOUNT_B.address, quantity: 5n },
46
+ { to: TEST_ACCOUNT_C.address, quantity: 2n },
47
+ { to: TEST_ACCOUNT_D.address, quantity: 2n },
48
+ { to: account.address, quantity: 1n },
49
+ ]);
50
+ });
51
+
52
+ it("should claim in batch", async () => {
53
+ const address = await deployERC721Contract({
54
+ account,
55
+ chain,
56
+ client,
57
+ params: {
58
+ name: "Test DropERC721",
59
+ contractURI: TEST_CONTRACT_URI,
60
+ },
61
+ type: "DropERC721",
62
+ });
63
+
64
+ const contract = getContract({
65
+ address,
66
+ chain,
67
+ client,
68
+ });
69
+
70
+ await sendAndConfirmTransaction({
71
+ transaction: lazyMint({
72
+ contract,
73
+ nfts: [
74
+ { name: "Test NFT 0" },
75
+ { name: "Test NFT 1" },
76
+ { name: "Test NFT 2" },
77
+ { name: "Test NFT 3" },
78
+ { name: "Test NFT 4" },
79
+ { name: "Test NFT 5" },
80
+ { name: "Test NFT 6" },
81
+ { name: "Test NFT 7" },
82
+ { name: "Test NFT 8" },
83
+ { name: "Test NFT 9" },
84
+ { name: "Test NFT 10" },
85
+ ],
86
+ }),
87
+ account,
88
+ });
89
+
90
+ await sendAndConfirmTransaction({
91
+ transaction: setClaimConditions({
92
+ contract,
93
+ phases: [{}],
94
+ }),
95
+ account: TEST_ACCOUNT_A,
96
+ });
97
+
98
+ const transaction = claimToBatch({
99
+ contract,
100
+ from: account.address,
101
+ content: [
102
+ {
103
+ to: account.address,
104
+ quantity: 1n,
105
+ },
106
+ {
107
+ to: TEST_ACCOUNT_B.address,
108
+ quantity: 2n,
109
+ },
110
+ {
111
+ to: TEST_ACCOUNT_B.address,
112
+ quantity: 3n,
113
+ },
114
+ { to: TEST_ACCOUNT_C.address, quantity: 2n },
115
+ { to: TEST_ACCOUNT_D.address, quantity: 2n },
116
+ { to: account.address, quantity: 1n },
117
+ ],
118
+ });
119
+
120
+ await sendAndConfirmTransaction({ account, transaction });
121
+
122
+ const nfts = await getNFTs({ contract, includeOwners: true });
123
+ expect(nfts.length).toBe(11);
124
+ expect(nfts[0]?.owner?.toLowerCase()).toBe(account.address.toLowerCase());
125
+ expect(nfts[1]?.owner?.toLowerCase()).toBe(
126
+ TEST_ACCOUNT_B.address.toLowerCase(),
127
+ );
128
+ expect(nfts[2]?.owner?.toLowerCase()).toBe(
129
+ TEST_ACCOUNT_B.address.toLowerCase(),
130
+ );
131
+ expect(nfts[3]?.owner?.toLowerCase()).toBe(
132
+ TEST_ACCOUNT_B.address.toLowerCase(),
133
+ );
134
+ expect(nfts[4]?.owner?.toLowerCase()).toBe(
135
+ TEST_ACCOUNT_B.address.toLowerCase(),
136
+ );
137
+ expect(nfts[5]?.owner?.toLowerCase()).toBe(
138
+ TEST_ACCOUNT_B.address.toLowerCase(),
139
+ );
140
+ expect(nfts[6]?.owner?.toLowerCase()).toBe(
141
+ TEST_ACCOUNT_C.address.toLowerCase(),
142
+ );
143
+ expect(nfts[7]?.owner?.toLowerCase()).toBe(
144
+ TEST_ACCOUNT_C.address.toLowerCase(),
145
+ );
146
+ expect(nfts[8]?.owner?.toLowerCase()).toBe(
147
+ TEST_ACCOUNT_D.address.toLowerCase(),
148
+ );
149
+ expect(nfts[9]?.owner?.toLowerCase()).toBe(
150
+ TEST_ACCOUNT_D.address.toLowerCase(),
151
+ );
152
+ expect(nfts[10]?.owner?.toLowerCase()).toBe(account.address.toLowerCase());
153
+ });
154
+ });