diff --git a/.changeset/hungry-dots-reply.md b/.changeset/hungry-dots-reply.md new file mode 100644 index 0000000000..8dbb280014 --- /dev/null +++ b/.changeset/hungry-dots-reply.md @@ -0,0 +1,5 @@ +--- +'astro': patch +--- + +Fix for CSS preprocessing using the static build diff --git a/examples/fast-build/src/pages/index.astro b/examples/fast-build/src/pages/index.astro index ef0136b277..24ec0039ac 100644 --- a/examples/fast-build/src/pages/index.astro +++ b/examples/fast-build/src/pages/index.astro @@ -16,6 +16,12 @@ import ExternalHoisted from '../components/ExternalHoisted.astro'; color: salmon; } +
diff --git a/packages/astro/src/vite-plugin-astro/compile.ts b/packages/astro/src/vite-plugin-astro/compile.ts index d99c96f4a6..be77b91c7d 100644 --- a/packages/astro/src/vite-plugin-astro/compile.ts +++ b/packages/astro/src/vite-plugin-astro/compile.ts @@ -50,15 +50,18 @@ async function compile(config: AstroConfig, filename: string, source: string, vi experimentalStaticExtraction: config.buildOptions.experimentalStaticBuild, // TODO add experimental flag here preprocessStyle: async (value: string, attrs: Record) => { - // When using this flag CSS is added via and therefore goes - // through Vite's CSS pipeline. We don't need to transform here, it will be - // transformed on CSS requests. - if (config.buildOptions.experimentalStaticBuild) { - return { code: value }; - } - const lang = `.${attrs?.lang || 'css'}`.toLowerCase(); try { + let prefix = ''; + // In the static build, strip away at-imports so that they can be resolved + // by the pseudo-module that gets created. + if(config.buildOptions.experimentalStaticBuild) { + value = value.replace(/(?:@import)\s(?:url\()?\s?["\'](.*?)["\']\s?\)?(?:[^;]*);?/gi, (match) => { + prefix += match; + // Replace with an empty string of the same length, to preserve source maps. + return new Array(match.length).fill(' ').join(''); + }); + } const result = await transformWithVite({ value, lang, @@ -76,7 +79,8 @@ async function compile(config: AstroConfig, filename: string, source: string, vi map = result.map.toString(); } } - return { code: result.code, map }; + const code = prefix += result.code; + return { code, map }; } catch (err) { // save error to throw in plugin context cssTransformError = err as any;