-
Notifications
You must be signed in to change notification settings - Fork 94
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
SWC Plugin #157
Comments
Thanks for opening this issue! Given Next's typical behaviour around deprecations, I don't see this as something we immediately have to act on. But I definitely see the need for an SWC plugin!
Given that status, I propose to wait until SWC v2 is released. |
@Skn0tt you can already use the Rust plugin APIs. Next.js is using them. Here's the source for the next.js plugins: https://github.com/vercel/next.js/tree/canary/packages/next/build/swc/src We definitely want an swc version of this. We're going to be writing rust version of our other blitz plugins too. |
I managed to get more information from the Vercel team: TLDR: There are no docs for SWC plugins because there is not yet an official SWC Rust plugin API. The SWC Rust plugin API is starting to be worked on now. So not much we can do for now. |
A quick fix would just be to manually use this package when needed instead of relying on Babel to do it, right? |
@elie222 correct |
Ah, just tried it: |
Then you might want to wrap all your props simply with
Disclaimer: this might need to be extended to cover any object structure, js data type. |
I made a nextjs plugin that does not disable the SWC transform You can try it here Basically it applies the superjson babel plugin only on the pages files, without adding a .babelrc file |
Putting this here for anybody who comes across this issue: @remorses's plugin, while not adding a |
Does it matter if it’s using Babel if SWC works? Or are we still seeing slow builds because of it. I’ve started using remorses package.
Best,
Eliezer
…On Mon, Nov 22 2021 at 9:57 AM, Simon Knott < ***@***.*** > wrote:
Putting this here for anybody who comes across this issue: @remorses (
https://github.com/remorses ) 's plugin, while not adding a.babelrc file,
still uses Babel (
https://github.com/remorses/next-superjson/blob/959b3dc6063976ac2298a86b7169e38034b7bcbe/next-superjson/src/index.ts#L25
). I consider this to be a work-around, the real goal will be to create an
SWC equivalent of babel-plugin-superjson-next.
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub (
#157 (comment) ) ,
or unsubscribe (
https://github.com/notifications/unsubscribe-auth/AAXSQXYIMPIWTW5HSTWHK7LUNHZXNANCNFSM5GTQEOPA
).
|
It will introduce another bundler into the pipeline, which will slow things down, yes. It won't be as big of a slowdown as the full-on babel strategy which happens when there's a |
@Skn0tt the Babel plugin only runs on the pages directory, this can’t be a performance problem unless you have a page 10k lines long |
That's a good point @remorses! Thank you, I missed that. |
Any updates on this? |
Could this be solved by using Next.js new middleware? That seems like a possible solution, adding superjson to all responses and then if one wants to use superjson in the component, they need to call superjson.parse? |
I would be happy to try make this into a plugin? It's a fairly simple plugin to make judging by the babel one |
That would be great @markhughes! |
I've been able to write the base of it but next.js does not yet allow adding custom swc plugins. Once they update swc and add plugin support I'll give it a proper test. |
@elie222 maybe using the stringify and parse methods can help preserve types? From a quick look at the readme it seems like sending the stringified string as a prop then parsing it with a type will preserve the type. |
Any updates on this? |
I've been meaning to test it in the nextjs experimental stuff :) i'll put it up on github i've just been super sick. |
I'm working on swc plugin of superjson for Next.js with some supports from main creator of swc. Also, a stale issue in current babel plugin would be resolved too. Coming ASAP! |
Done! You've been waiting for a long time. Please check README.md and follow the instructions to apply the plugin. I've already tested working in Next.js 12.2.4 But if you find any bugs, please leave issues and I will check it out quickly. |
@orionmiz that's awesome, great work!!! |
Next.js
seems to be switching frombabel
toswc
, see: vercel/next.js#29811In the next stable release,
swc
will be used by default to compile aNext.js
project if there is no custombabel.config.js
, with the goal to eventually completely drop support forbabel
.I guess this means, there will be a need for a
superjson-swc
plugin of some sort?babel-plugin-macro
is having a similar discussion about it here: kentcdodds/babel-plugin-macros#144What are your thoughts?
The text was updated successfully, but these errors were encountered: