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;