Skip to content

Fresh plugin for PostCSS - very fast in production ๐Ÿš€

Notifications You must be signed in to change notification settings

Kycermann/fresh-plugin-postcss

Folders and files

NameName
Last commit message
Last commit date

Latest commit

ย 

History

4 Commits
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 

Repository files navigation

fresh-plugin-postcss

Fresh plugin for PostCSS support - with high performance in production.

Recommended to use with a Fresh build step (deno task build).

Quick start

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;

Fast in production

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.

Issues and contributions

If a feature is missing, please open an issue.