From e9413654f60f3b40c65bf7c759cd0b8be99978ca Mon Sep 17 00:00:00 2001 From: Tobbe Lundberg Date: Fri, 21 Jul 2023 10:58:56 +0200 Subject: [PATCH] RSC: react-server condition. Poisoned imports (#8948) --- packages/vite/src/rscBuild.ts | 19 ++++++++++++------- packages/vite/src/waku-lib/build-server.ts | 12 +++++++++++- .../vite/src/waku-lib/rsc-handler-worker.ts | 12 +++++++----- 3 files changed, 30 insertions(+), 13 deletions(-) diff --git a/packages/vite/src/rscBuild.ts b/packages/vite/src/rscBuild.ts index d1cd6f4f7002..ce49570ca43e 100644 --- a/packages/vite/src/rscBuild.ts +++ b/packages/vite/src/rscBuild.ts @@ -36,13 +36,15 @@ export async function rscBuild(viteConfigPath: string) { (id) => serverEntryFileSet.add(id) ), ], - // ssr: { - // // FIXME Without this, waku/router isn't considered to have client - // // entries, and "No client entry" error occurs. - // // Unless we fix this, RSC-capable packages aren't supported. - // // This also seems to cause problems with pnpm. - // // noExternal: ['@redwoodjs/web', '@redwoodjs/router'], - // }, + ssr: { + noExternal: /^(?!node:)/, + // TODO (RSC): Figure out what the `external` list should be. Right + // now it's just copied from waku + external: ['react', 'minimatch'], + }, + resolve: { + conditions: ['react-server'], + }, build: { manifest: 'rsc-build-manifest.json', write: false, @@ -53,6 +55,9 @@ export async function rscBuild(viteConfigPath: string) { }, }, }, + legacy: { + buildSsrCjsExternalHeuristics: true, + }, }) const clientEntryFiles = Object.fromEntries( diff --git a/packages/vite/src/waku-lib/build-server.ts b/packages/vite/src/waku-lib/build-server.ts index ac8169a5cdda..80d555356b4e 100644 --- a/packages/vite/src/waku-lib/build-server.ts +++ b/packages/vite/src/waku-lib/build-server.ts @@ -33,9 +33,19 @@ export async function serverBuild( // ...configFileConfig, root: rwPaths.web.base, ssr: { - noExternal: ['..'], + noExternal: true, + // TODO (RSC): The code below is pretty much what waku does, but I don't + // understand it + // noExternal: Object.values(clientEntryFiles).map((fname) => { + // return path + // .relative(path.join(rwPaths.web.base, 'node_modules'), fname) + // .split('/')[0] + // }), }, plugins: [react()], + resolve: { + conditions: ['react-server'], + }, build: { ssr: true, ssrEmitAssets: true, diff --git a/packages/vite/src/waku-lib/rsc-handler-worker.ts b/packages/vite/src/waku-lib/rsc-handler-worker.ts index fef8612eb864..c7c4083727ea 100644 --- a/packages/vite/src/waku-lib/rsc-handler-worker.ts +++ b/packages/vite/src/waku-lib/rsc-handler-worker.ts @@ -152,12 +152,14 @@ const vitePromise = createServer({ parentPort.postMessage(mesg) }), ], + resolve: { + conditions: ['react-server'], + }, ssr: { - // FIXME Without this, "use client" directive in waku/router/client - // is ignored, and some errors occur. - // Unless we fix this, RSC-capable packages aren't supported. - // This also seems to cause problems with pnpm. - noExternal: ['waku'], + noExternal: /^(?!node:)/, + // TODO (RSC): Figure out what the `external` list should be. Right + // now it's just copied from waku + external: ['react', 'minimatch', 'react-server-dom-webpack'], }, appType: 'custom', })