Fresh plugin for PostCSS support - with high performance in production.
Recommended to use with a Fresh build step (deno task build
).
fresh.config.ts
:
import { FreshConfig } from "$fresh/server.ts";
import { asset } from "$fresh/runtime.ts";
import { compileArticles } from "./utils/article.js";
import { compilePostCss } from "./utils/postcss.ts";
// Use any plugins you want
import { postCssPlugin } from "https://deno.land/x/[email protected]/mod.ts";
export const config = {
plugins: [
postCssPlugin({
// By default, looks for all CSS files in "./static"
// {exts} and {walkPath} can be left out
exts: ["css"],
walkPath: "./static",
// Add your PostCSS plugins (instead of a function, you can give a plugins array)
// {importWithoutBundling} is like import but avoids static analysis
// to prevent bundling your build plugins into the bundle used in production
async plugins({ importWithoutBundling }) {
const [
{ default: cssAutoprefixer },
{ default: cssPresetEnv },
] = await Promise.all([
importWithoutBundling("npm:[email protected]"),
importWithoutBundling("npm:[email protected]"),
]);
return [
cssAutoprefixer,
cssPresetEnv,
];
},
// Pass in {asset} from Fresh's runtime
// (Not included in the plugin to avoid importing another Fresh version)
asset,
}),
],
} satisfies FreshConfig;
Development:
- Injects a single
<style>
tag during development - Styles are compiled just as they would be in production
Production (with build step):
- Writes a single CSS file to
_fresh/static
- Automatically injects the
<link>
tag in the HTML's<head>
- Uses a long cache expiry time (expires after a year or version change)
- Uses dynamic imports to avoid unnecessary bundling in production
The production optimisation is that unlike other plugins, this plugin only uses its depencencies in development and during the build step.
Provided you use the build step, even PostCSS is not imported in production.
If a feature is missing, please open an issue.