-
Notifications
You must be signed in to change notification settings - Fork 411
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
## Problem solved Short description of the bug fixed or feature added <!-- start pr-codex --> --- ## PR-Codex overview This PR focuses on significant updates to wallet support, increasing the number of supported wallets from 350+ to 500+. It also includes various code deletions, modifications, and new features across multiple components and files. ### Detailed summary - Increased wallet support from 350+ to 500+ across various components. - Updated `version` in `package.json` files. - Modified `ChainIcon` component to use a fallback icon. - Added `ModalPreview` for connect modal examples. - Updated descriptions in documentation and UI elements. - Refactored several components for better code clarity and functionality. - Deleted multiple unused assets and components. > The following files were skipped due to too many changes: `apps/dashboard/src/components/icons/ChainIcon.tsx`, `packages/thirdweb/src/react/core/utils/structuralSharing.test.ts`, `packages/thirdweb/src/contract/deployment/utils/bootstrap.ts`, `packages/thirdweb/src/react/web/utils/resolveMimeType.test.ts`, `apps/portal/src/app/connect/wallet/sign-in-methods/external-wallets/page.mdx`, `apps/dashboard/src/hooks/useCsvUpload.ts`, `apps/dashboard/src/app/nebula-app/(app)/components/Chats.tsx`, `packages/thirdweb/src/react/web/ui/MediaRenderer/mime/mime.test.ts`, `apps/portal/src/app/connect/account-abstraction/erc-20-paymaster/page.mdx`, `apps/dashboard/src/app/(dashboard)/(chain)/components/server/chain-icon.tsx`, `packages/thirdweb/src/contract/deployment/utils/create-2-factory.ts`, `packages/thirdweb/src/react/web/ui/MediaRenderer/icons.test.tsx`, `packages/thirdweb/src/react/web/ui/hooks/useShowMore.test.tsx`, `packages/thirdweb/src/react/web/ui/hooks/useDebouncedValue.test.tsx`, `apps/portal/src/app/connect/page.mdx`, `apps/portal/src/app/connect/wallet/sign-in-methods/configure/page.mdx`, `packages/thirdweb/src/react/core/utils/walletIcon.ts`, `apps/portal/src/app/typescript/v5/adapters/page.mdx`, `apps/portal/src/app/connect/wallet/get-started/page.mdx`, `apps/portal/src/app/react/v5/adapters/page.mdx`, `packages/thirdweb/src/react/web/ui/MediaRenderer/MediaRenderer.test.tsx`, `apps/portal/src/app/nebula/api-reference/page.mdx`, `packages/thirdweb/src/react/core/utils/walletIcon.test.ts`, `apps/dashboard/src/app/team/[team_slug]/[project_slug]/insight/[blueprint_slug]/blueprint-playground.stories.tsx`, `apps/dashboard/src/app/team/[team_slug]/[project_slug]/insight/[blueprint_slug]/blueprint-playground.client.tsx`, `apps/dashboard/src/app/(dashboard)/(chain)/[chain_id]/[contractAddress]/_components/claim-conditions/snapshot-upload.tsx`, `pnpm-lock.yaml` > ✨ Ask PR-Codex anything about this PR by commenting with `/codex {your question}` <!-- end pr-codex -->
- Loading branch information
Showing
21 changed files
with
1,118 additions
and
61 deletions.
There are no files selected for viewing
11 changes: 11 additions & 0 deletions
11
packages/thirdweb/src/react/core/providers/connection-manager.test.tsx
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
import { describe, expect, it } from "vitest"; | ||
import { renderHook } from "~test/react-render.js"; | ||
import { useConnectionManager } from "./connection-manager.js"; | ||
|
||
describe("useConnectionManager", () => { | ||
it("throws an error when used outside of ThirdwebProvider", () => { | ||
expect(() => { | ||
renderHook(() => useConnectionManager()); | ||
}).toThrow("useConnectionManager must be used within <ThirdwebProvider>"); | ||
}); | ||
}); |
19 changes: 19 additions & 0 deletions
19
packages/thirdweb/src/react/core/utils/isSmartWallet.test.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
import { describe, expect, it } from "vitest"; | ||
import { ANVIL_CHAIN } from "~test/chains.js"; | ||
import { createWallet } from "../../../wallets/create-wallet.js"; | ||
import { hasSmartAccount } from "./isSmartWallet.js"; | ||
|
||
describe("isSmartWallet", () => { | ||
it("should work if id is inApp and has smartAccount in wallet config", () => { | ||
const wallet = createWallet("inApp", { | ||
smartAccount: { | ||
chain: ANVIL_CHAIN, | ||
sponsorGas: true, | ||
overrides: { | ||
bundlerUrl: "your-bundler-url", | ||
}, | ||
}, | ||
}); | ||
expect(hasSmartAccount(wallet)).toBe(true); | ||
}); | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,57 @@ | ||
import { beforeEach, describe, expect, it, vi } from "vitest"; | ||
import type { AsyncStorage } from "../../../utils/storage/AsyncStorage.js"; | ||
import type { AuthArgsType } from "../../../wallets/in-app/core/authentication/types.js"; | ||
import { | ||
LAST_AUTH_PROVIDER_STORAGE_KEY, | ||
getLastAuthProvider, | ||
setLastAuthProvider, | ||
} from "./storage.js"; | ||
|
||
describe("Auth Provider Storage", () => { | ||
let mockStorage: AsyncStorage; | ||
|
||
beforeEach(() => { | ||
mockStorage = { | ||
getItem: vi.fn(), | ||
setItem: vi.fn(), | ||
removeItem: vi.fn(), | ||
}; | ||
}); | ||
|
||
describe("setLastAuthProvider", () => { | ||
it("should store the auth provider in storage", async () => { | ||
const authProvider: AuthArgsType["strategy"] = "email"; | ||
await setLastAuthProvider(authProvider, mockStorage); | ||
|
||
expect(mockStorage.setItem).toHaveBeenCalledWith( | ||
LAST_AUTH_PROVIDER_STORAGE_KEY, | ||
authProvider, | ||
); | ||
}); | ||
}); | ||
|
||
describe("getLastAuthProvider", () => { | ||
it("should retrieve the last auth provider from storage", async () => { | ||
const mockAuthProvider: AuthArgsType["strategy"] = "google"; | ||
vi.mocked(mockStorage.getItem).mockResolvedValue(mockAuthProvider); | ||
|
||
const result = await getLastAuthProvider(mockStorage); | ||
|
||
expect(mockStorage.getItem).toHaveBeenCalledWith( | ||
LAST_AUTH_PROVIDER_STORAGE_KEY, | ||
); | ||
expect(result).toBe(mockAuthProvider); | ||
}); | ||
|
||
it("should return null if no auth provider is stored", async () => { | ||
vi.mocked(mockStorage.getItem).mockResolvedValue(null); | ||
|
||
const result = await getLastAuthProvider(mockStorage); | ||
|
||
expect(mockStorage.getItem).toHaveBeenCalledWith( | ||
LAST_AUTH_PROVIDER_STORAGE_KEY, | ||
); | ||
expect(result).toBeNull(); | ||
}); | ||
}); | ||
}); |
55 changes: 55 additions & 0 deletions
55
packages/thirdweb/src/react/core/utils/structuralSharing.test.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,55 @@ | ||
import { describe, expect, it } from "vitest"; | ||
import { structuralSharing } from "./structuralSharing.js"; | ||
|
||
describe("structuralSharing", () => { | ||
it("should return the old data if it is deeply equal to the new data", () => { | ||
const oldData = { a: 1, b: { c: 2 } }; | ||
const newData = { a: 1, b: { c: 2 } }; | ||
const result = structuralSharing(oldData, newData); | ||
expect(result).toBe(oldData); | ||
}); | ||
|
||
it("should return a new object with shared structure for equal parts", () => { | ||
const oldData = { a: 1, b: { c: 2 }, d: 3 }; | ||
const newData = { a: 1, b: { c: 2 }, d: 4 }; | ||
const result = structuralSharing(oldData, newData); | ||
expect(result).not.toBe(oldData); | ||
expect(result).not.toBe(newData); | ||
expect(result.a).toBe(oldData.a); | ||
expect(result.b).toBe(oldData.b); | ||
expect(result.d).toBe(newData.d); | ||
}); | ||
|
||
it("should handle arrays correctly", () => { | ||
const oldData = [1, 2, [3, 4]]; | ||
const newData = [1, 2, [3, 5]]; | ||
const result = structuralSharing(oldData, newData); | ||
expect(result).not.toBe(oldData); | ||
expect(result).not.toBe(newData); | ||
expect(result[0]).toBe(oldData[0]); | ||
expect(result[1]).toBe(oldData[1]); | ||
expect(result[2]).not.toBe(oldData[2]); | ||
}); | ||
|
||
it("should handle undefined oldData", () => { | ||
const oldData = undefined; | ||
const newData = { a: 1 }; | ||
const result = structuralSharing(oldData, newData); | ||
expect(result).toBe(newData); | ||
}); | ||
|
||
it("should handle NaN values correctly", () => { | ||
const oldData = { a: Number.NaN }; | ||
const newData = { a: Number.NaN }; | ||
const result = structuralSharing(oldData, newData); | ||
expect(result).toBe(oldData); | ||
}); | ||
|
||
it("should handle objects with different constructors", () => { | ||
class CustomClass {} | ||
const oldData = new CustomClass(); | ||
const newData = { a: 1 }; | ||
const result = structuralSharing(oldData, newData); | ||
expect(result).toBe(newData); | ||
}); | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,81 @@ | ||
import { describe, expect, it } from "vitest"; | ||
import { genericWalletIcon, getSocialIcon, socialIcons } from "./walletIcon.js"; | ||
|
||
const emailIcon = | ||
""; | ||
const phoneIcon = | ||
""; | ||
const guestIcon = | ||
""; | ||
const passkeyIcon = | ||
""; | ||
|
||
describe("walletIcon", () => { | ||
it("should return google icon", () => { | ||
expect(getSocialIcon("google")).toBe(socialIcons.google); | ||
}); | ||
|
||
it("should return coinbase icon", () => { | ||
expect(getSocialIcon("coinbase")).toBe(socialIcons.coinbase); | ||
}); | ||
|
||
it("should return apple icon", () => { | ||
expect(getSocialIcon("apple")).toBe(socialIcons.apple); | ||
}); | ||
|
||
it("should return facebook icon", () => { | ||
expect(getSocialIcon("facebook")).toBe(socialIcons.facebook); | ||
}); | ||
|
||
it("should return phone icon", () => { | ||
expect(getSocialIcon("phone")).toBe(phoneIcon); | ||
}); | ||
|
||
it("should return email icon", () => { | ||
expect(getSocialIcon("email")).toBe(emailIcon); | ||
}); | ||
|
||
it("should return passkey icon", () => { | ||
expect(getSocialIcon("passkey")).toBe(passkeyIcon); | ||
}); | ||
|
||
it("should return discord icon", () => { | ||
expect(getSocialIcon("discord")).toBe(socialIcons.discord); | ||
}); | ||
|
||
it("should return line icon", () => { | ||
expect(getSocialIcon("line")).toBe(socialIcons.line); | ||
}); | ||
|
||
it("should return x icon", () => { | ||
expect(getSocialIcon("x")).toBe(socialIcons.x); | ||
}); | ||
|
||
it("should return farcaster icon", () => { | ||
expect(getSocialIcon("farcaster")).toBe(socialIcons.farcaster); | ||
}); | ||
|
||
it("should return telegram icon", () => { | ||
expect(getSocialIcon("telegram")).toBe(socialIcons.telegram); | ||
}); | ||
|
||
it("should return twitch icon", () => { | ||
expect(getSocialIcon("twitch")).toBe(socialIcons.twitch); | ||
}); | ||
|
||
it("should return github icon", () => { | ||
expect(getSocialIcon("github")).toBe(socialIcons.github); | ||
}); | ||
|
||
it("should return steam icon", () => { | ||
expect(getSocialIcon("steam")).toBe(socialIcons.steam); | ||
}); | ||
|
||
it("should return guest icon", () => { | ||
expect(getSocialIcon("guest")).toBe(guestIcon); | ||
}); | ||
|
||
it("should return generic wallet icon for unknown provider", () => { | ||
expect(getSocialIcon("unknown")).toBe(genericWalletIcon); | ||
}); | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.