Fix use of preprocessors with the static build (#2490)
* Fix use of preprocessors with the static build * Adds a changeset
This commit is contained in:
parent
aebe7f57d9
commit
69d5b70900
3 changed files with 23 additions and 8 deletions
5
.changeset/hungry-dots-reply.md
Normal file
5
.changeset/hungry-dots-reply.md
Normal file
|
@ -0,0 +1,5 @@
|
|||
---
|
||||
'astro': patch
|
||||
---
|
||||
|
||||
Fix for CSS preprocessing using the static build
|
|
@ -16,6 +16,12 @@ import ExternalHoisted from '../components/ExternalHoisted.astro';
|
|||
color: salmon;
|
||||
}
|
||||
</style>
|
||||
<style lang="scss">
|
||||
$color: purple;
|
||||
h2 {
|
||||
color: purple;
|
||||
}
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
<section>
|
||||
|
|
|
@ -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<string, string>) => {
|
||||
// When using this flag CSS is added via <link> 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;
|
||||
|
|
Loading…
Reference in a new issue