thirdweb 5.64.0-nightly-cdb907f175f7472d1fb3dea6547d946514564085-20241023000322 → 5.64.0-nightly-e6e994479fb8386b1740de4170f33446f038f2b1-20241024000332

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (430) 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/mintAdditionalSupplyToBatch.js +41 -1
  18. package/dist/cjs/extensions/erc1155/write/mintAdditionalSupplyToBatch.js.map +1 -1
  19. package/dist/cjs/extensions/erc721/drops/write/claimToBatch.js +115 -0
  20. package/dist/cjs/extensions/erc721/drops/write/claimToBatch.js.map +1 -0
  21. package/dist/cjs/react/core/utils/walletIcon.js +2 -2
  22. package/dist/cjs/react/core/utils/walletIcon.js.map +1 -1
  23. package/dist/cjs/react/web/hooks/transaction/useSendTransaction.js +3 -4
  24. package/dist/cjs/react/web/hooks/transaction/useSendTransaction.js.map +1 -1
  25. package/dist/cjs/react/web/ui/ConnectWallet/Details.js +2 -2
  26. package/dist/cjs/react/web/ui/ConnectWallet/Details.js.map +1 -1
  27. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/BuyScreen.js +3 -3
  28. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/BuyScreen.js.map +1 -1
  29. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/DirectPaymentModeScreen.js +2 -2
  30. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/DirectPaymentModeScreen.js.map +1 -1
  31. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/TransactionModeScreen.js +2 -2
  32. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/TransactionModeScreen.js.map +1 -1
  33. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/fiat/FiatFlow.js +2 -2
  34. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/fiat/FiatFlow.js.map +1 -1
  35. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/swap/ConfirmationScreen.js +5 -5
  36. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/swap/ConfirmationScreen.js.map +1 -1
  37. package/dist/cjs/react/web/ui/ConnectWallet/screens/LinkedProfilesScreen.js +1 -1
  38. package/dist/cjs/react/web/ui/TransactionButton/TransactionModal.js +2 -2
  39. package/dist/cjs/react/web/ui/TransactionButton/TransactionModal.js.map +1 -1
  40. package/dist/cjs/react/web/ui/components/WalletImage.js +1 -1
  41. package/dist/cjs/react/web/wallets/shared/ConnectWalletSocialOptions.js +2 -2
  42. package/dist/cjs/version.js +1 -1
  43. package/dist/cjs/wallets/__generated__/getWalletInfo.js +45 -15
  44. package/dist/cjs/wallets/__generated__/getWalletInfo.js.map +1 -1
  45. package/dist/cjs/wallets/__generated__/wallet/app.nightly/image.js +7 -0
  46. package/dist/cjs/wallets/__generated__/wallet/app.nightly/image.js.map +1 -0
  47. package/dist/cjs/wallets/__generated__/wallet/app.nightly/index.js +34 -0
  48. package/dist/cjs/wallets/__generated__/wallet/app.nightly/index.js.map +1 -0
  49. package/dist/cjs/wallets/__generated__/wallet/app.status/image.js +1 -1
  50. package/dist/cjs/wallets/__generated__/wallet/app.status/image.js.map +1 -1
  51. package/dist/cjs/wallets/__generated__/wallet/app.status/index.js +1 -1
  52. package/dist/cjs/wallets/__generated__/wallet/app.walletnow/index.js +1 -1
  53. package/dist/cjs/wallets/__generated__/wallet/app.walletnow/index.js.map +1 -1
  54. package/dist/cjs/wallets/__generated__/wallet/com.beexo/image.js +7 -0
  55. package/dist/cjs/wallets/__generated__/wallet/com.beexo/image.js.map +1 -0
  56. package/dist/cjs/wallets/__generated__/wallet/{org.nitrogen → com.beexo}/index.js +9 -9
  57. package/dist/cjs/wallets/__generated__/wallet/com.beexo/index.js.map +1 -0
  58. package/dist/cjs/wallets/__generated__/wallet/com.brave.wallet/image.js +1 -1
  59. package/dist/cjs/wallets/__generated__/wallet/com.brave.wallet/image.js.map +1 -1
  60. package/dist/cjs/wallets/__generated__/wallet/com.brave.wallet/index.js +9 -9
  61. package/dist/cjs/wallets/__generated__/wallet/com.brave.wallet/index.js.map +1 -1
  62. package/dist/cjs/wallets/__generated__/wallet/com.coin98/image.js +1 -1
  63. package/dist/cjs/wallets/__generated__/wallet/com.coin98/image.js.map +1 -1
  64. package/dist/cjs/wallets/__generated__/wallet/com.coin98/index.js +1 -1
  65. package/dist/cjs/wallets/__generated__/wallet/com.crypto/image.js +1 -1
  66. package/dist/cjs/wallets/__generated__/wallet/com.crypto/image.js.map +1 -1
  67. package/dist/cjs/wallets/__generated__/wallet/com.crypto/index.js +1 -1
  68. package/dist/cjs/wallets/__generated__/wallet/com.daffione/image.js +7 -0
  69. package/dist/cjs/wallets/__generated__/wallet/{org.nitrogen → com.daffione}/image.js.map +1 -1
  70. package/dist/cjs/wallets/__generated__/wallet/com.daffione/index.js +34 -0
  71. package/dist/cjs/wallets/__generated__/wallet/com.daffione/index.js.map +1 -0
  72. package/dist/cjs/wallets/__generated__/wallet/com.ipmb/image.js +7 -0
  73. package/dist/cjs/wallets/__generated__/wallet/com.ipmb/image.js.map +1 -0
  74. package/dist/cjs/wallets/__generated__/wallet/com.ipmb/index.js +34 -0
  75. package/dist/cjs/wallets/__generated__/wallet/com.ipmb/index.js.map +1 -0
  76. package/dist/cjs/wallets/__generated__/wallet/com.webauth/image.js +7 -0
  77. package/dist/cjs/wallets/__generated__/wallet/com.webauth/image.js.map +1 -0
  78. package/dist/cjs/wallets/__generated__/wallet/com.webauth/index.js +34 -0
  79. package/dist/cjs/wallets/__generated__/wallet/com.webauth/index.js.map +1 -0
  80. package/dist/cjs/wallets/__generated__/wallet/finance.openwallet/index.js +2 -2
  81. package/dist/cjs/wallets/__generated__/wallet/finance.openwallet/index.js.map +1 -1
  82. package/dist/cjs/wallets/__generated__/wallet/finance.plena/index.js +1 -1
  83. package/dist/cjs/wallets/__generated__/wallet/finance.plena/index.js.map +1 -1
  84. package/dist/cjs/wallets/__generated__/wallet/id.plumaa/image.js +7 -0
  85. package/dist/cjs/wallets/__generated__/wallet/id.plumaa/image.js.map +1 -0
  86. package/dist/cjs/wallets/__generated__/wallet/id.plumaa/index.js +34 -0
  87. package/dist/cjs/wallets/__generated__/wallet/id.plumaa/index.js.map +1 -0
  88. package/dist/cjs/wallets/__generated__/wallet/io.miraiapp/image.js +1 -1
  89. package/dist/cjs/wallets/__generated__/wallet/io.miraiapp/image.js.map +1 -1
  90. package/dist/cjs/wallets/__generated__/wallet/io.miraiapp/index.js +1 -1
  91. package/dist/cjs/wallets/__generated__/wallet/io.owallet/image.js +7 -0
  92. package/dist/cjs/wallets/__generated__/wallet/io.owallet/image.js.map +1 -0
  93. package/dist/cjs/wallets/__generated__/wallet/io.owallet/index.js +34 -0
  94. package/dist/cjs/wallets/__generated__/wallet/io.owallet/index.js.map +1 -0
  95. package/dist/cjs/wallets/__generated__/wallet/io.tradestrike/image.js +1 -1
  96. package/dist/cjs/wallets/__generated__/wallet/io.tradestrike/image.js.map +1 -1
  97. package/dist/cjs/wallets/__generated__/wallet/io.tradestrike/index.js +2 -2
  98. package/dist/cjs/wallets/__generated__/wallet/io.tradestrike/index.js.map +1 -1
  99. package/dist/cjs/wallets/__generated__/wallet-infos.js +45 -15
  100. package/dist/cjs/wallets/__generated__/wallet-infos.js.map +1 -1
  101. package/dist/cjs/wallets/coinbase/coinbase-wallet.js +3 -3
  102. package/dist/cjs/wallets/coinbase/coinbase-wallet.js.map +1 -1
  103. package/dist/cjs/wallets/coinbase/coinbaseWebSDK.js +20 -8
  104. package/dist/cjs/wallets/coinbase/coinbaseWebSDK.js.map +1 -1
  105. package/dist/cjs/wallets/create-wallet.js +11 -6
  106. package/dist/cjs/wallets/create-wallet.js.map +1 -1
  107. package/dist/cjs/wallets/in-app/core/wallet/enclave-wallet.js +13 -3
  108. package/dist/cjs/wallets/in-app/core/wallet/enclave-wallet.js.map +1 -1
  109. package/dist/cjs/wallets/in-app/core/wallet/in-app-core.js +5 -3
  110. package/dist/cjs/wallets/in-app/core/wallet/in-app-core.js.map +1 -1
  111. package/dist/cjs/wallets/in-app/web/lib/iframe-wallet.js +9 -2
  112. package/dist/cjs/wallets/in-app/web/lib/iframe-wallet.js.map +1 -1
  113. package/dist/cjs/wallets/injected/index.js +36 -8
  114. package/dist/cjs/wallets/injected/index.js.map +1 -1
  115. package/dist/cjs/wallets/native/create-wallet.js +3 -3
  116. package/dist/cjs/wallets/native/create-wallet.js.map +1 -1
  117. package/dist/cjs/wallets/smart/smart-wallet.js +3 -3
  118. package/dist/cjs/wallets/smart/smart-wallet.js.map +1 -1
  119. package/dist/cjs/wallets/wallet-connect/controller.js +20 -8
  120. package/dist/cjs/wallets/wallet-connect/controller.js.map +1 -1
  121. package/dist/esm/analytics/track/connect.js +18 -0
  122. package/dist/esm/analytics/track/connect.js.map +1 -0
  123. package/dist/esm/analytics/track/index.js +18 -0
  124. package/dist/esm/analytics/track/index.js.map +1 -0
  125. package/dist/esm/analytics/track/pay.js +23 -0
  126. package/dist/esm/analytics/track/pay.js.map +1 -0
  127. package/dist/esm/analytics/track/siwe.js +29 -0
  128. package/dist/esm/analytics/track/siwe.js.map +1 -0
  129. package/dist/esm/analytics/track/transaction.js +33 -0
  130. package/dist/esm/analytics/track/transaction.js.map +1 -0
  131. package/dist/esm/auth/core/verify-login-payload.js +19 -1
  132. package/dist/esm/auth/core/verify-login-payload.js.map +1 -1
  133. package/dist/esm/exports/extensions/erc721.js +1 -0
  134. package/dist/esm/exports/extensions/erc721.js.map +1 -1
  135. package/dist/esm/exports/wallets/in-app.js +1 -1
  136. package/dist/esm/exports/wallets/in-app.js.map +1 -1
  137. package/dist/esm/extensions/erc1155/write/mintAdditionalSupplyToBatch.js +40 -1
  138. package/dist/esm/extensions/erc1155/write/mintAdditionalSupplyToBatch.js.map +1 -1
  139. package/dist/esm/extensions/erc721/drops/write/claimToBatch.js +111 -0
  140. package/dist/esm/extensions/erc721/drops/write/claimToBatch.js.map +1 -0
  141. package/dist/esm/react/core/utils/walletIcon.js +1 -1
  142. package/dist/esm/react/core/utils/walletIcon.js.map +1 -1
  143. package/dist/esm/react/web/hooks/transaction/useSendTransaction.js +3 -4
  144. package/dist/esm/react/web/hooks/transaction/useSendTransaction.js.map +1 -1
  145. package/dist/esm/react/web/ui/ConnectWallet/Details.js +1 -1
  146. package/dist/esm/react/web/ui/ConnectWallet/Details.js.map +1 -1
  147. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/BuyScreen.js +1 -1
  148. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/BuyScreen.js.map +1 -1
  149. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/DirectPaymentModeScreen.js +1 -1
  150. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/DirectPaymentModeScreen.js.map +1 -1
  151. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/TransactionModeScreen.js +1 -1
  152. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/TransactionModeScreen.js.map +1 -1
  153. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/fiat/FiatFlow.js +1 -1
  154. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/fiat/FiatFlow.js.map +1 -1
  155. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/swap/ConfirmationScreen.js +1 -1
  156. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/swap/ConfirmationScreen.js.map +1 -1
  157. package/dist/esm/react/web/ui/ConnectWallet/screens/LinkedProfilesScreen.js +2 -2
  158. package/dist/esm/react/web/ui/TransactionButton/TransactionModal.js +1 -1
  159. package/dist/esm/react/web/ui/TransactionButton/TransactionModal.js.map +1 -1
  160. package/dist/esm/react/web/ui/components/WalletImage.js +2 -2
  161. package/dist/esm/react/web/wallets/shared/ConnectWalletSocialOptions.js +3 -3
  162. package/dist/esm/version.js +1 -1
  163. package/dist/esm/wallets/__generated__/getWalletInfo.js +45 -15
  164. package/dist/esm/wallets/__generated__/getWalletInfo.js.map +1 -1
  165. package/dist/esm/wallets/__generated__/wallet/app.nightly/image.js +5 -0
  166. package/dist/esm/wallets/__generated__/wallet/app.nightly/image.js.map +1 -0
  167. package/dist/esm/wallets/__generated__/wallet/app.nightly/index.js +31 -0
  168. package/dist/esm/wallets/__generated__/wallet/app.nightly/index.js.map +1 -0
  169. package/dist/esm/wallets/__generated__/wallet/app.status/image.js +1 -1
  170. package/dist/esm/wallets/__generated__/wallet/app.status/image.js.map +1 -1
  171. package/dist/esm/wallets/__generated__/wallet/app.status/index.js +1 -1
  172. package/dist/esm/wallets/__generated__/wallet/app.walletnow/index.js +1 -1
  173. package/dist/esm/wallets/__generated__/wallet/app.walletnow/index.js.map +1 -1
  174. package/dist/esm/wallets/__generated__/wallet/com.beexo/image.js +5 -0
  175. package/dist/esm/wallets/__generated__/wallet/com.beexo/image.js.map +1 -0
  176. package/dist/esm/wallets/__generated__/wallet/{org.nitrogen → com.beexo}/index.js +9 -9
  177. package/dist/esm/wallets/__generated__/wallet/com.beexo/index.js.map +1 -0
  178. package/dist/esm/wallets/__generated__/wallet/com.brave.wallet/image.js +1 -1
  179. package/dist/esm/wallets/__generated__/wallet/com.brave.wallet/image.js.map +1 -1
  180. package/dist/esm/wallets/__generated__/wallet/com.brave.wallet/index.js +9 -9
  181. package/dist/esm/wallets/__generated__/wallet/com.brave.wallet/index.js.map +1 -1
  182. package/dist/esm/wallets/__generated__/wallet/com.coin98/image.js +1 -1
  183. package/dist/esm/wallets/__generated__/wallet/com.coin98/image.js.map +1 -1
  184. package/dist/esm/wallets/__generated__/wallet/com.coin98/index.js +1 -1
  185. package/dist/esm/wallets/__generated__/wallet/com.crypto/image.js +1 -1
  186. package/dist/esm/wallets/__generated__/wallet/com.crypto/image.js.map +1 -1
  187. package/dist/esm/wallets/__generated__/wallet/com.crypto/index.js +1 -1
  188. package/dist/esm/wallets/__generated__/wallet/com.daffione/image.js +5 -0
  189. package/dist/esm/wallets/__generated__/wallet/{org.nitrogen → com.daffione}/image.js.map +1 -1
  190. package/dist/esm/wallets/__generated__/wallet/com.daffione/index.js +31 -0
  191. package/dist/esm/wallets/__generated__/wallet/com.daffione/index.js.map +1 -0
  192. package/dist/esm/wallets/__generated__/wallet/com.ipmb/image.js +5 -0
  193. package/dist/esm/wallets/__generated__/wallet/com.ipmb/image.js.map +1 -0
  194. package/dist/esm/wallets/__generated__/wallet/com.ipmb/index.js +31 -0
  195. package/dist/esm/wallets/__generated__/wallet/com.ipmb/index.js.map +1 -0
  196. package/dist/esm/wallets/__generated__/wallet/com.webauth/image.js +5 -0
  197. package/dist/esm/wallets/__generated__/wallet/com.webauth/image.js.map +1 -0
  198. package/dist/esm/wallets/__generated__/wallet/com.webauth/index.js +31 -0
  199. package/dist/esm/wallets/__generated__/wallet/com.webauth/index.js.map +1 -0
  200. package/dist/esm/wallets/__generated__/wallet/finance.openwallet/index.js +2 -2
  201. package/dist/esm/wallets/__generated__/wallet/finance.openwallet/index.js.map +1 -1
  202. package/dist/esm/wallets/__generated__/wallet/finance.plena/index.js +1 -1
  203. package/dist/esm/wallets/__generated__/wallet/finance.plena/index.js.map +1 -1
  204. package/dist/esm/wallets/__generated__/wallet/id.plumaa/image.js +5 -0
  205. package/dist/esm/wallets/__generated__/wallet/id.plumaa/image.js.map +1 -0
  206. package/dist/esm/wallets/__generated__/wallet/id.plumaa/index.js +31 -0
  207. package/dist/esm/wallets/__generated__/wallet/id.plumaa/index.js.map +1 -0
  208. package/dist/esm/wallets/__generated__/wallet/io.miraiapp/image.js +1 -1
  209. package/dist/esm/wallets/__generated__/wallet/io.miraiapp/image.js.map +1 -1
  210. package/dist/esm/wallets/__generated__/wallet/io.miraiapp/index.js +1 -1
  211. package/dist/esm/wallets/__generated__/wallet/io.owallet/image.js +5 -0
  212. package/dist/esm/wallets/__generated__/wallet/io.owallet/image.js.map +1 -0
  213. package/dist/esm/wallets/__generated__/wallet/io.owallet/index.js +31 -0
  214. package/dist/esm/wallets/__generated__/wallet/io.owallet/index.js.map +1 -0
  215. package/dist/esm/wallets/__generated__/wallet/io.tradestrike/image.js +1 -1
  216. package/dist/esm/wallets/__generated__/wallet/io.tradestrike/image.js.map +1 -1
  217. package/dist/esm/wallets/__generated__/wallet/io.tradestrike/index.js +2 -2
  218. package/dist/esm/wallets/__generated__/wallet/io.tradestrike/index.js.map +1 -1
  219. package/dist/esm/wallets/__generated__/wallet-infos.js +45 -15
  220. package/dist/esm/wallets/__generated__/wallet-infos.js.map +1 -1
  221. package/dist/esm/wallets/coinbase/coinbase-wallet.js +1 -1
  222. package/dist/esm/wallets/coinbase/coinbase-wallet.js.map +1 -1
  223. package/dist/esm/wallets/coinbase/coinbaseWebSDK.js +20 -8
  224. package/dist/esm/wallets/coinbase/coinbaseWebSDK.js.map +1 -1
  225. package/dist/esm/wallets/create-wallet.js +7 -2
  226. package/dist/esm/wallets/create-wallet.js.map +1 -1
  227. package/dist/esm/wallets/in-app/core/wallet/enclave-wallet.js +13 -3
  228. package/dist/esm/wallets/in-app/core/wallet/enclave-wallet.js.map +1 -1
  229. package/dist/esm/wallets/in-app/core/wallet/in-app-core.js +3 -1
  230. package/dist/esm/wallets/in-app/core/wallet/in-app-core.js.map +1 -1
  231. package/dist/esm/wallets/in-app/web/lib/iframe-wallet.js +9 -2
  232. package/dist/esm/wallets/in-app/web/lib/iframe-wallet.js.map +1 -1
  233. package/dist/esm/wallets/injected/index.js +36 -8
  234. package/dist/esm/wallets/injected/index.js.map +1 -1
  235. package/dist/esm/wallets/native/create-wallet.js +1 -1
  236. package/dist/esm/wallets/native/create-wallet.js.map +1 -1
  237. package/dist/esm/wallets/smart/smart-wallet.js +1 -1
  238. package/dist/esm/wallets/smart/smart-wallet.js.map +1 -1
  239. package/dist/esm/wallets/wallet-connect/controller.js +20 -8
  240. package/dist/esm/wallets/wallet-connect/controller.js.map +1 -1
  241. package/dist/types/analytics/track/connect.d.ts +12 -0
  242. package/dist/types/analytics/track/connect.d.ts.map +1 -0
  243. package/dist/types/analytics/track/index.d.ts +11 -0
  244. package/dist/types/analytics/track/index.d.ts.map +1 -0
  245. package/dist/types/analytics/{track.d.ts → track/pay.d.ts} +5 -11
  246. package/dist/types/analytics/track/pay.d.ts.map +1 -0
  247. package/dist/types/analytics/track/siwe.d.ts +19 -0
  248. package/dist/types/analytics/track/siwe.d.ts.map +1 -0
  249. package/dist/types/analytics/track/transaction.d.ts +24 -0
  250. package/dist/types/analytics/track/transaction.d.ts.map +1 -0
  251. package/dist/types/auth/core/verify-login-payload.d.ts.map +1 -1
  252. package/dist/types/exports/extensions/erc721.d.ts +1 -0
  253. package/dist/types/exports/extensions/erc721.d.ts.map +1 -1
  254. package/dist/types/exports/wallets/in-app.d.ts +1 -1
  255. package/dist/types/exports/wallets/in-app.d.ts.map +1 -1
  256. package/dist/types/extensions/erc1155/write/mintAdditionalSupplyToBatch.d.ts +23 -3
  257. package/dist/types/extensions/erc1155/write/mintAdditionalSupplyToBatch.d.ts.map +1 -1
  258. package/dist/types/extensions/erc721/drops/write/claimToBatch.d.ts +71 -0
  259. package/dist/types/extensions/erc721/drops/write/claimToBatch.d.ts.map +1 -0
  260. package/dist/types/react/core/utils/walletIcon.d.ts +2 -1
  261. package/dist/types/react/core/utils/walletIcon.d.ts.map +1 -1
  262. package/dist/types/react/web/hooks/transaction/useSendTransaction.d.ts +3 -4
  263. package/dist/types/react/web/hooks/transaction/useSendTransaction.d.ts.map +1 -1
  264. package/dist/types/react/web/ui/ConnectWallet/Details.d.ts.map +1 -1
  265. package/dist/types/react/web/ui/ConnectWallet/screens/Buy/swap/ConfirmationScreen.d.ts.map +1 -1
  266. package/dist/types/version.d.ts +1 -1
  267. package/dist/types/wallets/__generated__/getWalletInfo.d.ts.map +1 -1
  268. package/dist/types/wallets/__generated__/wallet/app.nightly/image.d.ts +3 -0
  269. package/dist/types/wallets/__generated__/wallet/app.nightly/image.d.ts.map +1 -0
  270. package/dist/types/wallets/__generated__/wallet/app.nightly/index.d.ts +29 -0
  271. package/dist/types/wallets/__generated__/wallet/app.nightly/index.d.ts.map +1 -0
  272. package/dist/types/wallets/__generated__/wallet/app.status/image.d.ts +1 -1
  273. package/dist/types/wallets/__generated__/wallet/app.status/image.d.ts.map +1 -1
  274. package/dist/types/wallets/__generated__/wallet/app.status/index.d.ts +1 -1
  275. package/dist/types/wallets/__generated__/wallet/app.walletnow/index.d.ts +1 -1
  276. package/dist/types/wallets/__generated__/wallet/com.beexo/image.d.ts +3 -0
  277. package/dist/types/wallets/__generated__/wallet/com.beexo/image.d.ts.map +1 -0
  278. package/dist/types/wallets/__generated__/wallet/{org.nitrogen → com.beexo}/index.d.ts +9 -9
  279. package/dist/types/wallets/__generated__/wallet/com.beexo/index.d.ts.map +1 -0
  280. package/dist/types/wallets/__generated__/wallet/com.brave.wallet/image.d.ts +1 -1
  281. package/dist/types/wallets/__generated__/wallet/com.brave.wallet/image.d.ts.map +1 -1
  282. package/dist/types/wallets/__generated__/wallet/com.brave.wallet/index.d.ts +9 -9
  283. package/dist/types/wallets/__generated__/wallet/com.brave.wallet/index.d.ts.map +1 -1
  284. package/dist/types/wallets/__generated__/wallet/com.coin98/image.d.ts +1 -1
  285. package/dist/types/wallets/__generated__/wallet/com.coin98/image.d.ts.map +1 -1
  286. package/dist/types/wallets/__generated__/wallet/com.coin98/index.d.ts +1 -1
  287. package/dist/types/wallets/__generated__/wallet/com.crypto/image.d.ts +1 -1
  288. package/dist/types/wallets/__generated__/wallet/com.crypto/image.d.ts.map +1 -1
  289. package/dist/types/wallets/__generated__/wallet/com.crypto/index.d.ts +1 -1
  290. package/dist/types/wallets/__generated__/wallet/com.daffione/image.d.ts +3 -0
  291. package/dist/types/wallets/__generated__/wallet/com.daffione/image.d.ts.map +1 -0
  292. package/dist/types/wallets/__generated__/wallet/com.daffione/index.d.ts +29 -0
  293. package/dist/types/wallets/__generated__/wallet/{org.nitrogen → com.daffione}/index.d.ts.map +1 -1
  294. package/dist/types/wallets/__generated__/wallet/com.ipmb/image.d.ts +3 -0
  295. package/dist/types/wallets/__generated__/wallet/com.ipmb/image.d.ts.map +1 -0
  296. package/dist/types/wallets/__generated__/wallet/com.ipmb/index.d.ts +29 -0
  297. package/dist/types/wallets/__generated__/wallet/com.ipmb/index.d.ts.map +1 -0
  298. package/dist/types/wallets/__generated__/wallet/com.webauth/image.d.ts +3 -0
  299. package/dist/types/wallets/__generated__/wallet/com.webauth/image.d.ts.map +1 -0
  300. package/dist/types/wallets/__generated__/wallet/com.webauth/index.d.ts +29 -0
  301. package/dist/types/wallets/__generated__/wallet/com.webauth/index.d.ts.map +1 -0
  302. package/dist/types/wallets/__generated__/wallet/finance.openwallet/index.d.ts +2 -2
  303. package/dist/types/wallets/__generated__/wallet/finance.plena/index.d.ts +1 -1
  304. package/dist/types/wallets/__generated__/wallet/id.plumaa/image.d.ts +3 -0
  305. package/dist/types/wallets/__generated__/wallet/id.plumaa/image.d.ts.map +1 -0
  306. package/dist/types/wallets/__generated__/wallet/id.plumaa/index.d.ts +29 -0
  307. package/dist/types/wallets/__generated__/wallet/id.plumaa/index.d.ts.map +1 -0
  308. package/dist/types/wallets/__generated__/wallet/io.miraiapp/image.d.ts +1 -1
  309. package/dist/types/wallets/__generated__/wallet/io.miraiapp/image.d.ts.map +1 -1
  310. package/dist/types/wallets/__generated__/wallet/io.miraiapp/index.d.ts +1 -1
  311. package/dist/types/wallets/__generated__/wallet/io.owallet/image.d.ts +3 -0
  312. package/dist/types/wallets/__generated__/wallet/io.owallet/image.d.ts.map +1 -0
  313. package/dist/types/wallets/__generated__/wallet/io.owallet/index.d.ts +29 -0
  314. package/dist/types/wallets/__generated__/wallet/io.owallet/index.d.ts.map +1 -0
  315. package/dist/types/wallets/__generated__/wallet/io.tradestrike/image.d.ts +1 -1
  316. package/dist/types/wallets/__generated__/wallet/io.tradestrike/image.d.ts.map +1 -1
  317. package/dist/types/wallets/__generated__/wallet/io.tradestrike/index.d.ts +2 -2
  318. package/dist/types/wallets/__generated__/wallet-ids.d.ts +2 -2
  319. package/dist/types/wallets/__generated__/wallet-ids.d.ts.map +1 -1
  320. package/dist/types/wallets/__generated__/wallet-infos.d.ts +36 -12
  321. package/dist/types/wallets/__generated__/wallet-infos.d.ts.map +1 -1
  322. package/dist/types/wallets/coinbase/coinbaseWebSDK.d.ts +1 -1
  323. package/dist/types/wallets/coinbase/coinbaseWebSDK.d.ts.map +1 -1
  324. package/dist/types/wallets/create-wallet.d.ts.map +1 -1
  325. package/dist/types/wallets/getAllWalletsList.d.ts +36 -12
  326. package/dist/types/wallets/getAllWalletsList.d.ts.map +1 -1
  327. package/dist/types/wallets/in-app/core/wallet/enclave-wallet.d.ts.map +1 -1
  328. package/dist/types/wallets/in-app/core/wallet/in-app-core.d.ts.map +1 -1
  329. package/dist/types/wallets/in-app/web/lib/iframe-wallet.d.ts.map +1 -1
  330. package/dist/types/wallets/injected/index.d.ts +15 -2
  331. package/dist/types/wallets/injected/index.d.ts.map +1 -1
  332. package/dist/types/wallets/wallet-connect/controller.d.ts +2 -1
  333. package/dist/types/wallets/wallet-connect/controller.d.ts.map +1 -1
  334. package/package.json +1 -1
  335. package/src/analytics/track/connect.test.ts +78 -0
  336. package/src/analytics/track/connect.ts +25 -0
  337. package/src/analytics/track/index.ts +30 -0
  338. package/src/analytics/track/pay.test.ts +98 -0
  339. package/src/analytics/track/pay.ts +37 -0
  340. package/src/analytics/track/siwe.test.ts +110 -0
  341. package/src/analytics/track/siwe.ts +48 -0
  342. package/src/analytics/track/track.test.ts +107 -0
  343. package/src/analytics/track/transaction.test.ts +130 -0
  344. package/src/analytics/track/transaction.ts +57 -0
  345. package/src/auth/core/verify-login-payload.ts +25 -1
  346. package/src/exports/extensions/erc721.ts +4 -0
  347. package/src/exports/wallets/in-app.ts +4 -1
  348. package/src/extensions/erc1155/drop1155.test.ts +11 -0
  349. package/src/extensions/erc1155/token1155.test.ts +170 -2
  350. package/src/extensions/erc1155/write/lazyMint.test.ts +2 -22
  351. package/src/extensions/erc1155/write/mintAdditionalSupplyToBatch.test.ts +16 -85
  352. package/src/extensions/erc1155/write/mintAdditionalSupplyToBatch.ts +51 -4
  353. package/src/extensions/erc721/drops/write/claimTo.test.ts +15 -0
  354. package/src/extensions/erc721/drops/write/claimToBatch.test.ts +154 -0
  355. package/src/extensions/erc721/drops/write/claimToBatch.ts +144 -0
  356. package/src/react/core/utils/walletIcon.ts +3 -1
  357. package/src/react/web/hooks/transaction/useSendTransaction.tsx +3 -4
  358. package/src/react/web/ui/ConnectWallet/Details.tsx +2 -4
  359. package/src/react/web/ui/ConnectWallet/screens/Buy/BuyScreen.tsx +1 -1
  360. package/src/react/web/ui/ConnectWallet/screens/Buy/DirectPaymentModeScreen.tsx +1 -1
  361. package/src/react/web/ui/ConnectWallet/screens/Buy/TransactionModeScreen.tsx +1 -1
  362. package/src/react/web/ui/ConnectWallet/screens/Buy/fiat/FiatFlow.tsx +1 -1
  363. package/src/react/web/ui/ConnectWallet/screens/Buy/swap/ConfirmationScreen.tsx +1 -1
  364. package/src/react/web/ui/ConnectWallet/screens/LinkedProfilesScreen.tsx +2 -2
  365. package/src/react/web/ui/TransactionButton/TransactionModal.tsx +1 -1
  366. package/src/react/web/ui/components/WalletImage.tsx +2 -2
  367. package/src/react/web/wallets/shared/ConnectWalletSocialOptions.tsx +3 -3
  368. package/src/version.ts +1 -1
  369. package/src/wallets/__generated__/getWalletInfo.ts +67 -25
  370. package/src/wallets/__generated__/wallet/app.nightly/image.ts +7 -0
  371. package/src/wallets/__generated__/wallet/app.nightly/index.ts +34 -0
  372. package/src/wallets/__generated__/wallet/app.status/image.ts +1 -1
  373. package/src/wallets/__generated__/wallet/app.status/index.ts +1 -1
  374. package/src/wallets/__generated__/wallet/app.walletnow/index.ts +1 -1
  375. package/src/wallets/__generated__/wallet/com.beexo/image.ts +7 -0
  376. package/src/wallets/__generated__/wallet/com.beexo/index.ts +31 -0
  377. package/src/wallets/__generated__/wallet/com.brave.wallet/image.ts +1 -1
  378. package/src/wallets/__generated__/wallet/com.brave.wallet/index.ts +9 -11
  379. package/src/wallets/__generated__/wallet/com.coin98/image.ts +1 -1
  380. package/src/wallets/__generated__/wallet/com.coin98/index.ts +1 -1
  381. package/src/wallets/__generated__/wallet/com.crypto/image.ts +1 -1
  382. package/src/wallets/__generated__/wallet/com.crypto/index.ts +1 -1
  383. package/src/wallets/__generated__/wallet/com.daffione/image.ts +7 -0
  384. package/src/wallets/__generated__/wallet/com.daffione/index.ts +31 -0
  385. package/src/wallets/__generated__/wallet/com.ipmb/image.ts +7 -0
  386. package/src/wallets/__generated__/wallet/com.ipmb/index.ts +32 -0
  387. package/src/wallets/__generated__/wallet/com.webauth/image.ts +7 -0
  388. package/src/wallets/__generated__/wallet/{org.nitrogen → com.webauth}/index.ts +8 -8
  389. package/src/wallets/__generated__/wallet/finance.openwallet/index.ts +2 -2
  390. package/src/wallets/__generated__/wallet/finance.plena/index.ts +1 -1
  391. package/src/wallets/__generated__/wallet/id.plumaa/image.ts +7 -0
  392. package/src/wallets/__generated__/wallet/id.plumaa/index.ts +31 -0
  393. package/src/wallets/__generated__/wallet/io.miraiapp/image.ts +1 -1
  394. package/src/wallets/__generated__/wallet/io.miraiapp/index.ts +1 -1
  395. package/src/wallets/__generated__/wallet/io.owallet/image.ts +7 -0
  396. package/src/wallets/__generated__/wallet/io.owallet/index.ts +32 -0
  397. package/src/wallets/__generated__/wallet/io.tradestrike/image.ts +1 -1
  398. package/src/wallets/__generated__/wallet/io.tradestrike/index.ts +2 -2
  399. package/src/wallets/__generated__/wallet-ids.ts +9 -6
  400. package/src/wallets/__generated__/wallet-infos.ts +45 -15
  401. package/src/wallets/coinbase/coinbase-wallet.ts +1 -1
  402. package/src/wallets/coinbase/coinbaseWebSDK.ts +30 -7
  403. package/src/wallets/create-wallet.ts +6 -5
  404. package/src/wallets/in-app/core/wallet/enclave-wallet.ts +16 -3
  405. package/src/wallets/in-app/core/wallet/in-app-core.ts +3 -1
  406. package/src/wallets/in-app/web/lib/iframe-wallet.ts +12 -2
  407. package/src/wallets/injected/index.ts +72 -17
  408. package/src/wallets/native/create-wallet.ts +1 -1
  409. package/src/wallets/smart/smart-wallet.ts +1 -1
  410. package/src/wallets/wallet-connect/controller.ts +29 -7
  411. package/dist/cjs/analytics/track.js +0 -51
  412. package/dist/cjs/analytics/track.js.map +0 -1
  413. package/dist/cjs/wallets/__generated__/wallet/org.nitrogen/image.js +0 -7
  414. package/dist/cjs/wallets/__generated__/wallet/org.nitrogen/index.js.map +0 -1
  415. package/dist/esm/analytics/track.js +0 -47
  416. package/dist/esm/analytics/track.js.map +0 -1
  417. package/dist/esm/wallets/__generated__/wallet/org.nitrogen/image.js +0 -5
  418. package/dist/esm/wallets/__generated__/wallet/org.nitrogen/index.js.map +0 -1
  419. package/dist/types/analytics/track.d.ts.map +0 -1
  420. package/dist/types/wallets/__generated__/wallet/org.nitrogen/image.d.ts +0 -3
  421. package/dist/types/wallets/__generated__/wallet/org.nitrogen/image.d.ts.map +0 -1
  422. package/src/analytics/track.ts +0 -67
  423. package/src/extensions/erc1155/read/getNFTs.test.ts +0 -44
  424. package/src/extensions/erc1155/read/getOwnedNFTs.test.ts +0 -62
  425. package/src/extensions/erc1155/read/getOwnedTokenIds.test.ts +0 -50
  426. package/src/extensions/erc1155/write/mintAdditionalSupplyTo.test.ts +0 -38
  427. package/src/extensions/erc1155/write/mintTo.test.ts +0 -42
  428. package/src/extensions/erc1155/write/mintToBatch.test.ts +0 -77
  429. package/src/extensions/erc1155/write/updateTokenURI.test.ts +0 -54
  430. package/src/wallets/__generated__/wallet/org.nitrogen/image.ts +0 -7
@@ -1,90 +1,21 @@
1
+ import {} from "viem";
1
2
  import { describe, expect, it } from "vitest";
2
- import { ANVIL_CHAIN } from "~test/chains.js";
3
- import { TEST_CONTRACT_URI } from "~test/ipfs-uris.js";
4
- import { TEST_CLIENT } from "~test/test-clients.js";
5
3
  import { TEST_ACCOUNT_C } from "~test/test-wallets.js";
6
- import { 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
+ });
@@ -0,0 +1,144 @@
1
+ import type { Address } from "abitype";
2
+ import { multicall } from "../../../../extensions/common/__generated__/IMulticall/write/multicall.js";
3
+ import type {
4
+ BaseTransactionOptions,
5
+ WithOverrides,
6
+ } from "../../../../transaction/types.js";
7
+ import { getClaimParams } from "../../../../utils/extensions/drops/get-claim-params.js";
8
+ import { encodeClaim } from "../../__generated__/IDrop/write/claim.js";
9
+
10
+ /**
11
+ * @extension ERC721
12
+ */
13
+ export type ClaimToBatchParams = WithOverrides<{
14
+ content: Array<{
15
+ to: Address;
16
+ quantity: bigint;
17
+ }>;
18
+ from?: Address;
19
+ }>;
20
+
21
+ /**
22
+ * This extension batches multiple `claimTo` extensions into one single multicall.
23
+ * Keep in mind that there is a limit of how many NFTs you can claim per transaction.
24
+ * This limit varies depends on the network that you are transacting on.
25
+ *
26
+ * You are recommended to experiment with the number to figure out the best number for your chain of choice.
27
+ * @extension ERC721
28
+ * @param options the transaction options
29
+ * @returns A promise that resolves to the transaction result.
30
+ *
31
+ * @example
32
+ * ```ts
33
+ * import { claimToBatch } from "thirdweb/extensions/erc721";
34
+ *
35
+ * const transaction = claimToBatch({
36
+ * contract: nftDropContract,
37
+ * from: claimer.address, // address of the one calling this transaction
38
+ * content: [
39
+ * { to: "0x...1", quantity: 1n },
40
+ * { to: "0x...2", quantity: 12n },
41
+ * { to: "0x...3", quantity: 2n },
42
+ * ],
43
+ * });
44
+ * ```
45
+ */
46
+ export function claimToBatch(
47
+ options: BaseTransactionOptions<ClaimToBatchParams>,
48
+ ) {
49
+ return multicall({
50
+ contract: options.contract,
51
+ asyncParams: () => getClaimToBatchParams(options),
52
+ overrides: options.overrides,
53
+ });
54
+ }
55
+
56
+ /**
57
+ * @internal
58
+ */
59
+ async function getClaimToBatchParams(
60
+ options: BaseTransactionOptions<ClaimToBatchParams>,
61
+ ) {
62
+ const errorIndexTo = options.content.findIndex((o) => !o.to);
63
+ if (errorIndexTo !== -1) {
64
+ throw new Error(
65
+ `Error: Item at index ${errorIndexTo} is missing recipient address ("to")`,
66
+ );
67
+ }
68
+ const errorIndexQuantity = options.content.findIndex((o) => !o.quantity);
69
+ if (errorIndexQuantity !== -1) {
70
+ throw new Error(
71
+ `Error: Item at index ${errorIndexQuantity} is missing claim quantity`,
72
+ );
73
+ }
74
+ const content = optimizeClaimContent(options.content);
75
+ const data = await Promise.all(
76
+ content.map(async (item) => {
77
+ const claimParams = await getClaimParams({
78
+ type: "erc721",
79
+ contract: options.contract,
80
+ to: item.to,
81
+ from: options.from,
82
+ quantity: item.quantity,
83
+ });
84
+
85
+ return encodeClaim({
86
+ receiver: claimParams.receiver,
87
+ quantity: claimParams.quantity,
88
+ currency: claimParams.currency,
89
+ pricePerToken: claimParams.pricePerToken,
90
+ allowlistProof: claimParams.allowlistProof,
91
+ data: claimParams.data,
92
+ });
93
+ }),
94
+ );
95
+
96
+ return { data };
97
+ }
98
+
99
+ /**
100
+ * Optimization
101
+ * For identical addresses that stays next to each other in the array,
102
+ * we can combine them into one transaction _without altering the claiming order_
103
+ *
104
+ * For exampple, this structure:
105
+ * [
106
+ * {
107
+ * to: "0xabc",
108
+ * quantity: 1n,
109
+ * },
110
+ * {
111
+ * to: "0xabc",
112
+ * quantity: 13n,
113
+ * },
114
+ * ];
115
+ *
116
+ * ...can be combined in one tx (without altering the claiming order)
117
+ * {
118
+ * to: "0xabc",
119
+ * quantity: 14n,
120
+ * }
121
+ *
122
+ * @internal
123
+ */
124
+ export function optimizeClaimContent(
125
+ content: Array<{ to: Address; quantity: bigint }>,
126
+ ): Array<{ to: Address; quantity: bigint }> {
127
+ const results: Array<{ to: Address; quantity: bigint }> = [];
128
+ content.forEach((item, index) => {
129
+ const previousItem = results.at(-1);
130
+ if (
131
+ index > 0 &&
132
+ previousItem &&
133
+ item.to.toLowerCase() === previousItem.to.toLowerCase()
134
+ ) {
135
+ results[results.length - 1] = {
136
+ to: item.to,
137
+ quantity: item.quantity + previousItem.quantity,
138
+ };
139
+ } else {
140
+ results.push(item);
141
+ }
142
+ });
143
+ return results;
144
+ }
@@ -1,3 +1,5 @@
1
+ import type { AuthOption } from "../../../wallets/types.js";
2
+
1
3
  // TODO make the social icons usable in RN too
2
4
  const googleIconUri =
3
5
  "data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSI3MDUuNiIgaGVpZ2h0PSI3MjAiIHZpZXdCb3g9IjAgMCAxODYuNjkgMTkwLjUiIHhtbG5zOnY9Imh0dHBzOi8vdmVjdGEuaW8vbmFubyI+PGcgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoMTE4NC41ODMgNzY1LjE3MSkiPjxwYXRoIGNsaXAtcGF0aD0ibm9uZSIgbWFzaz0ibm9uZSIgZD0iTS0xMDg5LjMzMy02ODcuMjM5djM2Ljg4OGg1MS4yNjJjLTIuMjUxIDExLjg2My05LjAwNiAyMS45MDgtMTkuMTM3IDI4LjY2MmwzMC45MTMgMjMuOTg2YzE4LjAxMS0xNi42MjUgMjguNDAyLTQxLjA0NCAyOC40MDItNzAuMDUyIDAtNi43NTQtLjYwNi0xMy4yNDktMS43MzItMTkuNDgzeiIgZmlsbD0iIzQyODVmNCIvPjxwYXRoIGNsaXAtcGF0aD0ibm9uZSIgbWFzaz0ibm9uZSIgZD0iTS0xMTQyLjcxNC02NTEuNzkxbC02Ljk3MiA1LjMzNy0yNC42NzkgMTkuMjIzaDBjMTUuNjczIDMxLjA4NiA0Ny43OTYgNTIuNTYxIDg1LjAzIDUyLjU2MSAyNS43MTcgMCA0Ny4yNzgtOC40ODYgNjMuMDM4LTIzLjAzM2wtMzAuOTEzLTIzLjk4NmMtOC40ODYgNS43MTUtMTkuMzEgOS4xNzktMzIuMTI1IDkuMTc5LTI0Ljc2NSAwLTQ1LjgwNi0xNi43MTItNTMuMzQtMzkuMjI2eiIgZmlsbD0iIzM0YTg1MyIvPjxwYXRoIGNsaXAtcGF0aD0ibm9uZSIgbWFzaz0ibm9uZSIgZD0iTS0xMTc0LjM2NS03MTIuNjFjLTYuNDk0IDEyLjgxNS0xMC4yMTcgMjcuMjc2LTEwLjIxNyA0Mi42ODlzMy43MjMgMjkuODc0IDEwLjIxNyA0Mi42ODljMCAuMDg2IDMxLjY5My0yNC41OTIgMzEuNjkzLTI0LjU5Mi0xLjkwNS01LjcxNS0zLjAzMS0xMS43NzYtMy4wMzEtMTguMDk4czEuMTI2LTEyLjM4MyAzLjAzMS0xOC4wOTh6IiBmaWxsPSIjZmJiYzA1Ii8+PHBhdGggZD0iTS0xMDg5LjMzMy03MjcuMjQ0YzE0LjAyOCAwIDI2LjQ5NyA0Ljg0OSAzNi40NTUgMTQuMjAxbDI3LjI3Ni0yNy4yNzZjLTE2LjUzOS0xNS40MTMtMzguMDEzLTI0Ljg1Mi02My43MzEtMjQuODUyLTM3LjIzNCAwLTY5LjM1OSAyMS4zODgtODUuMDMyIDUyLjU2MWwzMS42OTIgMjQuNTkyYzcuNTMzLTIyLjUxNCAyOC41NzUtMzkuMjI2IDUzLjM0LTM5LjIyNnoiIGZpbGw9IiNlYTQzMzUiIGNsaXAtcGF0aD0ibm9uZSIgbWFzaz0ibm9uZSIvPjwvZz48L3N2Zz4=";
@@ -49,7 +51,7 @@ export const socialIcons = {
49
51
  };
50
52
 
51
53
  // TODO: this should return actual <svg> elements so they can be themed
52
- export function getWalletIcon(provider: string) {
54
+ export function getSocialIcon(provider: AuthOption | ({} & string)) {
53
55
  switch (provider) {
54
56
  case "google":
55
57
  return googleIconUri;
@@ -36,10 +36,9 @@ import { TransactionModal } from "../../ui/TransactionButton/TransactionModal.js
36
36
  *
37
37
  * const onClick = () => {
38
38
  * const transaction = prepareContractCall({
39
- * contract,
40
- * method: "function transfer(address to, uint256 value)",
41
- * params: [to, value],
42
- * }),
39
+ * contract,
40
+ * method: "function transfer(address to, uint256 value)",
41
+ * params: [to, value],
43
42
  * });
44
43
  * sendTx(transaction);
45
44
  * };
@@ -10,7 +10,7 @@ import {
10
10
  } from "@radix-ui/react-icons";
11
11
  import { useQuery } from "@tanstack/react-query";
12
12
  import { useContext, useEffect, useState } from "react";
13
- import { trackPayEvent } from "../../../../analytics/track.js";
13
+ import { trackPayEvent } from "../../../../analytics/track/pay.js";
14
14
  import type { Chain } from "../../../../chains/types.js";
15
15
  import type { ThirdwebClient } from "../../../../client/client.js";
16
16
  import { getContract } from "../../../../contract/contract.js";
@@ -200,9 +200,7 @@ export const ConnectedWalletDetails: React.FC<{
200
200
 
201
201
  const avatarSrc = props.detailsButton?.connectedAccountAvatarUrl || pfp;
202
202
 
203
- const combinedClassName = `${TW_CONNECTED_WALLET} ${
204
- props.detailsButton?.className || ""
205
- }`;
203
+ const combinedClassName = `${TW_CONNECTED_WALLET} ${props.detailsButton?.className || ""}`;
206
204
 
207
205
  return (
208
206
  <WalletInfoButton
@@ -1,7 +1,7 @@
1
1
  import { IdCardIcon } from "@radix-ui/react-icons";
2
2
  import { useQueryClient } from "@tanstack/react-query";
3
3
  import { useCallback, useMemo, useState } from "react";
4
- import { trackPayEvent } from "../../../../../../analytics/track.js";
4
+ import { trackPayEvent } from "../../../../../../analytics/track/pay.js";
5
5
  import type { Chain } from "../../../../../../chains/types.js";
6
6
  import type { ThirdwebClient } from "../../../../../../client/client.js";
7
7
  import { NATIVE_TOKEN_ADDRESS } from "../../../../../../constants/addresses.js";
@@ -1,5 +1,5 @@
1
1
  import { useQuery } from "@tanstack/react-query";
2
- import { trackPayEvent } from "../../../../../../analytics/track.js";
2
+ import { trackPayEvent } from "../../../../../../analytics/track/pay.js";
3
3
  import type { Chain } from "../../../../../../chains/types.js";
4
4
  import type { ThirdwebClient } from "../../../../../../client/client.js";
5
5
  import { NATIVE_TOKEN_ADDRESS } from "../../../../../../constants/addresses.js";
@@ -1,4 +1,4 @@
1
- import { trackPayEvent } from "../../../../../../analytics/track.js";
1
+ import { trackPayEvent } from "../../../../../../analytics/track/pay.js";
2
2
  import type { Chain } from "../../../../../../chains/types.js";
3
3
  import type { ThirdwebClient } from "../../../../../../client/client.js";
4
4
  import { NATIVE_TOKEN_ADDRESS } from "../../../../../../constants/addresses.js";
@@ -1,5 +1,5 @@
1
1
  import { useCallback, useState } from "react";
2
- import { trackPayEvent } from "../../../../../../../analytics/track.js";
2
+ import { trackPayEvent } from "../../../../../../../analytics/track/pay.js";
3
3
  import type { ThirdwebClient } from "../../../../../../../client/client.js";
4
4
  import type { BuyWithFiatQuote } from "../../../../../../../pay/buyWithFiat/getQuote.js";
5
5
  import {
@@ -1,6 +1,6 @@
1
1
  import { CrossCircledIcon } from "@radix-ui/react-icons";
2
2
  import { useState } from "react";
3
- import { trackPayEvent } from "../../../../../../../analytics/track.js";
3
+ import { trackPayEvent } from "../../../../../../../analytics/track/pay.js";
4
4
  import type { Chain } from "../../../../../../../chains/types.js";
5
5
  import type { ThirdwebClient } from "../../../../../../../client/client.js";
6
6
  import type { BuyWithCryptoQuote } from "../../../../../../../pay/buyWithCrypto/getQuote.js";
@@ -4,7 +4,7 @@ import { shortenAddress } from "../../../../../utils/address.js";
4
4
  import type { Profile } from "../../../../../wallets/in-app/core/authentication/types.js";
5
5
  import { fontSize, iconSize } from "../../../../core/design-system/index.js";
6
6
  import { useSocialProfiles } from "../../../../core/social/useSocialProfiles.js";
7
- import { getWalletIcon } from "../../../../core/utils/walletIcon.js";
7
+ import { getSocialIcon } from "../../../../core/utils/walletIcon.js";
8
8
  import { useProfiles } from "../../../hooks/wallets/useProfiles.js";
9
9
  import { LoadingScreen } from "../../../wallets/shared/LoadingScreen.js";
10
10
  import { Img } from "../../components/Img.js";
@@ -149,7 +149,7 @@ function LinkedProfile({
149
149
  </Container>
150
150
  ) : (
151
151
  <Img
152
- src={getWalletIcon(profile.type)}
152
+ src={getSocialIcon(profile.type)}
153
153
  width={iconSize.lg}
154
154
  height={iconSize.lg}
155
155
  loading="eager"
@@ -1,6 +1,6 @@
1
1
  import { useQuery } from "@tanstack/react-query";
2
2
  import { useState } from "react";
3
- import { trackPayEvent } from "../../../../analytics/track.js";
3
+ import { trackPayEvent } from "../../../../analytics/track/pay.js";
4
4
  import type { ThirdwebClient } from "../../../../client/client.js";
5
5
  import type { WaitForReceiptOptions } from "../../../../transaction/actions/wait-for-tx-receipt.js";
6
6
  import type { PreparedTransaction } from "../../../../transaction/prepare-transaction.js";
@@ -11,7 +11,7 @@ import { getLastAuthProvider } from "../../../core/utils/storage.js";
11
11
  import { useWalletImage } from "../../../core/utils/wallet.js";
12
12
  import {
13
13
  genericWalletIcon,
14
- getWalletIcon,
14
+ getSocialIcon,
15
15
  } from "../../../core/utils/walletIcon.js";
16
16
  import { Img } from "./Img.js";
17
17
 
@@ -43,7 +43,7 @@ export function WalletImage(props: {
43
43
  // when showing an active wallet icon - check last auth provider and override the IAW icon
44
44
  const lastAuthProvider = await getLastAuthProvider(storage);
45
45
  image = lastAuthProvider
46
- ? getWalletIcon(lastAuthProvider)
46
+ ? getSocialIcon(lastAuthProvider)
47
47
  : genericWalletIcon;
48
48
  } else {
49
49
  const mipdImage = getInstalledWalletProviders().find(
@@ -26,7 +26,7 @@ import {
26
26
  import { setLastAuthProvider } from "../../../core/utils/storage.js";
27
27
  import {
28
28
  emailIcon,
29
- getWalletIcon,
29
+ getSocialIcon,
30
30
  passkeyIcon,
31
31
  phoneIcon,
32
32
  socialIcons,
@@ -471,7 +471,7 @@ export const ConnectWalletSocialOptions = (
471
471
  {guestEnabled && (
472
472
  <WalletTypeRowButton
473
473
  client={props.client}
474
- icon={getWalletIcon("guest")}
474
+ icon={getSocialIcon("guest")}
475
475
  onClick={() => {
476
476
  handleGuestLogin();
477
477
  }}
@@ -483,7 +483,7 @@ export const ConnectWalletSocialOptions = (
483
483
  {props.isLinking && (
484
484
  <WalletTypeRowButton
485
485
  client={props.client}
486
- icon={getWalletIcon("")}
486
+ icon={getSocialIcon("")}
487
487
  onClick={() => {
488
488
  handleWalletLogin();
489
489
  }}