Skip to content

Latest commit

 

History

History
64 lines (45 loc) · 1.78 KB

README.md

File metadata and controls

64 lines (45 loc) · 1.78 KB

Intro

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"

Usage

  • 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