This is a config driven (i.e., pcss.config.js
) post css cli similar to rollup.config.js
.
The official postcss-cli takes a more command line driven approach, which is fine, but might not be suitable for some build workflows.
Note: Requires
package.json
"type": "module"
- Default to
pcss.config.js
(Must be esm) -c
to specify custom config file. All input/output path will be relative to the targeted config file.-w
to specify watch mode.
# Install the pcss-cli
npm install -D pcss-cli
Create a pcss.config.js
Note: autoprefixer, postcss-import, postcss-mixins, and postcss-nested are imported by default (so, you can just add the requires as below)
const prefixer = (await import('autoprefixer')).default;
const nested = (await import('postcss-nested')).default;
const importer = (await import('postcss-import')).default;
const plugins = [
prefixer,
importer,
nested
];
// NOTE: Paths are relative to the pcss.config.js, not to cwd
export default {
// required. Support single string, or array, will be processed in order
input: ['./pcss/main.pcss', './src/**/*.pcss'],
// required. single css file supported for now.
output: './css/all-bundle.css',
// optional. Override the input for watch files
watchPath: ['./pcss/**/*.pcss', './src/**/*.pcss'],
// postcss processor arrays
plugins
}
// Note: module.exports can return an array of the object above, for multiple processing units.
Run
# will use pcss.config.js
node ./node_module/.bin/pcss
# will use path/to/pcss.config.js, relative input/output path will be relative to path/to/
node ./node_module/.bin/pcss -c path/to/pcss.config.js
# will do watch mode
node ./node_module/.bin/pcss -w -c path/to/pcss.config.js