Skip to content

Commit

Permalink
Generate computed and non-computed assets
Browse files Browse the repository at this point in the history
The computed asset, 98.css, precomputes the values that uses CSS
variables. The non-computed asset, 98-full.css, preserves the variables
and uses the computed values as fallbacks for browsers without support
for custom properties.
  • Loading branch information
tpenguinltg committed Mar 16, 2021
1 parent fa6f527 commit 29147e1
Showing 1 changed file with 10 additions and 7 deletions.
17 changes: 10 additions & 7 deletions build.js
Original file line number Diff line number Diff line change
Expand Up @@ -10,25 +10,27 @@ const postcss = require("postcss");

const { homepage, version } = require("./package.json");

function buildCSS() {
function buildCSS(preserveVariables) {
const input =
`/*! 98.css v${version} - ${homepage} */\n` + fs.readFileSync("style.css");
const destination = preserveVariables ? "dist/98-full.css" : "dist/98.css";
const template = preserveVariables ? "[name]-full.[ext]" : "[name].[ext]";

return postcss()
.use(require("postcss-inline-svg"))
.use(require("postcss-css-variables"))
.use(require("postcss-css-variables")({ preserve: preserveVariables }))
.use(require("postcss-calc"))
.use(require("postcss-copy")({ dest: "dist", template: "[name].[ext]" }))
.use(require("postcss-copy")({ dest: "dist", template }))
.use(require("cssnano"))
.process(input, {
from: "style.css",
to: "dist/98.css",
to: destination,
map: { inline: false },
})
.then((result) => {
mkdirp.sync("dist");
fs.writeFileSync("dist/98.css", result.css);
fs.writeFileSync("dist/98.css.map", result.map.toString());
fs.writeFileSync(destination, result.css);
fs.writeFileSync(destination + ".map", result.map.toString());
});
}

Expand Down Expand Up @@ -72,7 +74,8 @@ function buildDocs() {
}

function build() {
buildCSS()
buildCSS(false)
.then(() => buildCSS(true))
.then(buildDocs)
.catch((err) => console.log(err));
}
Expand Down

0 comments on commit 29147e1

Please sign in to comment.