diff --git a/.changeset/tame-coats-repeat.md b/.changeset/tame-coats-repeat.md new file mode 100644 index 00000000000..b71dce9c741 --- /dev/null +++ b/.changeset/tame-coats-repeat.md @@ -0,0 +1,6 @@ +--- +'@clerk/clerk-js': patch +'@clerk/types': patch +--- + +Return to localhost when SSO callback fails on SignIn or SignUp diff --git a/packages/clerk-js/src/core/clerk.ts b/packages/clerk-js/src/core/clerk.ts index 12c6aa87604..6dba8fee658 100644 --- a/packages/clerk-js/src/core/clerk.ts +++ b/packages/clerk-js/src/core/clerk.ts @@ -1019,9 +1019,9 @@ export class Clerk implements ClerkInterface { const makeNavigate = (to: string) => () => navigate(to); - const navigateToSignIn = makeNavigate(displayConfig.signInUrl); + const navigateToSignIn = makeNavigate(params.signInUrl || displayConfig.signInUrl); - const navigateToSignUp = makeNavigate(displayConfig.signUpUrl); + const navigateToSignUp = makeNavigate(params.signUpUrl || displayConfig.signUpUrl); const navigateToFactorOne = makeNavigate( params.firstFactorUrl || diff --git a/packages/clerk-js/src/ui/components/SignIn/SignIn.tsx b/packages/clerk-js/src/ui/components/SignIn/SignIn.tsx index 7f5d8594e21..9ef2e7f8e2d 100644 --- a/packages/clerk-js/src/ui/components/SignIn/SignIn.tsx +++ b/packages/clerk-js/src/ui/components/SignIn/SignIn.tsx @@ -42,6 +42,8 @@ function SignInRoutes(): JSX.Element { { displayConfig: displayConfig, }); - let signUpUrl = pickRedirectionProp('signUpUrl', { ctx, options, displayConfig }, false); + // The `ctx` object here refers to the SignUp component's props. + // SignUp's own options won't have a `signUpUrl` property, so we have to get the value + // from the `path` prop instead, when the routing is set to 'path'. + let signUpUrl = + (ctx.routing === 'path' ? ctx.path : undefined) || + pickRedirectionProp('signUpUrl', { options, displayConfig }, false); if (authQs && ctx.routing !== 'virtual') { signUpUrl += `#/?${authQs}`; } @@ -175,7 +180,12 @@ export const useSignInContext = (): SignInContextType => { signUpUrl += `#/?${authQs}`; } - let signInUrl = pickRedirectionProp('signInUrl', { ctx, options, displayConfig }, false); + // The `ctx` object here refers to the SignIn component's props. + // SignIn's own options won't have a `signInUrl` property, so we have to get the value + // from the `path` prop instead, when the routing is set to 'path'. + let signInUrl = + (ctx.routing === 'path' ? ctx.path : undefined) || + pickRedirectionProp('signInUrl', { options, displayConfig }, false); if (authQs && ctx.routing !== 'virtual') { signInUrl += `#/?${authQs}`; } diff --git a/packages/elements/src/internals/machines/third-party/actors.ts b/packages/elements/src/internals/machines/third-party/actors.ts index 379a249e260..fdef6b85e1c 100644 --- a/packages/elements/src/internals/machines/third-party/actors.ts +++ b/packages/elements/src/internals/machines/third-party/actors.ts @@ -88,6 +88,8 @@ export const handleRedirectCallback = fromCallback, customNavigate, ); diff --git a/packages/types/src/clerk.ts b/packages/types/src/clerk.ts index ec515e4a331..d162c617016 100644 --- a/packages/types/src/clerk.ts +++ b/packages/types/src/clerk.ts @@ -451,6 +451,14 @@ export interface Clerk { } export type HandleOAuthCallbackParams = AfterActionURLs & { + /** + * Full URL or path where the SignIn component is mounted. + */ + signInUrl?: string; + /** + * Full URL or path where the SignUp component is mounted. + */ + signUpUrl?: string; /** * Full URL or path to navigate after successful sign in * or sign up.