From 273a320ae8189a76b67de105c1ae66b7dfb618b0 Mon Sep 17 00:00:00 2001 From: greg Date: Fri, 3 Jan 2025 14:26:52 -1000 Subject: [PATCH 01/30] [SDK] Fix: Remove co.lobstr (not EVM compatible) (#5869) --- .changeset/pink-gorillas-try.md | 5 + packages/thirdweb/scripts/wallets/generate.ts | 40 +-- .../web/ui/prebuilt/Wallet/icon.test.tsx | 4 +- .../wallets/__generated__/getWalletInfo.ts | 267 ++++++++++++++---- .../src/wallets/__generated__/wallet-ids.ts | 46 ++- .../src/wallets/__generated__/wallet-infos.ts | 163 ++++++++--- .../__generated__/wallet/ag.jup/image.ts | 7 + .../__generated__/wallet/ag.jup/index.ts | 32 +++ .../__generated__/wallet/app.berasig/image.ts | 7 + .../wallet/{io.xdefi => app.berasig}/index.ts | 14 +- .../__generated__/wallet/app.core/index.ts | 7 +- .../__generated__/wallet/app.keplr/image.ts | 2 +- .../__generated__/wallet/app.phantom/index.ts | 6 +- .../wallet/co.family.wallet/image.ts | 7 + .../wallet/co.family.wallet/index.ts | 31 ++ .../__generated__/wallet/co.lobstr/image.ts | 7 - .../__generated__/wallet/com.berasig/image.ts | 7 + .../__generated__/wallet/com.berasig/index.ts | 31 ++ .../__generated__/wallet/com.binance/image.ts | 2 +- .../__generated__/wallet/com.binance/index.ts | 6 +- .../wallet/com.bitget.web3/image.ts | 2 +- .../wallet/com.bitget.web3/index.ts | 2 +- .../__generated__/wallet/com.bitnovo/image.ts | 7 + .../{co.lobstr => com.bitnovo}/index.ts | 18 +- .../__generated__/wallet/com.bybit/image.ts | 2 +- .../__generated__/wallet/com.bybit/index.ts | 2 +- .../__generated__/wallet/com.coinomi/index.ts | 2 +- .../wallet/com.companyname.swaptobe/image.ts | 7 + .../wallet/com.companyname.swaptobe/index.ts | 32 +++ .../wallet/com.crypto.wallet/image.ts | 2 +- .../wallet/com.crypto.wallet/index.ts | 6 +- .../image.ts | 0 .../index.ts | 6 +- .../__generated__/wallet/com.kraken/image.ts | 2 +- .../__generated__/wallet/com.kraken/index.ts | 2 +- .../__generated__/wallet/com.ledger/image.ts | 2 +- .../__generated__/wallet/com.ledger/index.ts | 2 +- .../wallet/com.okex.wallet/image.ts | 2 +- .../wallet/com.okex.wallet/index.ts | 2 +- .../wallet/com.roninchain.wallet/image.ts | 2 +- .../wallet/com.roninchain.wallet/index.ts | 2 +- .../__generated__/wallet/com.safepal/image.ts | 2 +- .../__generated__/wallet/com.safepal/index.ts | 2 +- .../wallet/com.trustwallet.app/image.ts | 2 +- .../wallet/com.trustwallet.app/index.ts | 2 +- .../wallet/com.walletconnect.com/image.ts | 2 +- .../wallet/com.walletconnect.com/index.ts | 2 +- .../wallet/com.wemixplay/image.ts | 7 + .../wallet/com.wemixplay/index.ts | 32 +++ .../wallet/eu.flashsoft.clear-wallet/image.ts | 7 + .../wallet/eu.flashsoft.clear-wallet/index.ts | 32 +++ .../wallet/finance.porta/image.ts | 7 + .../wallet/finance.porta/index.ts | 32 +++ .../__generated__/wallet/global.safe/image.ts | 2 +- .../__generated__/wallet/global.safe/index.ts | 2 +- .../wallet/id.competence/image.ts | 2 +- .../__generated__/wallet/im.token/image.ts | 2 +- .../__generated__/wallet/im.token/index.ts | 4 +- .../__generated__/wallet/inc.tomo/image.ts | 2 +- .../__generated__/wallet/inc.tomo/index.ts | 6 +- .../wallet/io.1inch.wallet/image.ts | 2 +- .../wallet/io.1inch.wallet/index.ts | 2 +- .../image.ts | 0 .../index.ts | 11 +- .../{io.cypherwallet => io.cypherhq}/image.ts | 0 .../{io.cypherwallet => io.cypherhq}/index.ts | 6 +- .../wallet/io.getjoin.prd/image.ts | 7 + .../wallet/io.getjoin.prd/index.ts | 31 ++ .../__generated__/wallet/io.huddln/image.ts | 2 +- .../wallet/io.internetmoney/image.ts | 2 +- .../wallet/io.koalawallet/image.ts | 7 + .../wallet/io.koalawallet/index.ts | 33 +++ .../wallet/io.leapwallet/image.ts | 2 +- .../wallet/io.leapwallet/index.ts | 2 +- .../wallet/io.legionnetwork/image.ts | 7 + .../wallet/io.legionnetwork/index.ts | 32 +++ .../__generated__/wallet/io.metamask/image.ts | 2 +- .../__generated__/wallet/io.metamask/index.ts | 2 +- .../wallet/io.moonstake/image.ts | 2 +- .../__generated__/wallet/io.nonbank/image.ts | 7 + .../__generated__/wallet/io.nonbank/index.ts | 31 ++ .../__generated__/wallet/io.noone/image.ts | 2 +- .../__generated__/wallet/io.noone/index.ts | 2 +- .../wallet/io.safecryptowallet/image.ts | 7 + .../wallet/io.safecryptowallet/index.ts | 31 ++ .../wallet/io.universaleverything/image.ts | 7 + .../wallet/io.universaleverything/index.ts | 31 ++ .../wallet/io.walletverse/image.ts | 7 + .../wallet/io.walletverse/index.ts | 31 ++ .../__generated__/wallet/io.xdefi/image.ts | 7 - .../wallet/io.zerion.wallet/image.ts | 2 +- .../wallet/io.zerion.wallet/index.ts | 2 +- .../__generated__/wallet/me.rainbow/image.ts | 2 +- .../__generated__/wallet/me.rainbow/index.ts | 2 +- .../wallet/network.mrhb/image.ts | 2 +- .../wallet/network.over/image.ts | 7 + .../wallet/network.over/index.ts | 32 +++ .../wallet/org.alephium/image.ts | 7 + .../wallet/org.alephium/index.ts | 32 +++ .../__generated__/wallet/org.shefi/image.ts | 7 + .../__generated__/wallet/org.shefi/index.ts | 31 ++ .../__generated__/wallet/org.uniswap/image.ts | 2 +- .../__generated__/wallet/org.uniswap/index.ts | 2 +- .../wallet/pro.tokenpocket/image.ts | 2 +- .../wallet/pro.tokenpocket/index.ts | 2 +- .../__generated__/wallet/xyz.bonuz/image.ts | 2 +- .../__generated__/wallet/xyz.ctrl/image.ts | 7 + .../__generated__/wallet/xyz.ctrl/index.ts | 32 +++ .../wallet/xyz.talisman/image.ts | 7 + .../wallet/xyz.talisman/index.ts | 32 +++ .../wallet/xyz.timelesswallet/image.ts | 2 +- .../wallet/xyz.timelesswallet/index.ts | 2 +- 112 files changed, 1249 insertions(+), 228 deletions(-) create mode 100644 .changeset/pink-gorillas-try.md create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/ag.jup/image.ts create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/ag.jup/index.ts create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/app.berasig/image.ts rename packages/thirdweb/src/wallets/__generated__/wallet/{io.xdefi => app.berasig}/index.ts (60%) create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/co.family.wallet/image.ts create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/co.family.wallet/index.ts delete mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/co.lobstr/image.ts create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/com.berasig/image.ts create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/com.berasig/index.ts create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/com.bitnovo/image.ts rename packages/thirdweb/src/wallets/__generated__/wallet/{co.lobstr => com.bitnovo}/index.ts (58%) create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/com.companyname.swaptobe/image.ts create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/com.companyname.swaptobe/index.ts rename packages/thirdweb/src/wallets/__generated__/wallet/{group.com.flowfoundation.wallet => com.flowfoundation.wallet}/image.ts (100%) rename packages/thirdweb/src/wallets/__generated__/wallet/{group.com.flowfoundation.wallet => com.flowfoundation.wallet}/index.ts (85%) create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/com.wemixplay/image.ts create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/com.wemixplay/index.ts create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/eu.flashsoft.clear-wallet/image.ts create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/eu.flashsoft.clear-wallet/index.ts create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/finance.porta/image.ts create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/finance.porta/index.ts rename packages/thirdweb/src/wallets/__generated__/wallet/{io.leapwallet.CompassWallet => io.compasswallet}/image.ts (100%) rename packages/thirdweb/src/wallets/__generated__/wallet/{io.leapwallet.CompassWallet => io.compasswallet}/index.ts (75%) rename packages/thirdweb/src/wallets/__generated__/wallet/{io.cypherwallet => io.cypherhq}/image.ts (100%) rename packages/thirdweb/src/wallets/__generated__/wallet/{io.cypherwallet => io.cypherhq}/index.ts (89%) create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/io.getjoin.prd/image.ts create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/io.getjoin.prd/index.ts create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/io.koalawallet/image.ts create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/io.koalawallet/index.ts create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/io.legionnetwork/image.ts create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/io.legionnetwork/index.ts create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/io.nonbank/image.ts create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/io.nonbank/index.ts create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/io.safecryptowallet/image.ts create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/io.safecryptowallet/index.ts create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/io.universaleverything/image.ts create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/io.universaleverything/index.ts create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/io.walletverse/image.ts create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/io.walletverse/index.ts delete mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/io.xdefi/image.ts create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/network.over/image.ts create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/network.over/index.ts create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/org.alephium/image.ts create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/org.alephium/index.ts create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/org.shefi/image.ts create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/org.shefi/index.ts create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/xyz.ctrl/image.ts create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/xyz.ctrl/index.ts create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/xyz.talisman/image.ts create mode 100644 packages/thirdweb/src/wallets/__generated__/wallet/xyz.talisman/index.ts diff --git a/.changeset/pink-gorillas-try.md b/.changeset/pink-gorillas-try.md new file mode 100644 index 00000000000..d5735273f13 --- /dev/null +++ b/.changeset/pink-gorillas-try.md @@ -0,0 +1,5 @@ +--- +"thirdweb": patch +--- + +SDK: Removed co.lobstr from the available wallets (an unsupported non-EVM wallet) diff --git a/packages/thirdweb/scripts/wallets/generate.ts b/packages/thirdweb/scripts/wallets/generate.ts index caa624d31ef..75a2d2d1f1f 100644 --- a/packages/thirdweb/scripts/wallets/generate.ts +++ b/packages/thirdweb/scripts/wallets/generate.ts @@ -4,6 +4,10 @@ import { join } from "node:path"; import { format } from "prettier"; import sharp from "sharp"; +const EXCLUDED_WALLETS = [ + "co.lobstr", // Not EVM compatible +]; + const walletConnectWallets = await fetch( "https://explorer-api.walletconnect.com/w3m/v1/getAllListings?projectId=145769e410f16970a79ff77b2d89a1e0", ).then(async (res) => { @@ -96,24 +100,26 @@ function rdns(wallet: Wallet) { .join("."); } -const allWalletsWithIds = allWalletsArray.map((wallet) => { - // biome-ignore lint/performance/noDelete: aware it's bad but it's OK in generate script - // biome-ignore lint/suspicious/noExplicitAny: aware it's bad but it's OK in generate script - delete (wallet as any).order; - // biome-ignore lint/performance/noDelete: aware it's bad but it's OK in generate script - // biome-ignore lint/suspicious/noExplicitAny: aware it's bad but it's OK in generate script - delete (wallet as any).injected; - - const id = rdns(wallet); - - if (id && id in deepLinkSupportedWalletsRecord) { - wallet.deepLink = { - mobile: deepLinkSupportedWalletsRecord[id].mobile, - }; - } +const allWalletsWithIds = allWalletsArray + .map((wallet) => { + // biome-ignore lint/performance/noDelete: aware it's bad but it's OK in generate script + // biome-ignore lint/suspicious/noExplicitAny: aware it's bad but it's OK in generate script + delete (wallet as any).order; + // biome-ignore lint/performance/noDelete: aware it's bad but it's OK in generate script + // biome-ignore lint/suspicious/noExplicitAny: aware it's bad but it's OK in generate script + delete (wallet as any).injected; + + const id = rdns(wallet); + + if (id && id in deepLinkSupportedWalletsRecord) { + wallet.deepLink = { + mobile: deepLinkSupportedWalletsRecord[id].mobile, + }; + } - return { ...wallet, id: id }; -}); + return { ...wallet, id: id }; + }) + .filter((w) => !EXCLUDED_WALLETS.includes(w.id)); // filter duplicate ids, we'll keep the first ones diff --git a/packages/thirdweb/src/react/web/ui/prebuilt/Wallet/icon.test.tsx b/packages/thirdweb/src/react/web/ui/prebuilt/Wallet/icon.test.tsx index 5cfe730049d..907b7fe25e5 100644 --- a/packages/thirdweb/src/react/web/ui/prebuilt/Wallet/icon.test.tsx +++ b/packages/thirdweb/src/react/web/ui/prebuilt/Wallet/icon.test.tsx @@ -5,8 +5,8 @@ import { WalletProvider } from "./provider.js"; describe("WalletIcon", () => { it("should fetch wallet image", async () => { - expect(await fetchWalletImage({ id: "io.metamask" })).toBe( - "", + expect(await fetchWalletImage({ id: "io.metamask" })).toMatchInlineSnapshot( + `""`, ); }); diff --git a/packages/thirdweb/src/wallets/__generated__/getWalletInfo.ts b/packages/thirdweb/src/wallets/__generated__/getWalletInfo.ts index 0cd9c692120..aae750c7502 100644 --- a/packages/thirdweb/src/wallets/__generated__/getWalletInfo.ts +++ b/packages/thirdweb/src/wallets/__generated__/getWalletInfo.ts @@ -273,6 +273,13 @@ export async function getWalletInfo( : import("./wallet/com.mewwallet/index.js").then((w) => w.wallet) ) as Promise<[TImage] extends [true] ? string : any>; } + case "app.phantom": { + return ( + image + ? import("./wallet/app.phantom/image.js").then((img) => img.default) + : import("./wallet/app.phantom/index.js").then((w) => w.wallet) + ) as Promise<[TImage] extends [true] ? string : any>; + } case "com.fireblocks": { return ( image @@ -300,6 +307,17 @@ export async function getWalletInfo( : import("./wallet/com.alphawallet/index.js").then((w) => w.wallet) ) as Promise<[TImage] extends [true] ? string : any>; } + case "com.roninchain.wallet": { + return ( + image + ? import("./wallet/com.roninchain.wallet/image.js").then( + (img) => img.default, + ) + : import("./wallet/com.roninchain.wallet/index.js").then( + (w) => w.wallet, + ) + ) as Promise<[TImage] extends [true] ? string : any>; + } case "com.unstoppabledomains": { return ( image @@ -336,13 +354,6 @@ export async function getWalletInfo( : import("./wallet/app.omni/index.js").then((w) => w.wallet) ) as Promise<[TImage] extends [true] ? string : any>; } - case "co.lobstr": { - return ( - image - ? import("./wallet/co.lobstr/image.js").then((img) => img.default) - : import("./wallet/co.lobstr/index.js").then((w) => w.wallet) - ) as Promise<[TImage] extends [true] ? string : any>; - } case "technology.obvious": { return ( image @@ -569,13 +580,11 @@ export async function getWalletInfo( : import("./wallet/network.cvl/index.js").then((w) => w.wallet) ) as Promise<[TImage] extends [true] ? string : any>; } - case "io.cypherwallet": { + case "io.cypherhq": { return ( image - ? import("./wallet/io.cypherwallet/image.js").then( - (img) => img.default, - ) - : import("./wallet/io.cypherwallet/index.js").then((w) => w.wallet) + ? import("./wallet/io.cypherhq/image.js").then((img) => img.default) + : import("./wallet/io.cypherhq/index.js").then((w) => w.wallet) ) as Promise<[TImage] extends [true] ? string : any>; } case "app.status": { @@ -1270,6 +1279,13 @@ export async function getWalletInfo( : import("./wallet/com.kriptonio/index.js").then((w) => w.wallet) ) as Promise<[TImage] extends [true] ? string : any>; } + case "xyz.ctrl": { + return ( + image + ? import("./wallet/xyz.ctrl/image.js").then((img) => img.default) + : import("./wallet/xyz.ctrl/index.js").then((w) => w.wallet) + ) as Promise<[TImage] extends [true] ? string : any>; + } case "io.streakk": { return ( image @@ -1286,13 +1302,13 @@ export async function getWalletInfo( : import("./wallet/com.saitamatoken/index.js").then((w) => w.wallet) ) as Promise<[TImage] extends [true] ? string : any>; } - case "group.com.flowfoundation.wallet": { + case "com.flowfoundation.wallet": { return ( image - ? import("./wallet/group.com.flowfoundation.wallet/image.js").then( + ? import("./wallet/com.flowfoundation.wallet/image.js").then( (img) => img.default, ) - : import("./wallet/group.com.flowfoundation.wallet/index.js").then( + : import("./wallet/com.flowfoundation.wallet/index.js").then( (w) => w.wallet, ) ) as Promise<[TImage] extends [true] ? string : any>; @@ -1703,17 +1719,6 @@ export async function getWalletInfo( : import("./wallet/app.ryipay/index.js").then((w) => w.wallet) ) as Promise<[TImage] extends [true] ? string : any>; } - case "com.roninchain.wallet": { - return ( - image - ? import("./wallet/com.roninchain.wallet/image.js").then( - (img) => img.default, - ) - : import("./wallet/com.roninchain.wallet/index.js").then( - (w) => w.wallet, - ) - ) as Promise<[TImage] extends [true] ? string : any>; - } case "org.dota168": { return ( image @@ -2714,6 +2719,13 @@ export async function getWalletInfo( : import("./wallet/fun.tobi/index.js").then((w) => w.wallet) ) as Promise<[TImage] extends [true] ? string : any>; } + case "inc.tomo": { + return ( + image + ? import("./wallet/inc.tomo/image.js").then((img) => img.default) + : import("./wallet/inc.tomo/index.js").then((w) => w.wallet) + ) as Promise<[TImage] extends [true] ? string : any>; + } case "app.clot": { return ( image @@ -2806,6 +2818,15 @@ export async function getWalletInfo( : import("./wallet/io.uptn.dapp-web/index.js").then((w) => w.wallet) ) as Promise<[TImage] extends [true] ? string : any>; } + case "io.compasswallet": { + return ( + image + ? import("./wallet/io.compasswallet/image.js").then( + (img) => img.default, + ) + : import("./wallet/io.compasswallet/index.js").then((w) => w.wallet) + ) as Promise<[TImage] extends [true] ? string : any>; + } case "app.nicegram": { return ( image @@ -2891,22 +2912,147 @@ export async function getWalletInfo( ) ) as Promise<[TImage] extends [true] ? string : any>; } - case "com.coinbase.wallet": { + case "com.companyname.swaptobe": { return ( image - ? import("./wallet/com.coinbase.wallet/image.js").then( + ? import("./wallet/com.companyname.swaptobe/image.js").then( (img) => img.default, ) - : import("./wallet/com.coinbase.wallet/index.js").then( + : import("./wallet/com.companyname.swaptobe/index.js").then( (w) => w.wallet, ) ) as Promise<[TImage] extends [true] ? string : any>; } - case "app.phantom": { + case "finance.porta": { return ( image - ? import("./wallet/app.phantom/image.js").then((img) => img.default) - : import("./wallet/app.phantom/index.js").then((w) => w.wallet) + ? import("./wallet/finance.porta/image.js").then((img) => img.default) + : import("./wallet/finance.porta/index.js").then((w) => w.wallet) + ) as Promise<[TImage] extends [true] ? string : any>; + } + case "org.alephium": { + return ( + image + ? import("./wallet/org.alephium/image.js").then((img) => img.default) + : import("./wallet/org.alephium/index.js").then((w) => w.wallet) + ) as Promise<[TImage] extends [true] ? string : any>; + } + case "network.over": { + return ( + image + ? import("./wallet/network.over/image.js").then((img) => img.default) + : import("./wallet/network.over/index.js").then((w) => w.wallet) + ) as Promise<[TImage] extends [true] ? string : any>; + } + case "io.walletverse": { + return ( + image + ? import("./wallet/io.walletverse/image.js").then( + (img) => img.default, + ) + : import("./wallet/io.walletverse/index.js").then((w) => w.wallet) + ) as Promise<[TImage] extends [true] ? string : any>; + } + case "com.berasig": { + return ( + image + ? import("./wallet/com.berasig/image.js").then((img) => img.default) + : import("./wallet/com.berasig/index.js").then((w) => w.wallet) + ) as Promise<[TImage] extends [true] ? string : any>; + } + case "org.shefi": { + return ( + image + ? import("./wallet/org.shefi/image.js").then((img) => img.default) + : import("./wallet/org.shefi/index.js").then((w) => w.wallet) + ) as Promise<[TImage] extends [true] ? string : any>; + } + case "com.wemixplay": { + return ( + image + ? import("./wallet/com.wemixplay/image.js").then((img) => img.default) + : import("./wallet/com.wemixplay/index.js").then((w) => w.wallet) + ) as Promise<[TImage] extends [true] ? string : any>; + } + case "co.family.wallet": { + return ( + image + ? import("./wallet/co.family.wallet/image.js").then( + (img) => img.default, + ) + : import("./wallet/co.family.wallet/index.js").then((w) => w.wallet) + ) as Promise<[TImage] extends [true] ? string : any>; + } + case "io.legionnetwork": { + return ( + image + ? import("./wallet/io.legionnetwork/image.js").then( + (img) => img.default, + ) + : import("./wallet/io.legionnetwork/index.js").then((w) => w.wallet) + ) as Promise<[TImage] extends [true] ? string : any>; + } + case "com.bitnovo": { + return ( + image + ? import("./wallet/com.bitnovo/image.js").then((img) => img.default) + : import("./wallet/com.bitnovo/index.js").then((w) => w.wallet) + ) as Promise<[TImage] extends [true] ? string : any>; + } + case "io.safecryptowallet": { + return ( + image + ? import("./wallet/io.safecryptowallet/image.js").then( + (img) => img.default, + ) + : import("./wallet/io.safecryptowallet/index.js").then( + (w) => w.wallet, + ) + ) as Promise<[TImage] extends [true] ? string : any>; + } + case "ag.jup": { + return ( + image + ? import("./wallet/ag.jup/image.js").then((img) => img.default) + : import("./wallet/ag.jup/index.js").then((w) => w.wallet) + ) as Promise<[TImage] extends [true] ? string : any>; + } + case "io.koalawallet": { + return ( + image + ? import("./wallet/io.koalawallet/image.js").then( + (img) => img.default, + ) + : import("./wallet/io.koalawallet/index.js").then((w) => w.wallet) + ) as Promise<[TImage] extends [true] ? string : any>; + } + case "io.nonbank": { + return ( + image + ? import("./wallet/io.nonbank/image.js").then((img) => img.default) + : import("./wallet/io.nonbank/index.js").then((w) => w.wallet) + ) as Promise<[TImage] extends [true] ? string : any>; + } + case "io.universaleverything": { + return ( + image + ? import("./wallet/io.universaleverything/image.js").then( + (img) => img.default, + ) + : import("./wallet/io.universaleverything/index.js").then( + (w) => w.wallet, + ) + ) as Promise<[TImage] extends [true] ? string : any>; + } + case "com.coinbase.wallet": { + return ( + image + ? import("./wallet/com.coinbase.wallet/image.js").then( + (img) => img.default, + ) + : import("./wallet/com.coinbase.wallet/index.js").then( + (w) => w.wallet, + ) ) as Promise<[TImage] extends [true] ? string : any>; } case "io.rabby": { @@ -2925,13 +3071,6 @@ export async function getWalletInfo( : import("./wallet/com.brave.wallet/index.js").then((w) => w.wallet) ) as Promise<[TImage] extends [true] ? string : any>; } - case "io.xdefi": { - return ( - image - ? import("./wallet/io.xdefi/image.js").then((img) => img.default) - : import("./wallet/io.xdefi/index.js").then((w) => w.wallet) - ) as Promise<[TImage] extends [true] ? string : any>; - } case "com.moongate.one": { return ( image @@ -2980,13 +3119,6 @@ export async function getWalletInfo( : import("./wallet/io.finoa/index.js").then((w) => w.wallet) ) as Promise<[TImage] extends [true] ? string : any>; } - case "inc.tomo": { - return ( - image - ? import("./wallet/inc.tomo/image.js").then((img) => img.default) - : import("./wallet/inc.tomo/index.js").then((w) => w.wallet) - ) as Promise<[TImage] extends [true] ? string : any>; - } case "com.walletconnect.com": { return ( image @@ -2998,31 +3130,54 @@ export async function getWalletInfo( ) ) as Promise<[TImage] extends [true] ? string : any>; } - case "io.leapwallet.CompassWallet": { + case "app.nightly": { return ( image - ? import("./wallet/io.leapwallet.CompassWallet/image.js").then( + ? import("./wallet/app.nightly/image.js").then((img) => img.default) + : import("./wallet/app.nightly/index.js").then((w) => w.wallet) + ) as Promise<[TImage] extends [true] ? string : any>; + } + case "com.blazpay.wallet": { + return ( + image + ? import("./wallet/com.blazpay.wallet/image.js").then( (img) => img.default, ) - : import("./wallet/io.leapwallet.CompassWallet/index.js").then( - (w) => w.wallet, + : import("./wallet/com.blazpay.wallet/index.js").then((w) => w.wallet) + ) as Promise<[TImage] extends [true] ? string : any>; + } + case "io.getjoin.prd": { + return ( + image + ? import("./wallet/io.getjoin.prd/image.js").then( + (img) => img.default, ) + : import("./wallet/io.getjoin.prd/index.js").then((w) => w.wallet) ) as Promise<[TImage] extends [true] ? string : any>; } - case "app.nightly": { + case "xyz.talisman": { return ( image - ? import("./wallet/app.nightly/image.js").then((img) => img.default) - : import("./wallet/app.nightly/index.js").then((w) => w.wallet) + ? import("./wallet/xyz.talisman/image.js").then((img) => img.default) + : import("./wallet/xyz.talisman/index.js").then((w) => w.wallet) ) as Promise<[TImage] extends [true] ? string : any>; } - case "com.blazpay.wallet": { + case "eu.flashsoft.clear-wallet": { return ( image - ? import("./wallet/com.blazpay.wallet/image.js").then( + ? import("./wallet/eu.flashsoft.clear-wallet/image.js").then( (img) => img.default, ) - : import("./wallet/com.blazpay.wallet/index.js").then((w) => w.wallet) + : import("./wallet/eu.flashsoft.clear-wallet/index.js").then( + (w) => w.wallet, + ) + ) as Promise<[TImage] extends [true] ? string : any>; + } + case "app.berasig": { + return ( + image + ? import("./wallet/app.berasig/image.js").then((img) => img.default) + : import("./wallet/app.berasig/index.js").then((w) => w.wallet) ) as Promise<[TImage] extends [true] ? string : any>; } case "com.lootrush": { diff --git a/packages/thirdweb/src/wallets/__generated__/wallet-ids.ts b/packages/thirdweb/src/wallets/__generated__/wallet-ids.ts index 2d99e8d30cf..cfe9b7837d8 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet-ids.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet-ids.ts @@ -1,7 +1,7 @@ // This file is auto-generated by the `scripts/wallets/generate.ts` script. // Do not modify this file manually. -// 371 wallets +// 390 wallets export type WCSupportedWalletIds = | "io.metamask" | "com.trustwallet.app" @@ -29,14 +29,15 @@ export type WCSupportedWalletIds = | "app.backpack" | "com.zengo" | "com.mewwallet" + | "app.phantom" | "com.fireblocks" | "org.mathwallet" | "com.alphawallet" + | "com.roninchain.wallet" | "com.unstoppabledomains" | "app.keyring" | "xyz.frontier.wallet" | "app.omni" - | "co.lobstr" | "technology.obvious" | "com.ambire" | "com.mtpelerin" @@ -67,7 +68,7 @@ export type WCSupportedWalletIds = | "com.burritowallet" | "io.ancrypto" | "network.cvl" - | "io.cypherwallet" + | "io.cypherhq" | "app.status" | "io.enjin" | "io.trinity-tech" @@ -157,9 +158,10 @@ export type WCSupportedWalletIds = | "finance.slingshot" | "com.kriptonio" | "xyz.timelesswallet" + | "xyz.ctrl" | "io.streakk" | "com.saitamatoken" - | "group.com.flowfoundation.wallet" + | "com.flowfoundation.wallet" | "io.hippowallet" | "io.cosmostation" | "org.bitizen" @@ -216,7 +218,6 @@ export type WCSupportedWalletIds = | "co.muza" | "com.fxwallet" | "app.ryipay" - | "com.roninchain.wallet" | "org.dota168" | "io.altme" | "com.bitpie" @@ -349,6 +350,7 @@ export type WCSupportedWalletIds = | "io.shido" | "co.lifedefi" | "fun.tobi" + | "inc.tomo" | "app.clot" | "me.komet.app" | "io.guardiianwallet" @@ -362,6 +364,7 @@ export type WCSupportedWalletIds = | "xyz.orion" | "io.uptn.dapp-web" | "io.nabox" + | "io.compasswallet" | "app.nicegram" | "finance.openwallet" | "com.bitget.web3" @@ -373,9 +376,25 @@ export type WCSupportedWalletIds = | "com.webauth" | "id.plumaa" | "social.gm2" - | "nl.greenhood.wallet"; + | "nl.greenhood.wallet" + | "com.companyname.swaptobe" + | "finance.porta" + | "org.alephium" + | "network.over" + | "io.walletverse" + | "com.berasig" + | "org.shefi" + | "com.wemixplay" + | "co.family.wallet" + | "io.legionnetwork" + | "com.bitnovo" + | "io.safecryptowallet" + | "ag.jup" + | "io.koalawallet" + | "io.nonbank" + | "io.universaleverything"; -// 56 wallets +// 61 wallets export type InjectedSupportedWalletIds = | "io.metamask" | "com.trustwallet.app" @@ -390,6 +409,7 @@ export type InjectedSupportedWalletIds = | "com.coinbase.wallet" | "app.backpack" | "app.phantom" + | "com.roninchain.wallet" | "xyz.frontier.wallet" | "com.coin98" | "io.rabby" @@ -399,10 +419,9 @@ export type InjectedSupportedWalletIds = | "com.coolbitx.cwsapp" | "com.bifrostwallet" | "so.onekey.app.wallet" - | "io.xdefi" - | "group.com.flowfoundation.wallet" + | "xyz.ctrl" + | "com.flowfoundation.wallet" | "app.subwallet" - | "com.roninchain.wallet" | "app.zeal" | "xyz.roam.wallet" | "com.meld.app" @@ -425,10 +444,15 @@ export type InjectedSupportedWalletIds = | "com.elrond.maiar.wallet" | "com.zypto" | "com.walletconnect.com" - | "io.leapwallet.CompassWallet" | "app.nightly" | "nl.greenhood.wallet" | "com.blazpay.wallet" + | "com.companyname.swaptobe" + | "io.getjoin.prd" + | "xyz.talisman" + | "co.family.wallet" + | "eu.flashsoft.clear-wallet" + | "app.berasig" | "com.lootrush" | "app.core.extension" | "xyz.dawnwallet" diff --git a/packages/thirdweb/src/wallets/__generated__/wallet-infos.ts b/packages/thirdweb/src/wallets/__generated__/wallet-infos.ts index c4d93292620..d7c7efcc365 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet-infos.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet-infos.ts @@ -36,7 +36,7 @@ const ALL_MINIMAL_WALLET_INFOS = ([ }, { id: "com.binance", - name: "Binance Web3 Wallet", + name: "Binance Wallet", hasMobileSupport: true, }, { @@ -96,7 +96,7 @@ const ALL_MINIMAL_WALLET_INFOS = ([ }, { id: "com.crypto.wallet", - name: "Crypto.com | DeFi Wallet", + name: "Crypto.com Onchain", hasMobileSupport: true, }, { @@ -144,6 +144,11 @@ const ALL_MINIMAL_WALLET_INFOS = ([ name: "MEW wallet", hasMobileSupport: true, }, + { + id: "app.phantom", + name: "Phantom", + hasMobileSupport: true, + }, { id: "com.fireblocks", name: "Fireblocks", @@ -159,6 +164,11 @@ const ALL_MINIMAL_WALLET_INFOS = ([ name: "AlphaWallet", hasMobileSupport: true, }, + { + id: "com.roninchain.wallet", + name: "Ronin Wallet", + hasMobileSupport: true, + }, { id: "com.unstoppabledomains", name: "Unstoppable Domains", @@ -179,11 +189,6 @@ const ALL_MINIMAL_WALLET_INFOS = ([ name: "Omni", hasMobileSupport: true, }, - { - id: "co.lobstr", - name: "LOBSTR Wallet", - hasMobileSupport: true, - }, { id: "technology.obvious", name: "Obvious", @@ -335,7 +340,7 @@ const ALL_MINIMAL_WALLET_INFOS = ([ hasMobileSupport: true, }, { - id: "io.cypherwallet", + id: "io.cypherhq", name: "Cypher Wallet", hasMobileSupport: true, }, @@ -779,6 +784,11 @@ const ALL_MINIMAL_WALLET_INFOS = ([ name: "Kriptonio", hasMobileSupport: true, }, + { + id: "xyz.ctrl", + name: "Ctrl Wallet", + hasMobileSupport: true, + }, { id: "io.streakk", name: "Streakk Wallet", @@ -790,7 +800,7 @@ const ALL_MINIMAL_WALLET_INFOS = ([ hasMobileSupport: true, }, { - id: "group.com.flowfoundation.wallet", + id: "com.flowfoundation.wallet", name: "Flow Wallet", hasMobileSupport: true, }, @@ -1064,11 +1074,6 @@ const ALL_MINIMAL_WALLET_INFOS = ([ name: "RYIPAY", hasMobileSupport: true, }, - { - id: "com.roninchain.wallet", - name: "Ronin Wallet", - hasMobileSupport: true, - }, { id: "org.dota168", name: "MetaWallet", @@ -1709,6 +1714,11 @@ const ALL_MINIMAL_WALLET_INFOS = ([ name: "Tobi", hasMobileSupport: true, }, + { + id: "inc.tomo", + name: "Tomo Wallet", + hasMobileSupport: true, + }, { id: "app.clot", name: "Clot", @@ -1769,6 +1779,11 @@ const ALL_MINIMAL_WALLET_INFOS = ([ name: "UPTN", hasMobileSupport: true, }, + { + id: "io.compasswallet", + name: "Compass Wallet", + hasMobileSupport: true, + }, { id: "app.nicegram", name: "Nicegram Wallet", @@ -1825,13 +1840,88 @@ const ALL_MINIMAL_WALLET_INFOS = ([ hasMobileSupport: true, }, { - id: "com.coinbase.wallet", - name: "Coinbase Wallet", - hasMobileSupport: false, + id: "com.companyname.swaptobe", + name: "TobeWallet", + hasMobileSupport: true, }, { - id: "app.phantom", - name: "Phantom", + id: "finance.porta", + name: "PortaWallet", + hasMobileSupport: true, + }, + { + id: "org.alephium", + name: "Alephium Wallet", + hasMobileSupport: true, + }, + { + id: "network.over", + name: "OverFlex", + hasMobileSupport: true, + }, + { + id: "io.walletverse", + name: "Walletverse", + hasMobileSupport: true, + }, + { + id: "com.berasig", + name: "BeraSig", + hasMobileSupport: true, + }, + { + id: "org.shefi", + name: "SheFi", + hasMobileSupport: true, + }, + { + id: "com.wemixplay", + name: "WEMIX Play", + hasMobileSupport: true, + }, + { + id: "co.family.wallet", + name: "Family", + hasMobileSupport: true, + }, + { + id: "io.legionnetwork", + name: "LegionNetwork", + hasMobileSupport: true, + }, + { + id: "com.bitnovo", + name: "Bitnovo Wallet", + hasMobileSupport: true, + }, + { + id: "io.safecryptowallet", + name: "SafeWallet", + hasMobileSupport: true, + }, + { + id: "ag.jup", + name: "Jupiter", + hasMobileSupport: true, + }, + { + id: "io.koalawallet", + name: "Koala Wallet", + hasMobileSupport: true, + }, + { + id: "io.nonbank", + name: "NonBank", + hasMobileSupport: true, + }, + { + id: "io.universaleverything", + name: "UniversalProfiles", + hasMobileSupport: true, + }, + { + id: "com.coinbase.wallet", + name: "Coinbase Wallet", hasMobileSupport: false, }, { @@ -1844,11 +1934,6 @@ const ALL_MINIMAL_WALLET_INFOS = ([ name: "Brave Wallet", hasMobileSupport: false, }, - { - id: "io.xdefi", - name: "XDEFI Wallet", - hasMobileSupport: false, - }, { id: "com.moongate.one", name: "MG", @@ -1879,21 +1964,11 @@ const ALL_MINIMAL_WALLET_INFOS = ([ name: "FinoaConnect", hasMobileSupport: false, }, - { - id: "inc.tomo", - name: "tomo extension wallet", - hasMobileSupport: false, - }, { id: "com.walletconnect.com", name: "SampleW", hasMobileSupport: false, }, - { - id: "io.leapwallet.CompassWallet", - name: "Compass Wallet", - hasMobileSupport: false, - }, { id: "app.nightly", name: "Nightly", @@ -1904,6 +1979,26 @@ const ALL_MINIMAL_WALLET_INFOS = ([ name: "Blazpay", hasMobileSupport: false, }, + { + id: "io.getjoin.prd", + name: "JOIN MOBILE APP", + hasMobileSupport: false, + }, + { + id: "xyz.talisman", + name: "Talisman Wallet", + hasMobileSupport: false, + }, + { + id: "eu.flashsoft.clear-wallet", + name: "clear-wallet", + hasMobileSupport: false, + }, + { + id: "app.berasig", + name: "BeraSig", + hasMobileSupport: false, + }, { id: "com.lootrush", name: "LootRush", diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/ag.jup/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/ag.jup/image.ts new file mode 100644 index 00000000000..2244cca8c35 --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/ag.jup/image.ts @@ -0,0 +1,7 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +const image = + ""; + +export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/ag.jup/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/ag.jup/index.ts new file mode 100644 index 00000000000..e354ddc1ca4 --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/ag.jup/index.ts @@ -0,0 +1,32 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +export const wallet = { + id: "ag.jup", + name: "Jupiter", + homepage: "https://jup.ag/mobile", + image_id: "7601bec3-144f-4c9d-30a1-2d4a372ede00", + app: { + browser: null, + ios: "https://apps.apple.com/us/app/jupiter-solana-swap-wallet/id6484069059", + android: + "https://play.google.com/store/apps/details?id=ag.jup.jupiter.android", + mac: null, + windows: null, + linux: null, + chrome: null, + firefox: null, + safari: null, + edge: null, + opera: null, + }, + rdns: null, + mobile: { + native: "jupiter://", + universal: null, + }, + desktop: { + native: null, + universal: null, + }, +} as const; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/app.berasig/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/app.berasig/image.ts new file mode 100644 index 00000000000..f1709db85dd --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/app.berasig/image.ts @@ -0,0 +1,7 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +const image = + ""; + +export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/io.xdefi/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/app.berasig/index.ts similarity index 60% rename from packages/thirdweb/src/wallets/__generated__/wallet/io.xdefi/index.ts rename to packages/thirdweb/src/wallets/__generated__/wallet/app.berasig/index.ts index 7b0708d23aa..67cd6c71f9d 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/io.xdefi/index.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/app.berasig/index.ts @@ -2,25 +2,25 @@ // Do not modify this file manually. export const wallet = { - id: "io.xdefi", - name: "XDEFI Wallet", - homepage: "https://www.xdefi.io/", - image_id: "efec6318-7f96-4b30-9287-6c287660cd00", + id: "app.berasig", + name: "BeraSig", + homepage: "https://www.berasig.com/", + image_id: "4b9e9716-c86d-4f1e-4bcc-12af74af7400", app: { - browser: "https://www.xdefi.io/", + browser: null, ios: null, android: null, mac: null, windows: null, linux: null, chrome: - "https://chrome.google.com/webstore/detail/xdefi-wallet/hmeobnfnfcmdkdcmlblgagmfpfboieaf?hl=en", + "https://chromewebstore.google.com/detail/berasig/ckedkkegjbflcfblcjklibnedmfjppbj", firefox: null, safari: null, edge: null, opera: null, }, - rdns: "io.xdefi", + rdns: "app.berasig", mobile: { native: null, universal: null, diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/app.core/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/app.core/index.ts index 3f9c4d06c70..840f16ef0ab 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/app.core/index.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/app.core/index.ts @@ -8,7 +8,8 @@ export const wallet = { "https://core.app/?utm_source=referral&utm_medium=website&utm_campaign=walletconnect", image_id: "35f9c46e-cc57-4aa7-315d-e6ccb2a1d600", app: { - browser: null, + browser: + "https://core.app/?utm_source=referral&utm_medium=website&utm_campaign=walletconnect", ios: "https://apps.apple.com/us/app/core-crypto-wallet-nfts/id6443685999", android: "https://play.google.com/store/apps/details?id=com.avaxwallet&hl=en_US&gl=US", @@ -28,7 +29,7 @@ export const wallet = { universal: "https://core.app", }, desktop: { - native: null, - universal: null, + native: "core://", + universal: "https://core.app", }, } as const; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/app.keplr/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/app.keplr/image.ts index 0d8ea4e4a9a..595f7ebd04d 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/app.keplr/image.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/app.keplr/image.ts @@ -2,6 +2,6 @@ // Do not modify this file manually. const image = - ""; + ""; export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/app.phantom/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/app.phantom/index.ts index 7d674d810bc..5d8e116f310 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/app.phantom/index.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/app.phantom/index.ts @@ -8,8 +8,8 @@ export const wallet = { image_id: "c38443bb-b3c1-4697-e569-408de3fcc100", app: { browser: null, - ios: null, - android: null, + ios: "https://apps.apple.com/us/app/phantom-crypto-wallet/id1598432977", + android: "https://play.google.com/store/apps/details?id=app.phantom&hl=en", mac: null, windows: null, linux: null, @@ -22,7 +22,7 @@ export const wallet = { }, rdns: "app.phantom", mobile: { - native: null, + native: "phantom://", universal: null, }, desktop: { diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/co.family.wallet/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/co.family.wallet/image.ts new file mode 100644 index 00000000000..a1b9fb449c5 --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/co.family.wallet/image.ts @@ -0,0 +1,7 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +const image = + ""; + +export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/co.family.wallet/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/co.family.wallet/index.ts new file mode 100644 index 00000000000..704d745434f --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/co.family.wallet/index.ts @@ -0,0 +1,31 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +export const wallet = { + id: "co.family.wallet", + name: "Family", + homepage: "https://family.co", + image_id: "18ba1b99-6268-4d7e-bead-260e978b1a00", + app: { + browser: null, + ios: "https://apps.apple.com/us/app/family-ethereum-wallet/id1606779267", + android: null, + mac: null, + windows: null, + linux: null, + chrome: null, + firefox: null, + safari: null, + edge: null, + opera: null, + }, + rdns: "co.family.wallet", + mobile: { + native: "familywallet://", + universal: null, + }, + desktop: { + native: null, + universal: null, + }, +} as const; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/co.lobstr/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/co.lobstr/image.ts deleted file mode 100644 index 4d887da91f4..00000000000 --- a/packages/thirdweb/src/wallets/__generated__/wallet/co.lobstr/image.ts +++ /dev/null @@ -1,7 +0,0 @@ -// This file is auto-generated by the `scripts/wallets/generate.ts` script. -// Do not modify this file manually. - -const image = - ""; - -export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/com.berasig/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/com.berasig/image.ts new file mode 100644 index 00000000000..dd0598ae115 --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/com.berasig/image.ts @@ -0,0 +1,7 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +const image = + ""; + +export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/com.berasig/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/com.berasig/index.ts new file mode 100644 index 00000000000..a718b9d4d8b --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/com.berasig/index.ts @@ -0,0 +1,31 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +export const wallet = { + id: "com.berasig", + name: "BeraSig", + homepage: "https://berasig.com", + image_id: "41e234a7-d00e-4b08-f90b-0d5e86231c00", + app: { + browser: null, + ios: "https://apps.apple.com/us/app/berasig-wallet-on-berachain/id6502052535", + android: null, + mac: null, + windows: null, + linux: null, + chrome: null, + firefox: null, + safari: null, + edge: null, + opera: null, + }, + rdns: null, + mobile: { + native: "berasig://", + universal: null, + }, + desktop: { + native: null, + universal: null, + }, +} as const; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/com.binance/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/com.binance/image.ts index 0ad9178ddd5..5be39746d6c 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/com.binance/image.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/com.binance/image.ts @@ -2,6 +2,6 @@ // Do not modify this file manually. const image = - ""; + ""; export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/com.binance/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/com.binance/index.ts index ff9242aea9a..84ca5d8fde1 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/com.binance/index.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/com.binance/index.ts @@ -3,14 +3,14 @@ export const wallet = { id: "com.binance", - name: "Binance Web3 Wallet", + name: "Binance Wallet", homepage: "https://www.binance.com/en/web3wallet", - image_id: "ebac7b39-688c-41e3-7912-a4fefba74600", + image_id: "3d7eb880-7654-431f-ed84-a25712b45200", app: { browser: "https://www.binance.com/en/web3wallet", ios: "https://www.binance.com/en/download", android: "https://www.binance.com/en/download", - mac: "", + mac: null, windows: null, linux: null, chrome: null, diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/com.bitget.web3/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/com.bitget.web3/image.ts index b8e4827d718..bf8854b4b10 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/com.bitget.web3/image.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/com.bitget.web3/image.ts @@ -2,6 +2,6 @@ // Do not modify this file manually. const image = - ""; + ""; export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/com.bitget.web3/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/com.bitget.web3/index.ts index 087177cfebc..a626068f5ef 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/com.bitget.web3/index.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/com.bitget.web3/index.ts @@ -5,7 +5,7 @@ export const wallet = { id: "com.bitget.web3", name: "Bitget Wallet", homepage: "https://web3.bitget.com", - image_id: "68e8063a-ff69-4941-3b40-af09e2fcd700", + image_id: "ac927cca-531b-40e1-0ff2-4eefe946d100", app: { browser: "https://bitkeep.com", ios: "https://web3.bitget.com/en/wallet-download?type=0", diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/com.bitnovo/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/com.bitnovo/image.ts new file mode 100644 index 00000000000..7fb5e22fb89 --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/com.bitnovo/image.ts @@ -0,0 +1,7 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +const image = + ""; + +export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/co.lobstr/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/com.bitnovo/index.ts similarity index 58% rename from packages/thirdweb/src/wallets/__generated__/wallet/co.lobstr/index.ts rename to packages/thirdweb/src/wallets/__generated__/wallet/com.bitnovo/index.ts index bf6d98fd82c..64fbaa0e4a8 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/co.lobstr/index.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/com.bitnovo/index.ts @@ -2,14 +2,14 @@ // Do not modify this file manually. export const wallet = { - id: "co.lobstr", - name: "LOBSTR Wallet", - homepage: "https://lobstr.co/", - image_id: "0dafcaab-0852-47f7-85dd-436b86491d00", + id: "com.bitnovo", + name: "Bitnovo Wallet", + homepage: "https://bitnovo.com", + image_id: "c22b2af0-15a0-4e35-3417-1378b8239100", app: { - browser: "https://lobstr.co/", - ios: "https://apps.apple.com/us/app/lobstr-stellar-wallet/id1404357892", - android: "https://play.google.com/store/apps/details?id=com.lobstr.client", + browser: null, + ios: "https://apps.apple.com/es/app/bitnovo-compra-bitcoin/id1553430666", + android: "https://play.google.com/store/apps/details?id=com.bitnovo.Wallet", mac: null, windows: null, linux: null, @@ -21,8 +21,8 @@ export const wallet = { }, rdns: null, mobile: { - native: "lobstr://", - universal: "https://lobstr.co/uni/wc", + native: "bitnovowallet://", + universal: null, }, desktop: { native: null, diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/com.bybit/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/com.bybit/image.ts index 14959920ee3..53b34b093de 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/com.bybit/image.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/com.bybit/image.ts @@ -2,6 +2,6 @@ // Do not modify this file manually. const image = - ""; + ""; export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/com.bybit/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/com.bybit/index.ts index 0982c215baa..a6d03536558 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/com.bybit/index.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/com.bybit/index.ts @@ -5,7 +5,7 @@ export const wallet = { id: "com.bybit", name: "Bybit Wallet", homepage: "https://www.bybit.com/web3/", - image_id: "b9e64f74-0176-44fd-c603-673a45ed5b00", + image_id: "fa6b5b14-b135-43ea-b6c4-f33570dd5a00", app: { browser: null, ios: "https://apps.apple.com/US/app/id1488296980", diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/com.coinomi/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/com.coinomi/index.ts index b99b93f6ea7..f34426febde 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/com.coinomi/index.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/com.coinomi/index.ts @@ -4,7 +4,7 @@ export const wallet = { id: "com.coinomi", name: "Coinomi", - homepage: "https://www.coinomi.com/", + homepage: "https://www.coinomi.com", image_id: "3b446d16-a908-40c8-5835-9a6efe90dd00", app: { browser: null, diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/com.companyname.swaptobe/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/com.companyname.swaptobe/image.ts new file mode 100644 index 00000000000..90067cf2a42 --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/com.companyname.swaptobe/image.ts @@ -0,0 +1,7 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +const image = + ""; + +export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/com.companyname.swaptobe/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/com.companyname.swaptobe/index.ts new file mode 100644 index 00000000000..d73f548222f --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/com.companyname.swaptobe/index.ts @@ -0,0 +1,32 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +export const wallet = { + id: "com.companyname.swaptobe", + name: "TobeWallet", + homepage: "https://testnet.tobechain.net/testnet/faucet/", + image_id: "ccfadd90-2fe4-41c0-4762-32e1cf9b2700", + app: { + browser: null, + ios: null, + android: + "https://play.google.com/store/apps/details?id=com.companyname.swaptobe&hl=vi", + mac: null, + windows: null, + linux: null, + chrome: null, + firefox: null, + safari: null, + edge: null, + opera: null, + }, + rdns: "com.companyname.swaptobe", + mobile: { + native: "tobewallet://", + universal: null, + }, + desktop: { + native: "tobewallet://", + universal: null, + }, +} as const; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/com.crypto.wallet/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/com.crypto.wallet/image.ts index 18fa29e2367..a7ab0ed619e 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/com.crypto.wallet/image.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/com.crypto.wallet/image.ts @@ -2,6 +2,6 @@ // Do not modify this file manually. const image = - ""; + ""; export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/com.crypto.wallet/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/com.crypto.wallet/index.ts index 7907e125e42..b359feefc0f 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/com.crypto.wallet/index.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/com.crypto.wallet/index.ts @@ -3,9 +3,9 @@ export const wallet = { id: "com.crypto.wallet", - name: "Crypto.com | DeFi Wallet", - homepage: "https://crypto.com/", - image_id: "88388eb4-4471-4e72-c4b4-852d496fea00", + name: "Crypto.com Onchain", + homepage: "https://crypto.com/onchain", + image_id: "4903acdd-6463-44b6-3cf9-f23f4c75ca00", app: { browser: null, ios: "https://apps.apple.com/US/app/id1512048310?mt=8", diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/group.com.flowfoundation.wallet/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/com.flowfoundation.wallet/image.ts similarity index 100% rename from packages/thirdweb/src/wallets/__generated__/wallet/group.com.flowfoundation.wallet/image.ts rename to packages/thirdweb/src/wallets/__generated__/wallet/com.flowfoundation.wallet/image.ts diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/group.com.flowfoundation.wallet/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/com.flowfoundation.wallet/index.ts similarity index 85% rename from packages/thirdweb/src/wallets/__generated__/wallet/group.com.flowfoundation.wallet/index.ts rename to packages/thirdweb/src/wallets/__generated__/wallet/com.flowfoundation.wallet/index.ts index 89c96cc2c56..b02d914b3e6 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/group.com.flowfoundation.wallet/index.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/com.flowfoundation.wallet/index.ts @@ -2,7 +2,7 @@ // Do not modify this file manually. export const wallet = { - id: "group.com.flowfoundation.wallet", + id: "com.flowfoundation.wallet", name: "Flow Wallet", homepage: "https://wallet.flow.com/", image_id: "f67a1db8-5704-4353-ead8-bd85c02a8700", @@ -21,10 +21,10 @@ export const wallet = { edge: null, opera: null, }, - rdns: "group.com.flowfoundation.wallet", + rdns: "com.flowfoundation.wallet", mobile: { native: "frw://", - universal: "https://frw-link.lilico.app/wc", + universal: "https://frw-link.lilico.app", }, desktop: { native: null, diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/com.kraken/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/com.kraken/image.ts index b7e2c36eef5..458330bb850 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/com.kraken/image.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/com.kraken/image.ts @@ -2,6 +2,6 @@ // Do not modify this file manually. const image = - ""; + ""; export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/com.kraken/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/com.kraken/index.ts index a94f94bb4fc..c8b3c6028a6 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/com.kraken/index.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/com.kraken/index.ts @@ -5,7 +5,7 @@ export const wallet = { id: "com.kraken", name: "Kraken Wallet ", homepage: "https://www.kraken.com/wallet", - image_id: "8909e826-63e4-42b3-60b2-8a6a54060900", + image_id: "3f4e6025-d008-4edc-1fbd-19f54294a900", app: { browser: null, ios: "https://apps.apple.com/us/app/kraken-wallet/id1626327149", diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/com.ledger/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/com.ledger/image.ts index 4219f9e199c..a10d10e9a84 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/com.ledger/image.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/com.ledger/image.ts @@ -2,6 +2,6 @@ // Do not modify this file manually. const image = - ""; + ""; export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/com.ledger/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/com.ledger/index.ts index 1aa47bfa61d..2875cc69a5e 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/com.ledger/index.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/com.ledger/index.ts @@ -5,7 +5,7 @@ export const wallet = { id: "com.ledger", name: "Ledger Live", homepage: "https://www.ledger.com/ledger-live", - image_id: "a7f416de-aa03-4c5e-3280-ab49269aef00", + image_id: "c20e1cec-05e8-4ac6-a086-7ce355092400", app: { browser: null, ios: "https://itunes.apple.com/app/id1361671700", diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/com.okex.wallet/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/com.okex.wallet/image.ts index 4f3baba0008..dabe16dbb3d 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/com.okex.wallet/image.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/com.okex.wallet/image.ts @@ -2,6 +2,6 @@ // Do not modify this file manually. const image = - ""; + ""; export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/com.okex.wallet/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/com.okex.wallet/index.ts index 7e110cf6363..923ff7e7149 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/com.okex.wallet/index.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/com.okex.wallet/index.ts @@ -5,7 +5,7 @@ export const wallet = { id: "com.okex.wallet", name: "OKX Wallet", homepage: "https://www.okx.com/web3", - image_id: "45f2f08e-fc0c-4d62-3e63-404e72170500", + image_id: "b011bd5a-a887-44e2-12b0-39efbd9e5600", app: { browser: null, ios: "https://apps.apple.com/us/app/okx-buy-bitcoin-eth-crypto/id1327268470", diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/com.roninchain.wallet/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/com.roninchain.wallet/image.ts index ced0b87ce5f..0b2799ceb69 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/com.roninchain.wallet/image.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/com.roninchain.wallet/image.ts @@ -2,6 +2,6 @@ // Do not modify this file manually. const image = - ""; + ""; export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/com.roninchain.wallet/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/com.roninchain.wallet/index.ts index 05c6848c606..954e6978803 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/com.roninchain.wallet/index.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/com.roninchain.wallet/index.ts @@ -5,7 +5,7 @@ export const wallet = { id: "com.roninchain.wallet", name: "Ronin Wallet", homepage: "https://wallet.roninchain.com/", - image_id: "bd78de7e-36da-4552-ebdd-2e420ba05900", + image_id: "689f6eb4-0378-41e1-0993-0767400cb600", app: { browser: null, ios: "https://apps.apple.com/us/app/ronin-wallet/id1592675001", diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/com.safepal/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/com.safepal/image.ts index 6f917e00e12..3973d26dd8b 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/com.safepal/image.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/com.safepal/image.ts @@ -2,6 +2,6 @@ // Do not modify this file manually. const image = - ""; + ""; export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/com.safepal/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/com.safepal/index.ts index 6f5b9a9f87c..23a74d0fde1 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/com.safepal/index.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/com.safepal/index.ts @@ -5,7 +5,7 @@ export const wallet = { id: "com.safepal", name: "SafePal", homepage: "https://safepal.com/", - image_id: "252753e7-b783-4e03-7f77-d39864530900", + image_id: "4e7d6f52-f663-4fc1-4b88-eebe7fc72800", app: { browser: "https://chrome.google.com/webstore/detail/safepal-extension-wallet/lgmpcpglpngdoalbgeoldeajfclnhafa", diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/com.trustwallet.app/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/com.trustwallet.app/image.ts index 59c6daf9af0..ebd316ed9b0 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/com.trustwallet.app/image.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/com.trustwallet.app/image.ts @@ -2,6 +2,6 @@ // Do not modify this file manually. const image = - ""; + ""; export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/com.trustwallet.app/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/com.trustwallet.app/index.ts index f2b16c01599..cff395003d1 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/com.trustwallet.app/index.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/com.trustwallet.app/index.ts @@ -5,7 +5,7 @@ export const wallet = { id: "com.trustwallet.app", name: "Trust Wallet", homepage: "https://trustwallet.com/", - image_id: "7677b54f-3486-46e2-4e37-bf8747814f00", + image_id: "3386dde1-8b24-48c8-4b81-16979e342000", app: { browser: null, ios: "https://apps.apple.com/app/apple-store/id1288339409", diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/com.walletconnect.com/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/com.walletconnect.com/image.ts index 71b3c918a75..c719e7c3381 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/com.walletconnect.com/image.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/com.walletconnect.com/image.ts @@ -2,6 +2,6 @@ // Do not modify this file manually. const image = - ""; + ""; export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/com.walletconnect.com/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/com.walletconnect.com/index.ts index d4204e851d0..453e6d0d813 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/com.walletconnect.com/index.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/com.walletconnect.com/index.ts @@ -5,7 +5,7 @@ export const wallet = { id: "com.walletconnect.com", name: "SampleW", homepage: "https://walletconnect.com", - image_id: "b81aaf2d-3548-4e65-46cd-fd59fbb6b300", + image_id: "171f0822-acf5-4eba-4392-a2d16db90400", app: { browser: null, ios: null, diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/com.wemixplay/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/com.wemixplay/image.ts new file mode 100644 index 00000000000..59d03bb7973 --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/com.wemixplay/image.ts @@ -0,0 +1,7 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +const image = + ""; + +export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/com.wemixplay/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/com.wemixplay/index.ts new file mode 100644 index 00000000000..aeefd9f724e --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/com.wemixplay/index.ts @@ -0,0 +1,32 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +export const wallet = { + id: "com.wemixplay", + name: "WEMIX Play", + homepage: "https://wemixplay.com/", + image_id: "3d7b7226-3005-4ace-4a35-d5f67aee2300", + app: { + browser: null, + ios: "https://apps.apple.com/app/id6547834517", + android: + "https://play.google.com/store/apps/details?id=com.wemade.wemixplay", + mac: null, + windows: null, + linux: null, + chrome: null, + firefox: null, + safari: null, + edge: null, + opera: null, + }, + rdns: null, + mobile: { + native: "wpapp://wemixplay.com/", + universal: "https://wemixplay.onelink.me/Bq1n/cssdwedi", + }, + desktop: { + native: null, + universal: null, + }, +} as const; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/eu.flashsoft.clear-wallet/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/eu.flashsoft.clear-wallet/image.ts new file mode 100644 index 00000000000..c9e2571733d --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/eu.flashsoft.clear-wallet/image.ts @@ -0,0 +1,7 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +const image = + ""; + +export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/eu.flashsoft.clear-wallet/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/eu.flashsoft.clear-wallet/index.ts new file mode 100644 index 00000000000..49026a5f97d --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/eu.flashsoft.clear-wallet/index.ts @@ -0,0 +1,32 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +export const wallet = { + id: "eu.flashsoft.clear-wallet", + name: "clear-wallet", + homepage: "https://clear-wallet.flashsoft.eu", + image_id: "a6d4c2de-1bd9-404f-f3d2-3d2ed9bf5000", + app: { + browser: null, + ios: null, + android: null, + mac: null, + windows: null, + linux: null, + chrome: + "https://chromewebstore.google.com/detail/clear-evm-wallet-clw/djlahdpfkflehaepgohnnodmaajabdlg?hl=en&authuser=0", + firefox: null, + safari: null, + edge: null, + opera: null, + }, + rdns: "eu.flashsoft.clear-wallet", + mobile: { + native: null, + universal: null, + }, + desktop: { + native: null, + universal: null, + }, +} as const; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/finance.porta/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/finance.porta/image.ts new file mode 100644 index 00000000000..021a21a8b1b --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/finance.porta/image.ts @@ -0,0 +1,7 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +const image = + ""; + +export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/finance.porta/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/finance.porta/index.ts new file mode 100644 index 00000000000..64ac988a417 --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/finance.porta/index.ts @@ -0,0 +1,32 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +export const wallet = { + id: "finance.porta", + name: "PortaWallet", + homepage: "https://porta.finance", + image_id: "07bc52e6-c402-439d-faea-a5736cd25300", + app: { + browser: null, + ios: null, + android: + "https://play.google.com/store/apps/details?id=com.wallet.porta.android", + mac: null, + windows: null, + linux: null, + chrome: null, + firefox: null, + safari: null, + edge: null, + opera: null, + }, + rdns: null, + mobile: { + native: "porta://", + universal: null, + }, + desktop: { + native: null, + universal: null, + }, +} as const; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/global.safe/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/global.safe/image.ts index 2b81f7f1fc6..3d72e1dc392 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/global.safe/image.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/global.safe/image.ts @@ -2,6 +2,6 @@ // Do not modify this file manually. const image = - ""; + ""; export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/global.safe/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/global.safe/index.ts index 1dce4c1e994..e331529bbc9 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/global.safe/index.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/global.safe/index.ts @@ -5,7 +5,7 @@ export const wallet = { id: "global.safe", name: "Safe", homepage: "https://safe.global/", - image_id: "3913df81-63c2-4413-d60b-8ff83cbed500", + image_id: "a578bd45-b418-4111-2c56-8ddcd1417c00", app: { browser: "https://app.safe.global/", ios: "https://apps.apple.com/app/id1515759131", diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/id.competence/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/id.competence/image.ts index d2bbb6f711f..03550115b52 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/id.competence/image.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/id.competence/image.ts @@ -2,6 +2,6 @@ // Do not modify this file manually. const image = - ""; + ""; export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/im.token/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/im.token/image.ts index 60b749226c4..f038bdd2dc8 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/im.token/image.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/im.token/image.ts @@ -2,6 +2,6 @@ // Do not modify this file manually. const image = - ""; + ""; export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/im.token/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/im.token/index.ts index 5c6965c46e5..641fb22e684 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/im.token/index.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/im.token/index.ts @@ -5,12 +5,12 @@ export const wallet = { id: "im.token", name: "imToken", homepage: "https://token.im/", - image_id: "99520548-525c-49d7-fb2f-5db65293b000", + image_id: "67336675-0daa-489b-6885-cb95234bc400", app: { browser: "https://token.im/", ios: "https://apps.apple.com/us/app/imtoken2/id1384798940", android: "https://play.google.com/store/apps/details?id=im.token.app", - mac: "", + mac: null, windows: null, linux: null, chrome: null, diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/inc.tomo/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/inc.tomo/image.ts index 027ef894ae0..e15a7f07bc7 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/inc.tomo/image.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/inc.tomo/image.ts @@ -2,6 +2,6 @@ // Do not modify this file manually. const image = - ""; + ""; export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/inc.tomo/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/inc.tomo/index.ts index 58e94811532..bba58f286f7 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/inc.tomo/index.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/inc.tomo/index.ts @@ -3,9 +3,9 @@ export const wallet = { id: "inc.tomo", - name: "tomo extension wallet", + name: "Tomo Wallet", homepage: "https://tomo.inc", - image_id: "27e33ac7-b846-446d-a126-b0820904f800", + image_id: "95c9f957-b1e4-4619-fa7c-a77569d2fe00", app: { browser: null, ios: "https://apps.apple.com/us/app/tomo-inc/id6468010287", @@ -22,7 +22,7 @@ export const wallet = { }, rdns: "inc.tomo", mobile: { - native: null, + native: "tomo://", universal: null, }, desktop: { diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/io.1inch.wallet/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/io.1inch.wallet/image.ts index d5b62b5a19f..28d435cb5d0 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/io.1inch.wallet/image.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/io.1inch.wallet/image.ts @@ -2,6 +2,6 @@ // Do not modify this file manually. const image = - ""; + ""; export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/io.1inch.wallet/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/io.1inch.wallet/index.ts index f9f6adf635c..152b37a762e 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/io.1inch.wallet/index.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/io.1inch.wallet/index.ts @@ -5,7 +5,7 @@ export const wallet = { id: "io.1inch.wallet", name: "1inch Wallet", homepage: "http://wallet.1inch.io", - image_id: "52b1da3c-9e72-40ae-5dac-6142addd9c00", + image_id: "6c9f7cd6-c3d7-4b54-6f9d-663fe4b56000", app: { browser: null, ios: "https://apps.apple.com/us/app/1inch-defi-wallet/id1546049391", diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/io.leapwallet.CompassWallet/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/io.compasswallet/image.ts similarity index 100% rename from packages/thirdweb/src/wallets/__generated__/wallet/io.leapwallet.CompassWallet/image.ts rename to packages/thirdweb/src/wallets/__generated__/wallet/io.compasswallet/image.ts diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/io.leapwallet.CompassWallet/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/io.compasswallet/index.ts similarity index 75% rename from packages/thirdweb/src/wallets/__generated__/wallet/io.leapwallet.CompassWallet/index.ts rename to packages/thirdweb/src/wallets/__generated__/wallet/io.compasswallet/index.ts index f605b4cbeb2..fd5cd7e1acf 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/io.leapwallet.CompassWallet/index.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/io.compasswallet/index.ts @@ -2,14 +2,15 @@ // Do not modify this file manually. export const wallet = { - id: "io.leapwallet.CompassWallet", + id: "io.compasswallet", name: "Compass Wallet", homepage: "https://compasswallet.io/", image_id: "1d7dea00-96be-4ce8-ca15-d14bddbb5000", app: { browser: null, - ios: null, - android: null, + ios: "https://apps.apple.com/us/app/compass-wallet-for-sei/id6450257441", + android: + "https://play.google.com/store/apps/details?id=io.leapwallet.compass", mac: null, windows: null, linux: null, @@ -20,9 +21,9 @@ export const wallet = { edge: "https://chromewebstore.google.com/detail/compass-wallet-for-sei/anokgmphncpekkhclmingpimjmcooifb", opera: null, }, - rdns: "io.leapwallet.CompassWallet", + rdns: null, mobile: { - native: null, + native: "leapcompass://", universal: null, }, desktop: { diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/io.cypherwallet/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/io.cypherhq/image.ts similarity index 100% rename from packages/thirdweb/src/wallets/__generated__/wallet/io.cypherwallet/image.ts rename to packages/thirdweb/src/wallets/__generated__/wallet/io.cypherhq/image.ts diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/io.cypherwallet/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/io.cypherhq/index.ts similarity index 89% rename from packages/thirdweb/src/wallets/__generated__/wallet/io.cypherwallet/index.ts rename to packages/thirdweb/src/wallets/__generated__/wallet/io.cypherhq/index.ts index eea0c281821..0e7a01d099c 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/io.cypherwallet/index.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/io.cypherhq/index.ts @@ -2,9 +2,9 @@ // Do not modify this file manually. export const wallet = { - id: "io.cypherwallet", + id: "io.cypherhq", name: "Cypher Wallet", - homepage: "https://cypherwallet.io", + homepage: "https://cypherhq.io", image_id: "7bce0965-a4cc-4aad-6217-009d51017500", app: { browser: null, @@ -27,7 +27,7 @@ export const wallet = { universal: null, }, desktop: { - native: null, + native: "cypherwallet://", universal: null, }, } as const; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/io.getjoin.prd/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/io.getjoin.prd/image.ts new file mode 100644 index 00000000000..3c3d9286506 --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/io.getjoin.prd/image.ts @@ -0,0 +1,7 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +const image = + ""; + +export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/io.getjoin.prd/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/io.getjoin.prd/index.ts new file mode 100644 index 00000000000..99ee60cb632 --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/io.getjoin.prd/index.ts @@ -0,0 +1,31 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +export const wallet = { + id: "io.getjoin.prd", + name: "JOIN MOBILE APP", + homepage: "https://getjoin.io", + image_id: "bd200406-7b27-452f-bb23-14e22ac47500", + app: { + browser: null, + ios: "https://apps.apple.com/mk/app/join-wallet/id6590635145?uo=2", + android: "https://play.google.com/store/apps/details?id=io.getjoin.prd", + mac: null, + windows: null, + linux: null, + chrome: null, + firefox: null, + safari: null, + edge: null, + opera: null, + }, + rdns: "io.getjoin.prd", + mobile: { + native: null, + universal: null, + }, + desktop: { + native: null, + universal: null, + }, +} as const; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/io.huddln/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/io.huddln/image.ts index d9be7ad9e84..f93b27c1d84 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/io.huddln/image.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/io.huddln/image.ts @@ -2,6 +2,6 @@ // Do not modify this file manually. const image = - ""; + ""; export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/io.internetmoney/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/io.internetmoney/image.ts index e1a5cd61b6b..df426faaf6f 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/io.internetmoney/image.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/io.internetmoney/image.ts @@ -2,6 +2,6 @@ // Do not modify this file manually. const image = - ""; + ""; export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/io.koalawallet/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/io.koalawallet/image.ts new file mode 100644 index 00000000000..23818cf25f5 --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/io.koalawallet/image.ts @@ -0,0 +1,7 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +const image = + ""; + +export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/io.koalawallet/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/io.koalawallet/index.ts new file mode 100644 index 00000000000..951e54590a2 --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/io.koalawallet/index.ts @@ -0,0 +1,33 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +export const wallet = { + id: "io.koalawallet", + name: "Koala Wallet", + homepage: "https://koalawallet.io/", + image_id: "0d222367-ffaf-4402-3873-fdc80e521b00", + app: { + browser: null, + ios: "https://apps.apple.com/us/app/koala-wallet/id1627486259", + android: + "https://play.google.com/store/apps/details?id=com.eucalyptuslabs.kowallet", + mac: null, + windows: null, + linux: null, + chrome: + "https://chrome.google.com/webstore/detail/koala-wallet/lnnnmfcpbkafcpgdilckhmhbkkbpkmid", + firefox: null, + safari: null, + edge: "https://chrome.google.com/webstore/detail/koala-wallet/lnnnmfcpbkafcpgdilckhmhbkkbpkmid", + opera: null, + }, + rdns: null, + mobile: { + native: "kowallet://", + universal: null, + }, + desktop: { + native: null, + universal: null, + }, +} as const; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/io.leapwallet/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/io.leapwallet/image.ts index a88c8ab8fe3..0debc8ee148 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/io.leapwallet/image.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/io.leapwallet/image.ts @@ -2,6 +2,6 @@ // Do not modify this file manually. const image = - ""; + ""; export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/io.leapwallet/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/io.leapwallet/index.ts index 10674095fb4..47d50461cb0 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/io.leapwallet/index.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/io.leapwallet/index.ts @@ -5,7 +5,7 @@ export const wallet = { id: "io.leapwallet", name: "Leap Cosmos Wallet", homepage: "https://leapwallet.io/", - image_id: "73e6b2b2-8c02-42e9-84f5-82a859978200", + image_id: "d64ae9c7-c0be-495d-041e-35c6bb2cc100", app: { browser: null, ios: "https://apps.apple.com/in/app/leap-cosmos/id1642465549/", diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/io.legionnetwork/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/io.legionnetwork/image.ts new file mode 100644 index 00000000000..c41734240f9 --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/io.legionnetwork/image.ts @@ -0,0 +1,7 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +const image = + ""; + +export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/io.legionnetwork/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/io.legionnetwork/index.ts new file mode 100644 index 00000000000..a2db9e9f1da --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/io.legionnetwork/index.ts @@ -0,0 +1,32 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +export const wallet = { + id: "io.legionnetwork", + name: "LegionNetwork", + homepage: "https://www.legionnetwork.io/", + image_id: "26044229-4a61-4b14-a2ed-5413fe435a00", + app: { + browser: null, + ios: "https://apps.apple.com/gb/app/legion-network-crypto-superapp/id1602921528", + android: + "https://play.google.com/store/apps/details?id=com.legion.production&pcampaignid=web_share", + mac: null, + windows: null, + linux: null, + chrome: null, + firefox: null, + safari: null, + edge: null, + opera: null, + }, + rdns: null, + mobile: { + native: "legionapp://", + universal: null, + }, + desktop: { + native: null, + universal: null, + }, +} as const; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/io.metamask/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/io.metamask/image.ts index e56ed9bfe19..feba6456c54 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/io.metamask/image.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/io.metamask/image.ts @@ -2,6 +2,6 @@ // Do not modify this file manually. const image = - ""; + ""; export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/io.metamask/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/io.metamask/index.ts index 71c81b180da..57c0f5db99b 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/io.metamask/index.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/io.metamask/index.ts @@ -5,7 +5,7 @@ export const wallet = { id: "io.metamask", name: "MetaMask", homepage: "https://metamask.io/", - image_id: "018b2d52-10e9-4158-1fde-a5d5bac5aa00", + image_id: "fda51881-4e76-454e-68bb-20995c3f0700", app: { browser: null, ios: "https://apps.apple.com/us/app/metamask/id1438144202", diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/io.moonstake/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/io.moonstake/image.ts index 611fcca7a49..de0c4fe1f1d 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/io.moonstake/image.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/io.moonstake/image.ts @@ -2,6 +2,6 @@ // Do not modify this file manually. const image = - ""; + ""; export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/io.nonbank/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/io.nonbank/image.ts new file mode 100644 index 00000000000..7b3f0297007 --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/io.nonbank/image.ts @@ -0,0 +1,7 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +const image = + ""; + +export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/io.nonbank/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/io.nonbank/index.ts new file mode 100644 index 00000000000..73d78a45425 --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/io.nonbank/index.ts @@ -0,0 +1,31 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +export const wallet = { + id: "io.nonbank", + name: "NonBank", + homepage: "https://nonbank.io/", + image_id: "fe06c7ed-3df1-4cc7-9686-c920914abd00", + app: { + browser: null, + ios: "https://apps.apple.com/us/app/nonbank/id222", + android: "https://play.google.com/store/apps/details?id=io.nonbank", + mac: null, + windows: null, + linux: null, + chrome: null, + firefox: null, + safari: null, + edge: null, + opera: null, + }, + rdns: null, + mobile: { + native: "nonbank://", + universal: null, + }, + desktop: { + native: null, + universal: null, + }, +} as const; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/io.noone/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/io.noone/image.ts index 6d4bca33a96..64edc96dfe1 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/io.noone/image.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/io.noone/image.ts @@ -2,6 +2,6 @@ // Do not modify this file manually. const image = - ""; + ""; export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/io.noone/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/io.noone/index.ts index ae9197750e2..e065ec4ef67 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/io.noone/index.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/io.noone/index.ts @@ -23,7 +23,7 @@ export const wallet = { }, rdns: null, mobile: { - native: "://", + native: "crypto.noone.wallet://walletcon", universal: null, }, desktop: { diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/io.safecryptowallet/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/io.safecryptowallet/image.ts new file mode 100644 index 00000000000..5fd207d6654 --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/io.safecryptowallet/image.ts @@ -0,0 +1,7 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +const image = + ""; + +export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/io.safecryptowallet/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/io.safecryptowallet/index.ts new file mode 100644 index 00000000000..df50fa34344 --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/io.safecryptowallet/index.ts @@ -0,0 +1,31 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +export const wallet = { + id: "io.safecryptowallet", + name: "SafeWallet", + homepage: "https://safecryptowallet.io", + image_id: "c4f43408-612b-4777-c9d6-a022934ce600", + app: { + browser: null, + ios: "https://apps.apple.com/us/app/safe-crypto-wallet-blockchain/id6449599259?mt=8&shortlink=4ybm9n4d&c=safe+wallet&pid=clickwebsite&af_xp=custom&source_caller=ui", + android: null, + mac: null, + windows: null, + linux: null, + chrome: null, + firefox: null, + safari: null, + edge: null, + opera: null, + }, + rdns: null, + mobile: { + native: "safewallet://", + universal: null, + }, + desktop: { + native: null, + universal: null, + }, +} as const; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/io.universaleverything/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/io.universaleverything/image.ts new file mode 100644 index 00000000000..7ebf04b91c0 --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/io.universaleverything/image.ts @@ -0,0 +1,7 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +const image = + ""; + +export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/io.universaleverything/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/io.universaleverything/index.ts new file mode 100644 index 00000000000..83524367e43 --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/io.universaleverything/index.ts @@ -0,0 +1,31 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +export const wallet = { + id: "io.universaleverything", + name: "UniversalProfiles", + homepage: "https://universaleverything.io", + image_id: "4537fb11-ada3-4009-37c2-c70ed4b46300", + app: { + browser: null, + ios: "https://apps.apple.com/us/app/universalprofiles/id6702018631", + android: null, + mac: null, + windows: null, + linux: null, + chrome: null, + firefox: null, + safari: null, + edge: null, + opera: null, + }, + rdns: null, + mobile: { + native: "io.universaleverything.universalprofiles://wallet-connect", + universal: null, + }, + desktop: { + native: null, + universal: null, + }, +} as const; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/io.walletverse/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/io.walletverse/image.ts new file mode 100644 index 00000000000..97576b00906 --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/io.walletverse/image.ts @@ -0,0 +1,7 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +const image = + ""; + +export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/io.walletverse/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/io.walletverse/index.ts new file mode 100644 index 00000000000..86260b5caa0 --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/io.walletverse/index.ts @@ -0,0 +1,31 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +export const wallet = { + id: "io.walletverse", + name: "Walletverse", + homepage: "https://walletverse.io/", + image_id: "ca91138e-0546-4cfe-071d-2181241dc600", + app: { + browser: null, + ios: "https://apps.apple.com/us/app/wallet-verse-defi-buy-crypto/id6462672660", + android: "https://play.google.com/store/apps/details?id=com.walletverse", + mac: null, + windows: null, + linux: null, + chrome: null, + firefox: null, + safari: null, + edge: null, + opera: null, + }, + rdns: null, + mobile: { + native: "walletverse://", + universal: "https://walletverse.io", + }, + desktop: { + native: null, + universal: null, + }, +} as const; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/io.xdefi/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/io.xdefi/image.ts deleted file mode 100644 index 27e1fe8db31..00000000000 --- a/packages/thirdweb/src/wallets/__generated__/wallet/io.xdefi/image.ts +++ /dev/null @@ -1,7 +0,0 @@ -// This file is auto-generated by the `scripts/wallets/generate.ts` script. -// Do not modify this file manually. - -const image = - ""; - -export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/io.zerion.wallet/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/io.zerion.wallet/image.ts index 1b8b1695f15..7842e37346c 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/io.zerion.wallet/image.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/io.zerion.wallet/image.ts @@ -2,6 +2,6 @@ // Do not modify this file manually. const image = - ""; + ""; export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/io.zerion.wallet/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/io.zerion.wallet/index.ts index ee9e55ca4af..99c1a3fbd51 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/io.zerion.wallet/index.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/io.zerion.wallet/index.ts @@ -5,7 +5,7 @@ export const wallet = { id: "io.zerion.wallet", name: "Zerion", homepage: "https://zerion.io/", - image_id: "73f6f52f-7862-49e7-bb85-ba93ab72cc00", + image_id: "77c1d3dd-0213-400a-f9cc-bfd524c47f00", app: { browser: "https://app.zerion.io", ios: "https://apps.apple.com/app/id1456732565", diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/me.rainbow/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/me.rainbow/image.ts index cddc5f6f224..15e22dbf4a4 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/me.rainbow/image.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/me.rainbow/image.ts @@ -2,6 +2,6 @@ // Do not modify this file manually. const image = - ""; + ""; export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/me.rainbow/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/me.rainbow/index.ts index 091548230e6..66ac97e296e 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/me.rainbow/index.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/me.rainbow/index.ts @@ -5,7 +5,7 @@ export const wallet = { id: "me.rainbow", name: "Rainbow", homepage: "https://rainbow.me/", - image_id: "7a33d7f1-3d12-4b5c-f3ee-5cd83cb1b500", + image_id: "a9978739-0685-43d5-bb3c-c11545d91300", app: { browser: null, ios: "https://apps.apple.com/app/apple-store/id1457119021?pt=119997837&ct=wc&mt=8", diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/network.mrhb/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/network.mrhb/image.ts index e78aa3e7a0f..71e40aea00d 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/network.mrhb/image.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/network.mrhb/image.ts @@ -2,6 +2,6 @@ // Do not modify this file manually. const image = - ""; + ""; export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/network.over/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/network.over/image.ts new file mode 100644 index 00000000000..61ba5b2ac7d --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/network.over/image.ts @@ -0,0 +1,7 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +const image = + ""; + +export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/network.over/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/network.over/index.ts new file mode 100644 index 00000000000..b07f1aa42d0 --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/network.over/index.ts @@ -0,0 +1,32 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +export const wallet = { + id: "network.over", + name: "OverFlex", + homepage: "https://over.network/overflex", + image_id: "ac442ec8-206d-4885-41dc-005aa94bc500", + app: { + browser: null, + ios: "https://apps.apple.com/us/app/overwallet-for-over-protocol/id6447250892", + android: + "https://play.google.com/store/apps/details?id=com.superblock.overmobile", + mac: null, + windows: null, + linux: null, + chrome: null, + firefox: null, + safari: null, + edge: null, + opera: null, + }, + rdns: null, + mobile: { + native: "overflex://", + universal: null, + }, + desktop: { + native: null, + universal: null, + }, +} as const; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/org.alephium/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/org.alephium/image.ts new file mode 100644 index 00000000000..581a6dbfa8e --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/org.alephium/image.ts @@ -0,0 +1,7 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +const image = + ""; + +export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/org.alephium/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/org.alephium/index.ts new file mode 100644 index 00000000000..f1d26f14aed --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/org.alephium/index.ts @@ -0,0 +1,32 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +export const wallet = { + id: "org.alephium", + name: "Alephium Wallet", + homepage: "https://alephium.org/", + image_id: "3ece76f1-fc71-4fad-2d28-707f5a8d2300", + app: { + browser: null, + ios: "https://apps.apple.com/us/app/alephium-wallet/id6469043072", + android: + "https://play.google.com/store/apps/details?id=org.alephium.wallet", + mac: null, + windows: null, + linux: null, + chrome: null, + firefox: null, + safari: null, + edge: null, + opera: null, + }, + rdns: null, + mobile: { + native: "alephium://", + universal: null, + }, + desktop: { + native: null, + universal: null, + }, +} as const; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/org.shefi/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/org.shefi/image.ts new file mode 100644 index 00000000000..be5f01dd1ba --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/org.shefi/image.ts @@ -0,0 +1,7 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +const image = + ""; + +export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/org.shefi/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/org.shefi/index.ts new file mode 100644 index 00000000000..75e865d1b99 --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/org.shefi/index.ts @@ -0,0 +1,31 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +export const wallet = { + id: "org.shefi", + name: "SheFi", + homepage: "https://www.shefi.org", + image_id: "a1a909e8-526b-4452-8788-5bb21e2b9e00", + app: { + browser: null, + ios: "https://testflight.apple.com/join/CEmx1nCa", + android: "https://play.google.com/store/apps/details?id=org.shefi.app", + mac: null, + windows: null, + linux: null, + chrome: null, + firefox: null, + safari: null, + edge: null, + opera: null, + }, + rdns: null, + mobile: { + native: "shefi://", + universal: null, + }, + desktop: { + native: null, + universal: null, + }, +} as const; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/org.uniswap/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/org.uniswap/image.ts index a9c6bb28cdb..0d375b1bb9b 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/org.uniswap/image.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/org.uniswap/image.ts @@ -2,6 +2,6 @@ // Do not modify this file manually. const image = - ""; + ""; export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/org.uniswap/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/org.uniswap/index.ts index 4b6b2a65cde..8ae0f6bb769 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/org.uniswap/index.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/org.uniswap/index.ts @@ -5,7 +5,7 @@ export const wallet = { id: "org.uniswap", name: "Uniswap Wallet", homepage: "https://uniswap.org", - image_id: "bff9cf1f-df19-42ce-f62a-87f04df13c00", + image_id: "6033c33c-0773-48e3-a12f-e7fbf409e700", app: { browser: null, ios: "https://apps.apple.com/us/app/uniswap-wallet/id6443944476", diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/pro.tokenpocket/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/pro.tokenpocket/image.ts index 00c26300f1b..9144122f676 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/pro.tokenpocket/image.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/pro.tokenpocket/image.ts @@ -2,6 +2,6 @@ // Do not modify this file manually. const image = - ""; + ""; export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/pro.tokenpocket/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/pro.tokenpocket/index.ts index 08668a6d424..02b51f80107 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/pro.tokenpocket/index.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/pro.tokenpocket/index.ts @@ -5,7 +5,7 @@ export const wallet = { id: "pro.tokenpocket", name: "TokenPocket", homepage: "https://tokenpocket.pro/", - image_id: "f3119826-4ef5-4d31-4789-d4ae5c18e400", + image_id: "d8e930b6-ccde-471e-ecbe-6967b1c0c400", app: { browser: "https://chrome.google.com/webstore/detail/tokenpocket/mfgccjchihfkkindfppnaooecgfneiii", diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/xyz.bonuz/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/xyz.bonuz/image.ts index ecb7627957a..632fd16f307 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/xyz.bonuz/image.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/xyz.bonuz/image.ts @@ -2,6 +2,6 @@ // Do not modify this file manually. const image = - ""; + ""; export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/xyz.ctrl/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/xyz.ctrl/image.ts new file mode 100644 index 00000000000..aebbecfc59a --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/xyz.ctrl/image.ts @@ -0,0 +1,7 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +const image = + ""; + +export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/xyz.ctrl/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/xyz.ctrl/index.ts new file mode 100644 index 00000000000..171ad72bd1d --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/xyz.ctrl/index.ts @@ -0,0 +1,32 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +export const wallet = { + id: "xyz.ctrl", + name: "Ctrl Wallet", + homepage: "https://ctrl.xyz/", + image_id: "749856b0-3f0e-4876-4d0f-27835310db00", + app: { + browser: "https://ctrl.xyz/", + ios: "https://apps.apple.com/us/app/ctrl-wallet/id6630386336", + android: "https://play.google.com/store/apps/details?id=xyz.ctrl.wallet", + mac: null, + windows: null, + linux: null, + chrome: + "https://chrome.google.com/webstore/detail/ctrl-wallet/hmeobnfnfcmdkdcmlblgagmfpfboieaf?hl=en", + firefox: null, + safari: null, + edge: null, + opera: null, + }, + rdns: "xyz.ctrl", + mobile: { + native: "ctrl-mobile://", + universal: null, + }, + desktop: { + native: null, + universal: null, + }, +} as const; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/xyz.talisman/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/xyz.talisman/image.ts new file mode 100644 index 00000000000..9f15601ee5b --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/xyz.talisman/image.ts @@ -0,0 +1,7 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +const image = + ""; + +export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/xyz.talisman/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/xyz.talisman/index.ts new file mode 100644 index 00000000000..6bd474826c1 --- /dev/null +++ b/packages/thirdweb/src/wallets/__generated__/wallet/xyz.talisman/index.ts @@ -0,0 +1,32 @@ +// This file is auto-generated by the `scripts/wallets/generate.ts` script. +// Do not modify this file manually. + +export const wallet = { + id: "xyz.talisman", + name: "Talisman Wallet", + homepage: "https://talisman.xyz", + image_id: "ba290222-c3f3-4194-23bf-28ba7587af00", + app: { + browser: null, + ios: null, + android: null, + mac: null, + windows: null, + linux: null, + chrome: + "https://chromewebstore.google.com/detail/talisman-wallet/fijngjgcjhjmmpcmkeiomlglpeiijkld", + firefox: null, + safari: null, + edge: null, + opera: null, + }, + rdns: "xyz.talisman", + mobile: { + native: null, + universal: null, + }, + desktop: { + native: null, + universal: null, + }, +} as const; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/xyz.timelesswallet/image.ts b/packages/thirdweb/src/wallets/__generated__/wallet/xyz.timelesswallet/image.ts index 7081be01951..683f7d93489 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/xyz.timelesswallet/image.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/xyz.timelesswallet/image.ts @@ -2,6 +2,6 @@ // Do not modify this file manually. const image = - ""; + ""; export default image; diff --git a/packages/thirdweb/src/wallets/__generated__/wallet/xyz.timelesswallet/index.ts b/packages/thirdweb/src/wallets/__generated__/wallet/xyz.timelesswallet/index.ts index 5b7059cdfcb..c12d2e62003 100644 --- a/packages/thirdweb/src/wallets/__generated__/wallet/xyz.timelesswallet/index.ts +++ b/packages/thirdweb/src/wallets/__generated__/wallet/xyz.timelesswallet/index.ts @@ -5,7 +5,7 @@ export const wallet = { id: "xyz.timelesswallet", name: "Timeless X", homepage: "https://timelesswallet.xyz", - image_id: "92f1ead4-0bc4-4932-10d3-761c509b4d00", + image_id: "7870d465-6028-49cb-6667-d0a2cc509400", app: { browser: null, ios: "https://apps.apple.com/us/app/timeless-x/id6470180600", From a3f59e50e249d8b4fac765e025fc2cd102093e9c Mon Sep 17 00:00:00 2001 From: Nidz The Fact <106298826+nidz-the-fact@users.noreply.github.com> Date: Sat, 4 Jan 2025 12:50:41 +0700 Subject: [PATCH 02/30] Edit [DOCS]: Updated import. @thirdweb-dev/contracts and add _defaultAdmin (#5848) Signed-off-by: Nidz The Fact <106298826+nidz-the-fact@users.noreply.github.com> Signed-off-by: Joaquim Verges Co-authored-by: Joaquim Verges --- .../base-contracts/erc-4337/account-factory/page.mdx | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/apps/portal/src/app/contracts/build/base-contracts/erc-4337/account-factory/page.mdx b/apps/portal/src/app/contracts/build/base-contracts/erc-4337/account-factory/page.mdx index 352012e94ab..27ccd176f4f 100644 --- a/apps/portal/src/app/contracts/build/base-contracts/erc-4337/account-factory/page.mdx +++ b/apps/portal/src/app/contracts/build/base-contracts/erc-4337/account-factory/page.mdx @@ -15,7 +15,7 @@ export const metadata = createMetadata({ # AccountFactory ```solidity -import "@thirdweb-dev/contracts/smart-wallet/non-upgradeable/AccountFactory.sol"; +import "@thirdweb-dev/contracts/prebuilts/account/non-upgradeable/AccountFactory.sol"; ``` This contract inherits from the [`BaseAccountFactory`](/contracts/build/extensions/erc-4337/SmartWalletFactory) contract. @@ -54,17 +54,23 @@ npx thirdweb create contract ```bash npx thirdweb deploy ``` +> **Note: secret key required for this command `-k `** Or import the contract into your existing project and inherit from it. ```solidity -import "@thirdweb-dev/contracts/smart-wallet/non-upgradable/AccountFactory.sol"; +// SPDX-License-Identifier: GPL-3.0 +pragma solidity ^0.8.12; + +import "@thirdweb-dev/contracts/prebuilts/account/non-upgradeable/AccountFactory.sol"; contract MyAccountFactory is AccountFactory { constructor( + address _defaultAdmin, IEntryPoint _entrypoint ) AccountFactory( + _defaultAdmin, _entrypoint ) {} From 1e8ddcb3998d024cad794a2ee77100bd10a14f20 Mon Sep 17 00:00:00 2001 From: greg Date: Sat, 4 Jan 2025 21:33:17 -1000 Subject: [PATCH 03/30] [SDK] Fix: Undefined chain ID on eip1193 provider input (#5871) --- .changeset/yellow-experts-sparkle.md | 5 +++++ .../src/adapters/eip1193/from-eip1193.test.ts | 18 ++++++++++++++++++ .../thirdweb/src/wallets/injected/index.ts | 3 ++- 3 files changed, 25 insertions(+), 1 deletion(-) create mode 100644 .changeset/yellow-experts-sparkle.md diff --git a/.changeset/yellow-experts-sparkle.md b/.changeset/yellow-experts-sparkle.md new file mode 100644 index 00000000000..065a6690d90 --- /dev/null +++ b/.changeset/yellow-experts-sparkle.md @@ -0,0 +1,5 @@ +--- +"thirdweb": patch +--- + +SDK: Gracefully ignore chain with no chain ID in `fromEip1193Provider` diff --git a/packages/thirdweb/src/adapters/eip1193/from-eip1193.test.ts b/packages/thirdweb/src/adapters/eip1193/from-eip1193.test.ts index 48d9c4def2e..7e938545e2b 100644 --- a/packages/thirdweb/src/adapters/eip1193/from-eip1193.test.ts +++ b/packages/thirdweb/src/adapters/eip1193/from-eip1193.test.ts @@ -115,6 +115,24 @@ describe("fromProvider", () => { expect(chain).toBe(ANVIL_CHAIN); }); + test("should handle connection with no chainId", async () => { + const wallet = fromProvider({ + provider: { + ...mockProvider, + request: () => Promise.resolve([mockAccount.address]), + }, + }); + + await wallet.connect({ + client: TEST_CLIENT, + chain: { + ...ANVIL_CHAIN, + id: undefined, + // biome-ignore lint/suspicious/noExplicitAny: Testing unexpected input data + } as any, + }); + }); + test("should reset state on disconnect", async () => { const wallet = fromProvider({ provider: { diff --git a/packages/thirdweb/src/wallets/injected/index.ts b/packages/thirdweb/src/wallets/injected/index.ts index 9f343d074bc..89a160fcde5 100644 --- a/packages/thirdweb/src/wallets/injected/index.ts +++ b/packages/thirdweb/src/wallets/injected/index.ts @@ -85,7 +85,8 @@ export async function connectEip1193Wallet({ chain && chain.id === chainId ? chain : getCachedChain(chainId); // if we want a specific chainId and it is not the same as the provider chainId, trigger switchChain - if (chain && chain.id !== chainId) { + // we check for undefined chain ID since some chain-specific wallets like Abstract will not send a chain ID on connection + if (chain && typeof chain.id !== "undefined" && chain.id !== chainId) { await switchChain(provider, chain); connectedChain = chain; } From 2a9d9963b7f84a1de27ebceb940c617e0e98c99b Mon Sep 17 00:00:00 2001 From: gregfromstl Date: Sun, 5 Jan 2025 07:40:16 +0000 Subject: [PATCH 04/30] [Dashboard] Fix: If only one time period has analytics events (#5886) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit ## Notes for the reviewer Adds an edge case if a user only has events for a single time period. Previously, this would show 0 in the analytics summary since it normally takes the most recent *complete* time period. Now, it falls back to show the incomplete period if there is no complete period with data. ## How to test Run the dashboard and view the project client ID listed in the linear ticket --- ## PR-Codex overview This PR focuses on improving the handling of time series data in the `aggregateFn` function by ensuring that if there is only one data point, it uses that point instead of the previous one. This change is applied in two files. ### Detailed summary - Updated `aggregateFn` in `apps/dashboard/src/app/team/[team_slug]/[project_slug]/page.tsx`: - Added logic to check if there is only one valid data point. - If only one point exists, it uses the last data point; otherwise, it uses the previous one. - Updated `aggregateFn` in `apps/dashboard/src/app/team/[team_slug]/(team)/~/analytics/page.tsx`: - Similar logic added as in the previous file to handle time series data appropriately. > ✨ Ask PR-Codex anything about this PR by commenting with `/codex {your question}` --- .../src/app/team/[team_slug]/(team)/~/analytics/page.tsx | 5 ++++- .../src/app/team/[team_slug]/[project_slug]/page.tsx | 5 ++++- 2 files changed, 8 insertions(+), 2 deletions(-) diff --git a/apps/dashboard/src/app/team/[team_slug]/(team)/~/analytics/page.tsx b/apps/dashboard/src/app/team/[team_slug]/(team)/~/analytics/page.tsx index 1ba33619388..217dace6e70 100644 --- a/apps/dashboard/src/app/team/[team_slug]/(team)/~/analytics/page.tsx +++ b/apps/dashboard/src/app/team/[team_slug]/(team)/~/analytics/page.tsx @@ -257,7 +257,10 @@ function UsersChartCard({ } data={timeSeriesData} aggregateFn={(_data, key) => - timeSeriesData[timeSeriesData.length - 2]?.[key] + // If there is only one data point, use that one, otherwise use the previous + timeSeriesData.filter((d) => (d[key] as number) > 0).length >= 2 + ? timeSeriesData[timeSeriesData.length - 2]?.[key] + : timeSeriesData[timeSeriesData.length - 1]?.[key] } // Get the trend from the last two COMPLETE periods trendFn={(data, key) => diff --git a/apps/dashboard/src/app/team/[team_slug]/[project_slug]/page.tsx b/apps/dashboard/src/app/team/[team_slug]/[project_slug]/page.tsx index fee25daf6cf..44ce7556077 100644 --- a/apps/dashboard/src/app/team/[team_slug]/[project_slug]/page.tsx +++ b/apps/dashboard/src/app/team/[team_slug]/[project_slug]/page.tsx @@ -279,7 +279,10 @@ function UsersChartCard({ queryKey="usersChart" data={timeSeriesData} aggregateFn={(_data, key) => - timeSeriesData[timeSeriesData.length - 2]?.[key] + // If there is only one data point, use that one, otherwise use the previous + timeSeriesData.filter((d) => (d[key] as number) > 0).length >= 2 + ? timeSeriesData[timeSeriesData.length - 2]?.[key] + : timeSeriesData[timeSeriesData.length - 1]?.[key] } // Get the trend from the last two COMPLETE periods trendFn={(data, key) => From 810f3195793203446b76f2f6d50ba3e9d8eefc3f Mon Sep 17 00:00:00 2001 From: kien-ngo Date: Sun, 5 Jan 2025 21:40:06 +0000 Subject: [PATCH 05/30] [SDK] onTimeout for useAutoConnect | TOOL-2673 (#5879) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit TOOL-2673 --- ## PR-Codex overview This PR introduces an `onTimeout` callback to the `useAutoConnect` hook, enhancing its functionality by allowing users to define custom behavior when a connection attempt times out. It also includes tests for the new feature and refactors some wallet connection logic. ### Detailed summary - Added `onTimeout` callback to `useAutoConnect`. - Updated `useAutoConnectCore` to handle wallet connections with the new `onTimeout` feature. - Refactored `handleWalletConnection` function to improve clarity. - Added unit tests for `getUrlToken` covering various scenarios. - Updated test configurations for better matching of test files. > ✨ Ask PR-Codex anything about this PR by commenting with `/codex {your question}` --- .changeset/little-beds-dress.md | 5 + .../src/react/core/hooks/connection/types.ts | 5 + .../core/hooks/wallets/useAutoConnect.ts | 53 +++-- .../hooks/wallets/useAutoConnectCore.test.tsx | 187 ++++++++++++++++++ .../in-app/web/lib/get-url-token.test.tsx | 92 +++++++++ packages/thirdweb/test/vitest.config.ts | 2 +- 6 files changed, 331 insertions(+), 13 deletions(-) create mode 100644 .changeset/little-beds-dress.md create mode 100644 packages/thirdweb/src/react/core/hooks/wallets/useAutoConnectCore.test.tsx create mode 100644 packages/thirdweb/src/wallets/in-app/web/lib/get-url-token.test.tsx diff --git a/.changeset/little-beds-dress.md b/.changeset/little-beds-dress.md new file mode 100644 index 00000000000..017f1b6b385 --- /dev/null +++ b/.changeset/little-beds-dress.md @@ -0,0 +1,5 @@ +--- +"thirdweb": patch +--- + +Add onTimeout callback to useAutoConnect diff --git a/packages/thirdweb/src/react/core/hooks/connection/types.ts b/packages/thirdweb/src/react/core/hooks/connection/types.ts index 426211f212a..b362a375bec 100644 --- a/packages/thirdweb/src/react/core/hooks/connection/types.ts +++ b/packages/thirdweb/src/react/core/hooks/connection/types.ts @@ -113,4 +113,9 @@ export type AutoConnectProps = { * Optional chain to autoconnect to */ chain?: Chain; + + /** + * Callback to be called when the connection is timeout-ed + */ + onTimeout?: () => void; }; diff --git a/packages/thirdweb/src/react/core/hooks/wallets/useAutoConnect.ts b/packages/thirdweb/src/react/core/hooks/wallets/useAutoConnect.ts index 7c41dcd916e..0d450961584 100644 --- a/packages/thirdweb/src/react/core/hooks/wallets/useAutoConnect.ts +++ b/packages/thirdweb/src/react/core/hooks/wallets/useAutoConnect.ts @@ -1,9 +1,12 @@ "use client"; import { useQuery } from "@tanstack/react-query"; +import type { Chain } from "../../../../chains/types.js"; +import type { ThirdwebClient } from "../../../../client/client.js"; import type { AsyncStorage } from "../../../../utils/storage/AsyncStorage.js"; import { isEcosystemWallet } from "../../../../wallets/ecosystem/is-ecosystem-wallet.js"; import { ClientScopedStorage } from "../../../../wallets/in-app/core/authentication/client-scoped-storage.js"; +import type { AuthStoredTokenWithCookieReturnType } from "../../../../wallets/in-app/core/authentication/types.js"; import { getUrlToken } from "../../../../wallets/in-app/web/lib/get-url-token.js"; import type { Wallet } from "../../../../wallets/interfaces/wallet.js"; import { @@ -83,14 +86,6 @@ export function useAutoConnectCore( const lastConnectedChain = (await getLastConnectedChain(storage)) || props.chain; - async function handleWalletConnection(wallet: Wallet) { - return wallet.autoConnect({ - client: props.client, - chain: lastConnectedChain ?? undefined, - authResult, - }); - } - const availableWallets = [...wallets, ...(getInstalledWallets?.() ?? [])]; const activeWallet = lastActiveWalletId && @@ -100,9 +95,22 @@ export function useAutoConnectCore( if (activeWallet) { try { setConnectionStatus("connecting"); // only set connecting status if we are connecting the last active EOA - await timeoutPromise(handleWalletConnection(activeWallet), { - ms: timeout, - message: `AutoConnect timeout: ${timeout}ms limit exceeded.`, + await timeoutPromise( + handleWalletConnection({ + wallet: activeWallet, + client: props.client, + lastConnectedChain, + authResult, + }), + { + ms: timeout, + message: `AutoConnect timeout: ${timeout}ms limit exceeded.`, + }, + ).catch((err) => { + console.warn(err.message); + if (props.onTimeout) { + props.onTimeout(); + } }); // connected wallet could be activeWallet or smart wallet @@ -138,7 +146,12 @@ export function useAutoConnectCore( for (const wallet of otherWallets) { try { - await handleWalletConnection(wallet); + await handleWalletConnection({ + wallet, + client: props.client, + lastConnectedChain, + authResult, + }); manager.addConnectedWallet(wallet); } catch { // no-op @@ -158,3 +171,19 @@ export function useAutoConnectCore( return query; } + +/** + * @internal + */ +export async function handleWalletConnection(props: { + wallet: Wallet; + client: ThirdwebClient; + authResult: AuthStoredTokenWithCookieReturnType | undefined; + lastConnectedChain: Chain | undefined; +}) { + return props.wallet.autoConnect({ + client: props.client, + chain: props.lastConnectedChain, + authResult: props.authResult, + }); +} diff --git a/packages/thirdweb/src/react/core/hooks/wallets/useAutoConnectCore.test.tsx b/packages/thirdweb/src/react/core/hooks/wallets/useAutoConnectCore.test.tsx new file mode 100644 index 00000000000..c1ff08248f8 --- /dev/null +++ b/packages/thirdweb/src/react/core/hooks/wallets/useAutoConnectCore.test.tsx @@ -0,0 +1,187 @@ +import { renderHook, waitFor } from "@testing-library/react"; +import type { ReactNode } from "react"; +import { describe, expect, it, vi } from "vitest"; +import { MockStorage } from "~test/mocks/storage.js"; +import { TEST_CLIENT } from "~test/test-clients.js"; +import { TEST_ACCOUNT_A } from "~test/test-wallets.js"; +import { createWalletAdapter } from "../../../../adapters/wallet-adapter.js"; +import { ethereum } from "../../../../chains/chain-definitions/ethereum.js"; +import { isAddress } from "../../../../utils/address.js"; +import { createConnectionManager } from "../../../../wallets/manager/index.js"; +import type { WalletId } from "../../../../wallets/wallet-types.js"; +import { ThirdwebProvider } from "../../../web/providers/thirdweb-provider.js"; +import { ConnectionManagerCtx } from "../../providers/connection-manager.js"; +import { + handleWalletConnection, + useAutoConnectCore, +} from "./useAutoConnect.js"; + +describe("useAutoConnectCore", () => { + const mockStorage = new MockStorage(); + const manager = createConnectionManager(mockStorage); + + // Create a wrapper component with the mocked context + const wrapper = ({ children }: { children: ReactNode }) => { + return ( + + + {children} + + + ); + }; + + it("should return a useQuery result", async () => { + const wallet = createWalletAdapter({ + adaptedAccount: TEST_ACCOUNT_A, + client: TEST_CLIENT, + chain: ethereum, + onDisconnect: () => {}, + switchChain: () => {}, + }); + const { result } = renderHook( + () => + useAutoConnectCore( + mockStorage, + { + wallets: [wallet], + client: TEST_CLIENT, + }, + (id: WalletId) => + createWalletAdapter({ + adaptedAccount: TEST_ACCOUNT_A, + client: TEST_CLIENT, + chain: ethereum, + onDisconnect: () => { + console.warn(id); + }, + switchChain: () => {}, + }), + ), + { wrapper }, + ); + expect("data" in result.current).toBeTruthy(); + await waitFor(() => { + expect(typeof result.current.data).toBe("boolean"); + }); + }); + + it("should return `false` if there's no lastConnectedWalletIds", async () => { + const wallet = createWalletAdapter({ + adaptedAccount: TEST_ACCOUNT_A, + client: TEST_CLIENT, + chain: ethereum, + onDisconnect: () => {}, + switchChain: () => {}, + }); + const { result } = renderHook( + () => + useAutoConnectCore( + mockStorage, + { + wallets: [wallet], + client: TEST_CLIENT, + }, + (id: WalletId) => + createWalletAdapter({ + adaptedAccount: TEST_ACCOUNT_A, + client: TEST_CLIENT, + chain: ethereum, + onDisconnect: () => { + console.warn(id); + }, + switchChain: () => {}, + }), + ), + { wrapper }, + ); + await waitFor( + () => { + expect(result.current.data).toBe(false); + }, + { timeout: 1000 }, + ); + }); + + it("should call onTimeout on ... timeout", async () => { + const wallet = createWalletAdapter({ + adaptedAccount: TEST_ACCOUNT_A, + client: TEST_CLIENT, + chain: ethereum, + onDisconnect: () => {}, + switchChain: () => {}, + }); + mockStorage.setItem("thirdweb:active-wallet-id", wallet.id); + const warnSpy = vi.spyOn(console, "warn").mockImplementation(() => {}); + const infoSpy = vi.spyOn(console, "info").mockImplementation(() => {}); + // Purposefully mock the wallet.autoConnect method to test the timeout logic + wallet.autoConnect = () => + new Promise((resolve) => { + setTimeout(() => { + // @ts-ignore Mock purpose + resolve("Connection successful"); + }, 2100); + }); + renderHook( + () => + useAutoConnectCore( + mockStorage, + { + wallets: [wallet], + client: TEST_CLIENT, + onTimeout: () => console.info("TIMEOUTTED"), + timeout: 0, + }, + (id: WalletId) => + createWalletAdapter({ + adaptedAccount: TEST_ACCOUNT_A, + client: TEST_CLIENT, + chain: ethereum, + onDisconnect: () => { + console.warn(id); + }, + switchChain: () => {}, + }), + ), + { wrapper }, + ); + await waitFor( + () => { + expect(warnSpy).toHaveBeenCalled(); + expect(warnSpy).toHaveBeenCalledWith( + "AutoConnect timeout: 0ms limit exceeded.", + ); + expect(infoSpy).toHaveBeenCalled(); + expect(infoSpy).toHaveBeenCalledWith("TIMEOUTTED"); + warnSpy.mockRestore(); + }, + { timeout: 2000 }, + ); + }); +}); + +describe("handleWalletConnection", () => { + const wallet = createWalletAdapter({ + adaptedAccount: TEST_ACCOUNT_A, + client: TEST_CLIENT, + chain: ethereum, + onDisconnect: () => {}, + switchChain: () => {}, + }); + it("should return the correct result", async () => { + const result = await handleWalletConnection({ + client: TEST_CLIENT, + lastConnectedChain: ethereum, + authResult: undefined, + wallet, + }); + + expect("address" in result).toBe(true); + expect(isAddress(result.address)).toBe(true); + expect("sendTransaction" in result).toBe(true); + expect(typeof result.sendTransaction).toBe("function"); + expect("signMessage" in result).toBe(true); + expect("signTypedData" in result).toBe(true); + expect("signTransaction" in result).toBe(true); + }); +}); diff --git a/packages/thirdweb/src/wallets/in-app/web/lib/get-url-token.test.tsx b/packages/thirdweb/src/wallets/in-app/web/lib/get-url-token.test.tsx new file mode 100644 index 00000000000..a6fe356d0e7 --- /dev/null +++ b/packages/thirdweb/src/wallets/in-app/web/lib/get-url-token.test.tsx @@ -0,0 +1,92 @@ +import { afterEach, beforeEach, describe, expect, it } from "vitest"; +import { getUrlToken } from "./get-url-token.js"; + +describe("getUrlToken", () => { + let originalLocation: Location; + + beforeEach(() => { + originalLocation = window.location; + + Object.defineProperty(window, "location", { + value: { + ...originalLocation, + search: "", + }, + writable: true, + }); + }); + + afterEach(() => { + // Restore the original location object after each test + Object.defineProperty(window, "location", { + value: originalLocation, + writable: true, + }); + }); + + it("should return an empty object if not in web context", () => { + const originalWindow = window; + // biome-ignore lint/suspicious/noExplicitAny: Test + (global as any).window = undefined; + + const result = getUrlToken(); + // biome-ignore lint/suspicious/noExplicitAny: Test + (global as any).window = originalWindow; + + expect(result).toEqual({}); + }); + + it("should return an empty object if no parameters are present", () => { + const result = getUrlToken(); + expect(result).toEqual({}); + }); + + it("should parse walletId and authResult correctly", () => { + window.location.search = + "?walletId=123&authResult=%7B%22token%22%3A%22abc%22%7D"; + + const result = getUrlToken(); + + expect(result).toEqual({ + walletId: "123", + authResult: { token: "abc" }, + authProvider: null, + authCookie: null, + }); + }); + + it("should handle authCookie and update URL correctly", () => { + window.location.search = "?walletId=123&authCookie=myCookie"; + + const result = getUrlToken(); + + expect(result).toEqual({ + walletId: "123", + authResult: undefined, + authProvider: null, + authCookie: "myCookie", + }); + + // Check if URL has been updated correctly + expect(window.location.search).toBe("?walletId=123&authCookie=myCookie"); + }); + + it("should handle all parameters correctly", () => { + window.location.search = + "?walletId=123&authResult=%7B%22token%22%3A%22xyz%22%7D&authProvider=provider1&authCookie=myCookie"; + + const result = getUrlToken(); + + expect(result).toEqual({ + walletId: "123", + authResult: { token: "xyz" }, + authProvider: "provider1", + authCookie: "myCookie", + }); + + // Check if URL has been updated correctly + expect(window.location.search).toBe( + "?walletId=123&authResult=%7B%22token%22%3A%22xyz%22%7D&authProvider=provider1&authCookie=myCookie", + ); + }); +}); diff --git a/packages/thirdweb/test/vitest.config.ts b/packages/thirdweb/test/vitest.config.ts index 7ebaa7d1414..ea7f686c505 100644 --- a/packages/thirdweb/test/vitest.config.ts +++ b/packages/thirdweb/test/vitest.config.ts @@ -31,7 +31,7 @@ export default defineConfig({ ], include: ["src/**"], }, - environmentMatchGlobs: [["src/react/**/*.test.tsx", "happy-dom"]], + environmentMatchGlobs: [["src/**/*.test.tsx", "happy-dom"]], environment: "node", include: ["src/**/*.test.{ts,tsx}"], setupFiles: [join(__dirname, "./reactSetup.ts")], From 47789660d2f0b7c2c12d8375bda2cdfb01ac8c05 Mon Sep 17 00:00:00 2001 From: kien-ngo Date: Sun, 5 Jan 2025 23:06:03 +0000 Subject: [PATCH 06/30] CORE-458 | Improve the function comment of the Explorer (#5861) CORE-458 --- .../contract-function-comment.tsx | 61 ++------ .../hooks/useContractFunctionComment.ts | 139 ++++++++++++++++++ .../src/contract/actions/compiler-metadata.ts | 5 + 3 files changed, 153 insertions(+), 52 deletions(-) create mode 100644 apps/dashboard/src/contract-ui/hooks/useContractFunctionComment.ts diff --git a/apps/dashboard/src/components/contract-functions/contract-function-comment.tsx b/apps/dashboard/src/components/contract-functions/contract-function-comment.tsx index 818f9b23fd6..696f52e70a1 100644 --- a/apps/dashboard/src/components/contract-functions/contract-function-comment.tsx +++ b/apps/dashboard/src/components/contract-functions/contract-function-comment.tsx @@ -1,7 +1,6 @@ import { Badge } from "@/components/ui/badge"; import { CodeClient } from "@/components/ui/code/code.client"; -import { useContractSources } from "contract-ui/hooks/useContractSources"; -import { useMemo } from "react"; +import { useContractFunctionComment } from "contract-ui/hooks/useContractFunctionComment"; import type { ThirdwebContract } from "thirdweb"; /** @@ -11,24 +10,12 @@ export default function ContractFunctionComment({ contract, functionName, }: { contract: ThirdwebContract; functionName: string }) { - const sourceQuery = useContractSources(contract); - const comment = useMemo(() => { - if (!sourceQuery.data?.length) { - return null; - } - const file = sourceQuery.data.find((item) => - item.source.includes(functionName), - ); - if (!file) { - return null; - } - return extractFunctionComment(file.source, functionName); - }, [sourceQuery.data, functionName]); + const query = useContractFunctionComment(contract, functionName); - if (sourceQuery.isLoading) { + if (query.isLoading) { return null; } - if (!comment) { + if (!query.data) { return null; } return ( @@ -36,41 +23,11 @@ export default function ContractFunctionComment({

About this function Beta

- + ); } - -function extractFunctionComment( - // Tthe whole code from the solidity file containing (possibly) the function - solidityCode: string, - functionName: string, -): string | null { - // Regular expression to match function declarations and their preceding comments - // This regex now captures both single-line (//) and multi-line (/** */) comments - const functionRegex = - /(?:\/\/[^\n]*|\/\*\*[\s\S]*?\*\/)\s*function\s+(\w+)\s*\(/g; - - while (true) { - const match = functionRegex.exec(solidityCode); - if (match === null) { - return null; - } - const [fullMatch, name] = match; - if (!fullMatch || !fullMatch.length) { - return null; - } - if (name === functionName) { - // Extract the comment part - const comment = (fullMatch.split("function")[0] || "").trim(); - if (!comment) { - return null; - } - - if (/^[^a-zA-Z0-9]+$/.test(comment)) { - return null; - } - return comment; - } - } -} diff --git a/apps/dashboard/src/contract-ui/hooks/useContractFunctionComment.ts b/apps/dashboard/src/contract-ui/hooks/useContractFunctionComment.ts new file mode 100644 index 00000000000..f5bb0777fd1 --- /dev/null +++ b/apps/dashboard/src/contract-ui/hooks/useContractFunctionComment.ts @@ -0,0 +1,139 @@ +import { useThirdwebClient } from "@/constants/thirdweb.client"; +import { useQuery } from "@tanstack/react-query"; +import type { ThirdwebContract } from "thirdweb"; +import { getCompilerMetadata } from "thirdweb/contract"; +import { download } from "thirdweb/storage"; + +/** + * Try to extract the description (or comment) about a contract's method from our contract metadata endpoint + * + * An example of a contract that has both userdoc and devdoc: + * https://contract.thirdweb.com/metadata/1/0x303a465B659cBB0ab36eE643eA362c509EEb5213 + */ +export function useContractFunctionComment( + contract: ThirdwebContract, + functionName: string, +) { + const client = useThirdwebClient(); + return useQuery({ + queryKey: [ + "contract-function-comment", + contract?.chain.id || "", + contract?.address || "", + functionName, + ], + queryFn: async (): Promise => { + const data = await getCompilerMetadata(contract); + let comment = ""; + /** + * If the response data contains userdoc and/or devdoc + * we always prioritize using them. parsing the comment using regex should + * always be the last resort + */ + if (data.metadata.output.devdoc?.methods) { + const keys = Object.keys(data.metadata.output.devdoc.methods); + const matchingKey = keys.find( + (rawKey) => + rawKey.startsWith(functionName) && + rawKey.split("(")[0] === functionName, + ); + const devDocContent = matchingKey + ? data.metadata.output.devdoc.methods[matchingKey]?.details + : undefined; + if (devDocContent) { + comment += `@dev-doc: ${devDocContent}\n`; + } + } + if (data.metadata.output.userdoc?.methods) { + const keys = Object.keys(data.metadata.output.userdoc.methods); + const matchingKey = keys.find( + (rawKey) => + rawKey.startsWith(functionName) && + rawKey.split("(")[0] === functionName, + ); + const userDocContent = matchingKey + ? data.metadata.output.userdoc.methods[matchingKey]?.notice + : undefined; + if (userDocContent) { + comment += `@user-doc: ${userDocContent}\n`; + } + } + if (comment) { + return comment; + } + if (!data.metadata.sources) { + return ""; + } + const sources = await Promise.all( + Object.entries(data.metadata.sources).map(async ([path, info]) => { + if ("content" in info) { + return { + filename: path, + source: info.content || "Could not find source for this file", + }; + } + const urls = info.urls; + const ipfsLink = urls + ? urls.find((url) => url.includes("ipfs")) + : undefined; + if (ipfsLink) { + const ipfsHash = ipfsLink.split("ipfs/")[1]; + const source = await download({ + uri: `ipfs://${ipfsHash}`, + client, + }) + .then((r) => r.text()) + .catch(() => "Failed to fetch source from IPFS"); + return { + filename: path, + source, + }; + } + return { + filename: path, + source: "Could not find source for this file", + }; + }), + ); + const file = sources.find((item) => item.source.includes(functionName)); + if (!file) { + return ""; + } + return extractFunctionComment(file.source, functionName); + }, + }); +} + +function extractFunctionComment( + // The whole code from the solidity file containing (possibly) the function + solidityCode: string, + functionName: string, +): string { + // Regular expression to match function declarations and their preceding comments + // This regex now captures both single-line (//) and multi-line (/** */) comments + const functionRegex = + /(?:\/\/[^\n]*|\/\*\*[\s\S]*?\*\/)\s*function\s+(\w+)\s*\(/g; + + while (true) { + const match = functionRegex.exec(solidityCode); + if (match === null) { + return ""; + } + const [fullMatch, name] = match; + if (!fullMatch || !fullMatch.length) { + return ""; + } + if (name === functionName) { + // Extract the comment part + const comment = (fullMatch.split("function")[0] || "").trim(); + if (!comment) { + return ""; + } + + if (/^[^a-zA-Z0-9]+$/.test(comment)) { + return ""; + } + return comment; + } + } +} diff --git a/packages/thirdweb/src/contract/actions/compiler-metadata.ts b/packages/thirdweb/src/contract/actions/compiler-metadata.ts index 941e9ecba64..ed15561a7e5 100644 --- a/packages/thirdweb/src/contract/actions/compiler-metadata.ts +++ b/packages/thirdweb/src/contract/actions/compiler-metadata.ts @@ -9,6 +9,11 @@ export type CompilerMetadata = { // biome-ignore lint/suspicious/noExplicitAny: TODO: fix later by updating this type to match the specs here: https://docs.soliditylang.org/en/latest/metadata.html metadata: Record & { sources: Record; + output: { + abi: Abi; + devdoc?: Record>; + userdoc?: Record>; + }; }; info: { title?: string; From 430475913d30ef7a30cb3092f6ef09c0c998a9b6 Mon Sep 17 00:00:00 2001 From: AmineAfia Date: Sun, 5 Jan 2025 23:20:33 +0000 Subject: [PATCH 07/30] Add side nav link to ai docs in insight (#5885) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- title: "[SDK/Dashboard/Portal] Feature/Fix: Concise title for the changes" --- If you did not copy the branch name from Linear, paste the issue tag here (format is TEAM-0000): ## Notes for the reviewer Anything important to call out? Be sure to also clarify these in your comments. ## How to test Unit tests, playground, etc. --- ## PR-Codex overview This PR focuses on adding a new entry to the sidebar in the `sidebar.tsx` file of the `insight` section, specifically introducing a link for "Agents & LLMs". ### Detailed summary - Added a new sidebar entry: - `name`: "Agents & LLMs" - `href`: `${insightSlug}/agents-and-llms` > ✨ Ask PR-Codex anything about this PR by commenting with `/codex {your question}` --- apps/portal/src/app/insight/sidebar.tsx | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/apps/portal/src/app/insight/sidebar.tsx b/apps/portal/src/app/insight/sidebar.tsx index c3f6a9a76fd..40027e80201 100644 --- a/apps/portal/src/app/insight/sidebar.tsx +++ b/apps/portal/src/app/insight/sidebar.tsx @@ -25,6 +25,10 @@ export const sidebar: SideBar = { name: "Use cases", href: `${insightSlug}/use-cases`, }, + { + name: "Agents & LLMs", + href: `${insightSlug}/agents-and-llms`, + }, { name: "API Reference", href: "https://insight-api.thirdweb.com/reference", From e01193a659160fc84fcd54047043b23da56e3a90 Mon Sep 17 00:00:00 2001 From: greg Date: Sun, 5 Jan 2025 19:40:13 -1000 Subject: [PATCH 08/30] [SDK] Feature: Adds `getAdminAccount` to ecosystem wallets and cleans up smart account creation (#5829) --- .changeset/afraid-mails-sip.md | 5 + .../in-app/core/wallet/in-app-core.test.ts | 169 ++++++++++++------ .../wallets/in-app/core/wallet/in-app-core.ts | 33 ++-- .../src/wallets/in-app/core/wallet/index.ts | 23 ++- packages/thirdweb/src/wallets/smart/index.ts | 32 ++-- .../src/wallets/smart/smart-wallet.ts | 26 +-- .../thirdweb/src/wallets/smart/smart.test.ts | 58 ++---- 7 files changed, 198 insertions(+), 148 deletions(-) create mode 100644 .changeset/afraid-mails-sip.md diff --git a/.changeset/afraid-mails-sip.md b/.changeset/afraid-mails-sip.md new file mode 100644 index 00000000000..87d44e5d5d5 --- /dev/null +++ b/.changeset/afraid-mails-sip.md @@ -0,0 +1,5 @@ +--- +"thirdweb": minor +--- + +Feature: Adds getAdminAccount to inAppWallet interface for AA ecosystem wallets diff --git a/packages/thirdweb/src/wallets/in-app/core/wallet/in-app-core.test.ts b/packages/thirdweb/src/wallets/in-app/core/wallet/in-app-core.test.ts index 2dc112387ed..c92dd050060 100644 --- a/packages/thirdweb/src/wallets/in-app/core/wallet/in-app-core.test.ts +++ b/packages/thirdweb/src/wallets/in-app/core/wallet/in-app-core.test.ts @@ -1,42 +1,54 @@ import { beforeEach, describe, expect, it, vi } from "vitest"; +import { TEST_CLIENT } from "../../../../../test/src/test-clients.js"; +import { TEST_ACCOUNT_A } from "../../../../../test/src/test-wallets.js"; import { baseSepolia } from "../../../../chains/chain-definitions/base-sepolia.js"; -import { createThirdwebClient } from "../../../../client/client.js"; import { getEcosystemInfo } from "../../../ecosystem/get-ecosystem-wallet-auth-options.js"; -import type { Account } from "../../../interfaces/wallet.js"; +import { predictSmartAccountAddress } from "../../../smart/lib/calls.js"; +import { DEFAULT_ACCOUNT_FACTORY_V0_6 } from "../../../smart/lib/constants.js"; +import type { AuthLoginReturnType } from "../authentication/types.js"; import type { InAppConnector } from "../interfaces/connector.js"; import { createInAppWallet } from "./in-app-core.js"; -import { autoConnectInAppWallet, connectInAppWallet } from "./index.js"; +import * as InAppWallet from "./index.js"; vi.mock("../../../../analytics/track/connect.js", () => ({ trackConnect: vi.fn(), })); -vi.mock("./index.js", () => ({ - autoConnectInAppWallet: vi.fn(), - connectInAppWallet: vi.fn(), -})); - +vi.spyOn(InAppWallet, "connectInAppWallet"); +vi.spyOn(InAppWallet, "autoConnectInAppWallet"); vi.mock("../../../ecosystem/get-ecosystem-wallet-auth-options.js", () => ({ getEcosystemInfo: vi.fn(), })); -describe("createInAppWallet", () => { - const mockClient = createThirdwebClient({ - clientId: "test-client", - }); +describe.runIf(process.env.TW_SECRET_KEY)("createInAppWallet", () => { + const mockClient = TEST_CLIENT; const mockChain = baseSepolia; - const mockAccount = { address: "0x123" } as Account; + const mockAccount = TEST_ACCOUNT_A; + const mockUser = { + status: "Logged In, Wallet Initialized", + walletAddress: TEST_ACCOUNT_A.address, + authDetails: { + userWalletId: TEST_ACCOUNT_A.address, + recoveryShareManagement: "ENCLAVE", + email: "test@test.com", + }, + account: mockAccount, + } as const; + const mockAuthResult: AuthLoginReturnType = { + user: mockUser, + }; const mockConnectorFactory = vi.fn(() => Promise.resolve({ - connect: vi.fn(), + connect: vi.fn().mockResolvedValue(mockAuthResult), logout: vi.fn(() => Promise.resolve({ success: true })), authenticate: vi.fn(), getAccounts: vi.fn(), getAccount: vi.fn(), getProfiles: vi.fn(), - getUser: vi.fn(), + getUser: vi.fn().mockResolvedValue(mockUser), linkProfile: vi.fn(), + unlinkProfile: vi.fn(), preAuthenticate: vi.fn(), } as InAppConnector), ); @@ -46,8 +58,6 @@ describe("createInAppWallet", () => { }); it("should connect successfully", async () => { - vi.mocked(connectInAppWallet).mockResolvedValue([mockAccount, mockChain]); - const wallet = createInAppWallet({ connectorFactory: mockConnectorFactory, }); @@ -61,7 +71,7 @@ describe("createInAppWallet", () => { }); expect(result).toBe(mockAccount); - expect(connectInAppWallet).toHaveBeenCalledWith( + expect(InAppWallet.connectInAppWallet).toHaveBeenCalledWith( expect.objectContaining({ client: mockClient, chain: mockChain, @@ -72,11 +82,6 @@ describe("createInAppWallet", () => { }); it("should auto connect successfully", async () => { - vi.mocked(autoConnectInAppWallet).mockResolvedValue([ - mockAccount, - mockChain, - ]); - const wallet = createInAppWallet({ connectorFactory: mockConnectorFactory, }); @@ -87,7 +92,7 @@ describe("createInAppWallet", () => { }); expect(result).toBe(mockAccount); - expect(autoConnectInAppWallet).toHaveBeenCalledWith( + expect(InAppWallet.autoConnectInAppWallet).toHaveBeenCalledWith( expect.objectContaining({ client: mockClient, chain: mockChain, @@ -102,15 +107,13 @@ describe("createInAppWallet", () => { smartAccountOptions: { defaultChainId: mockChain.id, sponsorGas: true, - accountFactoryAddress: "0x456", + accountFactoryAddress: DEFAULT_ACCOUNT_FACTORY_V0_6, }, authOptions: [], name: "hello world", slug: "test-ecosystem", }); - vi.mocked(connectInAppWallet).mockResolvedValue([mockAccount, mockChain]); - const wallet = createInAppWallet({ connectorFactory: mockConnectorFactory, ecosystem: { id: "ecosystem.test-ecosystem" }, @@ -124,8 +127,14 @@ describe("createInAppWallet", () => { verificationCode: "", }); - expect(result).toBe(mockAccount); - expect(connectInAppWallet).toHaveBeenCalledWith( + const expectedSmartAccountAddress = await predictSmartAccountAddress({ + factoryAddress: DEFAULT_ACCOUNT_FACTORY_V0_6, + chain: mockChain, + adminAddress: TEST_ACCOUNT_A.address, + client: mockClient, + }); + expect(result.address).toBe(expectedSmartAccountAddress); + expect(InAppWallet.connectInAppWallet).toHaveBeenCalledWith( expect.objectContaining({ client: mockClient, chain: mockChain, @@ -134,7 +143,7 @@ describe("createInAppWallet", () => { smartAccount: expect.objectContaining({ chain: mockChain, sponsorGas: true, - factoryAddress: "0x456", + factoryAddress: DEFAULT_ACCOUNT_FACTORY_V0_6, }), }), expect.any(Object), @@ -145,15 +154,13 @@ describe("createInAppWallet", () => { smartAccountOptions: { defaultChainId: mockChain.id, sponsorGas: true, - accountFactoryAddress: "0x456", + accountFactoryAddress: DEFAULT_ACCOUNT_FACTORY_V0_6, }, authOptions: [], name: "hello world", slug: "test-ecosystem", }); - vi.mocked(connectInAppWallet).mockResolvedValue([mockAccount, mockChain]); - const wallet = createInAppWallet({ connectorFactory: mockConnectorFactory, ecosystem: { id: "ecosystem.test-ecosystem" }, @@ -166,8 +173,14 @@ describe("createInAppWallet", () => { verificationCode: "", }); - expect(result).toBe(mockAccount); - expect(connectInAppWallet).toHaveBeenCalledWith( + const expectedSmartAccountAddress = await predictSmartAccountAddress({ + factoryAddress: DEFAULT_ACCOUNT_FACTORY_V0_6, + chain: mockChain, + adminAddress: TEST_ACCOUNT_A.address, + client: mockClient, + }); + expect(result.address).toBe(expectedSmartAccountAddress); + expect(InAppWallet.connectInAppWallet).toHaveBeenCalledWith( expect.objectContaining({ client: mockClient, }), @@ -175,7 +188,7 @@ describe("createInAppWallet", () => { smartAccount: expect.objectContaining({ chain: mockChain, sponsorGas: true, - factoryAddress: "0x456", + factoryAddress: DEFAULT_ACCOUNT_FACTORY_V0_6, }), }), expect.any(Object), @@ -187,18 +200,13 @@ describe("createInAppWallet", () => { smartAccountOptions: { defaultChainId: mockChain.id, sponsorGas: true, - accountFactoryAddress: "0x456", + accountFactoryAddress: DEFAULT_ACCOUNT_FACTORY_V0_6, }, authOptions: [], name: "hello world", slug: "test-ecosystem", }); - vi.mocked(autoConnectInAppWallet).mockResolvedValue([ - mockAccount, - mockChain, - ]); - const wallet = createInAppWallet({ connectorFactory: mockConnectorFactory, ecosystem: { id: "ecosystem.test-ecosystem" }, @@ -209,8 +217,14 @@ describe("createInAppWallet", () => { chain: mockChain, }); - expect(result).toBe(mockAccount); - expect(autoConnectInAppWallet).toHaveBeenCalledWith( + const expectedSmartAccountAddress = await predictSmartAccountAddress({ + factoryAddress: DEFAULT_ACCOUNT_FACTORY_V0_6, + chain: mockChain, + adminAddress: TEST_ACCOUNT_A.address, + client: mockClient, + }); + expect(result.address).toBe(expectedSmartAccountAddress); + expect(InAppWallet.autoConnectInAppWallet).toHaveBeenCalledWith( expect.objectContaining({ client: mockClient, chain: mockChain, @@ -219,7 +233,7 @@ describe("createInAppWallet", () => { smartAccount: expect.objectContaining({ chain: mockChain, sponsorGas: true, - factoryAddress: "0x456", + factoryAddress: DEFAULT_ACCOUNT_FACTORY_V0_6, }), }), expect.any(Object), @@ -231,18 +245,13 @@ describe("createInAppWallet", () => { smartAccountOptions: { defaultChainId: mockChain.id, sponsorGas: true, - accountFactoryAddress: "0x456", + accountFactoryAddress: DEFAULT_ACCOUNT_FACTORY_V0_6, }, authOptions: [], name: "hello world", slug: "test-ecosystem", }); - vi.mocked(autoConnectInAppWallet).mockResolvedValue([ - mockAccount, - mockChain, - ]); - const wallet = createInAppWallet({ connectorFactory: mockConnectorFactory, ecosystem: { id: "ecosystem.test-ecosystem" }, @@ -252,8 +261,14 @@ describe("createInAppWallet", () => { client: mockClient, }); - expect(result).toBe(mockAccount); - expect(autoConnectInAppWallet).toHaveBeenCalledWith( + const expectedSmartAccountAddress = await predictSmartAccountAddress({ + factoryAddress: DEFAULT_ACCOUNT_FACTORY_V0_6, + chain: mockChain, + adminAddress: TEST_ACCOUNT_A.address, + client: mockClient, + }); + expect(result.address).toBe(expectedSmartAccountAddress); + expect(InAppWallet.autoConnectInAppWallet).toHaveBeenCalledWith( expect.objectContaining({ client: mockClient, }), @@ -261,10 +276,56 @@ describe("createInAppWallet", () => { smartAccount: expect.objectContaining({ chain: mockChain, sponsorGas: true, - factoryAddress: "0x456", + factoryAddress: DEFAULT_ACCOUNT_FACTORY_V0_6, }), }), expect.any(Object), ); }); + + it("should return undefined for getAdminAccount if the account is not a smart account", () => { + const wallet = createInAppWallet({ + connectorFactory: mockConnectorFactory, + }); + + expect(wallet.getAdminAccount?.()).toBeUndefined(); + }); + + it("should return undefined if no account is connected", () => { + const wallet = createInAppWallet({ + connectorFactory: mockConnectorFactory, + }); + + expect(wallet.getAdminAccount?.()).toBeUndefined(); + }); + + it("should return the admin account for a smart account", async () => { + vi.unmock("./index.js"); + vi.mocked(getEcosystemInfo).mockResolvedValue({ + smartAccountOptions: { + defaultChainId: mockChain.id, + sponsorGas: true, + accountFactoryAddress: DEFAULT_ACCOUNT_FACTORY_V0_6, + }, + authOptions: [], + name: "hello world", + slug: "test-ecosystem", + }); + + const wallet = createInAppWallet({ + connectorFactory: mockConnectorFactory, + ecosystem: { id: "ecosystem.test-ecosystem" }, + }); + + const smartAccount = await wallet.connect({ + client: mockClient, + strategy: "email", + email: "", + verificationCode: "", + }); + + const adminAccount = wallet.getAdminAccount?.(); + expect(adminAccount).toBeDefined(); + expect(adminAccount?.address).not.toBe(smartAccount.address); + }); }); diff --git a/packages/thirdweb/src/wallets/in-app/core/wallet/in-app-core.ts b/packages/thirdweb/src/wallets/in-app/core/wallet/in-app-core.ts index 751cbcbbf65..2d937a4ee85 100644 --- a/packages/thirdweb/src/wallets/in-app/core/wallet/in-app-core.ts +++ b/packages/thirdweb/src/wallets/in-app/core/wallet/in-app-core.ts @@ -48,6 +48,7 @@ export function createInAppWallet(args: { const emitter = createWalletEmitter<"inApp">(); let createOptions = _createOptions; let account: Account | undefined = undefined; + let adminAccount: Account | undefined = undefined; // Admin account if smartAccountOptions were provided with connection let chain: Chain | undefined = undefined; let client: ThirdwebClient | undefined; @@ -98,15 +99,16 @@ export function createInAppWallet(args: { } } - const [connectedAccount, connectedChain] = await autoConnectInAppWallet( - options, - createOptions, - connector, - ); + const { + account: connectedAccount, + chain: connectedChain, + adminAccount: _adminAccount, + } = await autoConnectInAppWallet(options, createOptions, connector); // set the states client = options.client; account = connectedAccount; + adminAccount = _adminAccount; chain = connectedChain; trackConnect({ client: options.client, @@ -151,14 +153,16 @@ export function createInAppWallet(args: { } } - const [connectedAccount, connectedChain] = await connectInAppWallet( - options, - createOptions, - connector, - ); + const { + account: connectedAccount, + chain: connectedChain, + adminAccount: _adminAccount, + } = await connectInAppWallet(options, createOptions, connector); + // set the states client = options.client; account = connectedAccount; + adminAccount = _adminAccount; chain = connectedChain; trackConnect({ client: options.client, @@ -184,6 +188,7 @@ export function createInAppWallet(args: { } } account = undefined; + adminAccount = undefined; chain = undefined; emitter.emit("disconnect", undefined); }, @@ -212,7 +217,11 @@ export function createInAppWallet(args: { } } - const [connectedAccount, connectedChain] = await autoConnectInAppWallet( + const { + account: connectedAccount, + chain: connectedChain, + adminAccount: _adminAccount, + } = await autoConnectInAppWallet( { chain: newChain, client, @@ -220,6 +229,7 @@ export function createInAppWallet(args: { createOptions, connector, ); + adminAccount = _adminAccount; account = connectedAccount; chain = connectedChain; } else { @@ -228,5 +238,6 @@ export function createInAppWallet(args: { } emitter.emit("chainChanged", newChain); }, + getAdminAccount: () => adminAccount, }; } diff --git a/packages/thirdweb/src/wallets/in-app/core/wallet/index.ts b/packages/thirdweb/src/wallets/in-app/core/wallet/index.ts index cd21db10632..accf32262a6 100644 --- a/packages/thirdweb/src/wallets/in-app/core/wallet/index.ts +++ b/packages/thirdweb/src/wallets/in-app/core/wallet/index.ts @@ -37,7 +37,7 @@ export async function connectInAppWallet( | CreateWalletArgs<"inApp">[1] | CreateWalletArgs[1], connector: InAppConnector, -): Promise<[Account, Chain]> { +): Promise<{ account: Account; chain: Chain; adminAccount?: Account }> { if ( // if auth mode is not specified, the default is popup createOptions?.auth?.mode !== "popup" && @@ -65,15 +65,16 @@ export async function connectInAppWallet( "smartAccount" in createOptions && createOptions?.smartAccount ) { - return convertToSmartAccount({ + const [account, chain] = await convertToSmartAccount({ client: options.client, authAccount, smartAccountOptions: createOptions.smartAccount, chain: options.chain, }); + return { account, chain, adminAccount: authAccount }; } - return [authAccount, options.chain || ethereum] as const; + return { account: authAccount, chain: options.chain || ethereum } as const; } /** @@ -87,7 +88,7 @@ export async function autoConnectInAppWallet( | CreateWalletArgs<"inApp">[1] | CreateWalletArgs[1], connector: InAppConnector, -): Promise<[Account, Chain]> { +): Promise<{ account: Account; chain: Chain; adminAccount?: Account }> { if (options.authResult && connector.loginWithAuthToken) { await connector.loginWithAuthToken(options.authResult); } @@ -104,15 +105,16 @@ export async function autoConnectInAppWallet( "smartAccount" in createOptions && createOptions?.smartAccount ) { - return convertToSmartAccount({ + const [account, chain] = await convertToSmartAccount({ client: options.client, authAccount, smartAccountOptions: createOptions.smartAccount, chain: options.chain, }); + return { account, chain, adminAccount: authAccount }; } - return [authAccount, options.chain || ethereum] as const; + return { account: authAccount, chain: options.chain || ethereum } as const; } async function convertToSmartAccount(options: { @@ -121,14 +123,9 @@ async function convertToSmartAccount(options: { smartAccountOptions: CreateWalletArgs<"smart">[1]; chain?: Chain; }) { - const [{ smartWallet }, { connectSmartWallet }] = await Promise.all([ - import("../../../smart/smart-wallet.js"), - import("../../../smart/index.js"), - ]); + const { connectSmartAccount } = await import("../../../smart/index.js"); - const sa = smartWallet(options.smartAccountOptions); - return connectSmartWallet( - sa, + return connectSmartAccount( { client: options.client, personalAccount: options.authAccount, diff --git a/packages/thirdweb/src/wallets/smart/index.ts b/packages/thirdweb/src/wallets/smart/index.ts index 2ae82742f55..ce22b54ab0c 100644 --- a/packages/thirdweb/src/wallets/smart/index.ts +++ b/packages/thirdweb/src/wallets/smart/index.ts @@ -69,28 +69,26 @@ export function isSmartWallet( } /** - * We can get the personal account for given smart account but not the other way around - this map gives us the reverse lookup + * For in-app wallets, the smart wallet creation is implicit so we track these to be able to retrieve the personal account for a smart account on the wallet API. + * Note: We have to go account to account here and NOT wallet to account because the smart wallet itself is never exposed to the in-app wallet, only the account. * @internal */ -const personalAccountToSmartAccountMap = new WeakMap< - Account, - Wallet<"smart"> ->(); - -const smartWalletToPersonalAccountMap = new WeakMap, Account>(); +const adminAccountToSmartAccountMap = new WeakMap(); +const smartAccountToAdminAccountMap = new WeakMap(); /** * @internal */ -export async function connectSmartWallet( - wallet: Wallet<"smart">, +export async function connectSmartAccount( connectionOptions: SmartWalletConnectionOptions, creationOptions: SmartWalletOptions, ): Promise<[Account, Chain]> { const { personalAccount, client, chain: connectChain } = connectionOptions; if (!personalAccount) { - throw new Error("Personal wallet does not have an account"); + throw new Error( + "No personal account provided for smart account connection", + ); } const options = creationOptions; @@ -177,8 +175,8 @@ export async function connectSmartWallet( client, }); - personalAccountToSmartAccountMap.set(personalAccount, wallet); - smartWalletToPersonalAccountMap.set(wallet, personalAccount); + adminAccountToSmartAccountMap.set(personalAccount, account); + smartAccountToAdminAccountMap.set(account, personalAccount); return [account, chain] as const; } @@ -186,15 +184,13 @@ export async function connectSmartWallet( /** * @internal */ -export async function disconnectSmartWallet( - wallet: Wallet<"smart">, -): Promise { +export async function disconnectSmartAccount(account: Account): Promise { // look up the personalAccount for the smart wallet - const personalAccount = smartWalletToPersonalAccountMap.get(wallet); + const personalAccount = smartAccountToAdminAccountMap.get(account); if (personalAccount) { // remove the mappings - personalAccountToSmartAccountMap.delete(personalAccount); - smartWalletToPersonalAccountMap.delete(wallet); + adminAccountToSmartAccountMap.delete(personalAccount); + smartAccountToAdminAccountMap.delete(account); } } diff --git a/packages/thirdweb/src/wallets/smart/smart-wallet.ts b/packages/thirdweb/src/wallets/smart/smart-wallet.ts index 5110b9dd0f8..0e2e7c6d887 100644 --- a/packages/thirdweb/src/wallets/smart/smart-wallet.ts +++ b/packages/thirdweb/src/wallets/smart/smart-wallet.ts @@ -137,7 +137,7 @@ export function smartWallet( let chain: Chain | undefined = undefined; let lastConnectOptions: WalletConnectionOption<"smart"> | undefined; - const _smartWallet: Wallet<"smart"> = { + return { id: "smart", subscribe: emitter.subscribe, getChain() { @@ -152,9 +152,10 @@ export function smartWallet( getAccount: () => account, getAdminAccount: () => adminAccount, autoConnect: async (options) => { - const { connectSmartWallet } = await import("./index.js"); + const { connectSmartAccount: connectSmartWallet } = await import( + "./index.js" + ); const [connectedAccount, connectedChain] = await connectSmartWallet( - _smartWallet, options, createOptions, ); @@ -172,9 +173,8 @@ export function smartWallet( return account; }, connect: async (options) => { - const { connectSmartWallet } = await import("./index.js"); - const [connectedAccount, connectedChain] = await connectSmartWallet( - _smartWallet, + const { connectSmartAccount } = await import("./index.js"); + const [connectedAccount, connectedChain] = await connectSmartAccount( options, createOptions, ); @@ -194,10 +194,13 @@ export function smartWallet( return account; }, disconnect: async () => { + if (account) { + const { disconnectSmartAccount } = await import("./index.js"); + await disconnectSmartAccount(account); + } account = undefined; + adminAccount = undefined; chain = undefined; - const { disconnectSmartWallet } = await import("./index.js"); - await disconnectSmartWallet(_smartWallet); emitter.emit("disconnect", undefined); }, switchChain: async (newChain: Chain) => { @@ -223,9 +226,8 @@ export function smartWallet( ); } } - const { connectSmartWallet } = await import("./index.js"); - const [connectedAccount, connectedChain] = await connectSmartWallet( - _smartWallet, + const { connectSmartAccount } = await import("./index.js"); + const [connectedAccount, connectedChain] = await connectSmartAccount( { ...lastConnectOptions, chain: newChain }, createOptions, ); @@ -235,6 +237,4 @@ export function smartWallet( emitter.emit("chainChanged", newChain); }, }; - - return _smartWallet; } diff --git a/packages/thirdweb/src/wallets/smart/smart.test.ts b/packages/thirdweb/src/wallets/smart/smart.test.ts index a72938f794e..06439a11904 100644 --- a/packages/thirdweb/src/wallets/smart/smart.test.ts +++ b/packages/thirdweb/src/wallets/smart/smart.test.ts @@ -2,7 +2,6 @@ import { describe, expect, it } from "vitest"; import { TEST_CLIENT } from "../../../test/src/test-clients.js"; import { defineChain } from "../../chains/utils.js"; import { generateAccount } from "../utils/generateAccount.js"; -import { connectSmartWallet, disconnectSmartWallet } from "./index.js"; import { smartWallet } from "./smart-wallet.js"; describe.runIf(process.env.TW_SECRET_KEY)("Smart Wallet Index", () => { @@ -17,67 +16,48 @@ describe.runIf(process.env.TW_SECRET_KEY)("Smart Wallet Index", () => { gasless: true, }); - const [account, connectedChain] = await connectSmartWallet( - wallet, - { - client, - personalAccount, - }, - { - chain, - gasless: true, - }, - ); + await wallet.connect({ + client, + personalAccount, + }); - expect(account.address).toBeDefined(); - expect(account.address).toMatch(/^0x[a-fA-F0-9]{40}$/); - expect(connectedChain.id).toBe(chain.id); + expect(wallet.getAccount()?.address).toBeDefined(); + expect(wallet.getAccount()?.address).toMatch(/^0x[a-fA-F0-9]{40}$/); + expect(wallet.getChain()?.id).toBe(chain.id); }); }); describe("disconnectSmartWallet", () => { it("should disconnect a smart wallet", async () => { const personalAccount = await generateAccount({ client }); + const wallet = smartWallet({ chain, gasless: true, }); - await connectSmartWallet( - wallet, - { - client, - personalAccount, - }, - { - chain, - gasless: true, - }, - ); + await wallet.connect({ + client, + personalAccount, + }); - await expect(disconnectSmartWallet(wallet)).resolves.not.toThrow(); + await expect(wallet.disconnect()).resolves.not.toThrow(); }); it("should clear wallet mappings on disconnect", async () => { const personalAccount = await generateAccount({ client }); + const wallet = smartWallet({ chain, gasless: true, }); - await connectSmartWallet( - wallet, - { - client, - personalAccount, - }, - { - chain, - gasless: true, - }, - ); + await wallet.connect({ + client, + personalAccount, + }); - await disconnectSmartWallet(wallet); + await wallet.disconnect(); // Verify wallet state is cleared expect(wallet.getAccount()).toBeUndefined(); From 0a7beb840e60c425384342b8f87388738470017c Mon Sep 17 00:00:00 2001 From: kien-ngo Date: Mon, 6 Jan 2025 11:59:12 +0000 Subject: [PATCH 09/30] [Dashboard] Dynamically fetch supported chains from Simplehash (#5866) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit ## Problem solved Short description of the bug fixed or feature added --- ## PR-Codex overview This PR focuses on refactoring the handling of SimpleHash support in the `wallet` API and related components. It introduces an asynchronous check for SimpleHash support and replaces direct checks with a hook for better data management. ### Detailed summary - Changed `isSimpleHashSupported` to return a chain slug instead of a boolean. - Updated the `generateSimpleHashUrl` function to use `chainSlug`. - Introduced `useSimplehashSupport` hook for querying SimpleHash support. - Refactored components to use the new hook instead of direct checks. - Removed unused `simpleHashSupportedChainIdsMap` and related types. > ✨ Ask PR-Codex anything about this PR by commenting with `/codex {your question}` --- .../(marketplace)/components/list-button.tsx | 7 +- .../(marketplace)/components/list-form.tsx | 6 +- .../api/nft/is-simplehash-supported/route.ts | 34 ++++++++ .../src/lib/wallet/nfts/simpleHash.ts | 61 +++++++++---- apps/dashboard/src/lib/wallet/nfts/types.ts | 87 ------------------- .../src/pages/api/wallet/nfts/[chainId].ts | 6 +- 6 files changed, 89 insertions(+), 112 deletions(-) create mode 100644 apps/dashboard/src/app/api/nft/is-simplehash-supported/route.ts diff --git a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/(marketplace)/components/list-button.tsx b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/(marketplace)/components/list-button.tsx index b05e7f9932c..d30ecc2e13d 100644 --- a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/(marketplace)/components/list-button.tsx +++ b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/(marketplace)/components/list-button.tsx @@ -13,7 +13,7 @@ import { ListerOnly } from "@3rdweb-sdk/react/components/roles/lister-only"; import type { Account } from "@3rdweb-sdk/react/hooks/useApi"; import { isAlchemySupported } from "lib/wallet/nfts/alchemy"; import { isMoralisSupported } from "lib/wallet/nfts/moralis"; -import { isSimpleHashSupported } from "lib/wallet/nfts/simpleHash"; +import { useSimplehashSupport } from "lib/wallet/nfts/simpleHash"; import { PlusIcon } from "lucide-react"; import { useState } from "react"; import type { ThirdwebContract } from "thirdweb"; @@ -40,9 +40,12 @@ export const CreateListingButton: React.FC = ({ const [open, setOpen] = useState(false); const [listingMode, setListingMode] = useState<(typeof LISTING_MODES)[number]>("Select NFT"); + + const simplehashQuery = useSimplehashSupport(contract.chain.id); + const isSupportedChain = contract.chain.id && - (isSimpleHashSupported(contract.chain.id) || + (simplehashQuery.data || isAlchemySupported(contract.chain.id) || isMoralisSupported(contract.chain.id)); return ( diff --git a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/(marketplace)/components/list-form.tsx b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/(marketplace)/components/list-form.tsx index b864b976426..67c6d02e134 100644 --- a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/(marketplace)/components/list-form.tsx +++ b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/(marketplace)/components/list-form.tsx @@ -21,7 +21,7 @@ import { useAllChainsData } from "hooks/chains/allChains"; import { useTxNotifications } from "hooks/useTxNotifications"; import { isAlchemySupported } from "lib/wallet/nfts/alchemy"; import { isMoralisSupported } from "lib/wallet/nfts/moralis"; -import { isSimpleHashSupported } from "lib/wallet/nfts/simpleHash"; +import { useSimplehashSupport } from "lib/wallet/nfts/simpleHash"; import type { WalletNFT } from "lib/wallet/nfts/types"; import { CircleAlertIcon, InfoIcon } from "lucide-react"; import Link from "next/link"; @@ -112,10 +112,10 @@ export const CreateListingsForm: React.FC = ({ const { idToChain } = useAllChainsData(); const network = idToChain.get(chainId); const [isFormLoading, setIsFormLoading] = useState(false); - + const simplehashQuery = useSimplehashSupport(contract.chain.id); const isSupportedChain = chainId && - (isSimpleHashSupported(chainId) || + (!!simplehashQuery.data || isAlchemySupported(chainId) || isMoralisSupported(chainId)); diff --git a/apps/dashboard/src/app/api/nft/is-simplehash-supported/route.ts b/apps/dashboard/src/app/api/nft/is-simplehash-supported/route.ts new file mode 100644 index 00000000000..e0a3ccb977e --- /dev/null +++ b/apps/dashboard/src/app/api/nft/is-simplehash-supported/route.ts @@ -0,0 +1,34 @@ +import { isSimpleHashSupported } from "lib/wallet/nfts/simpleHash"; +import { NextResponse } from "next/server"; +import type { NextRequest } from "next/server"; + +export const runtime = "edge"; + +export const GET = async (req: NextRequest) => { + const searchParams = req.nextUrl.searchParams; + const chainIdStr = searchParams.get("chainId"); + + if (!chainIdStr) { + return NextResponse.json( + { + error: "Missing chain ID parameter.", + }, + { status: 400 }, + ); + } + + const chainId = Number.parseInt(chainIdStr); + + if (!Number.isInteger(chainId)) { + return NextResponse.json( + { + error: "Invalid chain ID parameter.", + }, + { status: 400 }, + ); + } + + const found = await isSimpleHashSupported(chainId); + + return NextResponse.json({ result: found }); +}; diff --git a/apps/dashboard/src/lib/wallet/nfts/simpleHash.ts b/apps/dashboard/src/lib/wallet/nfts/simpleHash.ts index 906b62442bc..ad7bf7e0147 100644 --- a/apps/dashboard/src/lib/wallet/nfts/simpleHash.ts +++ b/apps/dashboard/src/lib/wallet/nfts/simpleHash.ts @@ -1,25 +1,50 @@ -import { - type GenerateURLParams, - type SimpleHashSupportedChainId, - type WalletNFT, - simpleHashSupportedChainIdsMap, - simpleHashSupportedNetworks, -} from "./types"; - -export function isSimpleHashSupported( +import { useQuery } from "@tanstack/react-query"; +import type { WalletNFT } from "./types"; + +/** + * Return the chain slug if the chain is supported by Simplehash, otherwise `undefined` + * Chain slug because we need it to fetch the owned NFTs using another endpoint + */ +export async function isSimpleHashSupported( chainId: number, -): chainId is SimpleHashSupportedChainId { - return simpleHashSupportedNetworks.includes(chainId.toString()); -} +): Promise { + if (!process.env.SIMPLEHASH_API_KEY) { + throw new Error("No Simplehash API Key"); + } -export function generateSimpleHashUrl({ chainId, owner }: GenerateURLParams) { + const options = { + method: "GET", + headers: { + "X-API-KEY": process.env.SIMPLEHASH_API_KEY, + }, + }; + const response: Array<{ + chain: string; + eip155_network_id: number; + is_testnet: boolean; + }> = await fetch("https://api.simplehash.com/api/v0/chains", options) + .then((r) => r.json()) + .catch(() => []); + + const found = response.find((chain) => chain.eip155_network_id === chainId); + return found?.chain; +} + +export function useSimplehashSupport(chainId: number) { + return useQuery({ + queryKey: ["simplehash-supported", chainId], + queryFn: () => isSimpleHashSupported(chainId), + enabled: !!chainId, + }); +} + +export function generateSimpleHashUrl({ + chainSlug, + owner, +}: { chainSlug: string; owner: string }) { const url = new URL("https://api.simplehash.com/api/v0/nfts/owners"); - url.searchParams.append("wallet_addresses", owner); - if (simpleHashSupportedChainIdsMap[chainId]) { - url.searchParams.append("chains", simpleHashSupportedChainIdsMap[chainId]); - } - + url.searchParams.append("chains", chainSlug); return url.toString(); } diff --git a/apps/dashboard/src/lib/wallet/nfts/types.ts b/apps/dashboard/src/lib/wallet/nfts/types.ts index 7edca7e101d..3c1fda87626 100644 --- a/apps/dashboard/src/lib/wallet/nfts/types.ts +++ b/apps/dashboard/src/lib/wallet/nfts/types.ts @@ -1,55 +1,29 @@ import type { NFT } from "thirdweb"; import { arbitrum, - arbitrumNova, - arbitrumSepolia, - astriaEvmDusknet, avalanche, - avalancheFuji, base, - baseSepolia, blast, blastSepolia, bsc, bscTestnet, - celo, cronos, - degen, ethereum, fantom, - frameTestnet, gnosis, gnosisChiadoTestnet, - godWoken, - godWokenTestnetV1, - hokumTestnet, linea, - lineaSepolia, - loot, - mantaPacific, - mantaPacificTestnet, moonbeam, optimism, - optimismSepolia, palm, - palmTestnet, polygon, polygonAmoy, polygonMumbai, polygonZkEvm, polygonZkEvmTestnet, - rari, - rariTestnet, - scroll, - scrollAlphaTestnet, - scrollSepoliaTestnet, sepolia, - xai, - xaiSepolia, zkSync, zkSyncSepolia, - zora, - zoraSepolia, } from "thirdweb/chains"; // Cannot use BigInt for the values here because it will result in error: "fail to serialize bigint" @@ -132,65 +106,8 @@ const moralisSupportedChainIdsMap: Record = { [4202]: "", }; -// List: https://docs.simplehash.com/reference/supported-chains-testnets -export const simpleHashSupportedChainIdsMap: Record = { - [arbitrum.id]: "arbitrum", - [arbitrumNova.id]: "arbitrum-nova", - [arbitrumSepolia.id]: "arbitrum-sepolia", - [astriaEvmDusknet.id]: "astria-devnet", - [avalanche.id]: "avalanche", - [avalancheFuji.id]: "avalanche-fuji", - [base.id]: "base", - [baseSepolia.id]: "base-sepolia", - [bsc.id]: "bsc", - [bscTestnet.id]: "bsc-testnet", - [blast.id]: "blast", - [blastSepolia.id]: "blast-sepolia", - [celo.id]: "celo", - [ethereum.id]: "ethereum", - [degen.id]: "degen", - [fantom.id]: "fantom", - [frameTestnet.id]: "frame-testnet", - [gnosis.id]: "gnosis", - [godWoken.id]: "godwoken", - [godWokenTestnetV1.id]: "godwoken-testnet", - [hokumTestnet.id]: "hokum-testnet", - [linea.id]: "linea", - [lineaSepolia.id]: "linea-testnet", - [loot.id]: "loot", - [mantaPacific.id]: "manta", - [mantaPacificTestnet.id]: "manta-testnet", - [moonbeam.id]: "moonbeam", - [polygonMumbai.id]: "polygon-mumbai", - [optimism.id]: "optimism", - [optimismSepolia.id]: "optimism-sepolia", - [palm.id]: "palm", - [palmTestnet.id]: "palm-testnet", - [polygon.id]: "polygon", - [polygonAmoy.id]: "polygon-amoy", - [polygonZkEvm.id]: "polygon-zkevm", - [polygonZkEvmTestnet.id]: "polygon-zkevm-testnet", - [rari.id]: "rari", - [rariTestnet.id]: "rari-testnet", - [scroll.id]: "scroll", - [scrollAlphaTestnet.id]: "scroll-testnet", - [scrollSepoliaTestnet.id]: "scroll-sepolia", - [sepolia.id]: "ethereum-sepolia", - [xai.id]: "xai", - [xaiSepolia.id]: "xai-sepolia", - [zkSync.id]: "zksync-era", - [zora.id]: "zora", - [zoraSepolia.id]: "zora-sepolia", - [1329]: "sei", - [1328]: "sei-atlantic-2", - [360]: "shape", - [33139]: "apechain", -}; - export type AlchemySupportedChainId = keyof typeof alchemySupportedChainIdsMap; export type MoralisSupportedChainId = keyof typeof moralisSupportedChainIdsMap; -export type SimpleHashSupportedChainId = - keyof typeof simpleHashSupportedChainIdsMap; export const alchemySupportedChainIds = Object.keys( alchemySupportedChainIdsMap, @@ -200,10 +117,6 @@ export const moralisSupportedChainIds = Object.keys( moralisSupportedChainIdsMap, ); -export const simpleHashSupportedNetworks = Object.keys( - simpleHashSupportedChainIdsMap, -); - export interface GenerateURLParams { chainId: number; owner: string; diff --git a/apps/dashboard/src/pages/api/wallet/nfts/[chainId].ts b/apps/dashboard/src/pages/api/wallet/nfts/[chainId].ts index 6f63cac99dd..efcac10efce 100644 --- a/apps/dashboard/src/pages/api/wallet/nfts/[chainId].ts +++ b/apps/dashboard/src/pages/api/wallet/nfts/[chainId].ts @@ -38,8 +38,10 @@ const handler = async ( } const chainId = Number.parseInt(queryChainId); - if (isSimpleHashSupported(chainId) && process.env.SIMPLEHASH_API_KEY) { - const url = generateSimpleHashUrl({ chainId, owner }); + const supportedChainSlug = await isSimpleHashSupported(chainId); + + if (supportedChainSlug && process.env.SIMPLEHASH_API_KEY) { + const url = generateSimpleHashUrl({ chainSlug: supportedChainSlug, owner }); const options = { method: "GET", From 18ef10b175defce2039fe185ae6fbe4d1d475c5e Mon Sep 17 00:00:00 2001 From: MananTank Date: Mon, 6 Jan 2025 13:54:41 +0000 Subject: [PATCH 10/30] [TOOL-2890] Dashboard: Fix spelling issues (#5891) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- ## PR-Codex overview This PR focuses on fixing typos, improving comments, and enhancing code readability across various files in the project. ### Detailed summary - Corrected typos in text labels (e.g., `Manange` to `Manage`, `Comunity` to `Community`). - Improved comments for clarity (e.g., `Fix colors on autofilled inputs` to `Fix colors on auto-filled inputs`). - Standardized variable names (e.g., `dispalyName` to `displayName`). - Enhanced consistency in formatting (e.g., `balancesisPending` to `balancesIsPending`). - Fixed minor grammatical issues in comments and strings throughout the code. > ✨ Ask PR-Codex anything about this PR by commenting with `/codex {your question}` --- apps/dashboard/src/@/api/team.ts | 4 +-- .../src/@/components/ui/button.stories.tsx | 4 +-- apps/dashboard/src/@/components/ui/button.tsx | 2 +- .../src/@/components/ui/select.stories.tsx | 2 +- .../src/@/constants/thirdweb.client.ts | 2 +- apps/dashboard/src/@/lib/DashboardRouter.tsx | 2 +- apps/dashboard/src/@/styles/globals.css | 2 +- .../@3rdweb-sdk/react/hooks/useActivity.ts | 2 +- .../components/client/add-chain-to-wallet.tsx | 2 +- .../components/server/FaucetSection.tsx | 2 +- .../(chain)/[chain_id]/(chainPage)/layout.tsx | 6 ++--- .../accounts/components/accounts-table.tsx | 2 +- .../[chain_id]/[contractAddress]/layout.tsx | 2 +- .../nft/AdvancedNFTMetadataFormGroup.tsx | 2 +- .../nfts/[tokenId]/components/claim-tab.tsx | 2 +- .../components/update-metadata-form.tsx | 4 +-- .../nfts/components/lazy-mint-form.tsx | 4 +-- .../nfts/components/mint-form.tsx | 4 +-- .../nfts/components/shared-metadata-form.tsx | 4 +-- .../proposals/components/delegate-button.tsx | 6 ++--- .../sources/ContractSourcesPage.tsx | 12 ++++----- .../split/ContractSplitPage.tsx | 2 +- .../split/components/distribute-button.tsx | 8 +++--- .../tokens/components/transfer-button.tsx | 4 +-- .../chainlist/components/client/filters.tsx | 2 +- .../chainlist/components/client/view.tsx | 4 +-- .../[contract_id]/[version]/page.tsx | 2 +- .../[publisher]/[contract_id]/page.tsx | 2 +- .../contract-actions-deploy.client.tsx | 4 +-- .../contract-actions-published.client.tsx | 4 +-- .../components/publish-based-deploy.tsx | 2 +- .../components/uri-based-deploy.tsx | 2 +- .../src/app/(dashboard)/support/page.tsx | 2 +- .../app/account/overview/AccountTeamsUI.tsx | 2 +- .../settings/AccountSettingsPageUI.tsx | 2 +- .../src/app/account/wallets/LinkWalletUI.tsx | 4 +-- .../nebula-app/(app)/components/ChatBar.tsx | 2 +- .../(app)/components/ChatPageContent.tsx | 4 +-- .../(app)/components/Chatbar.stories.tsx | 6 ++--- .../components/EmptyStateChatPageContent.tsx | 4 +-- .../(active)/configuration/constants.ts | 2 +- .../components/engine-access-tokens.tsx | 2 +- .../contract-subscriptions-table.tsx | 4 +-- .../(team)/~/projects/TeamProjectsPage.tsx | 14 +++++----- .../general/GeneralSettingsPage.stories.tsx | 4 +-- .../in-app-wallets/_components/footer.tsx | 2 +- .../connect/in-app-wallets/layout.tsx | 4 +-- .../blueprint-playground.client.tsx | 6 ++--- .../contract-deploy-form/custom-contract.tsx | 26 +++++++++---------- ...ular-contract-default-modules-fieldset.tsx | 12 ++++----- .../contract-publish-form/index.tsx | 4 +-- .../explore/contract-card/index.tsx | 8 +++--- .../explore/upsells/publish-submit.tsx | 2 +- .../components/PayNewCustomers.tsx | 4 +-- .../pay/PayAnalytics/hooks/usePayPurchases.ts | 6 ++--- .../src/components/pay/PayConfig.tsx | 2 +- .../components/settings/ApiKeys/Alerts.tsx | 8 +++--- .../ApiKeys/Create/LazyCreateAPIKeyDialog.tsx | 2 +- .../src/components/shared/TWTable.tsx | 2 +- .../SponsorshipPolicies/index.tsx | 6 ++--- .../tabs/code/components/code-overview.tsx | 2 +- .../src/pages/account-abstraction.tsx | 2 +- 62 files changed, 129 insertions(+), 129 deletions(-) diff --git a/apps/dashboard/src/@/api/team.ts b/apps/dashboard/src/@/api/team.ts index 6569df0fa2c..5baa85542e4 100644 --- a/apps/dashboard/src/@/api/team.ts +++ b/apps/dashboard/src/@/api/team.ts @@ -64,7 +64,7 @@ export async function getTeams() { return null; } -type TeamNebulWaitList = { +type TeamNebulaWaitList = { onWaitlist: boolean; createdAt: null | string; }; @@ -86,7 +86,7 @@ export async function getTeamNebulaWaitList(teamSlug: string) { ); if (res.ok) { - return (await res.json()).result as TeamNebulWaitList; + return (await res.json()).result as TeamNebulaWaitList; } return null; diff --git a/apps/dashboard/src/@/components/ui/button.stories.tsx b/apps/dashboard/src/@/components/ui/button.stories.tsx index 1bd5675e2e7..6b23ebffa6d 100644 --- a/apps/dashboard/src/@/components/ui/button.stories.tsx +++ b/apps/dashboard/src/@/components/ui/button.stories.tsx @@ -20,7 +20,7 @@ export const AllVariants: Story = { function Component() { return ( -
+
@@ -58,7 +58,7 @@ function Variants(props: { {props.size === "icon" ? ( ) : ( - "Desctructive" + "Destructive" )}
diff --git a/apps/dashboard/src/@/components/ui/button.tsx b/apps/dashboard/src/@/components/ui/button.tsx index d533e1b22ba..f2d72c6c9b8 100644 --- a/apps/dashboard/src/@/components/ui/button.tsx +++ b/apps/dashboard/src/@/components/ui/button.tsx @@ -15,7 +15,7 @@ const buttonVariants = cva( destructive: "bg-destructive hover:bg-destructive/90 text-semibold text-destructive-foreground ", outline: - "border border-input bg-transaprent hover:bg-accent hover:text-accent-foreground text-semibold", + "border border-input bg-transparent hover:bg-accent hover:text-accent-foreground text-semibold", secondary: "bg-secondary hover:bg-secondary/80 text-semibold text-secondary-foreground ", ghost: "hover:bg-accent text-semibold hover:text-accent-foreground", diff --git a/apps/dashboard/src/@/components/ui/select.stories.tsx b/apps/dashboard/src/@/components/ui/select.stories.tsx index f8951fa19d9..957c3586df9 100644 --- a/apps/dashboard/src/@/components/ui/select.stories.tsx +++ b/apps/dashboard/src/@/components/ui/select.stories.tsx @@ -31,7 +31,7 @@ function randomName() { function Component() { return ( -
+
diff --git a/apps/dashboard/src/@/constants/thirdweb.client.ts b/apps/dashboard/src/@/constants/thirdweb.client.ts index 3f1639657d6..60e982e2159 100644 --- a/apps/dashboard/src/@/constants/thirdweb.client.ts +++ b/apps/dashboard/src/@/constants/thirdweb.client.ts @@ -32,7 +32,7 @@ export function useThirdwebClient(jwt?: string) { }); return useMemo( - // prfer jwt from props over the one from the token query if it exists + // prefer jwt from props over the one from the token query if it exists () => getThirdwebClient(jwt || query.data), [jwt, query.data], ); diff --git a/apps/dashboard/src/@/lib/DashboardRouter.tsx b/apps/dashboard/src/@/lib/DashboardRouter.tsx index 531de6dd3fd..ac1fc432666 100644 --- a/apps/dashboard/src/@/lib/DashboardRouter.tsx +++ b/apps/dashboard/src/@/lib/DashboardRouter.tsx @@ -100,7 +100,7 @@ function DashboardRouterTopProgressBarInner() { } async function startEffect() { - // if the loading state remains for atleast 500ms start the progress bar + // if the loading state remains for at least 500ms start the progress bar await wait(500); if (isMounted) { updateProgressBar(0, 100); diff --git a/apps/dashboard/src/@/styles/globals.css b/apps/dashboard/src/@/styles/globals.css index 45302ce3ef9..d966cd7bccc 100644 --- a/apps/dashboard/src/@/styles/globals.css +++ b/apps/dashboard/src/@/styles/globals.css @@ -143,7 +143,7 @@ body { min-height: 100%; } -/* Fix colors on autofilled inputs */ +/* Fix colors on auto-filled inputs */ input:-webkit-autofill, input:-webkit-autofill:hover, input:-webkit-autofill:focus, diff --git a/apps/dashboard/src/@3rdweb-sdk/react/hooks/useActivity.ts b/apps/dashboard/src/@3rdweb-sdk/react/hooks/useActivity.ts index 5985f820340..13b04fe4570 100644 --- a/apps/dashboard/src/@3rdweb-sdk/react/hooks/useActivity.ts +++ b/apps/dashboard/src/@3rdweb-sdk/react/hooks/useActivity.ts @@ -22,7 +22,7 @@ export interface InternalTransaction { export function useActivity(contract: ThirdwebContract, autoUpdate?: boolean) { const abiQuery = useResolveContractAbi(contract); - // Get all the PreprareEvents from the contract abis + // Get all the Prepare Events from the contract abis const events: PreparedEvent[] = useMemo(() => { const eventsItems = (abiQuery.data || []).filter((o) => o.type === "event"); const eventSignatures = eventsItems.map((event) => formatAbiItem(event)); diff --git a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/(chainPage)/components/client/add-chain-to-wallet.tsx b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/(chainPage)/components/client/add-chain-to-wallet.tsx index 8c78782e31c..d75886fd248 100644 --- a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/(chainPage)/components/client/add-chain-to-wallet.tsx +++ b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/(chainPage)/components/client/add-chain-to-wallet.tsx @@ -47,7 +47,7 @@ export const AddChainToWallet: React.FC = (props) => { className="w-full gap-2" variant="outline" onClick={() => { - // Connct directly to this chain + // Connect directly to this chain if (!account) { return customConnectModal({ chain: props.chain }); } diff --git a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/(chainPage)/components/server/FaucetSection.tsx b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/(chainPage)/components/server/FaucetSection.tsx index 1e814a7d5be..3ae3cb9c187 100644 --- a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/(chainPage)/components/server/FaucetSection.tsx +++ b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/(chainPage)/components/server/FaucetSection.tsx @@ -12,7 +12,7 @@ export async function FaucetSection(props: { }) { const { chain, twAccount } = props; - // Check eligibilty. + // Check eligibility. const sanitizedChainName = chain.name.replace("Mainnet", "").trim(); const amountToGive = getFaucetClaimAmount(props.chain.chainId); diff --git a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/(chainPage)/layout.tsx b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/(chainPage)/layout.tsx index 0d9b963f380..0f9ea2d37ff 100644 --- a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/(chainPage)/layout.tsx +++ b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/(chainPage)/layout.tsx @@ -162,7 +162,7 @@ export default async function ChainPageLayout(props: { {/* Gas Sponsored badge - Mobile */} {chainMetadata?.gasSponsored && (
- +
)} @@ -182,7 +182,7 @@ export default async function ChainPageLayout(props: { {/* Gas Sponsored badge - Desktop */} {chainMetadata?.gasSponsored && (
- +
)}
@@ -221,7 +221,7 @@ export default async function ChainPageLayout(props: { ); } -function GasSponseredBadge() { +function GasSponsoredBadge() { return (
diff --git a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/accounts/components/accounts-table.tsx b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/accounts/components/accounts-table.tsx index 1057e113e3b..8273209efef 100644 --- a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/accounts/components/accounts-table.tsx +++ b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/accounts/components/accounts-table.tsx @@ -51,7 +51,7 @@ export const AccountsTable: React.FC = ({ contract }) => { const totalAccountsQuery = useReadContract(totalAccounts, { contract }); // the total size should never be more than max int size (that would be hella wallets!) - // so converting the totalAccounts to a nunber should be safe here + // so converting the totalAccounts to a number should be safe here const totalAccountsNum = useMemo( () => Number(totalAccountsQuery.data || 0), [totalAccountsQuery.data], diff --git a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/layout.tsx b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/layout.tsx index b5c9c702652..97c9ee710b3 100644 --- a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/layout.tsx +++ b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/layout.tsx @@ -52,7 +52,7 @@ export default async function Layout(props: { // check if the contract exists const isValidContract = await isContractDeployed(contract).catch(() => false); if (!isValidContract) { - // TODO - replace 404 with a better page to upsale deploy or other thirdweb products + // TODO - replace 404 with a better page to upsell deploy or other thirdweb products notFound(); } const contractPageMetadata = await getContractPageMetadata(contract); diff --git a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/modules/components/nft/AdvancedNFTMetadataFormGroup.tsx b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/modules/components/nft/AdvancedNFTMetadataFormGroup.tsx index 613e0937bb8..0550fa2e15d 100644 --- a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/modules/components/nft/AdvancedNFTMetadataFormGroup.tsx +++ b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/modules/components/nft/AdvancedNFTMetadataFormGroup.tsx @@ -82,7 +82,7 @@ export function AdvancedNFTMetadataFormGroup< - If you already have your NFT Animation URL preuploaded, you can + If you already have your NFT Animation URL pre-uploaded, you can set the URL or URI here. diff --git a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/nfts/[tokenId]/components/claim-tab.tsx b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/nfts/[tokenId]/components/claim-tab.tsx index 35e9ce91517..6e37d7e5249 100644 --- a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/nfts/[tokenId]/components/claim-tab.tsx +++ b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/nfts/[tokenId]/components/claim-tab.tsx @@ -59,7 +59,7 @@ const ClaimTabERC1155: React.FC = ({ if (approveTx) { const approvalPromise = sendAndConfirmTx.mutateAsync(approveTx); toast.promise(approvalPromise, { - success: "Approved succesfully", + success: "Approved successfully", error: "Failed to approve ERC20", }); await approvalPromise; diff --git a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/nfts/[tokenId]/components/update-metadata-form.tsx b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/nfts/[tokenId]/components/update-metadata-form.tsx index 78a305d8823..29fa3524010 100644 --- a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/nfts/[tokenId]/components/update-metadata-form.tsx +++ b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/nfts/[tokenId]/components/update-metadata-form.tsx @@ -361,7 +361,7 @@ export const UpdateNftMetadata: React.FC = ({ Image URL - If you already have your NFT image preuploaded, you can set the + If you already have your NFT image pre-uploaded, you can set the URL or URI here. @@ -372,7 +372,7 @@ export const UpdateNftMetadata: React.FC = ({ Animation URL - If you already have your NFT Animation URL preuploaded, you can + If you already have your NFT Animation URL pre-uploaded, you can set the URL or URI here. diff --git a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/nfts/components/lazy-mint-form.tsx b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/nfts/components/lazy-mint-form.tsx index 507bd9f016d..b6d2f82cac7 100644 --- a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/nfts/components/lazy-mint-form.tsx +++ b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/nfts/components/lazy-mint-form.tsx @@ -294,7 +294,7 @@ export const LazyMintNftForm: React.FC = ({ Image URL - If you already have your NFT image preuploaded, you can set + If you already have your NFT image pre-uploaded, you can set the URL or URI here. @@ -305,7 +305,7 @@ export const LazyMintNftForm: React.FC = ({ Animation URL - If you already have your NFT Animation URL preuploaded, you + If you already have your NFT Animation URL pre-uploaded, you can set the URL or URI here. diff --git a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/nfts/components/mint-form.tsx b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/nfts/components/mint-form.tsx index d252aeba2d3..6eb3bd6f01b 100644 --- a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/nfts/components/mint-form.tsx +++ b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/nfts/components/mint-form.tsx @@ -317,7 +317,7 @@ export const NFTMintForm: React.FC = ({ Image URL - If you already have your NFT image preuploaded, you can set + If you already have your NFT image pre-uploaded, you can set the URL or URI here. @@ -328,7 +328,7 @@ export const NFTMintForm: React.FC = ({ Animation URL - If you already have your NFT Animation URL preuploaded, you + If you already have your NFT Animation URL pre-uploaded, you can set the URL or URI here. diff --git a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/nfts/components/shared-metadata-form.tsx b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/nfts/components/shared-metadata-form.tsx index b2681a97eb7..0c434351e18 100644 --- a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/nfts/components/shared-metadata-form.tsx +++ b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/nfts/components/shared-metadata-form.tsx @@ -247,7 +247,7 @@ export const SharedMetadataForm: React.FC<{ Image URL - If you already have your NFT image preuploaded, you can set + If you already have your NFT image pre-uploaded, you can set the URL or URI here. @@ -258,7 +258,7 @@ export const SharedMetadataForm: React.FC<{ Animation URL - If you already have your NFT Animation URL preuploaded, you + If you already have your NFT Animation URL pre-uploaded, you can set the URL or URI here. diff --git a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/proposals/components/delegate-button.tsx b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/proposals/components/delegate-button.tsx index 8df04974319..f17a45f33df 100644 --- a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/proposals/components/delegate-button.tsx +++ b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/proposals/components/delegate-button.tsx @@ -30,7 +30,7 @@ export const DelegateButton: React.FC = ({ enabled: !!account, }, }); - const delgateMutation = useDelegateMutation(); + const delegateMutation = useDelegateMutation(); if (tokensDelegatedQuery.data || tokensDelegatedQuery.isPending) { return null; @@ -44,7 +44,7 @@ export const DelegateButton: React.FC = ({ transactionCount={1} onClick={() => { toast.promise( - delgateMutation.mutateAsync(contract, { + delegateMutation.mutateAsync(contract, { onSuccess: () => { trackEvent({ category: "vote", @@ -68,7 +68,7 @@ export const DelegateButton: React.FC = ({ }, ); }} - isPending={delgateMutation.isPending} + isPending={delegateMutation.isPending} > Delegate Tokens diff --git a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/sources/ContractSourcesPage.tsx b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/sources/ContractSourcesPage.tsx index e2770c6e44e..4db8aad7ca5 100644 --- a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/sources/ContractSourcesPage.tsx +++ b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/sources/ContractSourcesPage.tsx @@ -72,7 +72,7 @@ interface ConnectorModalProps { const VerifyContractModal: React.FC< ConnectorModalProps & { resetSignal: number } > = ({ isOpen, onClose, contract, resetSignal }) => { - const veryifyQuery = useQuery({ + const verifyQuery = useQuery({ queryKey: [ "verify-contract", contract.chain.id, @@ -101,23 +101,23 @@ const VerifyContractModal: React.FC< - {veryifyQuery.isPending && ( + {verifyQuery.isPending && ( Verifying... )} - {veryifyQuery?.error ? ( + {verifyQuery?.error ? ( - {veryifyQuery?.error.toString()} + {verifyQuery?.error.toString()} ) : null} - {veryifyQuery.data?.results - ? veryifyQuery.data?.results.map( + {verifyQuery.data?.results + ? verifyQuery.data?.results.map( (result: VerificationResult, index: number) => ( // biome-ignore lint/suspicious/noArrayIndexKey: FIXME diff --git a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/split/ContractSplitPage.tsx b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/split/ContractSplitPage.tsx index 3e1e8f66d11..99bb0ed76e9 100644 --- a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/split/ContractSplitPage.tsx +++ b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/split/ContractSplitPage.tsx @@ -110,7 +110,7 @@ export const ContractSplitPage: React.FC = ({ = ({ contract, balances, - balancesisPending, + balancesIsPending, balancesIsError, twAccount, ...restButtonProps @@ -37,13 +37,13 @@ export const DistributeButton: React.FC = ({ ) { return 1; } - if (!validBalances || balancesisPending) { + if (!validBalances || balancesIsPending) { return 0; } return validBalances?.filter( (b) => b.display_balance !== "0.0" && b.display_balance !== "0", ).length; - }, [validBalances, balancesisPending]); + }, [validBalances, balancesIsPending]); const mutation = useSplitDistributeFunds(contract); diff --git a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/tokens/components/transfer-button.tsx b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/tokens/components/transfer-button.tsx index dd9f2c2b41a..ed3d3310a10 100644 --- a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/tokens/components/transfer-button.tsx +++ b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/tokens/components/transfer-button.tsx @@ -140,8 +140,8 @@ export const TokenTransferButton: React.FC = ({ }, }); toast.promise(promise, { - loading: "Transfering tokens", - success: "Successfully transfered tokens", + loading: "Transferring tokens", + success: "Successfully transferred tokens", error: "Failed to transfer tokens", }); })} diff --git a/apps/dashboard/src/app/(dashboard)/(chain)/chainlist/components/client/filters.tsx b/apps/dashboard/src/app/(dashboard)/(chain)/chainlist/components/client/filters.tsx index 919e7a4567a..685671ade6f 100644 --- a/apps/dashboard/src/app/(dashboard)/(chain)/chainlist/components/client/filters.tsx +++ b/apps/dashboard/src/app/(dashboard)/(chain)/chainlist/components/client/filters.tsx @@ -162,7 +162,7 @@ export const ChainTypeFilter: React.FC = ({
- +
diff --git a/apps/dashboard/src/app/(dashboard)/(chain)/chainlist/components/client/view.tsx b/apps/dashboard/src/app/(dashboard)/(chain)/chainlist/components/client/view.tsx index 7ee28d54227..e1f1677c01b 100644 --- a/apps/dashboard/src/app/(dashboard)/(chain)/chainlist/components/client/view.tsx +++ b/apps/dashboard/src/app/(dashboard)/(chain)/chainlist/components/client/view.tsx @@ -6,11 +6,11 @@ import { Grid2X2Icon, ListIcon } from "lucide-react"; import { usePathname, useSearchParams } from "next/navigation"; import { useCallback } from "react"; -type hainListViewProps = { +type ChainListViewProps = { activeView: "grid" | "table"; }; -export const ChainListView: React.FC = ({ activeView }) => { +export const ChainListView: React.FC = ({ activeView }) => { const pathname = usePathname(); const searchParams = useSearchParams(); const router = useDashboardRouter(); diff --git a/apps/dashboard/src/app/(dashboard)/published-contract/[publisher]/[contract_id]/[version]/page.tsx b/apps/dashboard/src/app/(dashboard)/published-contract/[publisher]/[contract_id]/[version]/page.tsx index da711ad5814..783c15d7e65 100644 --- a/apps/dashboard/src/app/(dashboard)/published-contract/[publisher]/[contract_id]/[version]/page.tsx +++ b/apps/dashboard/src/app/(dashboard)/published-contract/[publisher]/[contract_id]/[version]/page.tsx @@ -76,7 +76,7 @@ export default async function PublishedContractPage( > diff --git a/apps/dashboard/src/app/(dashboard)/published-contract/[publisher]/[contract_id]/page.tsx b/apps/dashboard/src/app/(dashboard)/published-contract/[publisher]/[contract_id]/page.tsx index 5286594dd09..633acaf2568 100644 --- a/apps/dashboard/src/app/(dashboard)/published-contract/[publisher]/[contract_id]/page.tsx +++ b/apps/dashboard/src/app/(dashboard)/published-contract/[publisher]/[contract_id]/page.tsx @@ -45,7 +45,7 @@ export default async function PublishedContractPage( > diff --git a/apps/dashboard/src/app/(dashboard)/published-contract/components/contract-actions-deploy.client.tsx b/apps/dashboard/src/app/(dashboard)/published-contract/components/contract-actions-deploy.client.tsx index 3d073b2b031..e940cc00f0a 100644 --- a/apps/dashboard/src/app/(dashboard)/published-contract/components/contract-actions-deploy.client.tsx +++ b/apps/dashboard/src/app/(dashboard)/published-contract/components/contract-actions-deploy.client.tsx @@ -9,7 +9,7 @@ export function DeployActions(props: { publisher: string; contract_id: string; version?: string; - dispayName: string; + displayName: string; }) { const searchparams = useSearchParams(); @@ -30,7 +30,7 @@ export function DeployActions(props: { variant="outline" onClick={() => { shareLink({ - title: `Deploy ${props.dispayName}`, + title: `Deploy ${props.displayName}`, }); }} > diff --git a/apps/dashboard/src/app/(dashboard)/published-contract/components/contract-actions-published.client.tsx b/apps/dashboard/src/app/(dashboard)/published-contract/components/contract-actions-published.client.tsx index 13efeebc2a6..ca849ecad10 100644 --- a/apps/dashboard/src/app/(dashboard)/published-contract/components/contract-actions-published.client.tsx +++ b/apps/dashboard/src/app/(dashboard)/published-contract/components/contract-actions-published.client.tsx @@ -10,7 +10,7 @@ export function PublishedActions(props: { publisher: string; contract_id: string; version?: string; - dispayName: string; + displayName: string; }) { const searchparams = useSearchParams(); const stringifiedSearchParams = searchparams?.toString(); @@ -21,7 +21,7 @@ export function PublishedActions(props: { variant="outline" onClick={() => { shareLink({ - title: `Deploy ${props.dispayName}`, + title: `Deploy ${props.displayName}`, }); }} > diff --git a/apps/dashboard/src/app/(dashboard)/published-contract/components/publish-based-deploy.tsx b/apps/dashboard/src/app/(dashboard)/published-contract/components/publish-based-deploy.tsx index 67095f101f2..f3f119a7a36 100644 --- a/apps/dashboard/src/app/(dashboard)/published-contract/components/publish-based-deploy.tsx +++ b/apps/dashboard/src/app/(dashboard)/published-contract/components/publish-based-deploy.tsx @@ -81,7 +81,7 @@ export async function DeployFormForPublishInfo(props: PublishBasedDeployProps) { > diff --git a/apps/dashboard/src/app/(dashboard)/published-contract/components/uri-based-deploy.tsx b/apps/dashboard/src/app/(dashboard)/published-contract/components/uri-based-deploy.tsx index 67fab66cbc1..e68f5e1bdb1 100644 --- a/apps/dashboard/src/app/(dashboard)/published-contract/components/uri-based-deploy.tsx +++ b/apps/dashboard/src/app/(dashboard)/published-contract/components/uri-based-deploy.tsx @@ -30,7 +30,7 @@ export async function DeployFormForUri(props: DeployFormForUriProps) { redirect(`/login?next=${encodeURIComponent(pathname)}`); } - // TODO: remove the `ChakraProviderSetup` wrapper once the form is updated to no longer use chrakra + // TODO: remove the `ChakraProviderSetup` wrapper once the form is updated to no longer use chakra return ( - Discord Comunity + Discord Community diff --git a/apps/dashboard/src/app/account/overview/AccountTeamsUI.tsx b/apps/dashboard/src/app/account/overview/AccountTeamsUI.tsx index 4826fd6e2cd..1e009aa42ec 100644 --- a/apps/dashboard/src/app/account/overview/AccountTeamsUI.tsx +++ b/apps/dashboard/src/app/account/overview/AccountTeamsUI.tsx @@ -145,7 +145,7 @@ function TeamRow(props: { href={`/team/${props.team.slug}/~/settings`} className="w-full p-1 " > - Manange + Manage diff --git a/apps/dashboard/src/app/account/settings/AccountSettingsPageUI.tsx b/apps/dashboard/src/app/account/settings/AccountSettingsPageUI.tsx index 18840ee4661..ce82075e369 100644 --- a/apps/dashboard/src/app/account/settings/AccountSettingsPageUI.tsx +++ b/apps/dashboard/src/app/account/settings/AccountSettingsPageUI.tsx @@ -213,7 +213,7 @@ function DeleteAccountCard() { function AccountEmailFormControl(props: { email: string; - status: "unverified" | "verfication-sent" | "verified"; + status: "unverified" | "verified"; sendEmail: (email: string) => Promise; updateEmailWithOTP: (otp: string) => Promise; }) { diff --git a/apps/dashboard/src/app/account/wallets/LinkWalletUI.tsx b/apps/dashboard/src/app/account/wallets/LinkWalletUI.tsx index 8ef674888e6..de79533a9f1 100644 --- a/apps/dashboard/src/app/account/wallets/LinkWalletUI.tsx +++ b/apps/dashboard/src/app/account/wallets/LinkWalletUI.tsx @@ -9,7 +9,7 @@ import { SearchInput } from "../components/SearchInput"; export function LinkWalletUI(props: { wallets: string[]; }) { - const [searchValue, setSerchValue] = useState(""); + const [searchValue, setSearchValue] = useState(""); const walletsToShow = !searchValue ? props.wallets : props.wallets.filter((v) => { @@ -40,7 +40,7 @@ export function LinkWalletUI(props: {
diff --git a/apps/dashboard/src/app/nebula-app/(app)/components/ChatBar.tsx b/apps/dashboard/src/app/nebula-app/(app)/components/ChatBar.tsx index 5f623c2d7c3..df1a08a181f 100644 --- a/apps/dashboard/src/app/nebula-app/(app)/components/ChatBar.tsx +++ b/apps/dashboard/src/app/nebula-app/(app)/components/ChatBar.tsx @@ -6,7 +6,7 @@ import { cn } from "@/lib/utils"; import { ArrowUpIcon, CircleStopIcon } from "lucide-react"; import { useState } from "react"; -export function Chatbar(props: { +export function ChatBar(props: { sendMessage: (message: string) => void; isChatStreaming: boolean; abortChatStream: () => void; diff --git a/apps/dashboard/src/app/nebula-app/(app)/components/ChatPageContent.tsx b/apps/dashboard/src/app/nebula-app/(app)/components/ChatPageContent.tsx index fbdf9f65cff..5c2bf88d260 100644 --- a/apps/dashboard/src/app/nebula-app/(app)/components/ChatPageContent.tsx +++ b/apps/dashboard/src/app/nebula-app/(app)/components/ChatPageContent.tsx @@ -18,7 +18,7 @@ import { type ContextFilters, promptNebula } from "../api/chat"; import { createSession, updateSession } from "../api/session"; import type { ExecuteConfig, SessionInfo } from "../api/types"; import { newChatPageUrlStore, newSessionsStore } from "../stores"; -import { Chatbar } from "./ChatBar"; +import { ChatBar } from "./ChatBar"; import { type ChatMessage, Chats } from "./Chats"; import ContextFiltersButton from "./ContextFilters"; import { EmptyStateChatPageContent } from "./EmptyStateChatPageContent"; @@ -406,7 +406,7 @@ export function ChatPageContent(props: { />
- { diff --git a/apps/dashboard/src/app/nebula-app/(app)/components/Chatbar.stories.tsx b/apps/dashboard/src/app/nebula-app/(app)/components/Chatbar.stories.tsx index e54cc308b11..100d697486a 100644 --- a/apps/dashboard/src/app/nebula-app/(app)/components/Chatbar.stories.tsx +++ b/apps/dashboard/src/app/nebula-app/(app)/components/Chatbar.stories.tsx @@ -1,6 +1,6 @@ import type { Meta, StoryObj } from "@storybook/react"; import { BadgeContainer, mobileViewport } from "../../../../stories/utils"; -import { Chatbar } from "./ChatBar"; +import { ChatBar } from "./ChatBar"; const meta = { title: "Nebula/Chatbar", @@ -30,7 +30,7 @@ function Story() { return (
- {}} isChatStreaming={false} sendMessage={() => {}} @@ -38,7 +38,7 @@ function Story() { - {}} isChatStreaming={true} sendMessage={() => {}} diff --git a/apps/dashboard/src/app/nebula-app/(app)/components/EmptyStateChatPageContent.tsx b/apps/dashboard/src/app/nebula-app/(app)/components/EmptyStateChatPageContent.tsx index 72626890f78..17a26b30a3c 100644 --- a/apps/dashboard/src/app/nebula-app/(app)/components/EmptyStateChatPageContent.tsx +++ b/apps/dashboard/src/app/nebula-app/(app)/components/EmptyStateChatPageContent.tsx @@ -3,7 +3,7 @@ import { ArrowUpRightIcon } from "lucide-react"; import { Button } from "../../../../@/components/ui/button"; import { NebulaIcon } from "../icons/NebulaIcon"; -import { Chatbar } from "./ChatBar"; +import { ChatBar } from "./ChatBar"; export function EmptyStateChatPageContent(props: { sendMessage: (message: string) => void; @@ -26,7 +26,7 @@ export function EmptyStateChatPageContent(props: {
- { diff --git a/apps/dashboard/src/app/team/[team_slug]/(team)/~/ecosystem/[slug]/(active)/configuration/constants.ts b/apps/dashboard/src/app/team/[team_slug]/(team)/~/ecosystem/[slug]/(active)/configuration/constants.ts index 4423781e36e..04dae439fd4 100644 --- a/apps/dashboard/src/app/team/[team_slug]/(team)/~/ecosystem/[slug]/(active)/configuration/constants.ts +++ b/apps/dashboard/src/app/team/[team_slug]/(team)/~/ecosystem/[slug]/(active)/configuration/constants.ts @@ -20,7 +20,7 @@ export const partnerFormSchema = z.object({ .refine((domains) => domains.every((d) => isDomainRegex.test(d)), { message: "Invalid domain format", // This error message CANNOT be within the array iteration, or the FormMessage won't be able to find it in the form state }) - .transform((s) => s.join(",")), // This is rejoined to return a string (and later split again) since react-hook-form's typings can't hnadle different input vs output types + .transform((s) => s.join(",")), // This is rejoined to return a string (and later split again) since react-hook-form's typings can't handle different input vs output types bundleIds: z .string() .trim() diff --git a/apps/dashboard/src/app/team/[team_slug]/(team)/~/engine/(instance)/[engineId]/access-tokens/components/engine-access-tokens.tsx b/apps/dashboard/src/app/team/[team_slug]/(team)/~/engine/(instance)/[engineId]/access-tokens/components/engine-access-tokens.tsx index 6231981e340..0a6ec16b40c 100644 --- a/apps/dashboard/src/app/team/[team_slug]/(team)/~/engine/(instance)/[engineId]/access-tokens/components/engine-access-tokens.tsx +++ b/apps/dashboard/src/app/team/[team_slug]/(team)/~/engine/(instance)/[engineId]/access-tokens/components/engine-access-tokens.tsx @@ -150,7 +150,7 @@ const KeypairAuthenticationPanel = ({ return ( <> - Keypair authentication allows your app to geneate short-lived access + Keypair authentication allows your app to generate short-lived access tokens.
They are securely signed by your backend and verified with a public key.{" "} diff --git a/apps/dashboard/src/app/team/[team_slug]/(team)/~/engine/(instance)/[engineId]/contract-subscriptions/components/contract-subscriptions-table.tsx b/apps/dashboard/src/app/team/[team_slug]/(team)/~/engine/(instance)/[engineId]/contract-subscriptions/components/contract-subscriptions-table.tsx index 69c18a2d571..c711406d35d 100644 --- a/apps/dashboard/src/app/team/[team_slug]/(team)/~/engine/(instance)/[engineId]/contract-subscriptions/components/contract-subscriptions-table.tsx +++ b/apps/dashboard/src/app/team/[team_slug]/(team)/~/engine/(instance)/[engineId]/contract-subscriptions/components/contract-subscriptions-table.tsx @@ -33,7 +33,7 @@ import { useV5DashboardChain } from "lib/v5-adapter"; import { InfoIcon, Trash2Icon } from "lucide-react"; import { useState } from "react"; import { eth_getBlockByNumber, getRpcClient } from "thirdweb"; -import { shortenAddress as shortenAddresThrows } from "thirdweb/utils"; +import { shortenAddress as shortenAddressThrows } from "thirdweb/utils"; import { Button, Card, FormLabel, LinkButton, Text } from "tw-components"; function shortenAddress(address: string) { @@ -42,7 +42,7 @@ function shortenAddress(address: string) { } try { - return shortenAddresThrows(address); + return shortenAddressThrows(address); } catch { return `${address.substring(0, 6)}...${address.substring(address.length - 4)}`; } diff --git a/apps/dashboard/src/app/team/[team_slug]/(team)/~/projects/TeamProjectsPage.tsx b/apps/dashboard/src/app/team/[team_slug]/(team)/~/projects/TeamProjectsPage.tsx index b7ee115f177..2bed7fbd2d1 100644 --- a/apps/dashboard/src/app/team/[team_slug]/(team)/~/projects/TeamProjectsPage.tsx +++ b/apps/dashboard/src/app/team/[team_slug]/(team)/~/projects/TeamProjectsPage.tsx @@ -23,7 +23,7 @@ import { ChevronDownIcon, PlusIcon, SearchIcon } from "lucide-react"; import Link from "next/link"; import { useState } from "react"; -type SortyById = "name" | "createdAt"; +type SortById = "name" | "createdAt"; export function TeamProjectsPage(props: { projects: Project[]; @@ -31,7 +31,7 @@ export function TeamProjectsPage(props: { }) { const { projects } = props; const [searchTerm, setSearchTerm] = useState(""); - const [sortBy, setSortBy] = useState("createdAt"); + const [sortBy, setSortBy] = useState("createdAt"); const [isCreateProjectDialogOpen, setIsCreateProjectDialogOpen] = useState(false); const router = useDashboardRouter(); @@ -206,11 +206,11 @@ function AddNewButton(props: { } function SelectBy(props: { - value: SortyById; - onChange: (value: SortyById) => void; + value: SortById; + onChange: (value: SortById) => void; }) { - const values: SortyById[] = ["name", "createdAt"]; - const valueToLabel: Record = { + const values: SortById[] = ["name", "createdAt"]; + const valueToLabel: Record = { name: "Name", createdAt: "Creation Date", }; @@ -219,7 +219,7 @@ function SelectBy(props: { )} diff --git a/apps/dashboard/src/contract-ui/tabs/code/components/code-overview.tsx b/apps/dashboard/src/contract-ui/tabs/code/components/code-overview.tsx index 5833967e979..81a65844f96 100644 --- a/apps/dashboard/src/contract-ui/tabs/code/components/code-overview.tsx +++ b/apps/dashboard/src/contract-ui/tabs/code/components/code-overview.tsx @@ -251,7 +251,7 @@ const chain = defineChain({{chainId}}); // First, connect the personal wallet, which can be any wallet (metamask, in-app, etc.) const personalWallet = inAppWallet(); -const peronalAccount = await personalWallet.connect({ +const personalAccount = await personalWallet.connect({ client, chain, strategy: "google", diff --git a/apps/dashboard/src/pages/account-abstraction.tsx b/apps/dashboard/src/pages/account-abstraction.tsx index 9fccc2d8f57..a604eab7685 100644 --- a/apps/dashboard/src/pages/account-abstraction.tsx +++ b/apps/dashboard/src/pages/account-abstraction.tsx @@ -171,7 +171,7 @@ const SmartWallet: ThirdwebNextPage = () => { /> Date: Tue, 7 Jan 2025 01:34:15 +0530 Subject: [PATCH 11/30] [TOOL-2764] Dashboard: Fix published contract version selector with duplicate versions (#5893) --- .../fetch-contracts-with-versions.ts | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/apps/dashboard/src/components/contract-components/fetch-contracts-with-versions.ts b/apps/dashboard/src/components/contract-components/fetch-contracts-with-versions.ts index 3a166d1be5f..15c046af9ce 100644 --- a/apps/dashboard/src/components/contract-components/fetch-contracts-with-versions.ts +++ b/apps/dashboard/src/components/contract-components/fetch-contracts-with-versions.ts @@ -47,7 +47,18 @@ export async function fetchPublishedContractVersions( ), ); - return responses.filter((r) => r.status === "fulfilled").map((r) => r.value); + const publishedContracts = responses + .filter((r) => r.status === "fulfilled") + .map((r) => r.value); + + // if there are two published contract with same version, keep the latest (first in list - list is already sorted) one + const uniquePublishedContracts = publishedContracts.filter( + (contract, idx, arr) => + // if this is the first occurrence of this version in list - keep it + arr.findIndex((c) => c.version === contract.version) === idx, + ); + + return uniquePublishedContracts; } export async function fetchPublishedContractVersion( From dd4b1e86e9f6a4349b7718f74080a00e42e994d5 Mon Sep 17 00:00:00 2001 From: Jonas Daniels Date: Mon, 6 Jan 2025 12:21:14 -0800 Subject: [PATCH 12/30] Version Packages (#5838) Co-authored-by: github-actions[bot] --- .changeset/afraid-mails-sip.md | 5 ---- .changeset/cyan-shrimps-battle.md | 5 ---- .changeset/fair-planes-doubt.md | 5 ---- .changeset/little-beds-dress.md | 5 ---- .changeset/metal-mails-ring.md | 20 ---------------- .changeset/pink-gorillas-try.md | 5 ---- .changeset/yellow-experts-sparkle.md | 5 ---- packages/thirdweb/CHANGELOG.md | 34 ++++++++++++++++++++++++++++ packages/thirdweb/package.json | 2 +- packages/wagmi-adapter/CHANGELOG.md | 2 ++ packages/wagmi-adapter/package.json | 2 +- 11 files changed, 38 insertions(+), 52 deletions(-) delete mode 100644 .changeset/afraid-mails-sip.md delete mode 100644 .changeset/cyan-shrimps-battle.md delete mode 100644 .changeset/fair-planes-doubt.md delete mode 100644 .changeset/little-beds-dress.md delete mode 100644 .changeset/metal-mails-ring.md delete mode 100644 .changeset/pink-gorillas-try.md delete mode 100644 .changeset/yellow-experts-sparkle.md diff --git a/.changeset/afraid-mails-sip.md b/.changeset/afraid-mails-sip.md deleted file mode 100644 index 87d44e5d5d5..00000000000 --- a/.changeset/afraid-mails-sip.md +++ /dev/null @@ -1,5 +0,0 @@ ---- -"thirdweb": minor ---- - -Feature: Adds getAdminAccount to inAppWallet interface for AA ecosystem wallets diff --git a/.changeset/cyan-shrimps-battle.md b/.changeset/cyan-shrimps-battle.md deleted file mode 100644 index deab0a05c96..00000000000 --- a/.changeset/cyan-shrimps-battle.md +++ /dev/null @@ -1,5 +0,0 @@ ---- -"thirdweb": patch ---- - -Update implementations diff --git a/.changeset/fair-planes-doubt.md b/.changeset/fair-planes-doubt.md deleted file mode 100644 index d3ca2bda5dc..00000000000 --- a/.changeset/fair-planes-doubt.md +++ /dev/null @@ -1,5 +0,0 @@ ---- -"thirdweb": patch ---- - -SDK: Fix chain switching in smart account transactions diff --git a/.changeset/little-beds-dress.md b/.changeset/little-beds-dress.md deleted file mode 100644 index 017f1b6b385..00000000000 --- a/.changeset/little-beds-dress.md +++ /dev/null @@ -1,5 +0,0 @@ ---- -"thirdweb": patch ---- - -Add onTimeout callback to useAutoConnect diff --git a/.changeset/metal-mails-ring.md b/.changeset/metal-mails-ring.md deleted file mode 100644 index 89c5f6f9e84..00000000000 --- a/.changeset/metal-mails-ring.md +++ /dev/null @@ -1,20 +0,0 @@ ---- -"thirdweb": patch ---- - -- Add onClose callback to Connect Details modal - -```tsx - { - // The last screen name that was being shown when user closed the modal - console.log({ screen }); - } - }} -/> -``` - -- Small fix for ChainIcon: Always resolve IPFS URI - -- Improve test coverage \ No newline at end of file diff --git a/.changeset/pink-gorillas-try.md b/.changeset/pink-gorillas-try.md deleted file mode 100644 index d5735273f13..00000000000 --- a/.changeset/pink-gorillas-try.md +++ /dev/null @@ -1,5 +0,0 @@ ---- -"thirdweb": patch ---- - -SDK: Removed co.lobstr from the available wallets (an unsupported non-EVM wallet) diff --git a/.changeset/yellow-experts-sparkle.md b/.changeset/yellow-experts-sparkle.md deleted file mode 100644 index 065a6690d90..00000000000 --- a/.changeset/yellow-experts-sparkle.md +++ /dev/null @@ -1,5 +0,0 @@ ---- -"thirdweb": patch ---- - -SDK: Gracefully ignore chain with no chain ID in `fromEip1193Provider` diff --git a/packages/thirdweb/CHANGELOG.md b/packages/thirdweb/CHANGELOG.md index e1eaa03753e..aaeb5f2ab7d 100644 --- a/packages/thirdweb/CHANGELOG.md +++ b/packages/thirdweb/CHANGELOG.md @@ -1,5 +1,39 @@ # thirdweb +## 5.81.0 + +### Minor Changes + +- [#5829](https://github.com/thirdweb-dev/js/pull/5829) [`e01193a`](https://github.com/thirdweb-dev/js/commit/e01193a659160fc84fcd54047043b23da56e3a90) Thanks [@gregfromstl](https://github.com/gregfromstl)! - Feature: Adds getAdminAccount to inAppWallet interface for AA ecosystem wallets + +### Patch Changes + +- [#5837](https://github.com/thirdweb-dev/js/pull/5837) [`ce3e850`](https://github.com/thirdweb-dev/js/commit/ce3e850fdbf34911e20919ecc2674e4a63f08fa3) Thanks [@kumaryash90](https://github.com/kumaryash90)! - Update implementations + +- [#5865](https://github.com/thirdweb-dev/js/pull/5865) [`a9547c5`](https://github.com/thirdweb-dev/js/commit/a9547c561f885cc343da8c4a018ba95d1dc91179) Thanks [@gregfromstl](https://github.com/gregfromstl)! - SDK: Fix chain switching in smart account transactions + +- [#5879](https://github.com/thirdweb-dev/js/pull/5879) [`810f319`](https://github.com/thirdweb-dev/js/commit/810f3195793203446b76f2f6d50ba3e9d8eefc3f) Thanks [@kien-ngo](https://github.com/kien-ngo)! - Add onTimeout callback to useAutoConnect + +- [#5605](https://github.com/thirdweb-dev/js/pull/5605) [`e9c23ad`](https://github.com/thirdweb-dev/js/commit/e9c23ade6799f2509175dabc3bc077b7a37a961b) Thanks [@kien-ngo](https://github.com/kien-ngo)! - - Add onClose callback to Connect Details modal + + ```tsx + { + // The last screen name that was being shown when user closed the modal + console.log({ screen }); + }, + }} + /> + ``` + + - Small fix for ChainIcon: Always resolve IPFS URI + - Improve test coverage + +- [#5869](https://github.com/thirdweb-dev/js/pull/5869) [`273a320`](https://github.com/thirdweb-dev/js/commit/273a320ae8189a76b67de105c1ae66b7dfb618b0) Thanks [@gregfromstl](https://github.com/gregfromstl)! - SDK: Removed co.lobstr from the available wallets (an unsupported non-EVM wallet) + +- [#5871](https://github.com/thirdweb-dev/js/pull/5871) [`1e8ddcb`](https://github.com/thirdweb-dev/js/commit/1e8ddcb3998d024cad794a2ee77100bd10a14f20) Thanks [@gregfromstl](https://github.com/gregfromstl)! - SDK: Gracefully ignore chain with no chain ID in `fromEip1193Provider` + ## 5.80.0 ### Minor Changes diff --git a/packages/thirdweb/package.json b/packages/thirdweb/package.json index 6b93bc3518c..321c18db151 100644 --- a/packages/thirdweb/package.json +++ b/packages/thirdweb/package.json @@ -1,6 +1,6 @@ { "name": "thirdweb", - "version": "5.80.0", + "version": "5.81.0", "repository": { "type": "git", "url": "git+https://github.com/thirdweb-dev/js.git#main" diff --git a/packages/wagmi-adapter/CHANGELOG.md b/packages/wagmi-adapter/CHANGELOG.md index bd409d73210..3821c162f1c 100644 --- a/packages/wagmi-adapter/CHANGELOG.md +++ b/packages/wagmi-adapter/CHANGELOG.md @@ -1,5 +1,7 @@ # @thirdweb-dev/wagmi-adapter +## 0.1.4 + ## 0.1.3 ## 0.1.2 diff --git a/packages/wagmi-adapter/package.json b/packages/wagmi-adapter/package.json index 8d5eb07ecec..b6330213816 100644 --- a/packages/wagmi-adapter/package.json +++ b/packages/wagmi-adapter/package.json @@ -1,6 +1,6 @@ { "name": "@thirdweb-dev/wagmi-adapter", - "version": "0.1.3", + "version": "0.1.4", "repository": { "type": "git", "url": "git+https://github.com/thirdweb-dev/js.git#main" From 5ca4493181c57b8c8cad29e55b158f9a54ebcdf4 Mon Sep 17 00:00:00 2001 From: MananTank Date: Mon, 6 Jan 2025 21:02:04 +0000 Subject: [PATCH 13/30] [TOOL-2925] Dashboard: Redirect to Nebula app if team has access instead of showing waitlist page (#5894) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit ## PR-Codex overview This PR introduces a check for `nebula` access in two `page.tsx` files, redirecting users to the Nebula web app if access is granted. It also maintains the existing login redirect functionality. ### Detailed summary - Added a check for `nebula` access using `team.enabledScopes.includes("nebula")`. - Redirects to `https://nebula.thirdweb.com` if access is granted. - Updated login redirect paths in both `page.tsx` files. > ✨ Ask PR-Codex anything about this PR by commenting with `/codex {your question}` --- .../src/app/team/[team_slug]/(team)/~/nebula/page.tsx | 8 ++++++++ .../app/team/[team_slug]/[project_slug]/nebula/page.tsx | 8 ++++++++ 2 files changed, 16 insertions(+) diff --git a/apps/dashboard/src/app/team/[team_slug]/(team)/~/nebula/page.tsx b/apps/dashboard/src/app/team/[team_slug]/(team)/~/nebula/page.tsx index 37991880188..fa58d1872d0 100644 --- a/apps/dashboard/src/app/team/[team_slug]/(team)/~/nebula/page.tsx +++ b/apps/dashboard/src/app/team/[team_slug]/(team)/~/nebula/page.tsx @@ -1,4 +1,5 @@ import { getTeamBySlug } from "@/api/team"; +import { redirect } from "next/navigation"; import { loginRedirect } from "../../../../../login/loginRedirect"; import { NebulaWaitListPage } from "../../../[project_slug]/nebula/components/nebula-waitlist-page"; @@ -14,5 +15,12 @@ export default async function Page(props: { loginRedirect(`/team/${params.team_slug}/~/nebula`); } + // if nebula access is already granted, redirect to nebula web app + const hasNebulaAccess = team.enabledScopes.includes("nebula"); + + if (hasNebulaAccess) { + redirect("https://nebula.thirdweb.com"); + } + return ; } diff --git a/apps/dashboard/src/app/team/[team_slug]/[project_slug]/nebula/page.tsx b/apps/dashboard/src/app/team/[team_slug]/[project_slug]/nebula/page.tsx index d7afd42ac0f..b932c51e479 100644 --- a/apps/dashboard/src/app/team/[team_slug]/[project_slug]/nebula/page.tsx +++ b/apps/dashboard/src/app/team/[team_slug]/[project_slug]/nebula/page.tsx @@ -1,4 +1,5 @@ import { getTeamBySlug } from "@/api/team"; +import { redirect } from "next/navigation"; import { loginRedirect } from "../../../../login/loginRedirect"; import { NebulaWaitListPage } from "./components/nebula-waitlist-page"; @@ -15,5 +16,12 @@ export default async function Page(props: { loginRedirect(`/team/${params.team_slug}/${params.project_slug}/nebula`); } + // if nebula access is already granted, redirect to nebula web app + const hasNebulaAccess = team.enabledScopes.includes("nebula"); + + if (hasNebulaAccess) { + redirect("https://nebula.thirdweb.com"); + } + return ; } From 6bbfc4dfcaf37544d296ee6f323db2dcd6ecf405 Mon Sep 17 00:00:00 2001 From: MananTank Date: Mon, 6 Jan 2025 21:35:11 +0000 Subject: [PATCH 14/30] [TOOL-2927] Dashboard: Update team member settings page alert (#5895) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit ## PR-Codex overview This PR updates the availability timeline for a feature in the `TeamMembersSettingsPage.tsx` file from Q4 2024 to Q1 2025. ### Detailed summary - Changed the text in the `AlertDescription` from "This feature will be available in Q4 2024" to "This feature will be available in Q1 2025". > ✨ Ask PR-Codex anything about this PR by commenting with `/codex {your question}` --- .../(team)/~/settings/members/TeamMembersSettingsPage.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/apps/dashboard/src/app/team/[team_slug]/(team)/~/settings/members/TeamMembersSettingsPage.tsx b/apps/dashboard/src/app/team/[team_slug]/(team)/~/settings/members/TeamMembersSettingsPage.tsx index 002525771c1..03690e02885 100644 --- a/apps/dashboard/src/app/team/[team_slug]/(team)/~/settings/members/TeamMembersSettingsPage.tsx +++ b/apps/dashboard/src/app/team/[team_slug]/(team)/~/settings/members/TeamMembersSettingsPage.tsx @@ -18,7 +18,7 @@ export function TeamMembersSettingsPage(props: { Inviting and Managing Team Members is not available yet - This feature will be available in Q4 2024 + This feature will be available in Q1 2025
From 9bc788427e46fa2cc09274ae098604592ede6d4c Mon Sep 17 00:00:00 2001 From: kien-ngo Date: Mon, 6 Jan 2025 21:58:19 +0000 Subject: [PATCH 15/30] [TOOL-2924] Catch error on fail-to-load metadata (#5892) TOOL-2924 --- .../[contractAddress]/nfts/components/reveal-button.tsx | 4 ++-- .../extensions/erc721/lazyMinting/read/getBatchesToReveal.ts | 4 ++-- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/nfts/components/reveal-button.tsx b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/nfts/components/reveal-button.tsx index 4b9cd98b351..92f07a607cc 100644 --- a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/nfts/components/reveal-button.tsx +++ b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/nfts/components/reveal-button.tsx @@ -70,7 +70,7 @@ export const NFTRevealButton: React.FC = ({ ); } - return batchesQuery.data?.length ? ( + return ( @@ -168,5 +168,5 @@ export const NFTRevealButton: React.FC = ({ - ) : null; + ); }; diff --git a/packages/thirdweb/src/extensions/erc721/lazyMinting/read/getBatchesToReveal.ts b/packages/thirdweb/src/extensions/erc721/lazyMinting/read/getBatchesToReveal.ts index aed3ae4b2c3..f38e168e449 100644 --- a/packages/thirdweb/src/extensions/erc721/lazyMinting/read/getBatchesToReveal.ts +++ b/packages/thirdweb/src/extensions/erc721/lazyMinting/read/getBatchesToReveal.ts @@ -15,7 +15,7 @@ import * as TokenURI from "../../__generated__/IERC721A/read/tokenURI.js"; export interface BatchToReveal { batchId: bigint; batchUri: string; - placeholderMetadata: NFTMetadata; + placeholderMetadata: NFTMetadata | undefined; } /** @@ -82,7 +82,7 @@ export async function getBatchesToReveal( tokenId: BigInt(i), tokenUri: uri, client: options.contract.client, - }); + }).catch(() => undefined); }), ); From fa7fe1e07445dba9c0fa4c509366ba13d174d74f Mon Sep 17 00:00:00 2001 From: kien-ngo Date: Mon, 6 Jan 2025 22:37:22 +0000 Subject: [PATCH 16/30] Remove tw-components Checkbox CORE-419 (#5890) CORE-419 --- .../components/create-account-button.tsx | 19 ++-------- .../components/add-access-token-button.tsx | 16 +++++---- .../add-contract-subscription-button.tsx | 35 ++++++++++--------- .../core-ui/batch-upload/batch-lazy-mint.tsx | 28 +++++++-------- apps/dashboard/src/tw-components/checkbox.tsx | 21 ----------- apps/dashboard/src/tw-components/index.ts | 1 - 6 files changed, 43 insertions(+), 77 deletions(-) delete mode 100644 apps/dashboard/src/tw-components/checkbox.tsx diff --git a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/accounts/components/create-account-button.tsx b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/accounts/components/create-account-button.tsx index 801e6d704c5..2ffdc9eca1e 100644 --- a/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/accounts/components/create-account-button.tsx +++ b/apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/accounts/components/create-account-button.tsx @@ -1,9 +1,8 @@ "use client"; import { Button } from "@/components/ui/button"; -import { Card } from "@/components/ui/card"; +import { ToolTipLabel } from "@/components/ui/tooltip"; import type { Account } from "@3rdweb-sdk/react/hooks/useApi"; -import { Tooltip } from "@chakra-ui/react"; import { TransactionButton } from "components/buttons/TransactionButton"; import type { ThirdwebContract } from "thirdweb"; import * as ERC4337Ext from "thirdweb/extensions/erc4337"; @@ -53,23 +52,11 @@ export const CreateAccountButton: React.FC = ({ if (isAccountDeployedQuery.data && accountsForAddressQuery.data?.length) { return ( - -

You can only initialize one account per EOA.

- - } - bg="transparent" - boxShadow="none" - bgColor="backgroundHighlight" - borderRadius="lg" - placement="right" - shouldWrapChildren - > + -
+ ); } diff --git a/apps/dashboard/src/app/team/[team_slug]/(team)/~/engine/(instance)/[engineId]/access-tokens/components/add-access-token-button.tsx b/apps/dashboard/src/app/team/[team_slug]/(team)/~/engine/(instance)/[engineId]/access-tokens/components/add-access-token-button.tsx index e43917a512f..daa5dd3c03a 100644 --- a/apps/dashboard/src/app/team/[team_slug]/(team)/~/engine/(instance)/[engineId]/access-tokens/components/add-access-token-button.tsx +++ b/apps/dashboard/src/app/team/[team_slug]/(team)/~/engine/(instance)/[engineId]/access-tokens/components/add-access-token-button.tsx @@ -1,3 +1,4 @@ +import { Checkbox, CheckboxWithLabel } from "@/components/ui/checkbox"; import { PlainTextCodeBlock } from "@/components/ui/code/plaintext-code"; import { useEngineCreateAccessToken } from "@3rdweb-sdk/react/hooks/useEngine"; import { @@ -14,7 +15,7 @@ import { useTrack } from "hooks/analytics/useTrack"; import { useTxNotifications } from "hooks/useTxNotifications"; import { CirclePlusIcon } from "lucide-react"; import { useState } from "react"; -import { Button, Checkbox, Text } from "tw-components"; +import { Button, Text } from "tw-components"; interface AddAccessTokenButtonProps { instanceUrl: string; @@ -92,12 +93,13 @@ export const AddAccessTokenButton: React.FC = ({ This access token will not be shown again. - setHasStoredToken(e.target.checked)} - > - I have securely stored this access token. - + + setHasStoredToken(!!val)} + /> + I have securely stored this access token. +
diff --git a/apps/dashboard/src/app/team/[team_slug]/(team)/~/engine/(instance)/[engineId]/contract-subscriptions/components/add-contract-subscription-button.tsx b/apps/dashboard/src/app/team/[team_slug]/(team)/~/engine/(instance)/[engineId]/contract-subscriptions/components/add-contract-subscription-button.tsx index 71dfb12033e..b2096041d55 100644 --- a/apps/dashboard/src/app/team/[team_slug]/(team)/~/engine/(instance)/[engineId]/contract-subscriptions/components/add-contract-subscription-button.tsx +++ b/apps/dashboard/src/app/team/[team_slug]/(team)/~/engine/(instance)/[engineId]/contract-subscriptions/components/add-contract-subscription-button.tsx @@ -1,6 +1,7 @@ "use client"; import { SingleNetworkSelector } from "@/components/blocks/NetworkSelectors"; +import { Checkbox, CheckboxWithLabel } from "@/components/ui/checkbox"; import { useThirdwebClient } from "@/constants/thirdweb.client"; import { type AddContractSubscriptionInput, @@ -36,7 +37,6 @@ import { getContract, isAddress } from "thirdweb"; import { Button, Card, - Checkbox, FormErrorMessage, FormHelperText, FormLabel, @@ -327,8 +327,8 @@ const ModalBodyInputData = ({ { - const { checked } = e.target; + onCheckedChange={(val) => { + const checked = !!val; form.setValue("processEventLogs", checked); if (checked) { processEventLogsDisclosure.onOpen(); @@ -380,21 +380,22 @@ const ModalBodyInputData = ({
- { - const { checked } = e.target; - form.setValue("processTransactionReceipts", checked); - if (checked) { - processTransactionReceiptsDisclosure.onOpen(); - } else { - processTransactionReceiptsDisclosure.onClose(); - } - }} - > + + { + const checked = !!val; + form.setValue("processTransactionReceipts", checked); + if (checked) { + processTransactionReceiptsDisclosure.onOpen(); + } else { + processTransactionReceiptsDisclosure.onClose(); + } + }} + /> Transaction Receipts - + {/* Shows all/specific functions if processing transaction receipts */}
diff --git a/apps/dashboard/src/core-ui/batch-upload/batch-lazy-mint.tsx b/apps/dashboard/src/core-ui/batch-upload/batch-lazy-mint.tsx index a60a360250b..da5b076f741 100644 --- a/apps/dashboard/src/core-ui/batch-upload/batch-lazy-mint.tsx +++ b/apps/dashboard/src/core-ui/batch-upload/batch-lazy-mint.tsx @@ -1,10 +1,10 @@ "use client"; +import { Checkbox, CheckboxWithLabel } from "@/components/ui/checkbox"; import type { Account } from "@3rdweb-sdk/react/hooks/useApi"; import { Alert, AlertIcon, - Box, Flex, FormControl, Input, @@ -24,7 +24,6 @@ import type { CreateDelayedRevealBatchParams } from "thirdweb/extensions/erc721" import type { NFTInput } from "thirdweb/utils"; import { Button, - Checkbox, FormErrorMessage, FormHelperText, FormLabel, @@ -196,7 +195,7 @@ export const BatchLazyMint: ComponentWithChildren< />
- +