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

bug: NextJS 15 server side rendering errors. #6059

Closed
3 tasks done
GtaExFab opened this issue Nov 26, 2024 · 19 comments
Closed
3 tasks done

bug: NextJS 15 server side rendering errors. #6059

GtaExFab opened this issue Nov 26, 2024 · 19 comments
Assignees
Labels
Bug: Validated This PR or Issue is verified to be a bug within Stencil Help Wanted

Comments

@GtaExFab
Copy link

Prerequisites

Stencil Version

4.22.3

Current Behavior

Hi Ionic/Stencil Team !
We work on our Design system for 2 years now with StencilJS and we are facing a issue with StencilJS WebComponent with NextJS 15 server side rendering.
When we use the SSR of NextJS 15 we have this error below:

⨯ Internal error: Error: Objects are not valid as a React child (found: object with keys {$$typeof, type, key, ref, props, _owner, _store}). If you meant to render a collection of children, use an array instead.
    at retryNode (C:\Users\Administrator\Desktop\NextJS SSR StencilJS\packages\nextjs15\node_modules\next\dist\compiled\next-server\app-page.runtime.dev.js:25:141772)
    at renderNodeDestructive (C:\Users\Administrator\Desktop\NextJS SSR StencilJS\packages\nextjs15\node_modules\next\dist\compiled\next-server\app-page.runtime.dev.js:25:136300)
    at retryNode (C:\Users\Administrator\Desktop\NextJS SSR StencilJS\packages\nextjs15\node_modules\next\dist\compiled\next-server\app-page.runtime.dev.js:25:141587)
    at performWork (C:\Users\Administrator\Desktop\NextJS SSR StencilJS\packages\nextjs15\node_modules\next\dist\compiled\next-server\app-page.runtime.dev.js:25:157739)
    at Immediate.<anonymous> (C:\Users\Administrator\Desktop\NextJS SSR StencilJS\packages\nextjs15\node_modules\next\dist\compiled\next-server\app-page.runtime.dev.js:25:59046)
    at process.processImmediate (node:internal/timers:480:21)
    at process.callbackTrampoline (node:internal/async_hooks:130:17)

The server page is returned with a 500 error and load.
Just after, NextJS switch on client rendering -> all prerendered HTML is not present in source page (in chrome network tab)
If we try to build the NextJS project we have an error on Shadow dom serialization and the same error as shown.

Expected Behavior

The server page is generated without error and returned page contains all prerendered HTML with StencilJS components.

System Info

System: node 20.15.0
    Platform: windows (10.0.26100)
   CPU Model: 12th Gen Intel(R) Core(TM) i7-12700 (20 cpus)
    Compiler: C:\Users\Administrator\Desktop\NextJS SSR StencilJS\node_modules\@stencil\core\compiler\stencil.js
       Build: 1732216626
     Stencil: 4.22.3
  TypeScript: 5.5.4
      Rollup: 2.56.3
      Parse5: 7.1.2
      jQuery: 4.0.0-pre
      Terser: 5.31.1

Steps to Reproduce

Install all packages
on root folder ->

npm install

Build projects in package with
stencil-components ->

npm run build

react-library ->

npm run build

react-library-ssr ->

npm run build

nextjs15 ->

npm run dev

Try page client with client rendering -> OK
http://localhost:3000/client

Try page server with server side rendering -> KO.
http://localhost:3000/server

Page make a 500 error and switch to client mode with error.

if you use

npm run build

A lot of errors are generated

Code Reproduction URL

https://github.com/GtaExFab/stenciljsnextjs15

Additional Information

Stackblitz project:
https://stackblitz.com/~/github.com/GtaExFab/stenciljsnextjs15

@ionitron-bot ionitron-bot bot added the triage label Nov 26, 2024
@christian-bromann christian-bromann added Bug: Validated This PR or Issue is verified to be a bug within Stencil and removed triage labels Nov 26, 2024
@christian-bromann christian-bromann self-assigned this Nov 26, 2024
@BohdanYavorskyi
Copy link

BohdanYavorskyi commented Nov 29, 2024

@christian-bromann Please check this one and give some estimate. It's a super annoying issue and a lot consumers use Nextjs nowadays.

I would also check why hydration scripts not injected automatically when it's server as that would solve everything.

I used to try hydrate script with custom Nextjs server just to check if it really works , and I could see all components on the page. It is not the option though as custom servers lacks tons of features

@christian-bromann
Copy link
Member

@BohdanYavorskyi like any open source project, we appreciate any pull request that provide a resolution to this issue, especially if this is a bug that impacts you, you may consider providing support here.

@christian-bromann
Copy link
Member

christian-bromann commented Dec 10, 2024

@BohdanYavorskyi @GtaExFab a potential fix has been implemented in ionic-team/stencil-ds-output-targets#562 and we plan to do a release tomorrow. Please keep an eye open and let us know if this problem got resolved after the upgrade, thanks!

@GtaExFab
Copy link
Author

@christian-bromann thanks for the info. We will test as soon as possible to gather feedbacks and see if the bug is fixed.

@NSpehler
Copy link

Hello @christian-bromann 👋

Unfortunately the new version 0.8.0 did not resolve this issue for me on Next.js 15 😞

@christian-bromann
Copy link
Member

@NSpehler can you provide a minimal reproduction case?

@GtaExFab
Copy link
Author

GtaExFab commented Dec 17, 2024

Hi, all!
Tested with the same posted solution with Stencil/Core 4.23.0 and React ouput target 0.8.0.
The same errors appear in server side rendering.

_Internal error: Error: Objects are not valid as a React child (found: object with keys {$$typeof, type, key, ref, props, _owner, store}). If you meant to render a collection of children, use an array instead.

https://github.com/GtaExFab/stenciljsnextjs15
I update the package.json to last version of two libs.
Tks for your help.

@NSpehler
Copy link

Thanks for that @GtaExFab!

@christian-bromann
Copy link
Member

Mhm .. not sure why it is failing this way. Any contributions that may resolve this bug are much appreciated!

@danielleroux
Copy link

danielleroux commented Dec 19, 2024

I managed to get the ssr part working again without a 500 error from the server side. I had to move all the html-react-parse stuff out of the ssr.tsx file into the nextjs project.

After some checks of the created react component of the parse function I discovered that the $$typeof was changed between $$typeof: Symbol(react.transitional.element) (use html-react-parse lib inside stencil-output-target) and '$$typeof': Symbol(react.element), (use html-react-parse lib inside nextjs project)

https://github.com/ionic-team/stencil-ds-output-targets/blob/2526b82cb4b01563f745c817af144772294e4517/packages/react/src/react/ssr.tsx#L193-L199

I will have to check the html-react-parse library if there are some dependencies to react 18.
Just wanted to share my recent insides.

@shabetya
Copy link

shabetya commented Jan 8, 2025

Hello,
are there any updates about this issue?
Thank you in advance!

@shabetya
Copy link

shabetya commented Jan 9, 2025

Hi, @christian-bromann
Sorry for bothering you

But if you have any news, could you share the plans for where you will release the fix?
Version 0.8.1 still has it.

@dwirz
Copy link
Contributor

dwirz commented Jan 9, 2025

Hi @christian-bromann,

Thank you for merging the PR I provided! 🙌 I believe it might address the issue described here: PR #583.

I was wondering if this change is available as a dev or canary npm package for testing? I tested it locally using npm pack and integrated it with our stencil components with Next.js 15 and React 19. However, I’m not entirely sure if the locally packed version was applied correctly.

It would be incredibly helpful if a packaged version could be published via npm for easier testing. Thanks so much in advance! 🙏

@dwirz
Copy link
Contributor

dwirz commented Jan 9, 2025

Never mind, I found the dev release on npm, but it didn’t work. 😕

I have a strong suspicion about what could be causing the problem. I’ll check it tomorrow and either let you know or directly provide a PR for stencil-ds-output-targets.

@NSpehler
Copy link

@dwirz Well... For some reason version 0.8.2 is working great for me using Next.js 15 and React 19 🥳

Thank you very much for your work on this!

@dwirz
Copy link
Contributor

dwirz commented Jan 12, 2025

@NSpehler you're welcome! 🙂 thanks to @christian-bromann for the fast review and release! 🎉

@GtaExFab
Copy link
Author

GtaExFab commented Jan 13, 2025

Hi all !

Thank you @NSpehler and @christian-bromann for this PR and release!
The last version of react-output-target and Stencil/Core generate a working server page 👍 .
I updated the project with all last package versions to continue testing and have a good project example:

  • Next: 15.1.4
  • React: 19.0.0
  • Stencil/core: 4.23.2
  • React-output-tartger: 0.8.2.

It remains a browser hydration error on className="hydrated" but it seems to come from NextJS.
Thank you all for this hard work!

@christian-bromann
Copy link
Member

christian-bromann commented Jan 13, 2025

@GtaExFab I am looking into whether we can remove Stencils behavior of adding hydrated classes to the document element, it shouldn't matter for the user and I believe is only a warning showed within dev environments. Thanks for confirming that everything is working.

Thank you @dwirz for the contribution!

@johnjenkins
Copy link
Contributor

I believe this warning isn't just for the document, but for any component.
I guess react doesn't know about the class name in it's JSX tree, so it throws the error - you'd need to get the class added to the vNode

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Bug: Validated This PR or Issue is verified to be a bug within Stencil Help Wanted
Projects
None yet
Development

No branches or pull requests

8 participants