From c5315fdcc330634e88a52689c370b34d0432d650 Mon Sep 17 00:00:00 2001 From: nikospapcom Date: Tue, 17 Dec 2024 16:05:25 +0200 Subject: [PATCH] fix(clerk-js,clerk-react,types): Optimize Coinbase SDK loading Instead of lazy loading the Coinbase SDK in getEthereumProvider(), move loading when the SignIn/SignUp components mount. This fix avoid the Safari to block the Coinbase popup --- packages/clerk-js/src/core/clerk.ts | 8 ++++---- packages/clerk-js/src/utils/web3.ts | 6 +++++- packages/react/src/isomorphicClerk.ts | 11 ----------- packages/types/src/clerk.ts | 2 -- 4 files changed, 9 insertions(+), 18 deletions(-) diff --git a/packages/clerk-js/src/core/clerk.ts b/packages/clerk-js/src/core/clerk.ts index 84c45794bac..0b0057b9228 100644 --- a/packages/clerk-js/src/core/clerk.ts +++ b/packages/clerk-js/src/core/clerk.ts @@ -183,7 +183,6 @@ export class Clerk implements ClerkInterface { protected internal_last_error: ClerkAPIError | null = null; // converted to protected environment to support `updateEnvironment` type assertion protected environment?: EnvironmentResource | null; - private __promise = createDeferredPromise(); #publishableKey = ''; #domain: DomainOrProxyUrl['domain']; @@ -201,6 +200,7 @@ export class Clerk implements ClerkInterface { #options: ClerkOptions = {}; #pageLifecycle: ReturnType | null = null; #touchThrottledUntil = 0; + #coinbaseSDKResolvers = createDeferredPromise(); public __internal_getCachedResources: | (() => Promise<{ client: ClientJSONSnapshot | null; environment: EnvironmentJSONSnapshot | null }>) @@ -1672,12 +1672,12 @@ export class Clerk implements ClerkInterface { this.environment = environment; } - public prefetchDependencies = async (): Promise => { + private prefetchDependencies = async (): Promise => { if (this.isCoinbaseWalletEnabled) { - window.__clerk_coinbase_sdk = this.__promise.promise as Promise; + window.__clerk_coinbase_sdk = this.#coinbaseSDKResolvers.promise as Promise; await import('@coinbase/wallet-sdk').then(mod => { - this.__promise.resolve(mod.CoinbaseWalletSDK); + this.#coinbaseSDKResolvers.resolve(mod.CoinbaseWalletSDK); }); } }; diff --git a/packages/clerk-js/src/utils/web3.ts b/packages/clerk-js/src/utils/web3.ts index 0a39b1ce7c2..aab1e5890c2 100644 --- a/packages/clerk-js/src/utils/web3.ts +++ b/packages/clerk-js/src/utils/web3.ts @@ -71,7 +71,11 @@ export async function generateSignatureWithOKXWallet(params: GenerateSignaturePa async function getEthereumProvider(provider: Web3Provider) { if (provider === 'coinbase_wallet') { - const CoinbaseWalletSDK = await window.__clerk_coinbase_sdk; + const CoinbaseWalletSDK = await window.__clerk_coinbase_sdk.catch(() => null); + if (!CoinbaseWalletSDK) { + throw new Error('Coinbase Wallet SDK is not loaded'); + } + const sdk = new CoinbaseWalletSDK({}); return sdk.makeWeb3Provider({ options: 'all' }); } diff --git a/packages/react/src/isomorphicClerk.ts b/packages/react/src/isomorphicClerk.ts index 5753546e603..f27c3385467 100644 --- a/packages/react/src/isomorphicClerk.ts +++ b/packages/react/src/isomorphicClerk.ts @@ -123,7 +123,6 @@ type IsomorphicLoadedClerk = Without< | 'client' | '__internal_getCachedResources' | '__internal_reloadInitialResources' - | 'prefetchDependencies' > & { // TODO: Align return type and parms handleRedirectCallback: (params: HandleOAuthCallbackParams) => void; @@ -174,7 +173,6 @@ type IsomorphicLoadedClerk = Without< mountSignIn: (node: HTMLDivElement, props: SignInProps) => void; mountUserProfile: (node: HTMLDivElement, props: UserProfileProps) => void; mountWaitlist: (node: HTMLDivElement, props: WaitlistProps) => void; - prefetchDependencies: () => void; client: ClientResource | undefined; }; @@ -1216,13 +1214,4 @@ export class IsomorphicClerk implements IsomorphicLoadedClerk { this.premountMethodCalls.set('signOut', callback); } }; - - prefetchDependencies = async (): Promise => { - const callback = () => this.clerkjs?.prefetchDependencies(); - if (this.clerkjs && this.#loaded) { - return callback() as Promise; - } else { - this.premountMethodCalls.set('prefetchDependencies', callback); - } - }; } diff --git a/packages/types/src/clerk.ts b/packages/types/src/clerk.ts index 759cd2110eb..d2db01407c4 100644 --- a/packages/types/src/clerk.ts +++ b/packages/types/src/clerk.ts @@ -609,8 +609,6 @@ export interface Clerk { * This funtion is used to reload the initial resources (Environment/Client) from the Frontend API. **/ __internal_reloadInitialResources: () => Promise; - - prefetchDependencies: () => Promise; } export type HandleOAuthCallbackParams = TransferableOption &