Running into some cryptic error. Help needed.
I am running into some error. This is on React 19, Nextjs 15 and all latest Convex. Has anyone seen this?
data:image/s3,"s3://crabby-images/70e98/70e9887e4ccbca48d775aa6be61a9544cf949444" alt="No description"
19 Replies
Any chance you're using Cloudflare? This React bug mentions Astro specifically but looks very similar: https://github.com/facebook/react/issues/31827
Hmm might not even be cloudflare specific, I think the error message just came from a cloudflare worker that was doing ssr maybe
This has popped up in a few other places with different tooling. MessageChannel is a Node API used for SSR, so this error is happening in a non-node context. Another maybe related issue here that does involve Next 15: https://github.com/resend/react-email/issues/1630
This comment from a Vercel team member seems to hit the root of the issue: https://github.com/vercel/next.js/issues/71865#issuecomment-2444377726
Thank you. Looking into all the links you shared now.
interesting that you're getting the same error from next (presumably in a vercel environment) and from the convex environment. neither of them implement MessageChannel. any idea why you might be importing "react-dom/server"?
Ah. Yes. That's interesting.
@erquhart , you saved the day. After much debugging, uninstalling and re-installing, react-email was indeed the culprit. Things worked once I commented out, and used pure html.
data:image/s3,"s3://crabby-images/3568a/3568a99045ec259db884aafd99897fac649ed069" alt="No description"
I initially tried jsx-email, but that had a bun of node things that made convex unhappy.
hmm i think we want "react-email" to work. we'll look into it. can you share the exact version of react-email and react-dom and other packages that may be relevant (
npm ls
) 🙏Ah. It was not just react-email. Even after I removed react email, attempting to pass anything to the react prop of resend, triggered the same error. Just spent the last hour converting all to pure html with the help of claude. Then using the html prop instead with getSomeTemplate, which returns a html string. No errors. But If I pass the same html to the react prop, it shows the same error
I just updated all our packages. So the latest of all relevant package. The only react in the api folder is from resend and react-email. So its def something with react. Once I got rid of that, all works now
For example, the below does not work
data:image/s3,"s3://crabby-images/72e72/72e7243a141b1dbcc2f3c6495fbca0d071e8c156" alt="No description"
Sounds like react 19 specifically
Yes
This works:
data:image/s3,"s3://crabby-images/d760a/d760a79915ba8b0451739929c052f5c3376a6378" alt="No description"
@erquhart Yes. React 19.
Hi! I just ran into this exact issue tonight while trying to install and use react-email. Was there a solution identified?
Yeah, not using react. There’s a non-working and working example above
RIP
I love the simplicity of Convex Auth but might need to switch to Clerk
Just want to flag that we're having the same issue here, going for pure html for now, but would love to get updates if React 19 works at some point
Thanks for flagging, how would you describe the issue @David Alonso, "React emails don't work with React 19 in Convex?" Sounds like it's to do with some Node.js specific APIs?
Sounds like we need to prioritize this, but I don't know what the issue is yet. If it's a general runtime API we can add it, but if the issue is that React Email now only supports Node.js for React 19 that's something we need to open an issue about
ok looks like https://github.com/resend/react-email/issues/1630
GitHub
Error: A Node.js API is used (MessageChannel) which is not supporte...
Describe the Bug Using React 19 + Next.js 15 I want to use @react-email/render on edge runtime. However, I got this error: unhandledRejection: Error: A Node.js API is used (MessageChannel) which is...
yeah that's how I'd describe it but only based on what solved it for me, which was downgrading to react 18.3 (which is what the auth template uses). I briefly tried the pure HTML approach but that didn't seem to work for me (i might have missed something)