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

fix(nextjs, shared): Restores reverted commits and fixes issue with shared in nextjs #1807

Merged
merged 8 commits into from
Oct 5, 2023

Conversation

dimkl
Copy link
Contributor

@dimkl dimkl commented Sep 29, 2023

Description

Review it per commit

After restoring the reverted commits of #1806 , i found that the error was raised because there was some CSR only rendering files in @clerk/shared that did not have the use client directory set.
The culprits were:

  • packages/shared/src/hooks/contexts.tsx
  • packages/shared/src/hooks/createContextAndHook.ts

I tested the fix in the local playground/app-router and it seems that there is no error thrown.

Checklist

  • npm test runs as expected.
  • npm run build runs as expected.
  • (If applicable) JSDoc comments have been added or updated for any package exports
  • (If applicable) Documentation has been updated

Type of change

  • 🐛 Bug fix
  • 🌟 New feature
  • 🔨 Breaking change
  • 📖 Refactoring / dependency upgrade / documentation
  • other:

Packages affected

  • @clerk/clerk-js
  • @clerk/clerk-react
  • @clerk/nextjs
  • @clerk/remix
  • @clerk/types
  • @clerk/themes
  • @clerk/localizations
  • @clerk/clerk-expo
  • @clerk/backend
  • @clerk/clerk-sdk-node
  • @clerk/shared
  • @clerk/fastify
  • @clerk/chrome-extension
  • gatsby-plugin-clerk
  • build/tooling/chore

@dimkl dimkl self-assigned this Sep 29, 2023
@dimkl dimkl requested a review from a team as a code owner September 29, 2023 22:54
@changeset-bot
Copy link

changeset-bot bot commented Sep 29, 2023

🦋 Changeset detected

Latest commit: 319d166

The changes in this PR will be included in the next version bump.

This PR includes changesets to release 11 packages
Name Type
@clerk/backend Patch
@clerk/nextjs Patch
@clerk/shared Patch
@clerk/fastify Patch
gatsby-plugin-clerk Patch
@clerk/remix Patch
@clerk/clerk-sdk-node Patch
@clerk/clerk-js Patch
@clerk/clerk-react Patch
@clerk/chrome-extension Patch
@clerk/clerk-expo Patch

Not sure what this means? Click here to learn what changesets are.

Click here if you're a maintainer who wants to add another changeset to this PR

@dimkl dimkl force-pushed the fix-nextjs-shared-deps branch 2 times, most recently from 635ad37 to 488bc28 Compare September 30, 2023 09:54
@LekoArts
Copy link
Member

LekoArts commented Oct 2, 2023

Since we've seen issues with this PR I think this round we should be more conservative and test more extensively. Basically, we'll need to check our usages of useX hooks and see those files have the use client directive.

We probably should do two things for sure:

@dimkl dimkl force-pushed the fix-nextjs-shared-deps branch from b71123b to 07c73ae Compare October 2, 2023 10:03
Copy link
Member

@panteliselef panteliselef left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Does it make sense to group all client related stuff with a "client-boundary" folder/file like we do for nextjs ?

@dimkl dimkl force-pushed the fix-nextjs-shared-deps branch 6 times, most recently from f484783 to 0305080 Compare October 3, 2023 13:00
@dimkl dimkl force-pushed the fix-nextjs-shared-deps branch 2 times, most recently from 82278e5 to 3613794 Compare October 3, 2023 13:31
@dimkl dimkl force-pushed the fix-nextjs-shared-deps branch 2 times, most recently from c019805 to e59325c Compare October 3, 2023 13:40
@dimkl dimkl force-pushed the fix-nextjs-shared-deps branch from 0b7ecb7 to c01b89f Compare October 3, 2023 13:51
@dimkl
Copy link
Contributor Author

dimkl commented Oct 3, 2023

Does it make sense to group all client related stuff with a "client-boundary" folder/file like we do for nextjs ?

@panteliselef Let's open a discussion in team-js channel and see how it goes. I think it makes sense.

@dimkl dimkl force-pushed the fix-nextjs-shared-deps branch from c01b89f to bffe9d9 Compare October 3, 2023 16:28
@nikosdouvlis
Copy link
Member

!snapshot

@clerk-cookie
Copy link
Collaborator

Hey @nikosdouvlis - the snapshot version command generated the following package versions:

Package Version
@clerk/backend 0.30.2-snapshot.bffe9d9
@clerk/chrome-extension 0.4.5-snapshot.bffe9d9
@clerk/clerk-js 4.60.0-snapshot.bffe9d9
@clerk/clerk-expo 0.19.7-snapshot.bffe9d9
@clerk/fastify 0.6.12-snapshot.bffe9d9
gatsby-plugin-clerk 4.4.13-snapshot.bffe9d9
@clerk/localizations 1.26.3-snapshot.bffe9d9
@clerk/nextjs 4.25.2-snapshot.bffe9d9
@clerk/clerk-react 4.26.2-snapshot.bffe9d9
@clerk/remix 3.0.4-snapshot.bffe9d9
@clerk/clerk-sdk-node 4.12.11-snapshot.bffe9d9
@clerk/shared 0.24.2-snapshot.bffe9d9
@clerk/themes 1.7.7-snapshot.bffe9d9
@clerk/types 3.54.0-snapshot.bffe9d9

Tip: use the snippet copy button below to quickly install the required packages.

# @clerk/backend
npm i @clerk/[email protected]
# @clerk/chrome-extension
npm i @clerk/[email protected]
# @clerk/clerk-js
npm i @clerk/[email protected]
# @clerk/clerk-expo
npm i @clerk/[email protected]
# @clerk/fastify
npm i @clerk/[email protected]
# gatsby-plugin-clerk
npm i [email protected]
# @clerk/localizations
npm i @clerk/[email protected]
# @clerk/nextjs
npm i @clerk/[email protected]
# @clerk/clerk-react
npm i @clerk/[email protected]
# @clerk/remix
npm i @clerk/[email protected]
# @clerk/clerk-sdk-node
npm i @clerk/[email protected]
# @clerk/shared
npm i @clerk/[email protected]
# @clerk/themes
npm i @clerk/[email protected]
# @clerk/types
npm i @clerk/[email protected]

@dimkl dimkl force-pushed the fix-nextjs-shared-deps branch from bffe9d9 to 63f77bd Compare October 4, 2023 14:07
@dimkl dimkl force-pushed the fix-nextjs-shared-deps branch from 63f77bd to 25e6acd Compare October 5, 2023 10:36
dimkl and others added 7 commits October 5, 2023 15:01
…/nextjs)

node_modules/@clerk/shared/dist/cjs/hooks/createContextAndHook.js (43:35)
 @ createContext
createContext only works in Client Components. Add the "use client"
 directive at the top of the file to use it. Read more:
 https://nextjs.org/docs/messages/context-in-server-component
    at createContextAndHook (webpack-internal:///(rsc)/./node_modules/
     @clerk/shared/dist/cjs/hooks/createContextAndHook.js:48:38)
    at eval (webpack-internal:///(rsc)/./node_modules/@clerk/shared/
     dist/cjs/hooks/contexts.js:53:110)
Even though we had imports of `@clerk/shared` the dependency
was missing from package.json of `@clerk/nextjs` and the
`@clerk/shared` defined in `@clerk/clerk-react` package.json
was used (that's why no error was raised from the imports).
…ache

issue: Error: Failed to execute turbo (Unable to locate Go binary).
ERROR Unable to find Go binary. Please report this issue at ...

turbo GH: vercel/turborepo#5381
@dimkl dimkl force-pushed the fix-nextjs-shared-deps branch from 9acaa62 to 319d166 Compare October 5, 2023 12:01
@dimkl dimkl added this pull request to the merge queue Oct 5, 2023
@dimkl dimkl removed this pull request from the merge queue due to a manual request Oct 5, 2023
@dimkl dimkl added this pull request to the merge queue Oct 5, 2023
Merged via the queue into main with commit 7d3cbcb Oct 5, 2023
5 checks passed
@dimkl dimkl deleted the fix-nextjs-shared-deps branch October 5, 2023 16:24
@clerk-cookie clerk-cookie mentioned this pull request Oct 5, 2023
@clerk-cookie
Copy link
Collaborator

This PR has been automatically locked since there has not been any recent activity after it was closed. Please open a new issue for related bugs.

@clerk clerk locked as resolved and limited conversation to collaborators Oct 5, 2024
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants