Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

UserProfile component triggers hard navs on Nextjs (and others) #3547

Closed
4 tasks done
arlyon opened this issue Jun 11, 2024 · 11 comments
Closed
4 tasks done

UserProfile component triggers hard navs on Nextjs (and others) #3547

arlyon opened this issue Jun 11, 2024 · 11 comments
Labels
bug Something isn't working Stale

Comments

@arlyon
Copy link

arlyon commented Jun 11, 2024

Preliminary Checks

Reproduction

Publishable key

pk_test_cHJvLW9yeXgtMjcuY2xlcmsuYWNjb3VudHMuZGV2JA

Description

It would be nice if the router was able to specialize for frameworks and default to a client side nav in supported cases rather than a hard serverside one. This seems to already be the case for navigation between sign in and sign up.

Steps to reproduce:

  1. Visit a self hosted profile
  2. Click to a different tab
  3. Observe hard navigation

Expected behavior:

I am using nextjs, so it would be nice if this leveraged the framework to make the navigation seamless.

Actual behavior:

A hard nav.

Environment

N/A
@arlyon arlyon added the needs-triage A ticket that needs to be triaged by a team member label Jun 11, 2024
@jescalan jescalan removed the needs-triage A ticket that needs to be triaged by a team member label Jun 12, 2024
@jescalan jescalan added the confirmed label Jun 12, 2024 — with Linear
Copy link
Contributor

Are you using the latest version of the nextjs SDK at the moment? We think we fixed this in the latest version, just want to confirm.

@LekoArts LekoArts added the needs-reproduction Awaiting a minimal reproduction label Jun 12, 2024
@arlyon
Copy link
Author

arlyon commented Jun 13, 2024

5.1.5 still displays the behaviour for me

Nothing here seems out of place. Feel free to make an account, I will delete it after (and I don't even have a DB so your personal data doesn't go anywhere except clerk). Locally, the project doesn't need any particular setup for reproing. Required env vars are as follows

NEXT_PUBLIC_CLERK_PUBLISHABLE_KEY=<redacted>
CLERK_SECRET_KEY=<redacted>
NEXT_PUBLIC_CLERK_SIGN_IN_URL="/sign-in"
NEXT_PUBLIC_CLERK_SIGN_UP_URL="/sign-up"

@clerk-cookie
Copy link
Collaborator

Hello 👋

In an effort to keep our GitHub issues clean and focused, we close any issues that are awaiting a reproduction after 8 days on inactivity, and it has been 7 days. This issue will be closed tomorrow unless a reproduction is provided. If it takes longer than this to get a reproduction, that's ok, just drop a comment and we will remove the Stale label.

How to create a minimal reproduction

Thanks for being a part of the Clerk community! 🙏

@clerk-cookie
Copy link
Collaborator

After 8 days without a reproduction being supplied, we are closing this issue. Keep in mind, I'm just a robot, so if I've closed this issue in error, please reply here and my human colleagues will reopen it. Likewise if a reproduction is prepared after it has been closed.

@clerk-cookie clerk-cookie closed this as not planned Won't fix, can't repro, duplicate, stale Jun 23, 2024
@jescalan
Copy link
Contributor

This isn't a minimal reproduction unfortunately, it's a link to part of an entire built-out app. Our instructions for creating a minimal reproduction linked above should outline how to make this happen!

@arlyon
Copy link
Author

arlyon commented Jul 9, 2024

@jescalan please reopen https://github.com/arlyon/clerk-hard-nav

  • set env vars from a clerk app
  • visit /profile, sign in
  • visit /profile, switch between profile submenus
  • observe hard nav

Same applies to orgs fwiw

@brkalow brkalow removed Stale needs-reproduction Awaiting a minimal reproduction labels Jul 9, 2024
@brkalow brkalow reopened this Jul 9, 2024
@linear linear bot removed the confirmed label Jul 9, 2024
@jescalan
Copy link
Contributor

Hey @arlyon - I just pulled down your reproduction and tested it, and there were no hard navigations performed when switching between profile tabs. Opening the developer console while the navigation is being performed shows dom elements being patched directly, and the network tab shows that there is no hard navigation running.

Some follow up questions:

  • I used the keys for a test clerk app I have set up. Did you have a different experience when using the reproduction? If so, the only difference would be the keys, so it may have to do with some configuration in the app you were using to test, though I can't really imagine what it would be.
  • Do we have different definitions of "hard nav" perhaps? I was seeing the app re-render, which sometimes causes a brief flicker on the screen as the dom is updated. Or are you interpreting the change in url as a hard navigation? If so, next.js normally will update the url directly even for a client-side navigation using the history api - seeing a change in the URL no longer means that a full navigation was performed after the introduction of this browser API.

@arlyon
Copy link
Author

arlyon commented Jul 10, 2024

Oof thanks for the patience. What I thought was a 'hard nav' was the flicker accompanied with the catchall check in dev mode producing an html request in the network tab when switching pages. In production this does not happen and you are correct it is client-side only. My next request is, then, what I can do to reduce / eliminate the flicker. I take it this issue is that the clerk profile widget is not a react tree and needs to be re-initialized? If that is the case I can definitely live with it and will consider re-implementing it 'natively' down the line.

@arlyon
Copy link
Author

arlyon commented Jul 10, 2024

Screenshot for reference

image

@linear linear bot added the bug Something isn't working label Aug 9, 2024
@clerk-cookie
Copy link
Collaborator

Hello 👋

We currently close issues after 40 days of inactivity. It's been 30 days since the last update here. If we missed this issue, please reply here. Otherwise, we'll close this issue in 10 days.

As a friendly reminder: The best way to see an issue fixed is to open a pull request. If you're not sure how to do that, please check out our contributing guide.

Thanks for being a part of the Clerk community! 🙏

@clerk-cookie
Copy link
Collaborator

Hello again 👋

After 40 days of no activity, we'll close this issue. Keep in mind, I'm just a robot, so if I've closed this issue in error, please reply here and my human colleagues will reopen it.

As a friendly reminder: The best way to see an issue fixed is to open a pull request. If you're not sure how to do that, please check out our contributing guide.

Thanks for being a part of the Clerk community! 🙏

@clerk-cookie clerk-cookie closed this as not planned Won't fix, can't repro, duplicate, stale Sep 20, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working Stale
Projects
None yet
Development

No branches or pull requests

5 participants