From f6cbfde164ecaa5eb1a59f086ce0c27874be6d19 Mon Sep 17 00:00:00 2001 From: kanno <812137533@qq.com> Date: Wed, 20 Dec 2023 17:16:22 +0800 Subject: [PATCH] fix: nuxt can't work --- .gitignore | 3 ++- examples/nuxt-demo/package.json | 4 +++- src/index.ts | 8 +++++--- 3 files changed, 10 insertions(+), 5 deletions(-) diff --git a/.gitignore b/.gitignore index 6bdd84d..22da892 100644 --- a/.gitignore +++ b/.gitignore @@ -15,4 +15,5 @@ build *.mts.timestamp-* -.nuxt \ No newline at end of file +.nuxt +.output \ No newline at end of file diff --git a/examples/nuxt-demo/package.json b/examples/nuxt-demo/package.json index 3b9b875..3d577af 100644 --- a/examples/nuxt-demo/package.json +++ b/examples/nuxt-demo/package.json @@ -2,7 +2,9 @@ "name": "nuxt-demo", "type": "module", "scripts": { - "dev": "nuxt dev" + "dev": "nuxt dev", + "build": "nuxt build", + "preview": "nuxt preview" }, "devDependencies": { "@nuxt/kit": "^3.8.2", diff --git a/src/index.ts b/src/index.ts index 50d2510..a60fdfe 100644 --- a/src/index.ts +++ b/src/index.ts @@ -57,9 +57,11 @@ function transformWithStylex(code: string, id: string, transformOptions: Transfo // But from a design principles. We won't need it. Only using virtual module is enough. // Judging from the previous experimental implementation of style9,It's worth to do it. -const VIRTUAL_STYLEX_MODULE = '\0stylex:virtual' +// I don't understand why nuxt has to handle virtual module. so i had to change the name :( +// And ensure that the middleware only process the correct request headers. +const VIRTUAL_STYLEX_MODULE = '\0vite-plugin:stylex' -const VIRTUAL_STYLEX_CSS_MODULE = VIRTUAL_STYLEX_MODULE + '.css' +const VIRTUAL_STYLEX_CSS_MODULE = 'vite-plugin:stylex.css' const VITE_INTERNAL_CSS_PLUGIN_NAMES = ['vite:css', 'vite:css-post'] @@ -71,7 +73,7 @@ function createSSRMiddleware(processStylexRules: () => string): NextHandleFuncti const { host } = req.headers const url = new URL(req.originalUrl, `${protocol}://${host}`) // Check style sheet is registered. - if (url.pathname.endsWith('.css') && url.pathname.includes('stylex:virtual')) { + if (url.pathname.endsWith('.css') && url.pathname.includes('vite-plugin:stylex') && req.headers['content-type'] === 'text/css') { res.setHeader('Content-Type', 'text/css') res.end(processStylexRules()) return